LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

WORM Global

Solved!
Go to solution

polymorphic vi's handle all the rubbish, I agree it is more work to build the system but during usage you don't see the vi's, you only see the polymorphic base vi.

And they all can be created  from one vi that has to be copied and only thevalue input and valueoutput have to be changed into the next type.

So LabVIEW handles everything except the the first one.

The gain is that you don't have to convert the output into the correct type making your real vi's easier to read.

greetings from the Netherlands
0 Kudos
Message 21 of 43
(2,937 Views)

I've built polymorphics before and it is a lot of trouble, so I really don't want to do this at this time.  Please feel free to create a polymorphic version if you wish.  I like the variant version.  It isn't hard to convert the variant to data.  I will look into using LVOOP as Ray mentioned.  It may give the best of both worlds.

 

- tbob

Inventor of the WORM Global
0 Kudos
Message 22 of 43
(2,916 Views)

Great

Let us see what comes out of it, thanks for starting this.

greetings from the Netherlands
0 Kudos
Message 23 of 43
(2,897 Views)

I'm not trying to beat up on your idea, Albert.  Please don't get me wrong.  It's just that I'm lazy.  To cover all possible variable types, you would have to produce 15 polymorphics for numerics alone, then 15 more for numeric arrays, string, string array, boolean, boolean array, path, path array, enums, etc....  Over 40 in all.  I'm way to lazy to do this.  I'm afraid LVOOP will have the same problem, although I have not looked into it yet.  Maybe someone could enlighten me on a way to not use variants without having to write a ton of code.

 

- tbob

Inventor of the WORM Global
0 Kudos
Message 24 of 43
(2,863 Views)
This will give you a reason to do a newer version in the future.  😉
0 Kudos
Message 25 of 43
(2,832 Views)

tbob-

Just wanted to share another variant on your WORM.  I switched to a feedback node and used variant atributes like Ton suggested.

 

Functionality:

1. Always check the WORM for the global and report it if found - otherwise pass out what was passed in.

2. Add new global if:

  a - Global not found.

  b - Global name is not empty.

  c - Value In is not empth.

 

The WORM variant is not output.

 

Also, a little nugget I discovered - you can use the "Empty String/Path?" directly on variants.

 

 

 

Message 26 of 43
(2,717 Views)

Great suggestion.  I will look into it when I get a chance.  Today I hope.

 

- tbob

Inventor of the WORM Global
0 Kudos
Message 27 of 43
(2,693 Views)

Globally initializing the feedback node on first call eliminates the need for the Select node...

 

 

 

0 Kudos
Message 28 of 43
(2,682 Views)

I have incorporated the Variant Attribute scheme into the WORM Global.  I like the idea, thanx Ton P.  No need for an array. 

 

Sorry, paulmw, I don't like feedback nodes so I used my good ole while loop with a shift register.  I find feedback nodes hard to follow.  Also, since your code does not produce proper error messages, I kept my architecture intact.  So here is version 3 of the WORM Global.

 

- tbob

Inventor of the WORM Global
0 Kudos
Message 29 of 43
(2,668 Views)

No apologies necessary, just here to share... I've been using feedback nodes 'almost' as long as shift registers (to date my LV experience) and find them very useful, especially in FPGA code. So I find that recognizing their function is not too difficult.  Being able to initialize the feedback node on first call is very handy. 

 

In your latest version, I would recommend moving the initialization (or "delete all") on first call outside of the first case statement that checks for an empty Global Name.  With it where it is there is the potential to not initialize on first call because of a possible empty string for the name.  Of course it will generate an error if it is empty, but if you try to programmatically handle that error and retry, then the initialization never happens as intended.  I've attached a modified version.

 

As to what errors are proper can be as subjective as the feedback node vs shift register.  I did consider the error codes you generated and felt that they didn't warrant generating an error except possibly one: if the name was an empty string.  The "found" Boolean I felt was a sufficient indication and thought that leaving it up to a higher level to decided if an error is needed based that indicator (when considering what was attempted when the VI was executed).  For example, one may not consider it an "error" if Value_In had data for a global that already exists.

 

0 Kudos
Message 30 of 43
(2,650 Views)