在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

一文帶你秒懂IEEE 754浮點數

朱老師物聯網大講堂 ? 2024-03-18 08:09 ? 次閱讀

一、簡介

1、常見的浮點數表示方式是IEEE 754標準,它規定了浮點數的存儲格式和運算規則,這個標準定義了兩種浮點數表示:單精度和雙精度。

2、任何一個浮點數的二進制數可以寫為:NUM = (-1) ^ S* 2 ^ E * M 。以float32類型舉例:

2.1、S表示符號:S為0時表示一個正數;當S為1時表示一個負數

2.2、E表示階乘、指數:E是一個無符號整數,所以E的取值范圍為(0~ 255)。但是在計數中指數是可以為負的,所以規定在存入E時,在它原本的值上加上中間數(127),在使用時減去中間數(127),這樣E的真正取值范圍就成了(-127~128)。對于E還分為以下三種情況:

(1)E不全為0,不全為1:這時就用正常的計算規則,E的真實值就是E的字面值減去127(中間值),M的值要加上最前面的省去的1

(2)E全為0:這時指數E等于1-127為真實值,M不再加上舍去的1,而是還原為0.xxxxxxxx小數。這樣為了表示0,和一些很小的整數。

(3)E全為1時分三種浮點數特殊情況:M全為0時,±無窮大(取決于符號位);M為非全0時,表示NaN。

d350f726-e4bb-11ee-9118-92fbcf53809c.png

2.3、M表示有效數字、尾數:規定M的值一定是1 <= M < 2,可以寫成1.xxxxxxx的形式,所以規定M在存儲時舍去第一個1,只存儲小數點之后的數字。這樣做節省了空間,以float類型為例,就可以保存23位小數信息,加上舍去的1就可以用23位來表示24個有效的信息

3、單精度(32位):符號位(1 bit)、指數位(8 bits)、尾數位(23 bits)

4、雙精度(64位):符號位(1 bit)、指數位(11 bits)、尾數位(52 bits)

5、存儲格式:以float32的浮點數舉例如下圖

d3610cce-e4bb-11ee-9118-92fbcf53809c.png

二、十轉二進制

1、以float32浮點數和23.375浮點數舉例

2、整數轉換方式:對2取余

d378a65e-e4bb-11ee-9118-92fbcf53809c.png

3、小數轉換方式:對小數進行2乘留整再對小數2乘直至為小數部分為0

d384ed1a-e4bb-11ee-9118-92fbcf53809c.png

4、合并整數和小數部分:10111 和小數部分 0.011 得到二進制浮點數 10111.011

5、規范化和指數表示6、最終,將符號位、指數和尾數合并,得到IEEE 754標準的二進制浮點數表示為:

d39326a0-e4bb-11ee-9118-92fbcf53809c.png

三、二轉十進制

1、以上面的23.375浮點數的轉換結果0 10000011 01110110000000000000000舉例
2、主要是這個公式:NUM = (-1) ^ S * 2 ^ E * M,分三步第一步:(-1) ^ S第二步:2 ^ E第三步:M3、符號位 (-1) ^ S:(-1)^04、指數位 2 ^ E :將二進制轉十進制為131,然后減去偏移值127,得到5、那么這里就是 2 ^ 46、M:分兩步

  1. 先轉換為二進制浮點數,根據E不全為0或1的規則得到:1.01110110000000000000000
  2. 再用2的階乘的方式轉換為浮點數,如下:

d399cd3e-e4bb-11ee-9118-92fbcf53809c.png

四、誤差

1、如下代碼展示

d3a5c42c-e4bb-11ee-9118-92fbcf53809c.png

2、原因:在計算機中,由于浮點數的表示方式是有限的,有些十進制小數無法精確表示為二進制浮點數。這導致在進行浮點數運算時可能出現舍入誤差,進而導致預期的結果和實際的二進制浮點數表示的結果不完全相等。

3、將0.1轉為二進制

