data:image/s3,"s3://crabby-images/55c5d/55c5d6620d11361e76a2ebfda06c593a8c727cd4" alt="sp_Feed"
data:image/s3,"s3://crabby-images/5624f/5624f474911652537ad17533a8b81273817b5200" alt="sp_TopicIcon"
3:58 am
data:image/s3,"s3://crabby-images/bc621/bc621c5a090527418e3fc243bd71b66ae02cb170" alt="Avatar"
April 30, 2017
data:image/s3,"s3://crabby-images/688f4/688f43be8adbc126371652b01b237fef15fb08d0" alt="sp_UserOfflineSmall"
Hi everyone,
I just started with the arduino compiler (very nice tool!!) and run into a problem with shift register (SR) in a sub VI. The problem is that the SR does is not retaining the data, the execution setting of the VI is OK (non-reentrant).
I wrote a little test VI (attached) with a SR, a local and a global variable performing he same job. I also run the subVI by itself. When running in LabVIEW all 3 methods work the same, no matter if it is called as sub VI or run by itself. When compiling and running on the arduino by itself, all 3 are OK again, but when calling as a sub VI from another VI only local and global variables work, the SR does not.
I use LabVIEW 2015 Pro SP1, Arduino Mega 2560, the latest compiler and IDE.
Can you please help me on this?
Thank you and greetings, gr
10:59 pm
data:image/s3,"s3://crabby-images/4c420/4c42056580c6dbf677d8b428bdba2456cb021dc8" alt="Avatar"
March 12, 2015
data:image/s3,"s3://crabby-images/688f4/688f43be8adbc126371652b01b237fef15fb08d0" alt="sp_UserOfflineSmall"
Hello;
The issue you are facing is due to uninitialized SRs inside a subVI. You can find a detailed explanation as to why that doesn't work on this post:
https://www.geverywhere.com/for.....pport-fgv/
As a workaround, you will need to replace the data the uninitialized SR is handling with Global Variables.
Filipe
Cheers
Filipe
12:47 am
data:image/s3,"s3://crabby-images/bc621/bc621c5a090527418e3fc243bd71b66ae02cb170" alt="Avatar"
April 30, 2017
data:image/s3,"s3://crabby-images/688f4/688f43be8adbc126371652b01b237fef15fb08d0" alt="sp_UserOfflineSmall"
filipealtoe said
Hello;The issue you are facing is due to uninitialized SRs inside a subVI. You can find a detailed explanation as to why that doesn't work on this post:
https://www.geverywhere.com/for.....pport-fgv/
As a workaround, you will need to replace the data the uninitialized SR is handling with Global Variables.
Filipe
Hi Filipe,
thank you for clarification. I am using a lot of functional globals and NI has uninitialized SRs in PID and some other subVIs too. I guess I have to rewrite them ....
Anyway, thanks and greetings, Günter
10:22 am
data:image/s3,"s3://crabby-images/bc621/bc621c5a090527418e3fc243bd71b66ae02cb170" alt="Avatar"
May 24, 2017
data:image/s3,"s3://crabby-images/688f4/688f43be8adbc126371652b01b237fef15fb08d0" alt="sp_UserOfflineSmall"
Hi
Also faced the need to generate extra subVI.
The issue you are facing is due to uninitialized SRs inside a subVI...
As a workaround, you will need to replace the data the uninitialized SR is handling with Global Variables...
Can add it in compiller:
for not reentrant subVI:
automatic initialization and create SRs or Global Variables before main cycle - on the level 0.
Once.
for reentrant subVI:
automatic initialization and create SRs or Global Variables before main cycle - on the level 0.
N times - for every reentrant subVI clone.
See VI, how the number of extra lines SRs.
39
1 Guest(s)
data:image/s3,"s3://crabby-images/85520/855201fda91364994bc45a07763ff7d63a0b5e71" alt="sp_Information"