久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 7628|回復: 0
打印 上一主題 下一主題
收起左側

單片機浮點數運算實現

[復制鏈接]
跳轉到指定樓層
樓主
ID:50658 發表于 2013-6-12 23:32 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
單片機浮點數運算實現:浮點數顯示子函數和顯示十進制尾數和階的子函數。
(1)浮點數顯示子函數。
/********************************
函數名稱: void DispF(float f)
功能 :用科學記數法顯示浮點數,在float全范圍內精確顯示,超出范圍給出提示。
說明 :浮點數表示范圍為+-1.175494E-38到+-3.402823E+38
入口參數:f為要顯示的浮點數
返回值 :無
********************************/

void DispF(float f)  

{

      float  tf, b;

      unsigned long w, tw;

      char i, j;

      if(f<0)

       {

        PrintChar(’-’);

        f=-1.0*f;

       }

     if(f<1.175494E-38)

       {

         printf("?.??????");   //太小了,超出了最小范圍。

         return;

       }

     if(f>1E35)            //f>10^35

       {

        tf=f/1E35;

        b=1000.0;

        for(i=0,j=38;i<4;i++,j--)

         {

if(tf/b<1)

            b=b/10.0;

          else

break;

          w=f/(1E29*b);      //1E35*b/1E6

          PrintW(w,j);

         }

}

     else if(f>1E28)

       {

        tf=f/1E28;

        b=1E7;

        for(i=0,j=35;i<8;i++,j--)

          {

if(tf/b<1)

             b=b/10.0;

           else

   break;

           w=f/(1E22*b);     //1E28*b/1E6

           PrintW(w,j);

          }

}

      else if(f>1E21)

        {

         tf=f/1E21;

         b=1E7;

         for(i=0,j=28;i<8;i++,j--)

         {

if(tf/b<1)

b=b/10.0;

          else

break;

          w=f/(1E15*b);      //1E21*b/1E6

          PrintW(w,j);

         }

}

      else if(f>1E14)

        {

         tf=f/1E14;

         b=1E7;

         for(i=0,j=21;i<8;i++,j--)

         {

if(tf/b<1)

            b=b/10.0;

          else

break;

          w=f/(1E8*b);       //1E14*b/1E6

          PrintW(w,j);

          }

         }

      else if(f>1E7)

        {

         tf=f/1E7;

         b=1E7;

         for(i=0,j=14;i<8;i++,j--)

           {

if(tf/b<1)

b=b/10.0;

            else

break;

            w=f/(10.0*b);      //1E28*b/1E6

            PrintW(w,j);

           }

}

      else if(f>1)

        {

          tf=f;

          b=1E7;

          for(i=0,j=7;i<8;i++,j--)

          if(tf/b<1)

            b=b/10.0;

          else

break;

          w=f/(1E-6*b);       //1E0*b/1E6

          PrintW(w,j);

         }

      else if(f>1E-7)

        {

         tf=f*1E7;           //10^-7      

         b=1E7;

         for(i=0,j=0;i<8;i++,j--)

           {

if(tf/b<1)

b=b/10.0;

            else

break;

            w=f*(1E13/b);     //(1E7/b)*1E6

            PrintW(w,j);

           }

}

       else if(f>1E-14)

         {

           tf=f*1E14;        //10^-14        

           b=1E7;

           for(i=0,j=-7;i<8;i++,j--)

           {

if(tf/b<1)

b=b/10.0;

            else

break;

            w=f*(1E20/b);    //(1E14/b)*1E6

            PrintW(w,j);

           }

}

       else if(f>1E-21)

         {

           tf=f*1E21;       //10^-21

           b=1E7;

           for(i=0,j=-14;i<8;i++,j--)

             {

if(tf/b<1)

b=b/10.0;

              else

break;

              w=f*(1E27/b);    //(1E21/b)*1E6

              PrintW(w,j);

              }

           }

        else if(f>1E-28)

           {

             tf=f*1E28;            //10^-28

             b=1E7;

             for(i=0,j=-21;i<8;i++,j--)

               {

if(tf/b<1)

b=b/10.0;

                else

break;

                w=f*(1E34/b);      //(1E28/b)*1E6

                PrintW(w,j);

              }

}

         else if(f>1E-35)

           {

             tf=f*1E35;             //10^-35

             b=1E7;

             for(i=0,j=-28;i<8;i++,j--)

               {

if(tf/b<1)

b=b/10.0;

                 else

break;

                 w=f*(1E35/b)*1E6;   //(1E35/b)*1E6

                 PrintW(w,j);

               }

             }

        else

          {

            tf=f*1E38;                 //f<=10^-35

            b=1000.0;

            for(i=0,j=-35;i<4;i++,j--)

             {

if(tf/b<1)

b=b/10.0;

               else

break;

               w=f*(1E38/b)*1E6;      //(1E38/b)*1E6

               PrintW(w,j);

              }

            }

}

(2)顯示十進制尾數和階的子函數。

/********************************

函數名稱: void PrintW(unsigned long w,char j)

功能 :科學記數法,顯示十進制尾數和階碼

入口參數:w為尾數,j為階碼

返回值 :無

********************************/

void PrintW(unsigned long w,char j)

{

        char i;

        unsigned long tw,b;

        if(j<-38)                //太小了,超出最小表數范圍。

          {

           printf("?.??????");

           return;

           }          

if(j>38)                   //此算法不會出現j>38的情況

         {

           printf("*.******");

           return;

         }

tw=w/1000000;

       PrintChar(tw+’0’);

       PrintChar(’-’);

       w=w-tw*1000000;

       b=100000;

       for(i=0;i<6;i++)

         {

          tw=w/b;

          PrintChar(tw+’0’);

          w=w-tw*b;

          b=b/10;

          }

      printf("E%d",(int)j);

}
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 香蕉久久a毛片 | 成人福利电影 | 成人午夜影院 | 免费看啪啪网站 | 成人在线免费视频观看 | 欧美精品区 | 东方伊人免费在线观看 | 国产色 | 久久精品久久久 | 精精国产xxxx视频在线播放 | 欧美成人影院在线 | 日韩中文字幕视频 | 欧美视频一区 | 亚洲日韩中文字幕一区 | 国产高清一区二区三区 | 欧美最猛黑人xxxx黑人 | 在线视频日韩 | 永久免费在线观看 | 亚洲精品久久久久avwww潮水 | 国产免费高清 | 国产一区二区三区不卡av | 免费在线观看一区二区三区 | 日韩电影a| 在线免费观看欧美 | 欧美激情精品久久久久久 | 欧美日韩高清免费 | 免费观看的av毛片的网站 | 亚洲一二三视频 | 欧美日日| 一区二区在线看 | 午夜激情网 | www.亚洲视频| 日本一道本 | 亚洲激情综合网 | 国产激情视频网址 | 国产视频精品区 | 久久人爽 | 日韩精品视频在线观看一区二区三区 | 亚洲精品久久久一区二区三区 | 日本免费黄色 | 欧美日本免费 |