FPGA數(shù)字信號處理之CORDIC算法
出處:維庫電子市場網(wǎng) 發(fā)布于:2023-03-08 11:51:02
2、由于點1位于第四象限,說明轉(zhuǎn)多了,再往逆時針方向轉(zhuǎn)π/4,得到點2;3、點2位置象限,順時針旋轉(zhuǎn)π/8,得到點3,
4、由于點3位于第四象限,說明轉(zhuǎn)多了,再往逆時針方向轉(zhuǎn)π/16,得到點4;5、點4位置象限,順時針旋轉(zhuǎn)π/32,得到點5....(根據(jù)所需精度,確定旋轉(zhuǎn)次數(shù)即可)
終把旋轉(zhuǎn)的角度求和就得到了任意坐標(biāo)[10,20]的角度值,其中坐標(biāo)旋轉(zhuǎn)用的三角函數(shù)公式為:
X1=cos(θ)(X0-Y0*tan(θ))
Y1=cos(θ)(Y0+X0*tan(θ))上邊的例子能說明cordic算法的思想,在確定旋轉(zhuǎn)次數(shù)之后,每次旋轉(zhuǎn)的cos(θ)和tan(θ)值是確定的,這樣我們就可以用提前存儲的cos(θ)和tan(θ)值去計算任意坐標(biāo)的角度值。
但是上面角度旋轉(zhuǎn)過程中用到了乘法運算,并沒有簡化運算量。接下來對cordic進一步優(yōu)化,將上式中的cos(θ)舍棄,得到如下的結(jié)果:
循環(huán)過程中Y的正負(fù)判斷象限,決定旋轉(zhuǎn)方向,但是X/Y坐標(biāo)會向外無限循環(huán),這時候旋轉(zhuǎn)得到的X/Y坐標(biāo)會擴展很多倍,如下圖,注意下圖中的坐標(biāo)軸刻度是1E17。
上述旋轉(zhuǎn)過程的計算變化成了:
X1=(X0-Y0*tan(θ))
Y1=(Y0+X0*tan(θ))每次旋轉(zhuǎn)減少了兩個乘法,在需要知道正確坐標(biāo)值的情景下,比如要知道該信號的幅度,由于cordic算法的旋轉(zhuǎn)測試是確定的,所以cos(θ)確定的,所以cos(θ1)*cos(θ2)*cos(θ3)*...*cos(θn)是一個定值,只需要在旋轉(zhuǎn)之后將的X/Y值與cos(θ1)*cos(θ2)*cos(θ3)*...*cos(θn)這個定值相乘即可。上面的旋轉(zhuǎn)過程還是用到了乘法,乘法依然是FPGA/IC中的緊俏資源,下一篇文章介紹如何不用乘法的在FPGA中實現(xiàn)CORDIC。版權(quán)與免責(zé)聲明
凡本網(wǎng)注明“出處:維庫電子市場網(wǎng)”的所有作品,版權(quán)均屬于維庫電子市場網(wǎng),轉(zhuǎn)載請必須注明維庫電子市場網(wǎng),http://udpf.com.cn,違反者本網(wǎng)將追究相關(guān)法律責(zé)任。
本網(wǎng)轉(zhuǎn)載并注明自其它出處的作品,目的在于傳遞更多信息,并不代表本網(wǎng)贊同其觀點或證實其內(nèi)容的真實性,不承擔(dān)此類作品侵權(quán)行為的直接責(zé)任及連帶責(zé)任。其他媒體、網(wǎng)站或個人從本網(wǎng)轉(zhuǎn)載時,必須保留本網(wǎng)注明的作品出處,并自負(fù)版權(quán)等法律責(zé)任。
如涉及作品內(nèi)容、版權(quán)等問題,請在作品發(fā)表之日起一周內(nèi)與本網(wǎng)聯(lián)系,否則視為放棄相關(guān)權(quán)利。
- TTL、RS232、485 到底能傳輸多遠(yuǎn)距離2025/9/16 15:43:19
- 信號之時域如何轉(zhuǎn)換成頻域2025/9/2 17:19:53
- 探究 TVS 布局與靜電放電防護效果之間的內(nèi)在聯(lián)系2025/9/1 16:45:12
- 高扇出信號線優(yōu)化技巧(下)2025/8/28 16:10:19
- 高扇出信號線的優(yōu)化策略(上)2025/8/28 16:05:16