 mthheitor
		
			mthheitor
		
		
		
		
		
		
		
		
	
			06-27-2019 07:51 AM
Hello
I'm building a subvi named "subvi_gráficos.vi", that will filter and show data from a soldering machine.
I'm testing my subvi with a old data from that machine (Dados.txt).
But when I run my code, I'm noticing that my main.vi is running kinda slow. The main.vi is a VI that I built to test if the subvi is ok.
Can you please tell me why the code is running slow?
That's worrying me, because if the code runs slow when the soldering machine is on, maybe I will lose data.
Main
Subvi
 wiebe@CARYA
		
			wiebe@CARYA
		
		
		 
		
		
		
		
		
	
			06-27-2019 08:14 AM
The stuff in the main before the subVI can be put outside the loop.
The buffering of the array size seems a bit weird. It might actually slow things down, as LV might need a copy of the array. Not exactly sure what the point is...
You're using Index & Bundle Cluster Array. That's a big big big waste of CPU. Why not simply put the array in a cluster, and build an array for those cluster? That will be a lot faster.
What is slow? You're processing 24000X6 values. That will take some time.
 Yamaeda
		
			Yamaeda
		
		
		
		
		
		
		
		
	
			06-27-2019 09:52 AM
In your main loop you're adding to the array in an uncontrolled manner, that array will grow very fast and soon you'll be processing millions of numbers.
/Y
 wiebe@CARYA
		
			wiebe@CARYA
		
		
		 
		
		
		
		
		
	
			06-27-2019 10:09 AM
@Yamaeda wrote:
In your main loop you're adding to the array in an uncontrolled manner, that array will grow very fast and soon you'll be processing millions of numbers.
/Y
Good catch. The uninitialized shift register.
So not only will it run slow. It will run slower and slower until you get an Out Of Memory.
07-12-2019 03:50 PM
The main.vi it's only a test VI, the only thing that will be used from it is the XY Graph display.
The important VI is "subvi_graficos.vi" (implemented in the machine)
A doubt: how can I do the "simulation" of process the data (.txt) and build a XY Graph over time (simulating the real machine process) without the uninitialized shift register?
And didn't knew about the Index & Bundle Cluster Array. The array of cluster seems more reasonable. Thanks @wiebe@CARYA
 wiebe@CARYA
		
			wiebe@CARYA
		
		
		 
		
		
		
		
		
	
			07-15-2019 01:58 AM
@mthheitor wrote:A doubt: how can I do the "simulation" of process the data (.txt) and build a XY Graph over time (simulating the real machine process) without the uninitialized shift register?
There's no easy answer to that, AFAIC.
You're algorithm needs to be adapted to handle the data in a point by point way. Meaning it will need an initialize to reset the first time (or for a 2nd set of data), and remember it's state over different runs. For instance a PtByPt average will run, and then remember the number of samples and the average. Then the next run, it can use that data to add the new data to the average.
The sate will be kept in an uninitialized shift register or feedback node. Or if you're into OO, put the state in the class's private data, and put the class object in a shift register. This has added benefits when upscaling, for instance if you have an array of inputs to process. The non-OO version can't do that, and when you have >1 instances, you'd need to make it reentrant, or the instances will communicate with each other.
Another option is to simply read all the data, and then pass it once to the algorithm. You're doing that now, but only after running several small iterations. Not sure it if's feasible as a final solution.