欧美性猛交xxxx免费看_牛牛在线视频国产免费_天堂草原电视剧在线观看免费_国产粉嫩高清在线观看_国产欧美日本亚洲精品一5区

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

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

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

Q格式的表示方式以及相應(yīng)的運(yùn)算

我快閉嘴 ? 來(lái)源:小麥大叔 ? 作者:小麥大叔 ? 2022-09-23 15:20 ? 次閱讀

用過(guò)DSP的應(yīng)該都知道Q格式吧;

  • 1 前言

  • 2 Q數(shù)據(jù)的表示

    • 2.1 范圍和精度

    • 2.2 推導(dǎo)

  • 3 Q數(shù)據(jù)的運(yùn)算

    • 3.1 0x7FFF

    • 3.2 0x8000

    • 3.3 加法

    • 3.4 減法

    • 3.5 乘法

    • 3.6 除法

  • 4 常見(jiàn)Q格式的數(shù)據(jù)范圍

  • 5 0x5f3759df

  • 6 總結(jié)

1 前言

Q格式是二進(jìn)制的定點(diǎn)數(shù)格式,相對(duì)于浮點(diǎn)數(shù),Q格式指定了相應(yīng)的小數(shù)位數(shù)和整數(shù)位數(shù),在沒(méi)有浮點(diǎn)運(yùn)算的平臺(tái)上,可以更快地對(duì)浮點(diǎn)數(shù)據(jù)進(jìn)行處理,以及應(yīng)用在需要恒定分辨率的程序中(浮點(diǎn)數(shù)的精度是會(huì)變化的);
需要注意的是Q格式是概念上小數(shù)定點(diǎn),通過(guò)選擇常規(guī)的二進(jìn)制數(shù)整數(shù)位數(shù)和小數(shù)位數(shù),從而達(dá)到所需要的數(shù)值范圍和精度,這里可能有點(diǎn)抽象,下面繼續(xù)看介紹。

2 Q數(shù)據(jù)的表示

2.1 范圍和精度

定點(diǎn)數(shù)通常表示為,其中m為整數(shù)個(gè)數(shù),n為小數(shù)個(gè)數(shù),其中最高位位符號(hào)位并且以二進(jìn)制補(bǔ)碼的形式存儲(chǔ);

  • 范圍:
  • 精度:

無(wú)符號(hào)的用表示;

  • 范圍:
  • 精度:

2.2 推導(dǎo)

無(wú)符號(hào)Q格式數(shù)據(jù)的推導(dǎo)這里以一個(gè)16位無(wú)符號(hào)整數(shù)為例,所能表示的最大數(shù)據(jù)的二進(jìn)制形式如下圖所示;

425afab4-3a80-11ed-9e49-dac502259ad0.png

所以不難看出,的范圍大小和精度;根據(jù)等比數(shù)列求和公式得到,整數(shù)域最大值如下:

小數(shù)域最大值如下:

因此的范圍滿(mǎn)足 ;

有符號(hào)Q格式數(shù)據(jù)的推導(dǎo)這里以一個(gè)16位有符號(hào)整數(shù)為例,所能表示的最大數(shù)據(jù)的二進(jìn)制形式如下圖所示;

426c1362-3a80-11ed-9e49-dac502259ad0.png

所以不難求出,的范圍大小和精度;根據(jù)等比數(shù)列求和公式得到,整數(shù)域最大值如下:

小數(shù)域最大值如下:

因此最大能表示的數(shù)為:;

所能表示的最小數(shù)據(jù)的二進(jìn)制形式如下圖所示;

428a142a-3a80-11ed-9e49-dac502259ad0.png

可以從圖中看到,該數(shù)表示為;

補(bǔ)充一下:負(fù)數(shù)在計(jì)算機(jī)中是補(bǔ)碼的形式存在的,補(bǔ)碼=反碼+1,符號(hào)位為1則表示為負(fù)數(shù);
那么-4該如何表示呢?
8 bit數(shù)據(jù)為例,如下所示;
原碼:0B 0000 100
反碼:0B 1111 011
補(bǔ)碼:0B 1111 100

綜上,可以得到有符號(hào)的范圍是:

