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模块显示数据:
仿真结果仿真结果和计算结果相同。
网友评论