一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評(píng)論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會(huì)員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識(shí)你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

一文帶你秒懂IEEE 754浮點(diǎn)數(shù)

朱老師物聯(lián)網(wǎng)大講堂 ? 2024-03-18 08:09 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

一、簡(jiǎn)介

1、常見的浮點(diǎn)數(shù)表示方式是IEEE 754標(biāo)準(zhǔn),它規(guī)定了浮點(diǎn)數(shù)的存儲(chǔ)格式和運(yùn)算規(guī)則,這個(gè)標(biāo)準(zhǔn)定義了兩種浮點(diǎn)數(shù)表示:?jiǎn)尉群碗p精度。

2、任何一個(gè)浮點(diǎn)數(shù)的二進(jìn)制數(shù)可以寫為:NUM = (-1) ^ S* 2 ^ E * M 。以float32類型舉例:

2.1、S表示符號(hào):S為0時(shí)表示一個(gè)正數(shù);當(dāng)S為1時(shí)表示一個(gè)負(fù)數(shù)

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

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

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

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

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

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

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

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

5、存儲(chǔ)格式:以float32的浮點(diǎn)數(shù)舉例如下圖

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

二、十轉(zhuǎn)二進(jìn)制

1、以float32浮點(diǎn)數(shù)和23.375浮點(diǎn)數(shù)舉例

2、整數(shù)轉(zhuǎn)換方式:對(duì)2取余

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

3、小數(shù)轉(zhuǎn)換方式:對(duì)小數(shù)進(jìn)行2乘留整再對(duì)小數(shù)2乘直至為小數(shù)部分為0

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

4、合并整數(shù)和小數(shù)部分:10111 和小數(shù)部分 0.011 得到二進(jìn)制浮點(diǎn)數(shù) 10111.011

5、規(guī)范化和指數(shù)表示6、最終,將符號(hào)位、指數(shù)和尾數(shù)合并,得到IEEE 754標(biāo)準(zhǔn)的二進(jìn)制浮點(diǎn)數(shù)表示為:

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

三、二轉(zhuǎn)十進(jìn)制

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

  1. 先轉(zhuǎn)換為二進(jìn)制浮點(diǎn)數(shù),根據(jù)E不全為0或1的規(guī)則得到:1.01110110000000000000000
  2. 再用2的階乘的方式轉(zhuǎn)換為浮點(diǎn)數(shù),如下:

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

四、誤差

1、如下代碼展示

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

2、原因:在計(jì)算機(jī)中,由于浮點(diǎn)數(shù)的表示方式是有限的,有些十進(jìn)制小數(shù)無法精確表示為二進(jìn)制浮點(diǎn)數(shù)。這導(dǎo)致在進(jìn)行浮點(diǎn)數(shù)運(yùn)算時(shí)可能出現(xiàn)舍入誤差,進(jìn)而導(dǎo)致預(yù)期的結(jié)果和實(shí)際的二進(jìn)制浮點(diǎn)數(shù)表示的結(jié)果不完全相等。

3、將0.1轉(zhuǎn)為二進(jìn)制

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

4、這個(gè)過程會(huì)一直持續(xù)下去,因?yàn)?0.1 在二進(jìn)制中是一個(gè)無限循環(huán)小數(shù)。

5、將-0.1轉(zhuǎn)為二進(jìn)制

6、首先,-0.1 可以表示為二進(jìn)制的補(bǔ)碼形式。如果我們考慮一個(gè)32位的單精度浮點(diǎn)數(shù),其符號(hào)位為1,指數(shù)位為127(偏移值),尾數(shù)部分為 0.00011001100110011001100...(重復(fù)的 1100 模式)。

7、進(jìn)行加法操作

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

8、這個(gè)結(jié)果實(shí)際上是一個(gè)無限循環(huán)的二進(jìn)制小數(shù)。由于計(jì)算機(jī)內(nèi)存是有限的,最終只能存儲(chǔ)一個(gè)有限位數(shù)的二進(jìn)制小數(shù),因此可能會(huì)進(jìn)行截?cái)嗷蛏崛氩僮鳎瑢?dǎo)致精度損失。

9、在實(shí)際計(jì)算機(jī)系統(tǒng)中,這種舍入誤差可能會(huì)導(dǎo)致結(jié)果不等于精確的零,因?yàn)槲覀儾荒芫_地表示無限循環(huán)小數(shù)。這就是為什么在計(jì)算機(jī)編程中進(jìn)行浮點(diǎn)數(shù)比較時(shí),通常使用一個(gè)小的誤差范圍而不是直接比較相等。

