DSP中浮點(diǎn)轉(zhuǎn)定點(diǎn)運(yùn)算--定點(diǎn)數(shù)模擬浮點(diǎn)數(shù)運(yùn)算及常見(jiàn)的策略
4.定點(diǎn)數(shù)模擬浮點(diǎn)數(shù)運(yùn)算及常見(jiàn)的策略
相信大家到現(xiàn)在已經(jīng)大致明白了浮點(diǎn)數(shù)轉(zhuǎn)換成定點(diǎn)數(shù)運(yùn)算的概貌。其實(shí),原理講起來(lái)很簡(jiǎn)單,真正應(yīng)用到實(shí)際的項(xiàng)目中,可能會(huì)遇到各種各樣的問(wèn)題。具我的經(jīng)驗(yàn),常見(jiàn)的策略有如下幾條:
1)除法轉(zhuǎn)換為乘法或移位運(yùn)算
我們知道,不管硬件平臺(tái)如果變換,除法運(yùn)算所需要的時(shí)鐘周期都遠(yuǎn)遠(yuǎn)多于乘法運(yùn)算和加減移位運(yùn)算,尤其是在嵌入式應(yīng)用中,“效率”顯得尤為重要。以筆者的經(jīng)驗(yàn),其實(shí),項(xiàng)目中的很大一部分除法運(yùn)算是可以轉(zhuǎn)換成乘法和移位運(yùn)算,效率還是有很大提升空間的。
2)查表計(jì)算
有些運(yùn)算表達(dá)式可能牽扯到很多頭疼的數(shù)學(xué)公式,尤其是在嵌入式硬件平臺(tái)上,出現(xiàn)這種公式很是頭疼,因?yàn)橛布嚓P(guān)的軟件平臺(tái)提供的功能很有限,有的就沒(méi)有很多“常見(jiàn)”的開(kāi)方等數(shù)學(xué)公式。如果該類(lèi)運(yùn)算在項(xiàng)目中很少出現(xiàn),而且其取值的個(gè)數(shù)也不多,那么就可以考慮對(duì)各種情況加以分析,把各種可能的結(jié)果制作成一個(gè)靜態(tài)的表格(可以理解成數(shù)組),再加以簡(jiǎn)單的條件判斷語(yǔ)句就可以解決該類(lèi)問(wèn)題。
3)級(jí)數(shù)展開(kāi)
該問(wèn)題的背景同上面的問(wèn)題。對(duì)于一些數(shù)學(xué)公式,如果取值范圍不好處理,就可以采用級(jí)數(shù)展開(kāi)的方式。
4)分子分母同時(shí)變化
對(duì)于一些除法運(yùn)算,為了保證精度,如果分子的擴(kuò)大范圍不夠大的話,可以考慮縮小分母,也可以達(dá)到預(yù)期效果。具體的例子可以參考我的另一篇文章“解決了個(gè)困擾了2天的問(wèn)題,定點(diǎn)運(yùn)算問(wèn)題”。
以上就是本文的全部?jī)?nèi)容,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- 深入C/C++浮點(diǎn)數(shù)在內(nèi)存中的存儲(chǔ)方式詳解
- 浮點(diǎn)數(shù)在計(jì)算機(jī)中存儲(chǔ)方式是怎樣的
- DSP中浮點(diǎn)轉(zhuǎn)定點(diǎn)運(yùn)算--浮點(diǎn)與定點(diǎn)概述
- DSP中浮點(diǎn)轉(zhuǎn)定點(diǎn)運(yùn)算--浮點(diǎn)數(shù)的存儲(chǔ)格式
- DSP中浮點(diǎn)轉(zhuǎn)定點(diǎn)運(yùn)算--定點(diǎn)數(shù)的加減乘除運(yùn)算
- DSP中浮點(diǎn)轉(zhuǎn)定點(diǎn)運(yùn)算--舉例及編程中的心得
相關(guān)文章
C語(yǔ)言中字符串和數(shù)字的相互轉(zhuǎn)換實(shí)現(xiàn)代碼
以下是對(duì)C語(yǔ)言中字符串和數(shù)字的相互轉(zhuǎn)換實(shí)現(xiàn)代碼進(jìn)行了分析介紹,需要的朋友可以參考下2013-07-07C++使用FFmpeg實(shí)現(xiàn)YUV數(shù)據(jù)編碼轉(zhuǎn)視頻文件
這篇文章主要介紹了C++如何使用FFmpeg實(shí)現(xiàn)把一個(gè)YUV原始視頻數(shù)據(jù)(時(shí)間序列圖像)經(jīng)過(guò)h264編碼為視頻碼流,然后在使用mp4封裝格式封裝,感興趣的可以了解一下2023-06-06OpenCV和C++實(shí)現(xiàn)圖像的翻轉(zhuǎn)(鏡像)、平移、旋轉(zhuǎn)、仿射與透視變換
這篇文章主要給大家介紹了關(guān)于OpenCV和C++實(shí)現(xiàn)圖像的翻轉(zhuǎn)(鏡像)、平移、旋轉(zhuǎn)、仿射與透視變換的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2021-09-09Linux vmstat命令實(shí)戰(zhàn)詳細(xì)解析
這個(gè)命令是我查看Linux/Unix最喜愛(ài)的命令,一個(gè)是Linux/Unix都支持,二是相比top,我可以看到整個(gè)機(jī)器的CPU,內(nèi)存,IO的使用情況,而不是單單看到各個(gè)進(jìn)程的CPU使用率和內(nèi)存使用率(使用場(chǎng)景不一樣)2013-09-09C語(yǔ)言如何實(shí)現(xiàn)一些算法或者函數(shù)你知道嗎
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)一些算法或者函數(shù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2022-03-03