DSP中浮點轉(zhuǎn)定點運算--浮點數(shù)的存儲格式
二:浮點數(shù)的存儲格式
2.1 IEEE floating point standard
上面我們說了,浮點數(shù)的小數(shù)點是不固定的,如果每個人都按照自己的愛好存儲在電腦里,那不就亂套了嗎?那么怎么在計算機中存儲這種類型的數(shù)字呢?象這類古老的問題前人早都為我們做好了相應的規(guī)范,無規(guī)矩不成方圓嗎。我們平時所說的浮點數(shù)的存儲規(guī)范,就是由IEEE指定的,具體的規(guī)范文件是:IEEE Standard 754 for Binary Floating-Point Arithmetic。大家可以很容易的從網(wǎng)絡上下載到這篇文檔。
在c語言中,單精度(float)數(shù)據(jù)類型為32bits,具體的如下圖所示:
整個32bits分三部分,即
Sign:符號位,1 bit,0為正,1為負;
Exponent(bias):指數(shù)部分,8 bits,存儲格式為移碼存儲(后面還會說明),偏移量為127;
Mantissa(fraction):尾數(shù)部分。
對應的雙精度(double)類型的格式為:
同樣,64位也被分為了三部分,對照單精度,不用我說就可以理解各個部分的含義了吧?
是不是有點迷糊了,不要怕,理論這個東西最能忽悠人了,看起來很高深,其實也就是個屁大的事,舉個例子就很容易明白了。
舉例說明,如3.24x103,則對應的部分為,Sign為0,3為指數(shù)部分(注意計算機里面存儲的不是3,這里僅僅為了說明),3.24為尾數(shù)。我們知道,計算機“笨”的要死,只認識0和1,那么到底一個浮點數(shù)值在計算機存儲介質(zhì)中是如何存儲的呢?
例如,我們要想偷窺浮點類型的值4.25在計算機硬盤中存儲的廬山真面目,請跟我來:首先把4.25轉(zhuǎn)換成二進制的表達方式,即100.01,在詳細點,變成1.0001x22,好了,對號入座把。
Sign=0;
Exponent(bias)=2+127=129 (偏移量為127,就是直接加上個127了);
Mantissa=1.0001-1.0=0001(規(guī)格化后,小數(shù)點前總是整數(shù)1,全世界人都知道前面是1不是0,所以省略不寫了,即尾數(shù)部分不包括整數(shù)部分;當別人問你,為什么23 bit的尾數(shù)部分可以表示24位的精度,知道怎么回答了吧。 靠,什么,沒有看懂,再仔細讀兩便就知道了)。
對照上面的圖示,相信你已經(jīng)看明白了吧?相信你的智商。為了加深認識,再來一個。如果給定你一個二進制數(shù)字串,01000000100010000000000000000000,并告訴你這是一個float類型的值,讓你說出它是老幾,知道怎么算了吧?如果不知道,看下面的圖,我就不廢話解釋了。
2.2深入理解浮點存儲格式
為了更深入的理解浮點數(shù)的格式。我們使用C語言來做一件事。在C語言的世界里,強制類型轉(zhuǎn)換,大家應該都很熟悉了。例如:
float f=4.6;
int i;
…
i = (int)(f+0.5); // i=5
..
下面我們不使用強制類型轉(zhuǎn)化,我們自己來計算f轉(zhuǎn)換成整形應該等于幾?
把主要代碼帖出來,如下:
int ival= ((*(int *)(&fval)) & 0x07fffff) | 0x800000;
// 提取指數(shù)部分
int exponent = 150 - (((*(int *)(&fval)) >> 23) & 0xff);
if (exponent < 0)
ival = (ival<< -exponent);
else
ival = (ival >> exponent);
// 如果小于0,則將結(jié)果取反
if ((*(int *)&fval) & 0x80000000)
ival = -ival;
好好琢磨琢磨吧,看明白了,就說明你基本明白了浮點數(shù)的存儲格式,如果沒有看明白,接著看,知道明白為止。
以上就是本文的全部內(nèi)容,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
C++深入講解new與deleted關(guān)鍵字的使用
這篇文章主要介紹了C++中new與deleted關(guān)鍵字的使用,new在動態(tài)內(nèi)存中為對象分配空間并返回一個指向該對象的指針;delete接受一個動態(tài)對象的指針, 銷毀該對象, 并釋放與之關(guān)聯(lián)的內(nèi)存2022-05-05C++ Boost Serialization庫超詳細獎金額
Boost是為C++語言標準庫提供擴展的一些C++程序庫的總稱。Boost庫是一個可移植、提供源代碼的C++庫,作為標準庫的后備,是C++標準化進程的開發(fā)引擎之一,是為C++語言標準庫提供擴展的一些C++程序庫的總稱2022-12-12C++使用JsonCpp庫操作json格式數(shù)據(jù)示例
這篇文章主要介紹了C++使用JsonCpp庫操作json格式數(shù)據(jù),結(jié)合實例形式詳細分析了JsonCpp庫的下載及C++使用JsonCpp庫對json格式數(shù)據(jù)序列化相關(guān)操作技巧,需要的朋友可以參考下2017-06-06詳解C++的JSON靜態(tài)鏈接庫JsonCpp的使用方法
這篇文章主要介紹了C++的JSON靜態(tài)鏈接庫JsonCpp的使用方法,演示了使用JsonCpp生成和解析JSON的方法,以及C++通過JSON方式的socket通信示例,需要的朋友可以參考下2016-03-03