当前位置:文档之家› 1使用Matlab产生二进制文件bin

1使用Matlab产生二进制文件bin

1使用Matlab产生二进制文件bin
1使用Matlab产生二进制文件bin

Matlab中如何实现二进制文件的读写

说明:matlab产生的是.bin二进制文件。.bit是FPGA的比特流文件

1、文件的打开与关闭

1)打开文件

在读写文件之前,必须先用fopen函数打开或创建文件,并指定对该文件进行的操作方式。fopen 函数的调用格式为:

fid=fopen(文件名,‘打开方式')

说明:其中fid用于存储文件句柄值,如果返回的句柄值大于0,则说明文件打开成功。文件名用字符串形式,表示待打开的数据文件。常见的打开方式如下:

‘r':只读方式打开文件(默认的方式),该文件必须已存在。

‘r+':读写方式打开文件,打开后先读后写。该文件必须已存在。

‘w':打开后写入数据。该文件已存在则更新;不存在则创建。

‘w+':读写方式打开文件。先读后写。该文件已存在则更新;不存在则创建。

‘a':在打开的文件末端添加数据。文件不存在则创建。

‘a+':打开文件后,先读入数据再添加数据。文件不存在则创建。

另外,在这些字符串后添加一个“t”,如‘rt'或‘wt+',则将该文件以文本方式打开;如果添加的是“b”,则以二进制格式打开,这也是fopen函数默认的打开方式。

2)关闭文件

文件在进行完读、写等操作后,应及时关闭,以免数据丢失。关闭文件用fclose函数,调用格式为:

sta=fclose(fid)

说明:该函数关闭fid所表示的文件。sta表示关闭文件操作的返回代码,若关闭成功,返回0,否则返回-1。如果要关闭所有已打开的文件用fclose(‘all')。

2、二进制文件的读写操作

1)写二进制文件

fwrite函数按照指定的数据精度将矩阵中的元素写入到文件中。其调用格式为:

COUNT=fwrite(fid,A,'precision')

说明:其中COUNT返回所写的数据元素个数(可缺省),fid为文件句柄,A用来存放写入文件的数据,precision代表数据精度,常用的数据精度有:char、uchar、int、long、float、double等。缺省数据精度为uchar,即无符号字符格式。

例6.8 将一个二进制矩阵存入磁盘文件中。

>> a=[1 2 3 4 5 6 7 8 9];

>> fid=fopen('d:\test.bin','wb') %以二进制数据写入方式打开文件

fid =

3 %其值大于0,表示打开成功

>> fwrite(fid,a,'double')

ans =

9 %表示写入了9个数据

>> fclose(fid)

ans =

0 %表示关闭成功

2)读二进制文件

fread函数可以读取二进制文件的数据,并将数据存入矩阵。其调用格式为:

[A,COUNT]=fread(fid,size,'precision')

说明:其中A是用于存放读取数据的矩阵、COUNT是返回所读取的数据元素个数、fid为文件句柄、size为可选项,若不选用则读取整个文件内容;若选用则它的值可以是下列值:N(读取N 个元素到一个列向量)、inf(读取整个文件)、[M,N](读数据到M×N的矩阵中,数据按列存放)。precision用于控制所写数据的精度,其形式与fwrite函数相同。

%写一维数据至数据文件

n=0:pi/10:4*pi;

y=sin(n);

fip=fopen('C:\binary3.bin','wb');

fwrite(fip,Pxx,'double');

fclose(fip);

%从数据文件读取一维数据

fip=fopen('C:\binary3.bin','rb');

[M,N]表示[SIN,num]=fread(fip,[2,20],'double');%inf表示读取文件中的所有数据,1列中列中,N 表示将读取的数据放置在将读取的数据放置在%M行N fclose(fip)

%写二维数据至数据文件n=0:pi/10:4*pi; y1=sin(n);y2=sin(n);y3=0.5*sin(n); y=[y1;y2;y3];

fip=fopen('C:\binary4.bin','wb'); fwrite(fip,y,'double'); ,则表示存储数据正常fclose(fip); %返回指针的值为0

从数据文件读取二维数据% fip=fopen('C:\binary4.bin','rb'); 表示表示读取文件中的所有数据,[M,N][Array_2D,num]=fread(fip,inf,'double');%inf 1列中N行N列中,表示将读取的数据放置在%将读取的数据放置在M fclose(fip)

详细的范例如下。

**********************************

%写一维数据至数据文件n=0:pi/10:4*pi; y=sin(n); fip=fopen('C:\binary3.bin','wb');

fwrite(fip,Pxx,'double'); fclose(fip);

从数据文件读取一维数据% fip=fopen('C:\binary3.bin','rb'); [M,N]表示

[SIN,num]=fread(fip,[2,20],'double');%inf表示读取文件中的所有数据,列中N表示将读取的数据放置在1行将读取的数据放置在MN列中,fclose(fip);

********************************** **********************************

********************************************************************

3、matlab中读写二进制文件(.bit)。。。WXJ

1、在matlab中输入一下代码,然后产生代码binary1.bit

%clc%clear all;my6.mat load

,表示打开成功0) % fid返回值大于

fip=fopen('C:\binary1.bin','wb'fwrite(fip,mm,'int16') %按照整形数据写入,即每个数据占16位。返回指针的值表示写入多少个数据,则表示存储数据正常0%返回指针的值为

fclose(fip)

);,'rb'fip=fopen('C:\binary1.bin'%inf表示读取文件中的所有数据,[M,N]'int16');表示A=fread(fip,inf,列中1列中,N表示将读取的数据放置在将读取的数据放置在%M行

N fclose(fip)

下面为测试用代码%% i=1:400for B(i,1)=A(i,1);End

B

中按照列顺序(即自上而下从左mm写入.bit文件时,从矩阵fwrite()注意:函数把矩阵mm。并且.bit文件数据按照从左到右自上而下的顺序存储)到右顺序)写入.bit文件中(其中,文件中低八位写在高八位的前面。位数据时,在位或别的超过使用168.bit

注:查看.bit二进制文件使用的是EmEditer编辑器

:1如

:如2

,5)-即1000_0000_0000_0101(的原码是FFFB使用补码形式表示的,5-其中

相关主题
文本预览
相关文档 最新文档