d3b1f300-e4bb-11ee-9118-92fbcf53809c.png

4、這個過程會一直持續下去,因為 0.1 在二進制中是一個無限循環小數。

5、將-0.1轉為二進制

6、首先,-0.1 可以表示為二進制的補碼形式。如果我們考慮一個32位的單精度浮點數,其符號位為1,指數位為127(偏移值),尾數部分為 0.00011001100110011001100...(重復的 1100 模式)。

7、進行加法操作

d3c7e228-e4bb-11ee-9118-92fbcf53809c.png

8、這個結果實際上是一個無限循環的二進制小數。由于計算機內存是有限的,最終只能存儲一個有限位數的二進制小數,因此可能會進行截斷或舍入操作,導致精度損失。

9、在實際計算機系統中,這種舍入誤差可能會導致結果不等于精確的零,因為我們不能精確地表示無限循環小數。這就是為什么在計算機編程中進行浮點數比較時,通常使用一個小的誤差范圍而不是直接比較相等。

10、改進方式

d3d959e0-e4bb-11ee-9118-92fbcf53809c.png

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 計算機
    +關注

    關注

    19

    文章

    7628

    瀏覽量

    90174
  • 編程
    +關注

    關注

    88

    文章

    3679

    瀏覽量

    94866
  • 計算機系統
    +關注

    關注

    0

    文章

    290

    瀏覽量

    24520
