 MikeNuke
		
			MikeNuke
		
		
		
		
		
		
		
		
	
			09-29-2014 07:06 AM
Hi!
I built a subVI for an Oscilloscope VI that performs signal analysis.
Users should be able to open and close the subVI's window, but I cannot make it work as I wish.
What it should do is:
- open the subVI when an on-off control is clicked and start calculations
- close the subVI's window and stop calculations
- redo this passages every time the user needs it
What I builts does:
- open the subVI with the button and start calculations properly
- when I close the SUBVI window it opens again whith calculations stopped
- after re-closing, if I open the subVI with the button it does not calcuates
- after re-cliking the button it finally starts working again
I have attached the subVI and an example VI reproducing the loop containing the subVI.
Do you know a better (and more correct) way to make it work?
Thanks!
Mike
Solved! Go to Solution.
 crossrulz
		
			crossrulz
		
		
		 
		
		
		
		
		
	
			09-29-2014 07:20 AM
If your user closes the window, you button is still set to TRUE. So the calculations are actually still happening, you just can't see them. Then you click the button. But now the value is FALSE, so you will not be getting any calculations done. You hit the button a third time, and now it is TRUE, so you are making the calculations.
09-29-2014 07:38 AM
Mmm...
My interpretation:
- first "run" by clicking the button: the button is TRUE and the case structure passes TRUE to the local variable, keeping the subVI working.
- If I close the window, instead of passing FALSE from the event structure, the value TRUE is passed (why?), and on the next iteration the subVI is re-opened
- then, if I close the window again it passes FALSE (from the previous closure) and it remains closed
- if I push the button it opens without calculations because FALSE is passed from the second closure
- if I re-push the button it sets to TRUE and finally works
What I don't understand is why the subVI does not pass the value FALSE when it is closed, and does it on the next iteration
09-29-2014 08:49 AM
Is it possible that a race condition is occurring?
Maybe the closure of the window happens after the execution of the subVI inside the loop, so on the next loop iteration the subVI is executed again (button value TRUE) and it processes the "panel close" event and passes FALSE.
The same for the secon closure and the re-opening...
 crossrulz
		
			crossrulz
		
		
		 
		
		
		
		
		
	
			09-29-2014 08:55 AM
I just noticed a nasty race condition you have as well. If you toggle the button after the terminal was read but before the local variable is written to, your button toggle could be ignored due to the local overwritting your user.
What I would do with this setup would be to launch the subVI as a parallel process. The VI can maintain its own state and what not. You could then use User Events and/or Queues to send your data to the other process.
09-29-2014 10:08 AM
Hi!
I used parallel loops and a queue (new thing for me 🙂 ) and now it works.
Thank you!
Mike