Jump to content

mike5

Members
  • Posts

    160
  • Joined

  • Last visited

  • Days Won

    3

Everything posted by mike5

  1. As already stated in another thread, I'd like to set the priority of the VI from within the application. Since many objects are derived from the same class I use reentrant VIs, but the property node to set priority doesn't agree with Open VI reference "prepare for reentrant run" option. Can I simply remove the "propare for reentrant run" option and use property node to set Execution.IsReentrant to get the same results? Thanks, Mike And to add to the problem, once one instance of the of the VI is running, it is not possible to create another instance of the same VI and set its priority... Sigh!
  2. Also, I'd like to add that I would like to set/change the priority at run-time. Is this at all possible with execution priority? Thanks, Mike
  3. Well, I'm glad I have some options (setting VI/process priority was on my list as well, but I was looking for all possible options), but to answer some other questions as well. Regarding "arbitrary execution time" - as we all know, things change in a live system. Sometimes the application has to log some things, and sometimes it doesn't, so unless you are really doing just one specific thing on a real-time system, you don't really know how long an iteration may last. As I already stated, I am aware of the VI priority, but that only offers me 5 priorities with one that I think it's best avoided (the RT one). Timed loop offers 65535 priorities, but maybe 4 will be enough after all. I'll look into the thread that ShaunR suggested and hopefully find what I need there. Thank you all for your help, and if you have any other ideas, please keep them coming Mike
  4. Unfortunately the code is a framework thingy, so code could later be added that simply would not finish in the required amount of time Mike5
  5. Hi all. We have a project where parallel loops are needed, but also setting priority for each loop is a requirement. At first it seemed that "Timed loops" are an answer to these problems, since they support priority, but "Timed loops" have other problems with the code that doesn't execute quickly enough. So, in short I am looking for a solution that would give me the ability to set priorities for parallel loops and also support arbitrary execution time for each iteration. Thanks in advance, Mike
  6. Sorry for the late reply, I was not able to check this for a while... The two changes are: - VI recompiled: Changes to front panel data structure or block diagram data flow causes LabVIEW to recompile the VI, generating new execution code. - SubVI call(s) modified: A subVI's connector pane (or a polymorphic subVI's list of VIs) was modified. Show the Context Help window for the subVI and make sure the connections to the subVI on the block diagram are still correct. And I have not touched the code... And no xControl used. Br, Mike5
  7. I have an application composed of many objects, but whenever I shut it down and close the project it prompts me to save one of the VIs (always the same one), as if it was modified. I have inspected that VI and I cannot see what is causing this. Does any anyone know what may be going on? Thanks in advance, Mike
  8. Mystery "solved"! The restart doesn't work only on WinXP . On Windows 7 restart doesn't cause any problems. Not that this doesn't leave me with a problem, since the end result should work on any system (including RT targets)
  9. I have this rather strange problem. The VI I'm working with is based on a rather complex home-grown LVOOP. If I open the project and run the VI, then it works as it should. Then I stop it (from within the application, not "Abort Execution") and start it again, and it does not work as expected - it runs, but doesn't do what it is supposed to do. Then I add a strategically placed breakpoint, start it, and the VI works every time (I just need to hit "Continue" when it reaches the breakpoint). With the breakpoint active I can stop and start it as many times as I want. When I remove the breakpoint, the VI again starts working only on the first run again. Does anyone have a clue what is going on here? Miha
  10. I'm pretty new to this, but I think having a way of saying "Don't open front panels for SubVIs during tracing" would help a lot... Well, we have a collection of "active objects" communicating with each other, and they all have some parallel loops as well. IIUC each "process" and parallel loop gets its own copy of the attributes, which doesn't help much. Or am I wrong? Miha
  11. Yes, I have identified a deadlock as well. Unfortunately it was wrapped into multiple layers of VIs, so it wasn't obvious at first and required two days of tracing to discover. And on that note, am I the only one who finds debugging/tracing in LabView more useless than useful - with each VI opening two windows until you're completely lost. Any plans on somehow making the experience better? Thanks for all your help. Miha
  12. Thanks for your answer! Is the implicit semaphore implemented for all types IPE structures, or just the DVR related ones? If it is DVR only, don't other instances need it? Also, do you happen to know how is the semaphore locking resources-wise? Greedy? Slow? Alright? I'm hesitant to remove it now that I have it working, but I might sometime in the future, if all it does is to re-implement something that's already there. Br, Miha
  13. Hi all, IIUC (from some other threads on this forum) if in-place element fails to obtain a lock, it gives an error and provides you with a default value of whatever the reference points to, and continues. But that's not what I'm seeing. If an in-place element on DVR is used from two processes, then one of the processes simply "freezes" (enters an endless wait maybe). Also, since my DVR always point to a cluster, I'm using in-place element inside an in-place element (outer one for DVR, inner one for bundle). I'm mentioning this just in case that the freeze-up doesn't occur from accessing the DVR, but the bundle... Can anyone shed some light on how to process the same bundle from two different processes? Currently I have resorted to using semaphores to avoid the problem (and it seems to work), but is this the right way (performance-wise), or is there a better way? Thanks, Miha
  14. Suppose we have a device with multiple network interfaces. Now, we want to write to a shared variable from it. Is there a way to determine which interface (IP) will be used? Thanks and br, Miha
  15. What an excellent suggestion Thanks. Miha
  16. Yes, I was aware of this function, but I am not looking for a way of comparing two refnums (I'll need it of course), but I am looking for a way of instructing "set this variable to not-a-refnum". Miha
  17. I don't know whether to ask this here or on the other thread, but are there any drawbacks about using Variant Attributes on real-time targets? Besides memory... And on that note, is there a better way of getting the number of the elements in the Variant than producing names/values arrays just to get the length? Miha
  18. Is there a way to create a not-a-refnum of a specific type (sort of like NULL pointer)? For example, the shared variable refnum. Is it even necessary? What I would like to do is have a list of shared variables that I have opened, and I would like to know if the refnum is valid or not without some extended logic that tries to read from it or something like that... Miha
  19. And another question: If the DVR-in fails, is the in-place element skipped, or do I have to use the error wire to "skip" the code in the element? Miha
  20. Is there an equivalent of a hash table in LabView? Thanks in advance, Miha
  21. Thanks, I also did that. Am I correct in assuming this only works if you have DSC Module installed? Miha
  22. Thanks, I'll check that.
  23. Hi all, the document at http://zone.ni.com/devzone/cda/tut/p/id/4679 in the section titled Programmatic Access says: "As discussed above, you can create, configure, and deploy shared variables interactively using the LabVIEW Project, and you can read from and write to shared variables using the shared variable node on the block diagram or through front panel data binding. New in 2009, LabVIEW also provides programmatic access to all of this functionality. Use VI Server to create project libraries and shared variables programmatically in applications where you need to create large numbers of shared variables." I'm mostly interested in the last part, that is, creating Libraries and shared variables from the VI programmaticly, but I was unable to find the right components to achieve that (I'll keep trying, though). Can someone guide through the process or point me to a VI that does that? Thanks in advance, Miha
  24. Yes, thank you all for the clarification. I think what got me confused is the fact that Context Help leads you (me, at least) to believe that the VI Ref is in fact pointing to lvclass. Mike
  25. Thanks, I was looking at the Factory_UsingVIs.zip , which is referenced from a PDF with the same contents as your link. This one somehow creates that Strictly typed VI Ref which the Context Help then shows that is is really a reference to a lvclass. And that I could not recreate. I'll look at your example as well, thanks. And, yeah, I do use DVR in the class private data. Miha
×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.