當(dāng)前位置:首頁(yè) > 工業(yè)控制 > 電子設(shè)計(jì)自動(dòng)化

摘 要: 采用CORDIC算法實(shí)時(shí)計(jì)算正弦值的方法,替代傳統(tǒng)DDS中的正弦查找表,顯著節(jié)省了硬件資源,極大提高了轉(zhuǎn)換速度以及DDS的頻率和相位分辨率。將基于改進(jìn)的并行流水結(jié)構(gòu)的CORDIC算法作為IP應(yīng)用于高端DDS芯片中,同時(shí)利用Matlab的M語(yǔ)言進(jìn)行仿真與調(diào)試,可以直觀地看到該改進(jìn)算法的輸出波形。
關(guān)鍵詞: 直接數(shù)字頻率合成;CORDIC算法;Matlab

傳統(tǒng)DDS是由美國(guó)學(xué)者Tierney 等提出,采用查找表結(jié)構(gòu)實(shí)現(xiàn),很難滿足數(shù)字信號(hào)處理領(lǐng)域中高精度、高分辨率、實(shí)時(shí)運(yùn)算的要求。而采用基于CORDIC算法的DDS結(jié)構(gòu)可以很容易地滿足這些要求,且易于采用流水線技術(shù),因此這一技術(shù)越來越多的用于雷達(dá)等電子系統(tǒng)中[1]。本文提出了一種基于CORDIC算法的16位流水線并行結(jié)構(gòu)的DDS,取代傳統(tǒng)ROM查找表,實(shí)現(xiàn)了高速度和資源占用率低的要求。利用Matlab工具進(jìn)行仿真分析,不僅能直觀地看出輸出波形,而且加快了設(shè)計(jì)進(jìn)程。
1 DDS的基本結(jié)構(gòu)
DDS的基本結(jié)構(gòu)如圖1所示,主要包括:參考頻率源、相位累加器、ROM正弦查找表、D/A轉(zhuǎn)換器及低通濾波器。頻率控制字K決定了相位累加器的步進(jìn)大小。每一個(gè)時(shí)鐘周期,相位寄存器中的數(shù)值就累加一個(gè)步長(zhǎng)K,與初始相位相加后送入正弦查找表,正弦查找表一般是一個(gè)可編程存儲(chǔ)器,存有相應(yīng)的正弦波數(shù)據(jù)。存儲(chǔ)器將輸入的相位信息轉(zhuǎn)換為地址信息,再將地址映射為正弦幅度值,經(jīng)過D/A轉(zhuǎn)換器生成階梯波形,然后經(jīng)過低通濾波器得到頻率的連續(xù)波形。


這種結(jié)構(gòu)的缺點(diǎn)是ROM的容量與相位碼的位數(shù)成指數(shù)關(guān)系,而大容量的ROM意味著系統(tǒng)高功耗、高成本、低穩(wěn)定性。因此人們尋求直接計(jì)算正余弦值來代替ROM查找表。相位幅度轉(zhuǎn)換主要有查表法、多項(xiàng)式展開法以及CORDIC算法[2]。CORDIC算法在硬件實(shí)現(xiàn)上只需移位和加減運(yùn)算即可得到正余弦值,容易在VLSI芯片上實(shí)現(xiàn)。
2 CORDIC算法的原理及改進(jìn)
  CORDIC(The Co-ordinate Rotation Digital Computer)算法由J.Volder[3]1959年在美國(guó)航空控制系統(tǒng)設(shè)計(jì)中提出,是一種用于計(jì)算運(yùn)算函數(shù)的循環(huán)迭代算法。CORDIC算法的基本概念是將目標(biāo)旋轉(zhuǎn)角分解為一組預(yù)定單元旋轉(zhuǎn)角的加權(quán)和,用這組預(yù)先規(guī)定的基本角度的線性組合逼近。該算法的巧妙之處在于基本角的選取恰好使每次矢量以基本角度旋轉(zhuǎn)后,新矢量坐標(biāo)值的計(jì)算僅需要簡(jiǎn)單的移位和加減法就能完成[4]。

其中p稱為CORDIC算法的旋轉(zhuǎn)增益。實(shí)際的算法中不可能做無窮迭代,因此實(shí)際的增益與迭代次數(shù)有關(guān),當(dāng)?shù)螖?shù)逐漸增大時(shí),p就不斷逼近1.647。由于n不可能無窮大,因此會(huì)引入誤差。在迭代的過程中可以忽略cosθn項(xiàng),迭代的最后再將其乘入。這樣就得到:

從公式(7)而來的是CORDIC算法的迭代結(jié)構(gòu),在傳統(tǒng)的迭代結(jié)構(gòu)中隨著迭代次數(shù)的增加,其查找表的地址也隨之增加,查找表中存放旋轉(zhuǎn)的角度集。必須有一個(gè)狀態(tài)機(jī)來跟蹤迭代過程,這將導(dǎo)致運(yùn)行速度降低,不適合高速高精度的要求[6]。
采用流水線結(jié)構(gòu),能夠在執(zhí)行進(jìn)程的同時(shí)輸入數(shù)據(jù),從而極大提高程序的運(yùn)行效率。迭代性流水線結(jié)構(gòu)如圖2所示。


