LabVIEW Idea Exchange

Community Browser
cancel
Showing results for 
Search instead for 
Did you mean: 
Post an idea

Currently, the Deploy Library Invoke Node and DSC Deploy Libraries vi will only work with bound libraries that have a PSP based URL. (\\192.168.0.2\process\variable)  But there are some use cases where you need to have logical URL's (\\cRIO1\process\variable) that will adapt to changes in the .alias file which maps target names to IP addresses.  If this is your use case then it is tedious to do the same thing programmatically since you will have to create your bound libraries with an initial default PSP URL and then programatically modify all URL's based on a 'designated' target IP.  Since the project can do this I assume that it should be relatively easy to provide this functionality.

Allow units and other attributes to be attached to a DSC historical Trace.

I suggest that the LabVIEW application builder should include an option to rename shared variable libraries (i.e., add an index to the existing name) when building an application.  This is necessary for replicating an application.

 

For instance, for a component we developed we host shared variables on MyComputer (so that we can use DSC functionalities).  Applications on MyComputer (the view) and on a cRIO (the controller) read and write the shared variable values.

 

Now we want to clone these applications so that we can run multiple instances of them.  In particular, there will now be six instances of the cRIO application, each deployed on a separate cRIO; there will be six instances of the MyComputer application as well, but these will all run on the same PC.  Currently we anticipate (we have not done this yet) that we will be able to create six build files, each pointing to a separate aliases files, in order to handle the fact that the cRIOs will have unique IP addresses.  On the other hand, there is no way to handle building unique shared variable libraries in the application builder.  At the moment we can edit the project manually by changing the library name (e.g., add ‘A’ to the prototype name), then building the application, and repeating the process six times.  This is not especially difficult, but it is not a good long-term solution, since any change will require someone to repeat this process (and more importantly, know that they must do this!).  I suggest this functionality should be part of the build specification itself.

Epics Support in LabVIEW 2009 DSC Module has increased usability of LabVIEW in EPICS environment very much! But:

 

1. Import of database file is not really working!

When creating Epics client IO Server there is this nice feature to <Import> records from database file.

But when doing this there is only on field "VAL" per record created. All the other fields must be added manually though they are defined in the db file.

So please let the import routine pay attention to all the fields that are defined for each record by default and perhaps make it selectable.

This little change shouldn't be a big issue I guess. And it would increase the usability a lot!

 

2. With DSC it is possible to create on runtime only server types Modbus/Modbus Slave/OPC Client.

Please add Epics Server & Client here.

The goal is to be able DURING RUNTIME to first create sets of Env.Vaiables dynamically (already working with DSC) and then create the network publishing EPICS server.  

And of course the other way round: Please let me be able to create an EPICS client by importing a db (dbd) file dynamically and then bind it to dynamically created set of env. variables.

 

From what I heard from many of our synchrotron customers LabVIEW still has not arrived in this (huge!) EPICS community. 

I think it is on a good way with LV 2009 DSC Module. Please let it keep on going!

Currently the synchronous and asynchronous modes of writing data have little to no effect when communication over TCP. The write will return immediately after buffering the data to be written. However, the data it self may take considerable time to actually be written to the network. Absent some type of hand shaking at the application level there is no way for an application to wait until all the data has actually been written. The native LabVIEW TCP Write behaves in the same manner as the VISA write. Given this behavior it is impossible to implement a well behaved write queue for queuing up and transmitting data to a device. For example a normal print queue will open a connection and send the data to the printer. It will not attempt to open a second connection for the next print job until the first one has consumed all of the data. If a large amount of data is being written it can take time for all of it to be transmitted. The way the VISA or TCP write VIs behave the print queue would open a connection and write the data. However the call to the write would return immediately because the lower level network stack has accepted the data and buffered it. The print queue then believes the first job is complete and begins processing the second job. This will mean that a second connection will be opened. Some devices will allow multiple connections and some do not. However without the ability to actually wait for the data to be completely written the queue would have to continually try to open connections. This would be unnecessary network traffic and and unnecessary communication with the printer.

 

