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

上传人:b****7 文档编号:9239010 上传时间:2023-02-03 格式:DOCX 页数:9 大小:243.61KB
下载 相关 举报
1使用Matlab产生二进制文件bin.docx_第1页
第1页 / 共9页
1使用Matlab产生二进制文件bin.docx_第2页
第2页 / 共9页
1使用Matlab产生二进制文件bin.docx_第3页
第3页 / 共9页
1使用Matlab产生二进制文件bin.docx_第4页
第4页 / 共9页
1使用Matlab产生二进制文件bin.docx_第5页
第5页 / 共9页
点击查看更多>>
下载资源
资源描述

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

《1使用Matlab产生二进制文件bin.docx》由会员分享,可在线阅读,更多相关《1使用Matlab产生二进制文件bin.docx(9页珍藏版)》请在冰豆网上搜索。

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

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’)。

>>a=[123456789];

>>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');

[SIN,num]=fread(fip,[2,20],'double');%inf表示读取文件中的所有数据,[M,N]表示

%将读取的数据放置在M行N列中,N表示将读取的数据放置在1列中

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');

[Array_2D,num]=fread(fip,inf,'double');%inf表示读取文件中的所有数据,[M,N]表示

%将读取的数据放置在M行N列中,N表示将读取的数据放置在1列中

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');

[SIN,num]=fread(fip,[2,20],'double');%inf表示读取文件中的所有数据,[M,N]表示

将读取的数据放置在M行N列中,N表示将读取的数据放置在1列中

fclose(fip);

 

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

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

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

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

 

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

WXJ

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

%clc

%clearall;

loadmy6.mat

fip=fopen('C:

\binary1.bin','wb')%fid返回值大于0,表示打开成功

fwrite(fip,mm,'int16')%按照整形数据写入,即每个数据占16位。

返回指针的值表示写入多少个数据

fclose(fip)%返回指针的值为0,则表示存储数据正常

fip=fopen('C:

\binary1.bin','rb');

A=fread(fip,inf,'int16');%inf表示读取文件中的所有数据,[M,N]表示

%将读取的数据放置在M行N列中,N表示将读取的数据放置在1列中

fclose(fip)

%%下面为测试用代码

fori=1:

400

B(i,1)=A(i,1);

End

B

注意:

fwrite()函数把矩阵mm写入.bit文件时,从矩阵mm中按照列顺序(即自上而下从左到右顺序)写入.bit文件中(其中,.bit文件数据按照从左到右自上而下的顺序存储)。

并且使用16位或别的超过8位数据时,在.bit文件中低八位写在高八位的前面。

 

注:

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

如1:

如2:

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

 

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 高等教育 > 文学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1