LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Calling .NET assembly blocks execution

Solved!
Go to solution

Hello, 

 

I have a rather large project that controls translation stages, a camera and a laser. I was trying to incorporate a different laser and I run into the following issue. 

The laser software is written in .NET and the company game me a list of commands, properties and events I could use to call the functions I need, which are 1) set a rep rate, 2) start the laser, 3) stop the laser.

I achieved 1) without a problem, but as soon as I try to call the laser start method, the laser starts but the VI freezes and I cannot stop the laser (have to manually stop it on the device). Please note that as soon as I stop the laser this way, the VI resumes operations.

 

I tracked down the issue to the invoke node that is calling the method. I am attaching a screenshot of the highlighted execution. 

Before posting, I tried to figure out on my own how to solve this issue. I tried to register for an event (the "laser is running" event), but if the execution is halted, I cannot do much. 

It seems to me that the thread running the VI is waiting for the called method to return something and nothing is returned or that the thread is alted for some reason. Is this the case? If yes, is there a way around it?

 

If my "diagnosis" is wrong, feel free to correct me and suggest alternative routes. 

Also, I cannot change the software or the behavior of the .NET assembly.

 

Thanks, 

F.

 

0 Kudos
Message 1 of 13
(3,411 Views)

Is the "Start" button also controlling the stop via the Case Structure?

I'd be tempted to do the following to try and narrow down the issue:

  1. Remove the case structure - if you clicked the Start button, you want it to start.
  2. Monitor the error output from the "LaserRun" call - it may be returning something that then causes some other problem
  3. Check the status of the "Lock Front Panel" option in the Event Structure configuration for this case - probably the FP locks when the event is triggered, and that prevents the VI from doing anything else until the event finishes. That can cause locking in some circumstances - see this thread for some more discussion of the locking of front panels (or google). I'm not sure this is your problem (it would depend on other things not visible in the image) but worth checking.
  4. If possible upload the VI so we can see other parts (events, frames, etc).

GCentral
0 Kudos
Message 2 of 13
(3,323 Views)

I followed your advice and removed the case structure. 

The attached VI reproduces the issue.

Snippet.png

Briefly, I create a construct of ExLaserForm and I set an initial parameter to accept events. Then, I call the initialization method. This method has a 5 minutes warm-up that I can skip if I set another parameter (ThyState) to 1. To be sure, I tried skipping the warm up and waiting the 5 minutes. Same result.

All the other parameters are set in order to start the laser (I can explain if needed). As soon as I get to the "LaserRun", the laser starts to shoot, but the execution stops there.

 

F.

 

 

0 Kudos
Message 3 of 13
(3,305 Views)

Seems the root cause is that the "LaserRun" method is a blocking synchronous call. LabVIEW won't finish executing the node until the method returns, which it obviously does not. Did you design this assembly? Is there someone you can contact to ask how the API was intended to be used?

 

Also the class name has the word "Form" in it which is making me think you are trying to instantiate a Windows Form class. This is doable but there are caveats which you might be running into.

 

If you post the .NET assembly you are using then we could probably find out the internals of that LaserRun call.

Message 4 of 13
(3,257 Views)

 


@tyk007 wrote:

Seems the root cause is that the "LaserRun" method is a blocking synchronous call. LabVIEW won't finish executing the node until the method returns, which it obviously does not. Did you design this assembly? Is there someone you can contact to ask how the API was intended to be used?

 

Also the class name has the word "Form" in it which is making me think you are trying to instantiate a Windows Form class. This is doable but there are caveats which you might be running into.

 

If you post the .NET assembly you are using then we could probably find out the internals of that LaserRun call.


Your description of the issue is pretty much what I feared (A method without return). 

I did not write this .NET software, it is the software that came with the laser. It is a winform assembly. I cannot distribute the executable (I was calling it an assembly, but it's an exe). I have contacts in the manufacturing company, but they are not going to change the software. When I described them the issue (with plenty of details), all I got back was "Handle the following event EvLaserRunning raised by LaserRun.", which does not solve the issue because even if the event is raised, LabVIEW is still waiting for this method to return.

If no one has a way to go around this, I will turn to electronics and build a trigger using an arduino and bypass entirely this software.

0 Kudos
Message 5 of 13
(3,233 Views)
Solution
Accepted by FabrizioDonnarumma

Have a look at this post that I made a few months ago with a possible solution.

 

Basically, you would put the one non-returning node in a subVI by itself, then call that VI asynchronously, wait a bit (either timed or by using the event you mentioned), then kill the VI, then move on with your code.

0 Kudos
Message 6 of 13
(3,227 Views)

This might work. I will test it and see if it solve the issue. 

 

Thanks

 

0 Kudos
Message 7 of 13
(3,223 Views)

@Kyle97330 wrote:

Have a look at this post that I made a few months ago with a possible solution.

 

Basically, you would put the one non-returning node in a subVI by itself, then call that VI asynchronously, wait a bit (either timed or by using the event you mentioned), then kill the VI, then move on with your code.


I tried this approach. It would work well if you have a timed sequence in the asynchronous VI that stops that VI. Unfortunately, that is impossible in my case because any time sequence in the VI I would call would be stuck with the issue I described earlier. 

To implement this, I would need to literally kill the asynchronous subVI process from the main VI, which I believe it is not possible. 

0 Kudos
Message 8 of 13
(3,171 Views)
Solution
Accepted by FabrizioDonnarumma

When you start a process asynchronously you should have a reference, so killing it should be possible. Did you manage to register the mentioned event? If that's when the process is finished that's when it should be killed, although a timer should work.

/Y

G# - Award winning reference based OOP for LV, for free! - Qestit VIPM GitHub

Qestit Systems
Certified-LabVIEW-Developer
0 Kudos
Message 9 of 13
(3,158 Views)
Solution
Accepted by FabrizioDonnarumma

@Yamaeda wrote:

When you start a process asynchronously you should have a reference, so killing it should be possible. Did you manage to register the mentioned event? If that's when the process is finished that's when it should be killed, although a timer should work.

/Y


I made the two VIs attached to demonstrate the solution proposed above. 

I did not test it yet with my laser, but I think it should work.

Please note that in my application, I require a user or an not-timely-defined event to stop the subvi, hence the mechanism with buttons showed in the code below.

 

Make sure you change the SubVI path in the MainVI.vi

 

Download All
0 Kudos
Message 10 of 13
(3,128 Views)