固定点数据类型fixdt()

fixdt是matlab提供的用于描述一种固定点数据类型的函数

比如:fixdt(1,8,3)   fixdt(1,16)    fixdt(0,8,5)

固定点数据类型,其实就是二进制数据。

函数  fixdt()  一般包括3个参数,分别设置 符号,数据长度  和   小数数据长度

(1)符号,比如 fixdt(1,8,3) 第一个参数是 1,就表示该二进制的首位数字将用来表示符号位。则如果首位数字是1,那么这个二进制就表示“负数”;如果首位数字是0,那么这个二进制就表示“正数”。

(2)数据长度,fixdt(1,8,3) 第二个参数是 8,表示:该二进制数据一共8位,即8个二进制位。

(3)小数数据长度,fixdt(1,8,3) 第三个参数是 3,表示:最后三个数据位表示小数数据。

如果 fixdt()  函数只有两个参数,比如 fixdt(1,16) 就不用考虑小数数据位了。

还是以   fixdt(1,8,3) 为例,我们来表示  “ 3.875 ”

首先3.875是正数,所以二进制首位数字就为0 (不需要符号);二进制后三位表示小数部分,当后三位为111时, 再进一位就是1000,所以到第四位才能表示实数“1”,即2^3=1(注意二进制第一位是2^0,所以第四位是2^3)那么该二进制数据的分辨率就为1/(2^3)=0.125。小数部分0.875=0.125*7,那么后三位二进制就是:111。最后实数3由第四位和第五位表示“11”。则最后“ 3.875 ”将被表示为:00011111

在matlab中验证一下:

在Constant常数模块中按照fixdt(1,8,3) 数据类型输出3.875:

输入数据3.875
设置输出数据类型为  fixdt(1,8,3)

通过Display模块显示数据:

仿真结果

仿真结果和计算结果相同。

你可能感兴趣的:(固定点数据类型fixdt())