如何用matlab实现将正负小数矩阵转为二进制比特流比如说下列7行1列的矩阵转为每个数用8位二进制数来表示.x=-0.0039-0.0071-0.0071-0.00110.00430.00340.0029如果还有余力的大神,也恳请指教恢复回原来
来源:学生作业帮助网 编辑:作业帮 时间:2024/11/24 06:40:16
如何用matlab实现将正负小数矩阵转为二进制比特流比如说下列7行1列的矩阵转为每个数用8位二进制数来表示.x=-0.0039-0.0071-0.0071-0.00110.00430.00340.0029如果还有余力的大神,也恳请指教恢复回原来
如何用matlab实现将正负小数矩阵转为二进制比特流
比如说下列7行1列的矩阵转为每个数用8位二进制数来表示.
x=
-0.0039
-0.0071
-0.0071
-0.0011
0.0043
0.0034
0.0029
如果还有余力的大神,也恳请指教恢复回原来正负小数矩阵的源代码!求指教!
如何用matlab实现将正负小数矩阵转为二进制比特流比如说下列7行1列的矩阵转为每个数用8位二进制数来表示.x=-0.0039-0.0071-0.0071-0.00110.00430.00340.0029如果还有余力的大神,也恳请指教恢复回原来
8位二进制最多表示256种数据
显然不能使用浮点数来储存
看你的数据格式都是0.00xx的小数形式,那么我们可以用定点数来表示
一种比较简单的办法就是将原来的数乘上10000倍
那么都会变成整数,由于8位有符号整数的表达范围是-128~127
我们可以用8位有符号整数来表示你的数据,默认其表示的是小数点后4为的数
这样就可以获得-0.0128~0.0127范围以内的小数
解码也比较简单,每8位二进制数一起看成是一个8位有符号数
将获得的数除以10000,得到浮点数就是原来的小数了.
%编码
x=[-0.0039;-0.0071;-0.0071;-0.0011;0.0043;0.0034;0.0029;];
a=int8(x*10000);
fid=fopen('dat.bin','w');
fwrite(fid,a,'int8');%转化为进制流,写入文件
fclose(fid);
%解码
fid=fopen('dat.bin','r');
b=fread(fid,inf,'int8');%读出二进制流文件中的数据
fclose(fid);
y=b/10000;%还原数据