欧美大屁股bbbbxxxx,狼人大香伊蕉国产www亚洲,男ji大巴进入女人的视频小说,男人把ji大巴放进女人免费视频,免费情侣作爱视频

歡迎來到入門教程網(wǎng)!

C語言

當(dāng)前位置:主頁 > 軟件編程 > C語言 >

DSP中浮點(diǎn)轉(zhuǎn)定點(diǎn)運(yùn)算--浮點(diǎn)數(shù)的存儲格式

來源:本站原創(chuàng)|時間:2020-01-10|欄目:C語言|點(diǎn)擊: 次

二:浮點(diǎn)數(shù)的存儲格式

2.1 IEEE floating point standard

  上面我們說了,浮點(diǎn)數(shù)的小數(shù)點(diǎn)是不固定的,如果每個人都按照自己的愛好存儲在電腦里,那不就亂套了嗎?那么怎么在計算機(jī)中存儲這種類型的數(shù)字呢?象這類古老的問題前人早都為我們做好了相應(yīng)的規(guī)范,無規(guī)矩不成方圓嗎。我們平時所說的浮點(diǎn)數(shù)的存儲規(guī)范,就是由IEEE指定的,具體的規(guī)范文件是:IEEE Standard 754 for Binary Floating-Point Arithmetic。大家可以很容易的從網(wǎng)絡(luò)上下載到這篇文檔。

  在c語言中,單精度(float)數(shù)據(jù)類型為32bits,具體的如下圖所示:

整個32bits分三部分,即

  Sign:符號位,1 bit,0為正,1為負(fù);

  Exponent(bias):指數(shù)部分,8 bits,存儲格式為移碼存儲(后面還會說明),偏移量為127;

  Mantissa(fraction):尾數(shù)部分。

  對應(yīng)的雙精度(double)類型的格式為:

同樣,64位也被分為了三部分,對照單精度,不用我說就可以理解各個部分的含義了吧?

  是不是有點(diǎn)迷糊了,不要怕,理論這個東西最能忽悠人了,看起來很高深,其實(shí)也就是個屁大的事,舉個例子就很容易明白了。

舉例說明,如3.24x103,則對應(yīng)的部分為,Sign為0,3為指數(shù)部分(注意計算機(jī)里面存儲的不是3,這里僅僅為了說明),3.24為尾數(shù)。我們知道,計算機(jī)“笨”的要死,只認(rèn)識0和1,那么到底一個浮點(diǎn)數(shù)值在計算機(jī)存儲介質(zhì)中是如何存儲的呢?

例如,我們要想偷窺浮點(diǎn)類型的值4.25在計算機(jī)硬盤中存儲的廬山真面目,請跟我來:首先把4.25轉(zhuǎn)換成二進(jìn)制的表達(dá)方式,即100.01,在詳細(xì)點(diǎn),變成1.0001x22,好了,對號入座把。

Sign=0;

Exponent(bias)=2+127=129 (偏移量為127,就是直接加上個127了);

Mantissa=1.0001-1.0=0001(規(guī)格化后,小數(shù)點(diǎn)前總是整數(shù)1,全世界人都知道前面是1不是0,所以省略不寫了,即尾數(shù)部分不包括整數(shù)部分;當(dāng)別人問你,為什么23 bit的尾數(shù)部分可以表示24位的精度,知道怎么回答了吧。 靠,什么,沒有看懂,再仔細(xì)讀兩便就知道了)。

 

對照上面的圖示,相信你已經(jīng)看明白了吧?相信你的智商。為了加深認(rèn)識,再來一個。如果給定你一個二進(jìn)制數(shù)字串,01000000100010000000000000000000,并告訴你這是一個float類型的值,讓你說出它是老幾,知道怎么算了吧?如果不知道,看下面的圖,我就不廢話解釋了。

2.2深入理解浮點(diǎn)存儲格式

為了更深入的理解浮點(diǎn)數(shù)的格式。我們使用C語言來做一件事。在C語言的世界里,強(qiáng)制類型轉(zhuǎn)換,大家應(yīng)該都很熟悉了。例如:

復(fù)制代碼 代碼如下:

float f=4.6;

int i;

i = (int)(f+0.5); // i=5

..

下面我們不使用強(qiáng)制類型轉(zhuǎn)化,我們自己來計算f轉(zhuǎn)換成整形應(yīng)該等于幾?

把主要代碼帖出來,如下:

復(fù)制代碼 代碼如下:
//取23+1位的尾數(shù)部分

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;

好好琢磨琢磨吧,看明白了,就說明你基本明白了浮點(diǎn)數(shù)的存儲格式,如果沒有看明白,接著看,知道明白為止。

以上就是本文的全部內(nèi)容,希望能給大家一個參考,也希望大家多多支持我們。

上一篇:C++中memset函數(shù)用法詳解

欄    目:C語言

下一篇:C++11的for循環(huán),以及范圍Range類的簡單實(shí)現(xiàn)

本文標(biāo)題:DSP中浮點(diǎn)轉(zhuǎn)定點(diǎn)運(yùn)算--浮點(diǎn)數(shù)的存儲格式

本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/2215.html

網(wǎng)頁制作CMS教程網(wǎng)絡(luò)編程軟件編程腳本語言數(shù)據(jù)庫服務(wù)器

如果侵犯了您的權(quán)利,請與我們聯(lián)系,我們將在24小時內(nèi)進(jìn)行處理、任何非本站因素導(dǎo)致的法律后果,本站均不負(fù)任何責(zé)任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網(wǎng) 版權(quán)所有