LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

WORM Global

Solved!
Go to solution

Continued from old thread.

 

Here is my latest version of the WORM Global.  For those who are not familiar with this project, a WORM Global is a way to store variables where you can write to them once.  WORM stands for Write Once Read Many.  This vi holds an array of variants. 

 

You can add any variable at any time.  When adding, you write the value to the variable.  After adding, you cannot write to it again, there is no mechanism to do so.  But you can read the variable as many times as you wish.  This prevents race conditions from happening. 

 

It is useful to store constants (variables that are defined and then don't change).  An example of its use would be to store GPIB addresses of instruments, datalog file names, config file names, constants flags, and others. 

 

Upon first call, the array of variants is emptied to get rid of leftovers from previous use.  It is best to call this vi inside a loop, with two arrays as inputs to the loop:  an array of global names and an array of corresponding values.  Wire in the Add enum to the Action input.  Now the globals are set and can be used anywhere in the program.  To use, call the vi again with Read as the action.  Wire in the name of the global you want to read.  The output is a variant, but can be converted to its proper type using Variant to Data function. 

 

Another action is to Delete.  You can delete globals that are no longer needed at any time. 

 

If trying to add a global with a blank name, you will get an error.  If trying to read a global with a blank name, you will get an error.  If trying to add a global whose name already exists, you will get an error.  If trying to read a global whose name does not exist, you will get an error.  If you try to delete a global that does not exist, or one in which the name is blank, you will get an error.

 

Please review the vi and give me some feedback.  If you see problems, bugs, or have a better idead, I would love to hear about them.

 

- tbob

Inventor of the WORM Global
Message 1 of 43
(12,135 Views)

I'm wondering if a WORM should prevent deleting a variable and then adding a new one with the same name but a different value.  Or, am I worrying too much?

 

Example_VI.png

Message Edited by jcarmody on 05-12-2010 01:48 PM
Jim
You're entirely bonkers. But I'll tell you a secret. All the best people are. ~ Alice
For he does not know what will happen; So who can tell him when it will occur? Eccl. 8:7

0 Kudos
Message 2 of 43
(12,116 Views)

There could be valid reasons why someone would want to do this.  Maybe some condition could necessitate a change of value.  I think I'll leave it as it is.  Leave the programmer enough rope to hang himself if he wants to.

 

- tbob

Inventor of the WORM Global
0 Kudos
Message 3 of 43
(12,074 Views)
  • One question, any specific reason to use an array of clusters over a Variant with attributes?
    The searching for a specific tag (or name) should be way faster (something with black and red books) in large datasets for a Variant attribute list vs. an Array of strings.
  • Why not skip the search when the Global name in is empty?
  • You picked an error number from the NI error-list that is not standard and is not available to users.
  • This is really nit-picking but you used a 'default'  state in an enum-based case structure
  • Why expose the worm globals to the outside world?


here's a Variant based on your code.

 

Ton

 

Free Code Capture Tool! Version 2.1.3 with comments, web-upload, back-save and snippets!
Nederlandse LabVIEW user groep www.lvug.nl
My LabVIEW Ideas

LabVIEW, programming like it should be!
0 Kudos
Message 4 of 43
(12,070 Views)

You give 5 people the same problem and you will get 5 different codes.  Array of clusters is what popped up in my head when I started this.  Your other points are really trivial and a matter of personal preference.  Feel free to use whatever version you wish.  I did this for fun, and will probably not use it myself since I am happy with the standard Globals vi.  However, it may be of some use to others who are more concerned with race conditions.

 

- tbob

Inventor of the WORM Global
Message 5 of 43
(12,049 Views)

Yes you are correct 4 of the 5 points were somewhat trivial.

 

Your code is pretty nice though

 

An array of clusters is a good method, and I am not sure at what point the performance of the variant attributes will really matter.

 

 

 

Ton

Free Code Capture Tool! Version 2.1.3 with comments, web-upload, back-save and snippets!
Nederlandse LabVIEW user groep www.lvug.nl
My LabVIEW Ideas

LabVIEW, programming like it should be!
0 Kudos
Message 6 of 43
(12,013 Views)

jcarmody wrote:

I'm wondering if a WORM should prevent deleting a variable and then adding a new one with the same name but a different value.  Or, am I worrying too much?

 

Example_VI.png

Message Edited by jcarmody on 05-12-2010 01:48 PM

Salut le cousinDuSud,

 

Great post.  I like the idea of WORMs.

If it is Write Once Read Many, why would you allow deleting entries and allowing either a replacement of adding a new one?

Otherwise, you have a mechanism to update the WORM by deleting an entry and re-entering it or to give it a slightly different name.

 

I would simply allow one shot at entering everything.  If it's the wrong value, the programmer needs to fix it at the source, but shouldn't be able to re-write to it; otherwise, it should not be considered Write Once.  I'm thinking in the lines of  a ROM, not an EEPROM.  You could create two types, a WORM and a MWORM (equivalent to an EEPROM).

 

RayR

0 Kudos
Message 7 of 43
(11,989 Views)

Hmmm....  You make a valid point.  I think I will delete the delete function.  Having it only encourages bad programming practice.  Also, I will look into making a couple of changes as suggested by Ton.  Skip the search for name if name is blank, and remove the terminal for the array output so as not to expose the globals to the outside world.  These are all valid points.  I'll get to it sometime today.

 

- tbob

Inventor of the WORM Global
Message 8 of 43
(11,960 Views)

Now your talking... 😄

 

You're gonna be make a better WORM. 🙂

0 Kudos
Message 9 of 43
(11,943 Views)
Solution
Accepted by topic author tbob

OK here is the long awaited (about 2 hours), much anticipated, new WORM_Globals.vi.  Thanx to Ton and Ray and others who have contributed.  Now there are only two enum items, Add and Read.  No Delete and no Delete All.  Since Delete All was only used at first call, I just perform the action in a case structure on first call.  Name is checked for blank before any action takes place.  If blank, only an error is given, no action performed.  The globals array is not passed onto the world, I've deleted the terminal.

 

Any other suggestions are welcome.

 

 

- tbob

Inventor of the WORM Global
Message 10 of 43
(11,919 Views)