10、改進(jìn)方式

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

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請(qǐng)聯(lián)系本站處理。 舉報(bào)投訴
  • 計(jì)算機(jī)
    +關(guān)注

    關(guān)注

    19

    文章

    7663

    瀏覽量

    90827
  • 編程
    +關(guān)注

    關(guān)注

    88

    文章

    3689

    瀏覽量

    95270
  • 計(jì)算機(jī)系統(tǒng)

    關(guān)注

    0

    文章

    290

    瀏覽量

    24659
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評(píng)論

    相關(guān)推薦
    熱點(diǎn)推薦

    32位單精度IEEE-754浮點(diǎn)數(shù)轉(zhuǎn)換為10進(jìn)制數(shù)

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

    請(qǐng)問320F2812的浮點(diǎn)數(shù)算術(shù)標(biāo)準(zhǔn)是否遵循IEEE754 ?

    你好,我在進(jìn)行對(duì)雙精度浮點(diǎn)數(shù)(double)二進(jìn)制bit處理的時(shí)候,看到2812的浮點(diǎn)數(shù)IEEE754浮點(diǎn)數(shù)在內(nèi)存中存儲(chǔ)不樣。請(qǐng)問,32
    發(fā)表于 09-30 11:23

    幫助添加十進(jìn)制浮點(diǎn)數(shù)

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

    請(qǐng)問怎么將IEEE 754(32位十六進(jìn)制)轉(zhuǎn)換為十進(jìn)制浮點(diǎn)數(shù)

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

    IEEE754轉(zhuǎn)浮點(diǎn)數(shù)需要的數(shù)據(jù)類型轉(zhuǎn)換

    今天做了三個(gè)子VI,將16進(jìn)制字符串轉(zhuǎn)換成2進(jìn)制字符串,二進(jìn)制轉(zhuǎn)換成10進(jìn)制。按IEEE-754標(biāo)準(zhǔn)將4字節(jié)16進(jìn)制字符串轉(zhuǎn)換成浮點(diǎn)數(shù)。如果有誤,請(qǐng)大家指正。
    發(fā)表于 01-23 15:08

    浮點(diǎn)數(shù)IEEE 754標(biāo)準(zhǔn)相關(guān)資料分享

    浮點(diǎn)數(shù)IEEE 754標(biāo)準(zhǔn)簡(jiǎn)而言之,該標(biāo)準(zhǔn)采用了以2為基數(shù)的科學(xué)記數(shù)法記錄實(shí)數(shù),并將記數(shù)范圍上的4個(gè)邊界值定義為不同的特殊值。 上述元素之間的關(guān)系為:符號(hào)域S記錄了浮點(diǎn)數(shù)的符號(hào);階碼
    發(fā)表于 12-09 06:54

    ieee754標(biāo)準(zhǔn)下載

    ieee754標(biāo)準(zhǔn): IEEE754代碼標(biāo)準(zhǔn)表示法為便于軟件的移植,浮點(diǎn)數(shù)的表示格式應(yīng)該有統(tǒng)標(biāo)準(zhǔn)(定義)。1985年IEEE(Insti
    發(fā)表于 07-13 03:41 ?69次下載

    浮點(diǎn)數(shù)的表示方法

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

    IEEE754浮點(diǎn)數(shù)格式

    在計(jì)算機(jī)中,需要對(duì)小數(shù)進(jìn)行計(jì)算,因此需要相應(yīng)的電路支持。支持小數(shù)計(jì)算的電路有兩種:定點(diǎn)部件和浮點(diǎn)部件。定點(diǎn)部件與整數(shù)部件沒有本質(zhì)區(qū)別,只是要假設(shè)有個(gè)小數(shù)點(diǎn)存在于某兩位數(shù)之間,計(jì)算時(shí)需要把小數(shù)點(diǎn)對(duì)齊。本文首先介紹浮點(diǎn)數(shù)標(biāo)準(zhǔn)
    發(fā)表于 11-17 11:09 ?1.6w次閱讀

    Cortex-M4 浮點(diǎn)數(shù)的存儲(chǔ) 和 FPU(Floating Point Unit) 雜記

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

    浮點(diǎn)數(shù)的精度問題

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

    什么是浮點(diǎn)數(shù)浮點(diǎn)數(shù)在內(nèi)存中的存儲(chǔ)

    浮點(diǎn)型簡(jiǎn)單講就是實(shí)數(shù)的意思。浮點(diǎn)數(shù)在計(jì)算機(jī)中用以近似表示任意某個(gè)實(shí)數(shù)。
    的頭像 發(fā)表于 11-09 11:07 ?6401次閱讀
    什么是<b class='flag-5'>浮點(diǎn)數(shù)</b>?<b class='flag-5'>浮點(diǎn)數(shù)</b>在內(nèi)存中的存儲(chǔ)

    什么是浮點(diǎn)數(shù)

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

    PLC中浮點(diǎn)數(shù)的二進(jìn)制表示

    我們?nèi)粘J褂玫母黝悢?shù)據(jù),都是以二進(jìn)制的方式存儲(chǔ)的。以浮點(diǎn)數(shù)為例,在PLC中其表示方式使用了IEEE 754標(biāo)準(zhǔn)。許多編程語言中浮點(diǎn)數(shù)的實(shí)現(xiàn)也遵循該標(biāo)準(zhǔn)。
    的頭像 發(fā)表于 03-23 13:50 ?6570次閱讀
    PLC中<b class='flag-5'>浮點(diǎn)數(shù)</b>的二進(jìn)制表示

    modbus浮點(diǎn)數(shù)怎么讀取

    常重要的。 首先,要理解Modbus浮點(diǎn)數(shù)的表示方式。在Modbus協(xié)議中,浮點(diǎn)數(shù)采用了IEEE 754標(biāo)準(zhǔn)進(jìn)行編碼和解碼。IEEE
    的頭像 發(fā)表于 12-28 14:38 ?8103次閱讀