Read a binary file of format float
Mostra commenti meno recenti
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');
Risposte (2)
Salaheddin Hosseinzadeh
il 3 Giu 2015
Modificato: Salaheddin Hosseinzadeh
il 3 Giu 2015
0 voti
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 Commenti
Alon
il 3 Giu 2015
Alon
il 3 Giu 2015
Salaheddin Hosseinzadeh
il 3 Giu 2015
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
il 3 Giu 2015
0 voti
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 Commenti
Alon
il 3 Giu 2015
James Tursa
il 3 Giu 2015
Do you have the C# code that wrote the file? If so, please post the relevant parts that did the writing.
Alon
il 3 Giu 2015
James Tursa
il 3 Giu 2015
Modificato: James Tursa
il 3 Giu 2015
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
il 3 Giu 2015
Modificato: James Tursa
il 3 Giu 2015
"... 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
il 3 Giu 2015
Alon
il 3 Giu 2015
Alon
il 3 Giu 2015
Categorie
Scopri di più su Low-Level File I/O in Centro assistenza e File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!

