필터 지우기
필터 지우기

saving variables in a single .mat file

조회 수: 3 (최근 30일)
zozo
zozo 2012년 3월 26일
Hello,
I have 360 .mat files containing same variable in with different data (row vectors) each of size in(1x3800000) stored in them. They are of size 9.84GB (all 360 files).
Now I want to save them all in 1 .mat file as a matrix out(360x3800000).
How can I do it?
  댓글 수: 2
Daniel Shub
Daniel Shub 2012년 3월 26일
What problems are you running into?
zozo
zozo 2012년 3월 26일
I need to extract some data from each of these 360 files(row vectors) and do further processing. So, I do not want to load them 1 by 1,extract data, load again and so on. Having them all together in a cell/array makes it far easier.

댓글을 달려면 로그인하십시오.

채택된 답변

ndiaye bara
ndiaye bara 2012년 3월 26일
Try this code m=zeros(3800000,360); for k=1:360, eval(sprintf('load F*_%d.mat',k)); % F*=name of all your files .mat% eval(sprintf('y=F*_%d(:,1);',k)); disp(k); clear F* if k==1, m=y; else m=[m,y]; end end
save File m t %save the new file .mat
  댓글 수: 4
zozo
zozo 2012년 3월 27일
Same variable 'in' was saved each time, but with different file names as data(1).mat,data(2).mat,data(3).mat.......data(360).mat
Please suggest the syntax for my case.
Jan
Jan 2012년 3월 27일
Dear zozo, accepting an answer means, that it solves your problem.
Daniel and I have warned you that you cannot load a 11GB of data (360*3800000*8 byte per double) efficiently, if you have only 4GB of RAM. I assume you need 32GB RAM to work efficiently with such large data, 64GB is safer.
The above EVAL approach is cruel.
You currently did not specify in which format you want to store the data, DOUBLEs or SINGLEs, an integer type, as cell or matrix. Anyhow, I'm convinced, that it is the wrong approach due to the limited memory.

댓글을 달려면 로그인하십시오.

추가 답변 (2개)

Jan
Jan 2012년 3월 26일
Do you have a 64-bit Matlab version? How many RAM do you have installed? Do you want to store the values in one 360 x 3'800'000 array, a most likely more useful 3'800'000 x 360 array, of as separate vectors e.g. in a {1 x 360} cell. The later has the advantage, that it does not need a contiguos free block of memory.
  댓글 수: 4
Jan
Jan 2012년 3월 26일
4GB RAM is very lean for such a big chunk of data. If it is really necessary to keep all values in the RAM simultaneously, buy more RAM. Implementing workarounds to process the data in pieces will be more expensive.
Jan
Jan 2012년 3월 26일
@Siva: Does you comment concern the current topic? If so, please explain the connection. If not, please delete the comment and post it as a new question - with more details. Thanks.

댓글을 달려면 로그인하십시오.


Daniel Shub
Daniel Shub 2012년 3월 26일
In a comment to Jan you say you have 4 GB of RAM. Loading 9+ GB of data is going to bring your computer to a screeching halt.
Try and create an array of the required size and see what happens ...
x = randn(360, 38000000);
  댓글 수: 2
zozo
zozo 2012년 3월 26일
Yes, I think I will load 7x(50x3800000)+10 at a time. But Iam having problem loading them into 1 file as suggested by @ndiaye
Daniel Shub
Daniel Shub 2012년 3월 27일
Why? Nobody wants a 1+GB data file. Leave the files small and load them as needed. I doubt there is much of a benefit of doing a single huge load.

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Environment and Settings에 대해 자세히 알아보기

태그

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by