pete_dunham Posted October 4, 2010 Report Posted October 4, 2010 Hoping to get some insight from others; LAVA-ers have repeatedly saved the day for me. BACKGROUND: I spent time switching over a working program to a new architecture as it was becoming difficult to manage its scalability in its current state. However, with my new, more scalable architecture I must be missing a fundamental LV programming philosophy --> LabVIEW memory keeps increasing until it crashes (memory increasing and then CPU usage to ~100%). I have used the Tools -> Profile ->Performance and Memory and Tools -> Profile ->Show Buffer Allocations. I can see the VIs that are taking up more and more memory but am stumped on how to fix this problem. There was significant effort in my first redesign, and I was hoping I don't have to rework this architecture. To get right to the point, there are 2 basic designs that I thought were "clever" but must not be. The first is my basic SubVI structure. I created an array of cluster data where each array element is an object for each UUT I am testing (running parallel UUTs). I am using FOR loops to read/write the data of each "object". Note: I am not using LV's OOP features, just calling this cluster an object since it ties to a UUT. 1)Basic SubVI. 2) The example subVI above would be called in a "substate machine" <below>. I used state machines with functional globals, so that after each substate is driven the subVI is left (to access the main State Machine) and then comes back to the sub-state that is hanging out as a functional global. I am passing a lot of data (multiple clusters with arrays). I am guessing I have designed something that is fundamentally flawed. Can someone break my heart and tell me why. ***Right before posting this I noticed that the "sub-state machine" main data cluster doesn't need a shift-register terminal since this data is being passed in and out each time this subVI is run. Does this have an impact on memory?*** Thanks! Quote
Michael Aivaliotis Posted October 4, 2010 Report Posted October 4, 2010 Have you tried using the in-place element structure? 1 Quote
pete_dunham Posted October 4, 2010 Author Report Posted October 4, 2010 Have you tried using the in-place element structure? Thanks for the reply. I just researched that today. The development system that this project is tied to is stuck at LV 8.2.1. Am I correct in thinking that this structure isn't available for 8.2.1? Quote
asbo Posted October 4, 2010 Report Posted October 4, 2010 Thanks for the reply. I just researched that today. The development system that this project is tied to is stuck at LV 8.2.1. Am I correct in thinking that this structure isn't available for 8.2.1? You are indeed, the in-place structure was added in LabVIEW 8.5. Quote
Black Pearl Posted October 5, 2010 Report Posted October 5, 2010 I am passing a lot of data (multiple clusters with arrays). That could be an issue, as if you resize the array, the complete super-cluster must be reallocated/copied. But I would suggest to dig further. Try to get hold of the code section where LV crashes. If your project is big, you could implement a simple logger vi, that just writes to a file it's call chain. Then you know until which point the code did run fine. Felix Quote
pete_dunham Posted October 5, 2010 Author Report Posted October 5, 2010 Felix, Thanks for the recommendation. Because of how my program logic operates, I believe I know what code is running when LV gets stuck. Basically it is one (sub-)state machine that is run pretty continuously (gathering serial data). Other subVIs are run only periodically (change mux channel, increment counter, etc). What is strange is that there seems to be a tipping point in this code. Memory slows increases (not to concerned about this), but at one point in my program execution the CPU memory will almost double or triple and cause LV to stop responding. However, I am not changing what code I am executing at this point (that is, the subVI running during the crash has run many times before without this memory expansion). That could be an issue, as if you resize the array, the complete super-cluster must be reallocated/copied. But I would suggest to dig further. Try to get hold of the code section where LV crashes. If your project is big, you could implement a simple logger vi, that just writes to a file it's call chain. Then you know until which point the code did run fine. Felix Quote
MartinPeeker Posted October 5, 2010 Report Posted October 5, 2010 What is strange is that there seems to be a tipping point in this code. Memory slows increases (not to concerned about this), but at one point in my program execution the CPU memory will almost double or triple and cause LV to stop responding. However, I am not changing what code I am executing at this point (that is, the subVI running during the crash has run many times before without this memory expansion). To me that sounds like an array that has is growing and need to allocate more memory. LV allocates a chunk of memory for the array when it is created, if that memory space is about to run out it allocates another chunk of memory. Have you tried using Initialize Array to define the array siza from the start? //Martin Quote
Cat Posted October 5, 2010 Report Posted October 5, 2010 .Because of how my program logic operates, I believe I know what code is running when LV gets stuck. Basically it is one (sub-)state machine that is run pretty continuously (gathering serial data). Other subVIs are run only periodically (change mux channel, increment counter, etc). Something to try might be to replace that 1 vi that is gathering serial data with a dummy vi that just outputs a string of the same size you are expecting. See if that still produces a memory problem. My most confusing memory loss issues in the past was with a driver that wasn't playing well with a new computer, and not a code problem. If there's no other smoking gun, maybe you have something similar. Quote
Grampa_of_Oliva_n_Eden Posted October 5, 2010 Report Posted October 5, 2010 Hoping to get some insight from others; LAVA-ers have repeatedly saved the day for me. BACKGROUND: I spent time switching over a working program to a new architecture as it was becoming difficult to manage its scalability in its current state. However, with my new, more scalable architecture I must be missing a fundamental LV programming philosophy --> LabVIEW memory keeps increasing until it crashes (memory increasing and then CPU usage to ~100%). I have used the Tools -> Profile ->Performance and Memory and Tools -> Profile ->Show Buffer Allocations. I can see the VIs that are taking up more and more memory but am stumped on how to fix this problem. There was significant effort in my first redesign, and I was hoping I don't have to rework this architecture. To get right to the point, there are 2 basic designs that I thought were "clever" but must not be. The first is my basic SubVI structure. I created an array of cluster data where each array element is an object for each UUT I am testing (running parallel UUTs). I am using FOR loops to read/write the data of each "object". Note: I am not using LV's OOP features, just calling this cluster an object since it ties to a UUT. 1)Basic SubVI. 2) The example subVI above would be called in a "substate machine" <below>. I used state machines with functional globals, so that after each substate is driven the subVI is left (to access the main State Machine) and then comes back to the sub-state that is hanging out as a functional global. I am passing a lot of data (multiple clusters with arrays). I am guessing I have designed something that is fundamentally flawed. Can someone break my heart and tell me why. ***Right before posting this I noticed that the "sub-state machine" main data cluster doesn't need a shift-register terminal since this data is being passed in and out each time this subVI is run. Does this have an impact on memory?*** Thanks! That code construct resembles something that Shane and I looked into a while back. Check your buffer allocations. In some cases a stategic use of seq structures will help LV figure it can re-use the bufers. Q: Is the code you show the whole sub-VI or that code inside a case structure? Ben Quote
pete_dunham Posted October 5, 2010 Author Report Posted October 5, 2010 That code construct resembles something that Shane and I looked into a while back. Check your buffer allocations. In some cases a stategic use of seq structures will help LV figure it can re-use the bufers. Q: Is the code you show the whole sub-VI or that code inside a case structure? Ben Ben, Thanks for the reply. The original .png of the code was a sample VI that I made to simplify the question. But actually the subVI in question is three case statements deep (inserted below) Do you think that is the issue? I am not sure how to change my code for fewer buffer allocations with out some major re-design (which may need to happen, anyway) I should note to, per original post, that the PC this code runs on has 512MB of RAM. I plan to test the same code with more RAM installed. Will update if this fixes my memory problem. I hate to use a hardware forgive a design flaw (if that is what I have). But, it appears it is a balancing act --> paying some memory overhead for a scalable design; as I had a working program that was much harder to modify/understand (but didn't crash because of memory issues) Quote
Grampa_of_Oliva_n_Eden Posted October 5, 2010 Report Posted October 5, 2010 That code construct resembles something that Shane and I looked into a while back. Check your buffer allocations. In some cases a stategic use of seq structures will help LV figure it can re-use the bufers. Q: Is the code you show the whole sub-VI or that code inside a case structure? Ben URL for Dark-side discusion. http://forums.ni.com/t5/LabVIEW/cluster-array-performance-penalty/m-p/481919#M231529 Ben Quote
pete_dunham Posted October 5, 2010 Author Report Posted October 5, 2010 Have you tried using the in-place element structure? AND... URL for Dark-side discusion. http://forums.ni.com.../481919#M231529 Ben Per these replies--> it appears that LV 8.5+ (and higher) addressed this issue with the in-place structure. Now I need to convince my employer to leave 2007 (8.2.1) behind! Quote
Mellroth Posted October 6, 2010 Report Posted October 6, 2010 AND... Per these replies--> it appears that LV 8.5+ (and higher) addressed this issue with the in-place structure. Now I need to convince my employer to leave 2007 (8.2.1) behind! Hi, Even if you convert to a newer LabVIEW version I think you will still have to do some major redesign; In the picture posted in response to Bens question, you are entering the loop with both the complete cluster as well as an individual cluster element. Doing so should force LabVIEW into copying data. /J Quote
Grampa_of_Oliva_n_Eden Posted October 6, 2010 Report Posted October 6, 2010 Hi, Even if you convert to a newer LabVIEW version I think you will still have to do some major redesign; In the picture posted in response to Bens question, you are entering the loop with both the complete cluster as well as an individual cluster element. Doing so should force LabVIEW into copying data. /J Depends... on what is in that case structure. WIth a helper seq structure we can help LV "see" that the data buffer can be used in place so if the code is scheduled to do the opearations in the correct order, the copy is not required. Ben Quote
asbo Posted October 7, 2010 Report Posted October 7, 2010 WIth a helper seq structure we can help LV "see" that the data buffer can be used in place so if the code is scheduled to do the opearations in the correct order, the copy is not required. I'm not picking up what you're putting down about this helper sequence structure. Care to demonstrate? Quote
pete_dunham Posted October 7, 2010 Author Report Posted October 7, 2010 Depends... on what is in that case structure. WIth a helper seq structure we can help LV "see" that the data buffer can be used in place so if the code is scheduled to do the opearations in the correct order, the copy is not required. Ben I'm not picking up what you're putting down about this helper sequence structure. Care to demonstrate? Yes, I am still stuck on this. An upgraded PC and upgraded LabVIEW version 8.5 hasn't helped. LabVIEW just alocates up more memory before prompting with error message --> error message in 8.5.1 versus actual crash in 8.2.1. But I am struggling about where and how to implement the in-place structure to fix this. Also, I am not sure how to benefit from the Show Buffer Allocations. Hi, Even if you convert to a newer LabVIEW version I think you will still have to do some major redesign; In the picture posted in response to Bens question, you are entering the loop with both the complete cluster as well as an individual cluster element. Doing so should force LabVIEW into copying data. /J If this causes LabVIEW into copying data I am ; because it seems like this is an intuitive way to implement testing "objects" Without sending the complete <main data> cluster, along with a the individual <object>cluster elements (in certain subVIs), and the individual <object> array nested within the <main data> cluster -- there doesn't seem to be a way to keep my design neat. By neat I mean sending one cluster wire <main data> to my most top-level subVIs. Another, better, design approach doesn't jump out at me. I felt like I built this design on using LabVIEW "best practices" and programming technique, but clearly, I must still be missing something. Is the code presented a clearly depict a memory problem? Is it possible I am looking at the wrong section that is causing my program to crash? Other parts of my code use several VI server references which I know isn't best practice or desired. I checked to make sure I am closing all these references, but could this be an issue? Or is the consensus is my nested object artichitecture is killing this program? Thanks for everyone's input and insight. This problem is frustrating, but has been a great learning experience so far. -pete Quote
Mark Smith Posted October 7, 2010 Report Posted October 7, 2010 Now might be a good time to download an eval copy of the Execution Trace Toolkit - it's not without its own issues, but it really might be helpful in this instance to see where the memory is actually getting allocated at run time. Mark Quote
asbo Posted October 7, 2010 Report Posted October 7, 2010 Now might be a good time to download an eval copy of the Execution Trace Toolkit - it's not without its own issues, but it really might be helpful in this instance to see where the memory is actually getting allocated at run time. IIRC, you need at least 8.6 for that toolkit, but I could be mis-remembering. Either way, I'll vouch that it has a learning curve of its own, but once you get the hang of it, it can be a very valuable asset when you push the limits of LV. Quote
pete_dunham Posted October 8, 2010 Author Report Posted October 8, 2010 URL for Dark-side discusion. http://forums.ni.com.../481919#M231529 Ben Ben, Been reading over this link. A lot of good info. Thanks. ---- This explains what is happening to me: http://digital.ni.co...62571B5006B46E1 with problems described above(i think) Quote
ShaunR Posted October 8, 2010 Report Posted October 8, 2010 Ben, Been reading over this link. A lot of good info. Thanks. ---- This explains what is happening to me: http://digital.ni.co...62571B5006B46E1 with problems described above(i think) Looks like a move to a database is in order if you are shifting that much info around. Is MySQL or Access a viable option? Quote
asbo Posted October 8, 2010 Report Posted October 8, 2010 Looks like a move to a database is in order if you are shifting that much info around. Is MySQL or Access a viable option? Or SQLite? Quote
Grampa_of_Oliva_n_Eden Posted October 8, 2010 Report Posted October 8, 2010 Sorry about the hit-an-miss replies... many distractions. The show bufers will let you compare various code constructs to find one that minimize the number of buffer copies. What is in the Other case in the original image? That thread I linked from the dark-side included annotations about the buffers. The same approach could/should help. Re: seq structure Somewhere in the old LAVA I responded to a thread froma user with a pig icon (?) about memory. In that case the array size was forcing a "buffer copy on wire branch" and a seq structure helped LV figure out that it could check the size THEN latter do something in the same buffer. I hope that helps, Ben Quote
Grampa_of_Oliva_n_Eden Posted October 8, 2010 Report Posted October 8, 2010 Sorry about the hit-an-miss replies... many distractions. The show bufers will let you compare various code constructs to find one that minimize the number of buffer copies. What is in the Other case in the original image? That thread I linked from the dark-side included annotations about the buffers. The same approach could/should help. Re: seq structure Somewhere in the old LAVA I responded to a thread froma user with a pig icon (?) about memory. In that case the array size was forcing a "buffer copy on wire branch" and a seq structure helped LV figure out that it could check the size THEN latter do something in the same buffer. I hope that helps, Ben Found that old thread! http://lavag.org/topic/4656-memory-allocation/page__p__25647__hl__%22ben%22+inplace+%22array+size%22__fromsearch__1#entry25647 Ben 1 Quote
asbo Posted October 8, 2010 Report Posted October 8, 2010 Found that old thread! http://lavag.org/topic/4656-memory-allocation/page__p__25647__hl__%22ben%22+inplace+%22array+size%22__fromsearch__1#entry25647 Ben What a wild goose chase ... there's no pig avatar in sight. Quote
Grampa_of_Oliva_n_Eden Posted October 8, 2010 Report Posted October 8, 2010 What a wild goose chase ... there's no pig avatar in sight. Wild boar chase? I was just reporting what I remembered. The good news is I found that using the LAVA search box. Ben 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.