收藏 人收藏

    評論

    相關推薦
    熱點推薦

    32位單精度IEEE-754浮點數轉換為10進制數

    本帖最后由 hejin515 于 2016-6-5 16:02 編輯 請問誰接做過32位單精度IEEE-754浮點數的數據采集,LabVIEW如何實現將其轉換為十進制數?轉化的方式如下圖,用C好實現,但是用LabVIEW簡直覺得不可思議。
    發表于 06-05 15:59

    請問320F2812的浮點數算術標準是否遵循IEEE754 ?

    你好,我在進行對雙精度浮點數(double)二進制bit處理的時候,看到2812的浮點數IEEE754浮點數在內存中存儲不樣。請問,32
    發表于 09-30 11:23

    幫助添加十進制浮點數

    是否有可能代表IEEE-754-2008號。在Xilinx上(即沒有拆包)??或者是否有個std方法來解壓no。從ieee十進制浮點數到二進制格式??以上來自于谷歌翻譯以下為原文
    發表于 04-26 11:15

    請問怎么將IEEE 754(32位十六進制)轉換為十進制浮點數

    親愛的先生,我需要知道把IEEE 754(32位十六進制)轉換成pic24小數浮點數的方法。例如,如果我要將下面的十六進制數據轉換為浮點數arr[]="0x4203fc36"分隔
    發表于 09-04 06:54

    IEEE754浮點數需要的數據類型轉換

    今天做了三個子VI,將16進制字符串轉換成2進制字符串,二進制轉換成10進制。按IEEE-754標準將4字節16進制字符串轉換成浮點數。如果有誤,請大家指正。
    發表于 01-23 15:08

    浮點數IEEE 754標準相關資料分享

    浮點數IEEE 754標準簡而言之,該標準采用了以2為基數的科學記數法記錄實數,并將記數范圍上的4個邊界值定義為不同的特殊值。 上述元素之間的關系為:符號域S記錄了浮點數的符號;階碼
    發表于 12-09 06:54

    ieee754標準下載

    ieee754標準: IEEE754代碼標準表示法為便于軟件的移植,浮點數的表示格式應該有統標準(定義)。1985年IEEE(Insti
    發表于 07-13 03:41 ?69次下載

    浮點數的表示方法

    浮點數的表示方法  浮點數,是指小數點在數據中的位置可以左右移動的數據。它通常被表示成:    N = M* RE  這里的M(Mantissa)被稱為浮點數
    發表于 10-13 17:13 ?1.7w次閱讀
    <b class='flag-5'>浮點數</b>的表示方法

    IEEE754浮點數格式

    在計算機中,需要對小數進行計算,因此需要相應的電路支持。支持小數計算的電路有兩種:定點部件和浮點部件。定點部件與整數部件沒有本質區別,只是要假設有個小數點存在于某兩位數之間,計算時需要把小數點對齊。本文首先介紹浮點數標準
    發表于 11-17 11:09 ?1.6w次閱讀

    Cortex-M4 浮點數的存儲 和 FPU(Floating Point Unit) 雜記

    浮點數IEEE 754標準簡而言之,該標準采用了以2為基數的科學記數法記錄實數,并將記數范圍上的4個邊界值定義為不同的特殊值
    發表于 11-26 14:06 ?9次下載
    Cortex-M4 <b class='flag-5'>浮點數</b>的存儲 和 FPU(Floating Point Unit) 雜記

    浮點數的精度問題

    還是要從浮點數的存儲和標識出發來處理該問題,既然浮點數天然就存在定的誤差,而有時候計算又無法獲得唯的數值,如下圖所示,浮點數計算出來的實
    的頭像 發表于 08-11 14:28 ?5188次閱讀
    談<b class='flag-5'>一</b>談<b class='flag-5'>浮點數</b>的精度問題

    什么是浮點數?浮點數在內存中的存儲

    浮點型簡單講就是實數的意思。浮點數在計算機中用以近似表示任意某個實數。
    的頭像 發表于 11-09 11:07 ?6156次閱讀
    什么是<b class='flag-5'>浮點數</b>?<b class='flag-5'>浮點數</b>在內存中的存儲

    什么是浮點數

    Python數據類型第種:字符串(str)。 Python數據類型第二種:整數(int)。 Python數據類型第三種:浮點數,浮點數的英文名是float,浮點數沒有簡寫。
    的頭像 發表于 02-23 14:58 ?5194次閱讀

    PLC中浮點數的二進制表示

    我們日常使用的各類數據,都是以二進制的方式存儲的。以浮點數為例,在PLC中其表示方式使用了IEEE 754標準。許多編程語言中浮點數的實現也遵循該標準。
    的頭像 發表于 03-23 13:50 ?6308次閱讀
    PLC中<b class='flag-5'>浮點數</b>的二進制表示

    modbus浮點數怎么讀取

    常重要的。 首先,要理解Modbus浮點數的表示方式。在Modbus協議中,浮點數采用了IEEE 754標準進行編碼和解碼。IEEE
    的頭像 發表于 12-28 14:38 ?7727次閱讀
    主站蜘蛛池模板: 色婷婷成人网 | 免费国产成人午夜私人影视 | 一区二区视频网 | 国产高清在线免费 | 色婷婷激情五月综合 | 免费一级毛片清高播放 | 在线视频这里只有精品 | 小毛片在线观看 | 国产日日干| 天堂资源在线官网 | 午夜视频1000部免费看 | 色香欲综合成人免费视频 | 国产一线在线观看 | 日本特黄特色大片免费播放视频 | 97爱sese | 97就要鲁就要鲁夜夜爽 | 亚洲精品福利视频 | 欧美黄色片免费观看 | 日本aaaaa级毛片片 | www.jizz在线观看 | 男女艹逼软件 | 亚洲图片欧美色图 | 久久天天躁狠狠躁夜夜2020一 | 亚洲欧美强伦一区二区另类 | 免费一级欧美片在线观免看 | 亚洲黄色在线网站 | h黄网站| 免费的男女拍拍拍的视频 | 亚洲天堂va | 艹逼视频免费观看 | 99热这里只有精品一区二区三区 | 午夜视频免费看 | 精品卡1卡2卡三卡免费网站视频 | 久碰香蕉精品视频在线观看 | 免费国产不卡午夜福在线观看 | 久久草在线精品 | 麻豆国产三级在线观看 | 妖精视频亚洲 | 无码一区二区三区视频 | 日本特级淫片免费看 | 欧美综合一区二区三区 |