LabVIEW Idea Exchange

Community Browser
cancel
Showing results for 
Search instead for 
Did you mean: 
Post an idea
Something like "pure virtual functions" in C++,  I think it makes code more clear.
Message Edited by Support on 06-09-2009 08:32 AM

This idea will probably have a narrow audience... those of us who use the "zip" functions in LabVIEW. There is currently an unzip function that takes a zip file on disk, then writes the unzipped files back to disk. To manipulate zipped files, you must then access the disk and load into memory. In other words, 3 disk operations... read zip, write file, read file.

 

There needs to be a function that unzips the files into memory, with the output of this function as an array of flattened strings, byte arrays, or data pointers.

 

 

UnzipToMem.png


Message Edited by Support on 06-09-2009 08:35 AM

I currently have a 3D array that I need to remap to some strange looking discret calibration data by linear interpolation (there is no good model function, not even polynomial!)

 

(1) This requires deeply stacked FOR loops (image top).

 

(2) In many cases it would simplify code if we could use a single FOR loop, but specify to loop over all scalar elements in all dimensions. (SUGGESTION: right-click tunnel, select "index over all scalar elements" -> different tunnel look). This would cause the autoindexing output tunnels of scalars to produce a multidimensional array of the same size as the autoindexing input. In all respects it should act the same as if we would stack as many FOR loops as needed to strip the input down to a scalar array element (center image). The index terminal [i] would output an array of all current indices (3 elements in this case). I am not sure what to do about N. If it would accept an array, we need to make sure the size (=# of dimensions) is defined elsewhere if there are no autoindexing inputs for example).

 

Case (2) could be useful in many situations, especially for more complicated code than shown here. It would work for all situations where only the innermost loop contains real code.

 

(3) In this particular case, the "interpolate array" function could of course be made polymorphic to accept multidimensional arrays and produce outputs if the same size as shown at the bottom of the image. Case (3) is a more general suggestion. Many existing functions could be made "more polymorphic" to do the same operation on each element of an array such as shown here. Since all operations are independent, it could even be automatically parallelized internally to take advantage of multiple CPU cores. Good candidates are functions that have scalar inputs and output a single scalar. If I have time, I will go over the palettes and identify more candidates. It might even turn into a seperate idea here in this forum. 😉

 

 

Message Edited by altenbach on 06-05-2009 05:25 PM
Message Edited by altenbach on 06-05-2009 05:25 PM

LLBs always had the capability of marking a VI as toplevel.

 

I wonder if it would be possible to set a flag inside a VI so a VI is recognized as such from within e.g. windows explorer. (e.g. different default icon). Since this requires OS integrations, I don't know if this is even feasible.

 

Still, It should at least integrate with the LabVIEW project.

 

The default settings could be very simple:

  • A VI without any defined connectors in the connector pane is "toplevel".
  • If there is at least one defined connector, the toplevel designation is lost.
  • There should be a way to overwrite this in VI properties.

 

Many times, people attach a zip full of VIs without telling us the name of the toplevel VI, so this idea would limit the number of candidates to inspect.

I like using Linux whenever I can, particularly when running large software like LabVIEW, since it tends to crawl on my XP systems. I was happy to realize that LabVIEW works on Linux, but soon after I was disappointed by the lack of usefulness of it when interfacing with hardware. I need to use the RealTime module to interface with my RealTime Compact-RIO. I also need Linux support for the FPGA module, as I need to program the FPGA attached to my cRIO. I'm sure I am not the only person who would like the ability to do this.

 

Without support for any of the hardware or LabVIEW modules I need, the Linux version of LabVIEW is entirely useless to me, and XP as an OS simply cannot perform up to par for me.

When you write big programs you can add too many cases on a event structure.

The default text can not be changed and if you are trying to find a specific case it's quite hard.

It would be nice to be able to replace the entire text with a custom text, or add a comment to the existing one. 

With User events we can wire up the dynamic event terminal with null references to essentially switch off the event during run-time.  This is a great piece of functionality which unfortunately is NOT available for "static" Events (defined within the Event structure itself).

 

I would like very much to be able to set the refnum for a STATIC event to a null reference in order to switch off the STATIC events at run-time, essentially makiing it a Dynamic event.

 

I know we can link to any object within the VI server hierarchy at run-time and use this to generate dynamic events so why can't we have the extra functionality of USER/Dynamic events for the standard events?

 

In order to maintain compatibility with existing code, how about adding an additional Terminal to the Event Strucutre "Static Event terminal" which exposes the same functionality as the USER Events for the events defined within the Event strucutre.

 

Shane.

Using Google Apps and similar products I've come to really love the access I get to all that functionality regardsless of which computer I'm on.  Imagine how great it would be if you could have LabVIEW available in the same way!

 

All the work, your VI libs, the compilation etc. would be on the hosting server (sharing VI libs, source code control and collaboration in general could be made very flexible indeed). There would be a few challenges to overcome, e.g. when you are writing code for different targets, but nothing unsolvable I think...(if there are any show stoppers we could have both...a web based editor as well as the traditional solution).

 

And the host could offer you to work in previous versions of LabVIEW...and new versions would be available as soon as they are launched, and you could build apps for different operative systems in one go.... no volume license manager headaches...the list of possibilities and improvements is endlessSmiley Happy

 

Hello everybody,

 

in many projects I create some VIs, which I use as sub VIs in different VIs of my project. If I want to drop one of these sub VIs in a VI, I have either to switch to the project explorer an grab it there or right-click on the block diagramm and use the functions palette -> Select a VI... . It would be nice (and save time), if I could use the functions palette to directly browse my project VIs. Some sort of dynamic menu creation for project VIs, organized like the project tree folders. If projects could get a default icon as libraries and classes, this icon could be set as palette icon. And if there is a library in one folder (perhaps with a default icon), make this library as a sub menu in the functions palette.

 

Marc

In the past it was possible to Drag and Drop for the Select a VI... Dialog. I don't remember when it was removed but I want it back!

 

DragDropFromSelectaVI.png 

 

I like the Digital Display feature of the Chart and would like to see it in a Graph

 

I currently do this in an Xcontrol

I like to dynamically control subvis with the get and set control methods

 

what would be nice is to get or set a single element of a cluster by naming it similar to a structure element in C

 

ex.    cluster_element.jpg

Application Builder property dialog >> Source File Settings >> Customize VI Properties...

 

One property I'm really missing is "Allow user to resize window". Obviously it can be set in the VI itself but there is no way to overwrite this setting when building the application.

 

Resize Window VI Property.jpg

 

Some more powerful icon editors (eg this one) have been written by users. An official version would be much appreciated.

Allow Array to be directly wired to number of interations in FOR Loop.  Right clicking number of interactions "N" would allow user to select Array dimension.  The demension could be displayed as shown.  This removes the need to "array size" and "index array" functions. 

For loop - old.jpg

For loop - new.jpg

Building multitype tables would be relatively simple using arrays of clusters...if it had not been for the fact that there is always space between the elements - causing the table to look unnaturally spread out.

Create a graph and display all its legends, the graph palette, X scrollbar etc. - you now have a rather messy mix of objects that are quite difficult to arrange together or in a compact and stylish manner.

 

The sizes of the objects should be made to match in different arrangements (preferably compact ones) and their default positions should be a good starting point, not a mess.

 

You could also have different layout/style options so when you choose to create a graph you get a number of layout alternatives to start from...kind of like the way you get in Excel.

I would like to see a Suspend When Called Manager added to the development environment.  The functionality would be similar to the Break Point Manager (which is great).  When you open the Suspend When Called Manager it would allow you to see all VI's in the heirarchy that have Suspend When Called enabled and allow you to disable it.

When you pass a wire from within a case structure to outside a case structure, you have an option of "Use default if unwired".

 

If we had additionally an option for "Retain Current Value", this would simplify and prevent needless wiring, especially if we are using the state machine pattern. See images below for use case.

 

Case 1.png

case 2.png

My goal is to reduce palette bloat!

 

Let's look at the conversion palette. Certainly looks impressive, but why do we need so many different bullets??? They are basically all the same function:  A universal input and an output type.

 

I suggest that the 16 marked bullets on the image, plus some others (e.g. "to variant"), be combined into a single universal bullet where we can select the desired output type by a simple right-click. Whatever we select will determine the actual icon, so once things are in place, everything will look exactly as before.

 

When we first drop the universal icon on the diagram (or insert it into a wire), the context menu appears and we must select the desired output.