 MrHappyAsthma
		
			MrHappyAsthma
		
		
		
		
		
		
		
		
	
			05-12-2014 03:31 PM - edited 05-12-2014 03:33 PM
I am having trouble envisioning how to plan out this application. I originally was going to use an Event Driven Architecture with a Queued State Machine to parse Front Panel UI changes and respond accordingly. (Something like the solution found here).
Solved! Go to Solution.
 RavensFan
		
			RavensFan
		
		
		 
		
		
		
		
		
	
			05-12-2014 03:44 PM
Datalogging should be done in its own loop with the data passed by a queue.
You can have multiple queues and multiple consumer loops if you need to.
05-12-2014 03:53 PM
Would using a Notifier to a third loop work?
I.E. something like this:
[Event Loop - queues events]
[State Machine Loop - dequeues events & notifies datalog]
[Datalog Loop - when notified, start logging]
 pjr1121
		
			pjr1121
		
		
		
		
		
		
		
		
	
			05-12-2014 03:58 PM
When doing long scans, I break my datalogging loop into multiple states (begin, read value, continue?, stop....) this allows me to interupt the datalogging loop in response to user events. Say you started the scan with an incorrect setting; you wouldn't want to wait the full hour to try again, nor would you want for force crash LabVIEW to stop the loop. The begin phase initializes any required arrays/controls the read value takes in a small number of data points (lets say 10 or 60 seconds worth) and places them in a shift register array then proceeds to the "continue?" state. Here we check for any indicators (set by the event structure loop in response to use events) that would require us to stop prematurely. If non are found, read more values. The stop phase is entered when the measurement is complete or a user event requires it.
This allows allows for the easy addition of added features in the future (lets say you want to change an applied voltage bias in your sample every 10 min) by having the "continue?" state direct the process.
05-14-2014 03:57 PM
I ended up taking Ravensfan's idea and making the Datalog loop separate.
prj1121 brought up a good point, which I already have implemented, however it is too slow during the dataloging to handle other events between states.