I would like to see an open on the write VIs to allow for a true blocking write. The write will not return until the data has truly been transmitted. The current behavior is also valid and can be retained.

 

Note: I have not tested the behavior on other types of interfaces so I am not sure if this is a TCP only issue.

Hello old friends,  it has been a while!

 

I would like to see MQTT client functionality added to LabVIEW.

It has been needed for a very long time to have web accessible front panels.  During the development of NXG this problem was solved with the web module.  I am not sure why they stopped development with NXG because was an extremely nice upgrade and was making Labview more future-proof.  NXG was then turned into G web development software.  Personally, I think the web portion should be an addon and native to Labview as eventually, that is where it will need to go anyway.  In the meantime, the only solution we would have is to possibly use G Web Development software as a front end development and regular labview as a backend.  To do this cleanly we would really need the shared variables available in G web development environment.  This would open back up doors that were closed once NXG was not supported anymore and would offer a solution until something native is added to Labview.  In my world, every customer wants and expects web-accessible applications.  I get the response all the time "Your software can do all of this control but isn't accessible from a browser on our LAN - my residential doorbell can even do that".  If I am missing some method to implement this currently (other than SystemLink) please reach out and I appreciate you considering some kind of solution to fill this very large need.

 

PS - I still don't understand why NXG support stopped if anybody knows.  Took a little getting used to but I saw big potential with that development software.   

I really like the option to use indicators (connected to the connector pane) as the output for webservice methods. By default, Labview will serialize it to JSON, but text and xml are also options. It works quite well and it saves a lot of coding writing your own serialisation.
I have some suggestions for the serialize functionality:

 

1. order the JSON output by tabbing order when there are multiple output indicators. This prevents that you end up always clustering all controls into one, just to enforce order.

 

2. it would be nice if an enum could be represented by its string instead of its index.

 

3. support for maps

Report Writer BEFORE WIndows 10 was SUPER ROBUST! Now that Windows 10 came along there exist many "turds" left in the Registry when folks UPGRADE from Office 7 to Office 10.

What happens is the Registry NEVER NEEDED to be kept clean of extra junk because NOBODY EVER UPDATED Office.

 

Now every Joe on the planet updates their Windows 10 with the latest Office 10..


What happens if they do NOT FIRST UNINSTALL, is the Registry is left with "turds"


When Report Writer uses ActiveX to make calls to use Word, in the old days, there was a SINGLE key in the registry to allow the calling program to gracefully start Word or Excel, or whatever.


NOW< with Windows 10 there are FREQUENTLY multiple "keys" in a Registry that causxe the LabVIEW Report Writer to "Gag" and "Hang up" doing nothing.


The SOLUTION is for the Report Writer to PARSE the Registry for valid keys and allow the request to be passed to the propper called process.

 

If this is not clear, please look up the SR below. There are a TON of examples and videos explaining how to fix it.

 

I have been working with LV since Dr. G was roaming the halls on LV 3...

 

This is the FIRST TIME Report Writer has gotten "sick".


This is an EASY FIX for the devs and since Report Writer is a purchased plugin they sould be able to update it so it works well.

 

Currently, they have us fiddling with the Registry or telling customers to uninstall and reinstall Office. That is a BIG FAT NO-NO to big companies because Office WORKS COMPLETELY for them and even programs like SolidWorks and DXP that use Word and Excel for stuff.

 

My number 831-455-0418

 

DEVS:

Please see: Request #: 00994109] Can not get EXE BUilder to run on WIn 10

 

Please add to AF:

Ability to Get Actor Enqueuer by Path through hierarchy of actors e.g. /root/pactor/chactor could be used to get the enqueuer to chactor. This would probably require actors to have unique paths pointing to them. Having a system manager keeping all enqueuers on local system is not a bad thing. It is a good thing.

 

The 2017 and 2018 versions of the LabVIEW OPC UA Toolkit support data access amongst other features.

Is there already a plan or schedule to implement the PubSub amendment (nr 14) and provide PubSub support for the OPC UA toolkit?

