IEEE754 C 语言代码

void ConvertDexToIEE754(float fpointer,unsigned char *a)  //十进制转化为 IEEE745 小数
{   
    int Flag=0;
    double   integer,decimal;    //整数,小数  
    unsigned  long   bininteger,bindecimal;   //二进制整数,二进制小数
    int   _power,i;
    
    if(fpointer<0)
    {
      fpointer=fpointer*(-1);
      Flag=1;
    }

    decimal = modf(fpointer,&integer);   //将整数位到存到 integer ,小数位返回到decimal
    if(decimal || integer)    //判断 fpointer是否为0
    {         
     bindecimal = (unsigned  long )(decimal * 0x800000);   //0x800000=2^23 。得到小数位二进制表现形式         
     while((bindecimal & 0xff800000) > 0) //计算有没有超过23位二进制数           
     bindecimal >>= 1;         
     if(integer > 0)        
     {              
      bininteger = (unsigned  long )integer;             
       for(i=0;i<32;i++)               //计算整数部分的2的幂指数,整数位转化为二进制后的位数,计算小数点移动的位数
       {
          if(bininteger&0x1)
         _power = i;
         bininteger >>= 0x1;
       }
    bininteger = (unsigned  long )integer;
    bininteger &= ~(0x1 << _power); //去掉最高位的1
    if(_power >= 23) //如果幂指数>23 则舍弃小数位部分
    {
          bininteger >>= (_power-23);
          bindecimal = 127+_power;
          bininteger |= bindecimal << 23;
    }
    else
    {
          bininteger <<= (23 - _power);//将去掉最高位的整数二进制,移至第22为
          bindecimal >>= _power;       //将小数部分左移1,
          bininteger |= bindecimal;    //二者向或得到1.x的x,
          bindecimal = 127+_power;     //指数,右移的小数点数+127
          bininteger |= bindecimal << 23; // 指数为右移23为变为或上x。
    }
  }
    else if(integer == 0)
    {
            bindecimal <<= 9; //将小数部分的二进制移至最高位31位
            _power = 0;
            bininteger = bindecimal;
            while(bininteger == ((bindecimal<<1)>>1)) //判断小数位最高位是否为1.  最高位为0 :真
            {
              _power++;
              bindecimal <<= 0x1;
              bininteger = bindecimal;  //直到最高位为1,退出循环
            }
            _power++;
            bindecimal <<= 0x1;    //将1.x的1去掉 求x的值,
            bindecimal >>= 9;      //将小数位回到0-22位   
            bininteger = bindecimal; //暂存到二进制整数中,
            bindecimal = 127-_power;
            bininteger |= bindecimal << 23;  //将指数为右移值23为向或得到其值,
    }
     if(Flag==1)
      bininteger |= 0x80000000;


    i = 0;
    a[i++] =(unsigned char) ((bininteger >> 24) & 0xff);
    a[i++] = (unsigned char)((bininteger >> 16) & 0xff);
    a[i++] = (unsigned char)((bininteger >> 8 ) & 0xff);
    a[i++] =(unsigned char)( bininteger & 0xff);
    }
}

float ConvertIEE754ToDex(unsigned char *SpModRegister)
{
float x,fpointer;
unsigned long bininteger,bintmp;
int _power,i=0,s;

bintmp = SpModRegister[i++] << 8;
bintmp |= SpModRegister[i++];
bininteger = SpModRegister[i++] << 8;
bininteger |= SpModRegister[i++];
bininteger |= bintmp << 16;

if(bininteger == 0)
return 0.0;

bintmp = bininteger & 0x7FFFFF;
x = (double)bintmp / 0x800000;
bintmp = bininteger >> 23;
_power = bintmp & 0xff;

bintmp = bininteger & 0x80000000;
s = (bintmp) ? 1 : 0 ;

bintmp =(unsigned  long ) pow(2,fabs(_power-127)) ;
if(_power >= 127)
fpointer = (1+x) * bintmp ;
else
fpointer = (1+x) / bintmp ;
//bintmp = (fpointer * 10000 + 5)/10;
//fpointer = (double)bintmp / 1000;

 if(s)
   fpointer *= -1;

 return (fpointer);
}
  • 7
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值