05-29-2021 11:55 PM - edited 05-29-2021 11:56 PM
Hello,
I have attached a state machine that pauses the state and generates an error in state "Test 2". What changes can I make to the program that will generate a message to be emailed to the user and then shut the program down?
In state "Test 2", for example, an error might be thrown by the instrument or the instrument that data is being taken from stops responding.
What architecture do I have to use or what method to employ in this case?
05-30-2021 12:15 AM
You have a good start with the state machine. But you aren't doing much with it. Initialize --> Test 1 --> Test 2 --> Exit. It is a glorified stacked sequence structure.
State machines get their real power from decisions. Create another state called Message. Then have that called on an error in one of the other states. So if Test 1 is error free, go Test 2. Otherwise go to Message, which will then go to Exit.
Likewise Test 2 goes to Exit on no error, but Message then Exit if there is an error.
05-30-2021 12:35 AM
Thanks for your response!
I understand your solution if the error gets thrown, thanks! However, how do I handle getting out of state 1 if instrument/device hangs?
05-30-2021 12:00 PM
Hi hiNI,
@hiNI wrote:
how do I handle getting out of state 1 if instrument/device hangs?
Then you should run into a Timeout error…
05-30-2021 12:28 PM - edited 05-30-2021 12:29 PM
Hello,
Not in some cases. I have devices hooked up that does not give any responses back if there is a problem with the software in the DUT. Sometimes the device will just get stuck in the subvi and I will have to manually shutdown LabVIEW.
I do not know how to handle this problem. Is it possible to get something like a secondary time out, outside of the state machine shown that can shutdown the program safely? I have never used the produce/consumer template, but could this be a possible solution?
Thanks.
05-30-2021 12:32 PM
Hi hiNI,
@hiNI wrote:
I have devices hooked up that does not give any responses back if there is a problem with the software in the DUT. Sometimes the device will just get stuck in the subvi and I will have to manually shutdown LabVIEW.
You really should improve your whole setup to avoid such "getting stuck" problems…
@hiNI wrote:
Is it possible to get something like a secondary time out, outside of the state machine shown that can shutdown the program safely? I have never used the produce/consumer template, but could this be a possible solution?
When only the subVI used for device communication gets stuck you can implement some kind of watchdog routine to detect those "getting stuck" errors. Using producer/consumer schemes with VIs running in parallel might help here…
05-30-2021 01:07 PM
If the subVI can get stuck like that, then there is something wrong with the way the VI was written. The subVI should be handling the situation where a timeout occurs and passes that error up to the main VI once it ends itself.
05-30-2021 03:48 PM
@RavensFan wrote:
If the subVI can get stuck like that, then there is something wrong with the way the VI was written. The subVI should be handling the situation where a timeout occurs and passes that error up to the main VI once it ends itself.
Below is a kludge of an example, but I think it illustrates the OP's point. I set an extremely long timeout, set VISA Read to a serial port that has nothing to read. I close the port while the VISA Read function is waiting, I immediately get an error from the VISA Read function. However, instead of the program ending, it appears to run until the timeout time is reached even though the read function error-ed out before the timeout. Here the VISA Close appears to wait the rest of the timeout duration. Not sure what is going on, except if you have a long VISA timeout, you are stuck waiting for it.
See below:
mcduff
05-30-2021 08:20 PM
@RavensFan wrote:
If the subVI can get stuck like that, then there is something wrong with the way the VI was written. The subVI should be handling the situation where a timeout occurs and passes that error up to the main VI once it ends itself.
But O.P. don't get discouraged! You are asking the right questions!
06-01-2021 01:20 AM - edited 06-01-2021 01:23 AM
I have now modified my program as per the suggestion to send the state machine to a "Message" state if an error occurs.
1. Is there a more efficient way to accomplish this as I have multiple cases in my state machine and I will have to add this new comparison state in each case?
2. I am still not sure how to handle the case of a device hang. I am testing out a device that has prototype software and there are time that after I send a command the software in the device may cause a partial or total shutdown and I get no response from the device. In this case, how can I efficiently handle the "hang" and allow LabVIEW to notify me and then safely shut down? I am still not clear on how to accomplish this task.
Thanks for your time and inputs!