 ospl
		
			ospl
		
		
		
		
		
		
		
		
	
			04-24-2014 01:18 AM
I have binary data file of 200 MB of 1000561 rows and 32 columns when i am reading file and sequentially ploting memory full message generated.
Now I want to read file in parts like from 500th row to 5000th row with all column and plot it in the graph.
I tried to design logic using advanced file functions like set file position and read binary file block but still dont get the sollution.
Please help me out to solve this issue.
Thanks in advance..
Solved! Go to Solution.
 billko
		
			billko
		
		
		
		
		
		
		
		
	
			04-24-2014 01:38 AM
You have to know the format of the binary data before you can extract it. It's like having the decoder ring. What made this file?
04-24-2014 07:43 AM
Thanks for your quick reply..
Data stored in the form of string..
04-24-2014 08:02 AM
Actually this is my data coming from 32 AI channels at 1 ks/s samling rate so it is 1000 Seconds data of all channels.
As I am trying to read from read binary file and plot in graph by indexing labview showing Memory full error.
Now I want to provide user control to select duration to analyse in duration like from 50th sec to 150 sec.
So I want to read file in parts and plot it parallely in graph for analysis according to duration selected by user.
I want maximum analysis duaration of 100 sec.
Waiting for your reply...
thanks
 billko
		
			billko
		
		
		
		
		
		
		
		
	
			04-24-2014 09:47 AM
Probably the simplest thing to do is make a cluster of what you consider to be one "packet" of data. You write those packets using the "Write to Binary File." You retrieve the data using the "Read from Binary File" using the same cluster. Using that cluster tells LabVIEW how the data coming out should be interpreted. Of course, if you use the wrong cluster, the data is not interpreted correcly and you end up with gibberish.
Maybe your best format is an array of clusters.
 nathand
		
			nathand
		
		
		
		
		
		
		
		
	
			04-24-2014 10:57 AM
ospl wrote:
Data stored in the form of string..
Then this isn't really a binary file!
Can you provide an example section of the data file, along with a VI that shows what you've tried? There might be an easy fix to the memory problems, but there's no way to know without seeing your code.
If every data point within a particular column is stored in the same number of characters (so if you have a column that contains 5 and 50, you would need the values stored as something like "05.5" and "50.0" so that they both occupy 4 bytes) then it is easy to skip to a particular row. If you were really using a binary file, such that you were storing the numbers in their computer representation rather than as text, it would also be easy to skip to a particular row.
However, if you're using a string representation, then most likely each number is stored using as many characters (bytes) as is required to display the value, so there's no consistency. In this case, there's no quick way to skip the to the correct location in the file. If you can fit all the data in memory as numbers, then the best solution is probably to read in the entire file, convert to numeric, and display the appropriate section of the array.
 jatinpatel1489@
		
			jatinpatel1489@04-30-2014 05:23 AM
Hi ospl,
To read specific part of binary file I suggest you to set the file position from where you want to read data and specify how many block you need to read from binary file into read binary file.VI
for example if you write 2D array into binary file then mention you data type this 2D array and make your count (5000-500). Then set you file position. If you have 32 column and data type DBL then it makes 256 for second row and 256*500 for 501th row. Use this number as input to your get file position.vi.
I hope you will find you way through this.