3 Q數(shù)據(jù)的運(yùn)算

3.1 0x7FFF

最大數(shù)的十六進(jìn)制為0x7FFF,如下圖所示;

426c1362-3a80-11ed-9e49-dac502259ad0.png

3.2 0x8000

最小數(shù)的十六進(jìn)制為0X8000,如下圖所示;

428a142a-3a80-11ed-9e49-dac502259ad0.png

上述這兩種情況,下面都會(huì)用到。

3.3 加法

加法和減法需要兩個(gè)Q格式的數(shù)據(jù)定標(biāo)相同,即和滿(mǎn)足以下條件;

int16_tq_add(int16_ta,int16_tb)
{
returna+b;
}

上面的程序其實(shí)并不安全,在一般的DSP芯片具有防止溢出的指令,但是通常需要做一下溢出檢測(cè),具體如下所示;

//https://great.blog.csdn.net/
int16_tq_add_sat(int16_ta,int16_tb)
{
int16_tresult;
int32_ttmp;

tmp=(int32_t)a+(int32_t)b;
if(tmp>0x7FFF)
tmp=0x7FFF;
if(tmp-1*0x8000)
tmp=-1*0x8000;
result=(int16_t)tmp;

returnresult;
}

3.4 減法

類(lèi)似于加法的操作,需要相同定標(biāo)的兩個(gè)Q格式數(shù)進(jìn)行相減,但是不會(huì)存在溢出的情況;

//https://great.blog.csdn.net/
int16_tq_sub(int16_ta,int16_tb)
{
returna-b;
}

3.5 乘法

乘法同樣需要考慮溢出的問(wèn)題,這里通過(guò)sat16函數(shù),對(duì)溢出做了處理;

//https://great.blog.csdn.net/
//precomputedvalue:
#defineK(1<

//saturatetorangeofint16_t
int16_tsat16(int32_tx)
{
if(x>0x7FFF)return0x7FFF;
elseif(x-0x8000)return-0x8000;
elsereturn(int16_t)x;
}

int16_tq_mul(int16_ta,int16_tb)
{
int16_tresult;
int32_ttemp;

temp=(int32_t)a*(int32_t)b;//resulttypeisoperand'stype
//Rounding;midvaluesareroundedup
temp+=K;
//Correctbydividingbybaseandsaturateresult
result=sat16(temp>>Q);

returnresult;
}

3.6 除法

//https://great.blog.csdn.net/
int16_tq_div(int16_ta,int16_tb)
{
/*pre-multiplybythebase(UpscaletoQ16sothattheresultwillbeinQ8format)*/
int32_ttemp=(int32_t)a</*Rounding:midvaluesareroundedup(downfornegativevalues).*/
/*ORcomparemostsignificantbitsi.e.if(((temp>>31)&1)==((b>>15)&1))*/
if((temp>=0&&b>=0)||(temp0&&b0)){
temp+=b/2;/*ORshift1biti.e.temp+=(b>>1);*/
}else{
temp-=b/2;/*ORshift1biti.e.temp-=(b>>1);*/
}
return(int16_t)(temp/b);
}

4 常見(jiàn)Q格式的數(shù)據(jù)范圍

定點(diǎn)數(shù)和浮點(diǎn)數(shù)轉(zhuǎn)換的關(guān)系滿(mǎn)足以下公式:

其中為,m表示整數(shù)位數(shù),n表示小數(shù)位數(shù);

#include
#include
#include


