您的位置 首页 电路

在单片机中的浮点数编程

问题背景:在使用8BIT单片机进行开发,不支持浮点数运算。但是开发必须用到sin,cos,arctan等浮点数函数。苦想了两天,才发现,自己要当一…

问题布景:

在运用8BIT单片机进行开发,不支持浮点数运算。但是开发有必要用到sin,cos,arctan等浮点数函数。

苦想了两天,才发现,自己要当一回“计算机”。

单片机不支持浮点数,但是编程却一定要用到小数。这时,只好自界说“定点小数”了。

所需的浮点数规模有两个区域-1~1,-60~60。精度就按小数点后2、3位了。

如果在府第语言中,我想界说的数组是

double arctantable[95]=

{

0.0174551,0.0349208, 0.0524078, 0.0699268, 0.0874887, 0.105104, 0.122785, 0.140541, 0.158384, 0.176327,

0.19438, 0.212557, 0.230868, 0.249328, 0.267949, 0.286745, 0.305731, 0.32492, 0.344328, 0.36397,

0.383864, 0.404026, 0.424475, 0.445229, 0.466308, 0.487733, 0.509525, 0.531709, 0.554309, 0.57735,

0.600861, 0.624869, 0.649408, 0.674509, 0.700208, 0.726543, 0.753554, 0.781286, 0.809784, 0.8391,

0.869287, 0.900404, 0.932515, 0.965689, 1, 1.03553, 1.07237, 1.11061, 1.15037, 1.19175,

1.2349,1.27994, 1.32704, 1.37638, 1.42815, 1.48256, 1.53986, 1.60033, 1.66428, 1.73205,

1.80405, 1.88073, 1.96261, 2.0503,2.14451, 2.24604, 2.35585, 2.47509, 2.60509, 2.74748,

2.90421, 3.07768, 3.27085, 3.48741, 3.73205, 4.01078, 4.33148, 4.70463, 5.14455, 5.67128,

6.31375, 7.11537, 8.14434, 9.51436, 11.43, 14.3007, 19.0811, 28.6362, 57.2899,

-57.2897, -0.0174551, 0.0174551, 57.2897, -57.2897,-0.0174551

};

在单片机中,我可不能这样界说。会报错的。

调查数据后,咱们发现整数部分要6bit,符号位要1bit,小数部分(0.99)110 0011(7bit),故一个浮点数,用2byte来一共,高8bit是符号位和整数部分,低8bit是小数部分。

0.0174551(0.02)在单片机中,能够一共为0x0002;

0.0349208,可一共为0x0003;

-57.2897,可一共为0xb91d;等等……

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/fangan/dianlu/263701.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部