Read a binary file of format float
이전 댓글 표시
Hello, I have a binary file that holds a content of float array that wa written in c#. I want to read it into matlab to view that float array. I think I need to use the next command but it seems to fail:
myfloat=fread(fID,1,'float');
답변 (2개)
Salaheddin Hosseinzadeh
2015년 6월 3일
편집: Salaheddin Hosseinzadeh
2015년 6월 3일
0 개 추천
Hi Alon,
As a C# programmer you know that "it fails" is not enough!
BTW, sometime when I want to generate a file specially on drive C, I have to open MATLAB as an administrator! You may wanna to this as well.
댓글 수: 4
Alon
2015년 6월 3일
Alon
2015년 6월 3일
Salaheddin Hosseinzadeh
2015년 6월 3일
Dear Alon,
Just answer James questions.
When you open the file using fopen, do you get a valid File ID?
A valid file ID is an integer.
fileID = fopen('myfile.xyz')
Most importantly, pleaseee post the error message
James Tursa
2015년 6월 3일
0 개 추천
Did you open the file first to obtain a valid fID? Are you getting an error message? (If so, please post the entire message). Are you getting garbage for myfloat? (Indicating possible endian problem, or maybe header data not accounted for, or data is not really float, etc.)
댓글 수: 10
Alon
2015년 6월 3일
James Tursa
2015년 6월 3일
Do you have the C# code that wrote the file? If so, please post the relevant parts that did the writing.
Alon
2015년 6월 3일
James Tursa
2015년 6월 3일
편집: James Tursa
2015년 6월 3일
Are the values correct for the elements you did read? If so, are you sure there are 138444 floats in the file? What is the file size? To keep the values read in from fread as single use '*float' instead of 'float'.
James Tursa
2015년 6월 3일
편집: James Tursa
2015년 6월 3일
"... placed in wrong index ..."
Please elaborate on the above phrase. Do the numbers match exactly but in the wrong index? If so, give an example of the first few numbers on the C# side and their locations on the MATLAB side to detail explicitly what the indexing problem is you are seeing.
Using '*float' vs 'float' should not have changed any of the values, so your last comment doesn't make sense to me.
'float' --> Read the numbers as float and convert to duoble
'*float' --> Read the numbers as float and keep them that way (i.e., single)
Alon
2015년 6월 3일
Alon
2015년 6월 3일
Alon
2015년 6월 3일
카테고리
도움말 센터 및 File Exchange에서 Low-Level File I/O에 대해 자세히 알아보기
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!