3 Matlab軟件實(shí)現(xiàn)CORDIC算法仿真
Matlab是矩陣實(shí)驗(yàn)室(Matrix Laboratory)的簡(jiǎn)稱,是美國(guó)MathWorks公司出品的商業(yè)數(shù)學(xué)軟件,用于算法開發(fā)、數(shù)據(jù)可視化、數(shù)據(jù)分析以及數(shù)值計(jì)算的高級(jí)技術(shù)計(jì)算語(yǔ)言和交互式環(huán)境,主要包括Matlab和Simulink兩大部分。Matlab的應(yīng)用范圍非常廣,包括信號(hào)和圖像處理、通信、控制系統(tǒng)設(shè)計(jì)、測(cè)試和測(cè)量、財(cái)務(wù)建模和分析以及計(jì)算生物學(xué)等眾多應(yīng)用領(lǐng)域。本文利用Matlab的M語(yǔ)言進(jìn)行CORDIC算法的仿真,其優(yōu)勢(shì)在于仿真結(jié)果易于觀察,充分利用可以有效的加快設(shè)計(jì)進(jìn)程。
本程序遵照上述CORDIC算法編寫, 采用文件的方式編寫,下面是部分源程序。仿真輸出波形如圖3所示。

function[x,y]=get_sincos(Angle,precision)%Initial Angle and
precision
InitialAngle=Angle*pi/180;%Coneversion to radian
K=1.0;
for i=1:precision
cordic_table{i}.k=K;
cordic_table{i}.phase_rads=atan(K);
K=0.5*K;
end;
x=0.60725293510314;y=0;%Initial Value when computing
sin/cos
acc_phase_rads=InitialAngle;

for i=-90:1:90
[x,y]=get_sincos_fxp(i,22);
xx(j)=x;
yy(j)=y;
j=j+1;
end;
figure(1)
plot(xx,′r′)
hold on
plot(yy,′b′)
hold off
在傳統(tǒng)DDS設(shè)計(jì)的基礎(chǔ)上,用CORDIC算法取代傳統(tǒng)的查找表,提升了轉(zhuǎn)換速度和精度,同時(shí)基于改進(jìn)的并行流水線型的CORDIC,進(jìn)一步提升了轉(zhuǎn)換速度,在大部分轉(zhuǎn)換角度固定的情況下,對(duì)初始值進(jìn)行優(yōu)化可以節(jié)省1/3的硬件資源。該設(shè)計(jì)已經(jīng)作為IP應(yīng)用于高端DDS芯片中。
參考文獻(xiàn)
[1] 郭金淮,湯漢屏.DDS技術(shù)淺析[J].數(shù)據(jù)通信,2002(3).
[2] FATIMA S,WOOLDRIDGE M.An agent2based framework for multi2issue negotiation[J].Artificial Intelligence,2004,52(1):1245.
[3] 張明友.數(shù)字陣列雷達(dá)和軟件化雷達(dá)[M].北京:機(jī)械工業(yè)出版社,2008.
[4] VOLDER E.The CORDIC Trigonometric computation teclrnique[J].IRE Trans.Electronic Comp-Utters,1959,EC 8:330-334.
[5] 周柱.基于CORDIC算法的直接頻率合成技術(shù)的研究和應(yīng)用[D].國(guó)防科學(xué)技術(shù)大學(xué),2005.
[6] MAHARATNA K,VALLS J.50 Years of CORDIC:Algorithms,Architectures,and Applications[J].IEEE Circuits and Systems Society 1549-8328 2009:1893-1907.
[7] CONSIDINE V.CORDIC trigonometric function generate for DSP,CH2673-2/0000-2381/1.00[J].IEEE,1989.

本站聲明: 本文章由作者或相關(guān)機(jī)構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點(diǎn),本站亦不保證或承諾內(nèi)容真實(shí)性等。需要轉(zhuǎn)載請(qǐng)聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請(qǐng)及時(shí)聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫?dú)角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

倫敦2024年8月29日 /美通社/ -- 英國(guó)汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認(rèn)證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時(shí)1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動(dòng) BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運(yùn)行,同時(shí)企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險(xiǎn),如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報(bào)道,騰訊和網(wǎng)易近期正在縮減他們對(duì)日本游戲市場(chǎng)的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)開幕式在貴陽(yáng)舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國(guó)國(guó)際大數(shù)據(jù)產(chǎn)業(yè)博覽會(huì)上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語(yǔ)權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機(jī) 衛(wèi)星通信

要點(diǎn): 有效應(yīng)對(duì)環(huán)境變化,經(jīng)營(yíng)業(yè)績(jī)穩(wěn)中有升 落實(shí)提質(zhì)增效舉措,毛利潤(rùn)率延續(xù)升勢(shì) 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長(zhǎng) 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競(jìng)爭(zhēng)力 堅(jiān)持高質(zhì)量發(fā)展策略,塑強(qiáng)核心競(jìng)爭(zhēng)優(yōu)勢(shì)...

關(guān)鍵字: 通信 BSP 電信運(yùn)營(yíng)商 數(shù)字經(jīng)濟(jì)

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺(tái)與中國(guó)電影電視技術(shù)學(xué)會(huì)聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會(huì)上宣布正式成立。 活動(dòng)現(xiàn)場(chǎng) NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長(zhǎng)三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會(huì)上,軟通動(dòng)力信息技術(shù)(集團(tuán))股份有限公司(以下簡(jiǎn)稱"軟通動(dòng)力")與長(zhǎng)三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