I'm writing a VI for a lab which writes to a database. The number of measurements will vary depending upon which fixture is set up in the lab, and whether the experimenter decides to add extra ones. This results in a varying size array of doubles which gets written into a single database with generic column names c1-c200. The column names are cross-referenced in another table keyed to the lab fixture. 

The method I found here is to convert from array->cluster->variant->database insert. The problem with this is that a cluster's size must be available at compile time, making the varying array size more difficult. It also limits the size of the array/database entry to 256 elements in the array->cluster conversion. 

I know I could just populate and write a 200 element array into the database, but that increases database activity , is inelegant, and forces me to put zeros in the unused columns, instead of leaving them null. 

 

Attached is a VI which demonstrates what I would like, though it only works for doubles and is still limited by the 256 element limit. It could very easily be changed for integers or strings, but it would be best if it could take any type of array input, with a much larger size limit. 

Download All

When working with serial, tcp or some other odd communication protocol I find myself time and again working on a PC that either has nothing installed, can't install anything or is sitting behind a secured environment. Nor is there always a scope with analyzer readily available to trace the commands being sent & received to an instrument or DUT.

 

Can't parts of Wireshark or an another sniffer be built right into the Probe Watch functionality? That would be sweet.

 

P.S. VISA's "Interface Information:Interface Type" has a lot of variations that many devs likely don't even know about as they just drag a VISA onto the BD/FP.

The current version of the Ethernet/IP tool kit 781656-35 only functions as an adapter. I need it to also function as a scanner. Specifically to take control  of the point I/O module 1734-AENT module of the Allen Bradley RSlogix 5000 PLC. I need the Labview to replace the PLC RS l5000 logix software. I still want to use the Point IO modules.

What is needed :

A direct property to change the "Enable Aliasing" option (var_params.png). "Use binding" property only allows to user to change it after enable + deploy the shared variable with "Enable Aliasing" option manually checked once.

 

Problem in detail:

When a shared variable is created in a local library file, it is needed to check the "Enable Aliasing" checkbox manually once to connect to an URL of a remote tag / psp URL. 

After that, Enable aliasing parameter can be changed from the program via the parameter "Use binding". If an attempt to connect the variable to an URL is made with "Enable Aliasing" is not changed manually once beforehand, "A value is missing for the Enable Aliasing option" (missenable.png) or "Missing access type" errors occur (mat.png).

 

 

Why is it needed for :

Lack of this property permits the user to create shared variables with an URL connection in a Labview program . You need to create and check "Enable aliasing" manually once each time you need to create a shared variable. 

Download All

When a client performs an HTTP request to a LabVIEW WebService, if the resource exists but the method is not supported (e.g. PUT instead of GET), the WebService responds with a 404-Not Found status code, giving the (wrong) impression that the resource name is wrong or non-existent. It would be better to have the service respond with a more informative 405-Method Not Allowed or 501-Not Implemented.

Add TRDP (Train Real-time Data Protocol)

 

Train Real-time Data Protocol (TRDP) supports the increasing network requests on board of trains and railways. For more information:

https://sourceforge.net/p/tcnopen/trdp/923/tree/trunk/trdp/doc/TCN-TRDP2-D-BOM-011-18%20-%20TRDP%20User%27s%20Manual.pdf?format=raw

 

[admin edit: added description of TRDP and link to user manual]

NI LabVIEW Database Connectivity Toolkit Windows 10 64-bit
(Using 64-bit Software)
Not Supported.big problem!!!.

regards,

eyal.

As far as I understand the philosophy of RESTful services, one should also be able to address the same web resource with different methods, e.g. GET and PUT.

 

As a practical example, suppose I'm creating a REST API for controlling a data acquisition board, and I implement a method such as:

http://.../acquisition_board/sampling_rate

Here it would be desirable to use the GET and PUT methods on this very same resource, in order to retrieve the sampling rate (GET) and set the sampling rate (PUT).

 

At the moment, LabVIEW WebServices only allow to set a unique method for each resource, whereas it would be useful to allow multiple methods on the same resource, as shown in the example above.