Gary Rubin Posted December 15, 2009 Report Posted December 15, 2009 I have a LV8.6 subVI that is set to subroutine priority. It has 6 array indicators that are used for debugging and are not connected to terminals. When I have LV show me buffer allocations, I get flashing dots on these indicators. Given that I'm running in subroutine priority, is memory really allocated for for those? Thanks, Gary Quote
Steve Bird Posted December 15, 2009 Report Posted December 15, 2009 I have a LV8.6 subVI that is set to subroutine priority. It has 6 array indicators that are used for debugging and are not connected to terminals. When I have LV show me buffer allocations, I get flashing dots on these indicators. Given that I'm running in subroutine priority, is memory really allocated for for those? Thanks, Gary --- I don't think the priority has anything to do with the buffer allocations. One of the rules is that an indicator (that it fed data from a wire) will make a copy of that data at execution time. I don't think that rule is different for subroutines. If it's a performance issue, put the indicators into a conditional-disable structure. Steve Bird Culverson Software - Elegant software that is a pleasure to use. Culverson.com Blog for (mostly LabVIEW) programmers: Tips And Tricks Quote
Gary Rubin Posted December 15, 2009 Author Report Posted December 15, 2009 I don't think that rule is different for subroutines. If it's a performance issue, put the indicators into a conditional-disable structure. According to LV8.6 Help: In addition to not sharing time with other VIs, subroutine VI execution is streamlined so that front panel controls and indicators are not updated when the subroutine is called. A subroutine VI front panel reveals nothing about its execution. I figured that if the front panel indicators are not updated and the indicator is not connected to a terminal, there's no need to allocate memory for that indicator. I guess that's not the case, because a disable structure around the indicators did speed up my process considerably. Also, welcome to LAVA. Gary Quote
Grampa_of_Oliva_n_Eden Posted December 15, 2009 Report Posted December 15, 2009 According to LV8.6 Help: I figured that if the front panel indicators are not updated and the indicator is not connected to a terminal, there's no need to allocate memory for that indicator. I guess that's not the case, because a disable structure around the indicators did speed up my process considerably. Also, welcome to LAVA. Gary Another way to twist it so it make smore sense. Controls and indicators not on the icon connector can still be used, although I have not seen it much or often. If I wanted to icould write a value to an indicator (not on the connecto pane) in one call of a sub-VI and use a local to read that value on the next call. I have seen it used like Sr are used in an Action Engine (AE). I think I have even seen controls not on the icon connector used to localize VI for diferent langauges by using Invoke node set control method and savign the VI. No the GUI does not need to update but that data has to be there for it to read on another call. Ben Quote
jgcode Posted December 15, 2009 Report Posted December 15, 2009 Sorry off topic... Hi Steve Wow! Thats LabVIEW 1 on a Mac. You have been around a while! Very cool 1 Quote
Aristos Queue Posted December 17, 2009 Report Posted December 17, 2009 The buffer is still allocated. That doesn't mean anything is copied to it when the VI runs. That's true up through LV 2009. In later versions, ... oh... nevermind. Quote
Cat Posted December 18, 2009 Report Posted December 18, 2009 That's true up through LV 2009. In later versions, ... oh... nevermind. You are such a tease. Quote
Recommended Posts
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.