intmain()
{
//0111111111111111
int16_tq_max=32767;//0x7FFF
//1000000000000000
int16_tq_min=-32768;//0x8000
floatf_max=0;
floatf_min=0;
printf("
");
for(int8_ti=15;i>=0;i--){
f_max=(float)q_max/pow(2,i);
f_min=(float)q_min/pow(2,i);

printf("	|Q%d|Q%d.%d|%f|%f|
",
i,(15-i),i,f_max,f_min);
}

return0;
}

運(yùn)行得到結(jié)果如下所示;42d1c5f4-3a80-11ed-9e49-dac502259ad0.png

Q Qmn Max Min
Q 15 Q 0.15 0.999969 -1.000000
Q 14 Q 1.14 1.999939 -2.000000
Q 13 Q 2.13 3.999878 -4.000000
Q 12 Q 3.12 7.999756 -8.000000
Q 11 Q 4.11 15.999512 -16.000000
Q 10 Q 5.10 31.999023 -32.000000
Q 9 Q 6.9 63.998047 -64.000000
Q 8 Q 7.8 127.996094 -128.000000
Q 7 Q 8.7 255.992188 -256.000000
Q 6 Q 9.6 511.984375 -512.000000
Q 5 Q 10.5 1023.968750 -1024.000000
Q 4 Q 11.4 2047.937500 -2048.000000
Q 3 Q 12.3 4095.875000 -4096.000000
Q 2 Q 13.2 8191.750000 -8192.000000
Q 1 Q 14.1 16383.500000 -16384.000000
Q 0 Q 15.0 32767.000000 -32768.000000

5 0x5f3759df

Q格式雖然十分抽象,但是且看看這個(gè)數(shù)字0x5f3759df,感覺(jué)和Q格式有某種聯(lián)系,它是雷神之錘3中的一個(gè)算法的魔數(shù),畢竟游戲引擎需要充分考慮到效率,具體的由來(lái)可以看一下論文《Fast Inverse Square Root》,下面是源碼中剝出來(lái)的快速平方根算法;

floatQ_rsqrt(floatnumber)
{
longi;
floatx2,y;
constfloatthreehalfs=1.5F;

x2=number*0.5F;
y=number;
i=*(long*)&y;//evilfloatingpointbitlevelhacking
i=0x5f3759df-(i>>1);//whatthefuck?
y=*(float*)&i;
y=y*(threehalfs-(x2*y*y));//1stiteration
//y=y*(threehalfs-(x2*y*y));//2nditeration,thiscanberemoved

#ifndefQ3_VM
#ifdef__linux__
assert(!isnan(y));//bk010122-FPE?
#endif
#endif
returny;
}

6 總結(jié)

本文介紹了Q格式的表示方式以及相應(yīng)的運(yùn)算,另外需要注意在Q格式運(yùn)算的時(shí)候,兩者定標(biāo)必須相同,對(duì)于數(shù)據(jù)的溢出檢測(cè)也要做相應(yīng)的處理。

審核編輯:湯梓紅


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

    關(guān)注

    554

    文章

    8059

    瀏覽量

    350625
  • 二進(jìn)制
    +關(guān)注

    關(guān)注

    2

    文章

    801

    瀏覽量

    41766
  • Q格式
    +關(guān)注

    關(guān)注

    0

    文章

    2

    瀏覽量

    1597

原文標(biāo)題:浮點(diǎn)運(yùn)算耗時(shí),那試試定點(diǎn)運(yùn)算~(C語(yǔ)言的Q格式)

文章出處:【微信號(hào):嵌入式情報(bào)局,微信公眾號(hào):嵌入式情報(bào)局】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    Q格式計(jì)算

    表示負(fù)的最小值為1_111.1111 1111 1111 1111 1111 1111 1111|| |符號(hào) 整數(shù)小數(shù)算的的Q28格式的下限不就應(yīng)該是-7.999 999 996么?我這樣理解的錯(cuò)誤在哪里???
    發(fā)表于 08-19 06:43

    請(qǐng)問(wèn)Q格式Q0格式是不是一樣的東西?

    Q格式Q0格式,是不是一樣的東西?
    發(fā)表于 10-11 15:07

    請(qǐng)問(wèn)不同Q格式的用這個(gè)相乘怎么理解??

    Q21格式的,后面是Q15格式,看IQMath文檔_IQmpy是兩個(gè)Q格式相同的數(shù)相乘的,請(qǐng)問(wèn)
    發(fā)表于 11-22 09:59

    請(qǐng)問(wèn)如何理解脈沖格式表示的轉(zhuǎn)子電角速度?

    FOC庫(kù)中,電機(jī)轉(zhuǎn)子的電角速度用脈沖格式表示,什么意思
    發(fā)表于 05-09 22:14

    Q格式相乘問(wèn)題怎么解決

    );v.BaseRpm為Q0格式v.Speed為Q15格式,他兩個(gè)相乘為什么得到Q0格式的v.S
    發(fā)表于 05-19 10:34

    音頻信號(hào)在AIC3106和McASP之間的傳遞格式只能是Q15定點(diǎn)表示嗎?

    TI工程師您好,現(xiàn)在用OMAPL137做音頻信號(hào)處理,有兩個(gè)問(wèn)題:1)想問(wèn)一下音頻信號(hào)在AIC3106和McASP之間的傳遞格式只能是Q15定點(diǎn)表示嗎?我之前用浮點(diǎn)數(shù)試了一下不行。2)接收到的音頻
    發(fā)表于 05-22 08:00

    F28335的Q30格式有幾位有效數(shù)字?

    有人用過(guò)q格式定點(diǎn)運(yùn)算嗎,為什么我轉(zhuǎn)換的數(shù)不準(zhǔn)?比如_IQ30(-1.903162068687379),結(jié)果是-1.903162122;按照官方文檔,應(yīng)該有10位有效數(shù)字,為什么我的只有7位 ?請(qǐng)各路大神各顯神通,感激不盡!
    發(fā)表于 07-25 11:31

    請(qǐng)問(wèn)為什么DSP需要Q格式? q31、q15、q7和f32是什么意思?

    為什么DSP(數(shù)字信號(hào)處理)需要Q格式? q31、q15、q7和f32是什么意思?
    發(fā)表于 12-17 07:56

    DSP的Q格式是什么

    用過(guò)DSP的應(yīng)該都知道Q格式吧;
    發(fā)表于 07-28 09:02

    什么是HDV格式?什么是HDV標(biāo)準(zhǔn)?以及HDV的優(yōu)點(diǎn)

    什么是HDV格式? HDV格式是一種新的視頻格式,用于在普通DV 標(biāo)準(zhǔn)盒式錄像帶上拍攝和播放高清晰圖像。
    發(fā)表于 12-31 11:51 ?1.7w次閱讀

    讀卡器的安裝方式/支持閃存格式

    讀卡器的安裝方式/支持閃存格式 讀卡器的安裝方式              安裝
    發(fā)表于 01-09 15:07 ?1056次閱讀

    由輸入端選擇運(yùn)算方式的加、減法運(yùn)算電路

    由輸入端選擇運(yùn)算方式的加、減法運(yùn)算電路 電路的功能 這是一種配
    發(fā)表于 05-08 11:32 ?1751次閱讀
    由輸入端選擇<b class='flag-5'>運(yùn)算</b><b class='flag-5'>方式</b>的加、減法<b class='flag-5'>運(yùn)算</b>電路

    Q格式介紹_DSP

    Q格式 DSP【DSP的一個(gè)十分重要的格式
    發(fā)表于 01-06 14:38 ?0次下載

    電機(jī)的控制方式以及程序的編寫(xiě)

    本文給大家介紹一下各種電機(jī)的控制方式以及程序的編寫(xiě)。 1、起保停:I0.0啟動(dòng)I0.1停止Q0.0輸出(控制電機(jī)啟停接觸器),I0.0接通時(shí),Q0.0輸出,I0.1接通時(shí),
    的頭像 發(fā)表于 02-13 14:40 ?7176次閱讀
    電機(jī)的控制<b class='flag-5'>方式</b><b class='flag-5'>以及</b>程序的編寫(xiě)

    EtherCAT 數(shù)據(jù)幀格式和尋址方式簡(jiǎn)介

    EtherCAT是一個(gè)高實(shí)時(shí)性,高速和高效率的工業(yè)以太網(wǎng)技術(shù),數(shù)據(jù)根據(jù)自身獨(dú)有的數(shù)據(jù)幀格式進(jìn)行可靠傳輸,本文主要針對(duì)EtherCAT的數(shù)據(jù)幀格式和尋址方式進(jìn)行簡(jiǎn)單描述。EtherCAT的數(shù)據(jù)幀
    的頭像 發(fā)表于 04-12 08:25 ?1084次閱讀
    EtherCAT 數(shù)據(jù)幀<b class='flag-5'>格式</b>和尋址<b class='flag-5'>方式</b>簡(jiǎn)介