国产毛片a精品毛-国产毛片黄片-国产毛片久久国产-国产毛片久久精品-青娱乐极品在线-青娱乐精品

一種基于Spartan3E的DDS優化設計

發布時間:2011-9-7 21:58    發布者:Liming
關鍵詞: DDS , FPGA , Spartan3E
在高可靠應用領域,如果設計得當,將不會存在類似于MCU的復位不可靠和PC可能跑飛等問題。CPLD/FPGA的高可靠性還表現在,幾乎可將整個系統下載于同一芯片中,實現所謂片上系統,從而大大縮小了體積,易于管理和屏蔽。所以,本文將在對DDS的基本原理進行深入理解的基礎上,采用多級流水線控制技術對DDS的VHDL語言實現進行優化,同時考慮到系統設計中的異步接口的同步化設計問題,把該設計適配到Xilinx公司的最新90nm工藝的Spartan3E系列的FPGA中。
1 DDS基本原理及工作過程
一個基本的DDS由相位累加器、波形存儲器ROM、D/A轉換器和低通濾波器組成,如圖1所示。

在圖1中,fc為時鐘頻率,K為頻率控制字(N位),m為ROM地址線位數,n為ROM數據線寬度(一般也為D/A轉換器的位數),f0為輸出頻率。DDS的基本工作過程如下:每來一個時鐘脈沖fc,加法器將頻率控制字K與累加寄存器輸出的累加相位數據相加,把相加后的結果送至累加寄存器的數據輸入端。其中相位累加器由N位加法器與N位累加寄存器級聯構成,累加寄存器將加法器在上一個時鐘脈沖作用后所產生的新相位數據反饋到加法器的輸入端,以使加法器在下一個時鐘脈沖的作用下繼續與頻率控制字相加。這樣,相位累加器在時鐘作用下,不斷對頻率控制字進行線性相位累加。由此可見,相位累加器在每一個時鐘脈沖輸入時,把頻率控制字累加一次,相位累加器輸出的數據就是合成信號的相位,相位累加器的溢出頻率就是DDS輸出的信號頻率。用相位累加器輸出的數據作為波形存儲器ROM的相位取樣地址,可把存儲在波形存儲器內的波形抽樣值(二進制編碼)經查找表查出,完成相位到幅值轉換。波形存儲器的輸出送到D/A轉換器,D/A轉換器將數字量形式的波形幅值轉換成所要求合成頻率的模擬量形式信號,由低通濾波器濾除雜散波和諧波以后,輸出一個頻率為f0的正弦波。輸出頻率f0與時鐘頻率fc之間的關系滿足下式:

由式(1)可見,輸出頻率f0由fc和K共同決定,保持時鐘頻率一定,改變一次K值,即可合成一個新頻率的正弦波。DDS的最小輸出頻率(頻率分辨率)△f可由方程△f=f0/2N確定。可見,頻率分辨率在fc固定時,取決于相位累加器的位數N。只要N足夠大,理論上就可以獲得足夠高的頻率分辨精度。另外,由采樣定理,合成信號的頻率不能超過時鐘頻率的一半,即f0≤f0/2,因此頻率控制值的最大值Kmax應滿足Kmax≤2N-1。
2 DDS的優化設計與實現
采用VHDL硬件描述語言實現整個電路,不僅利于設計文檔的管理,而且方便了設計的修改和擴充,還可以實現在不同FPGA器件[4]之間的移植。以下采用VHDL語言,探討對FPGA實現DDS電路的三點優化方法。
2.1 流水線累加器
在用FPGA設計DDS電路時,相位累加器是決定DDS電路性能的一個關鍵部分。為使輸出波形具有較高的分辨率,本系統采用32位累加器。但若直接用32位加法器構成累加器,則加法器的延時會大大限制累加器的操作速度。因此,這里引入了流水線算法,即采用4個8位累加器級聯結構,每級用一個8位累加器實現該部分相位相加,然后將進位值傳給下一級做進一步累加。這樣可大幅提高系統的工作速度。但由于累加器是一個閉環反饋電路,因此必須使用寄存器,以保證系統的同步、準確運行。具體實現如圖2所示。


2.2 相位/幅度轉換電路
相位/幅度轉換電路是DDS電路中的另一個關鍵部分,設計中面臨的主要問題就是資源的開銷。該電路通常采用ROM結構,相位累加器的輸出是一種數字式鋸齒波,通過取它的若干位作為ROM的地址輸入,而后通過查表和運算,ROM就能輸出所需波形的量化數據。考慮到正弦函數的對稱性:在[0,2π]內,正弦函數關于x=π成奇對稱,在[0,π]內,關于x=π/2成軸對稱。因此,在正弦查找表中只須存儲相位在[0,π/2]的函數值。這樣,通過一個正弦碼表的前1/4周期就可以變換得到整個周期碼表,節省了近3/4的資源,非常可觀。具體實現如表1所示,為節省ROM資源,取相位累加器輸出的高8位做為ROM的輸入地址,其中最高位(MSB)控制對輸出信號符號的處理,次高位(MSB-1)控制對輸入地址的處理。


當MSB-1為‘0’(一,三象限)時,對查找地址phase(5...0)不做任何處理;當其為‘1’(二,四象限)時,對phase(5...0)取反。ROM的輸出為10位數據,其中最高位為符號位。當MSB為‘0’(一,二象限)時,輸出信號符號位為‘0’,低9為ROM中的幅度數據;當其為‘1’(三,四象限)時,輸出信號符號位為‘1’,低9位為ROM中的幅度數據的相反數的補碼。ROM的VHDL實現的主要部分如下:
architecture Behavioral of rom is
signal sin:STD_LOGIC_VECTOR(8 downto 0);
signal temp:STD_LOGIC_VECTOR(5 downto 0);
begin
temp<=phase when MSB-1=′0′ else
not phase;
process(temp)
begin
case temp is
when ″000000″=>
sin<=″000000000″;
…… --正弦查找表由MATLAB生成
end case;
end process;
data_out<=″0″ & sin when MSB=′0′ else
″1″ & not sin+″000000001″;
end Behavioral;
2.3 同步接口電路設計
在使用DDS時,需要為其提供頻率控制字K的值,一般通過中央控制單元MCU來完成,其以數據總線及寫時鐘信號的方式與FPGA內的DDS實體進行通訊,同時DDS在FPGA內部又是在本地時鐘fc驅動下運行。由于MCU的寫時鐘和FPGA內的本地時鐘異步,兩者之間進行通訊難免存在數據不穩等問題,特別是在通訊速度較高時,這一異步接口問題會更加突出。為了實現異步接口的同步化,本文提出了如圖3所示的接口同步電路。


        3 硬件實現及仿真結果

本文使用VHDL 語言對各個模塊及DDS系統進行描述。頂層文件如下所示:
Entity dds is
Port(reset:in std_logic;--全局復位信號
fre:in std_logic_vector(7 downto 0);
--頻率控制字輸入
clk:in std_logic;
--系統時鐘
fwwrn:in std_logic;--頻率控制字寫信號
gen:in std_logic_vector(0 downto 0);--波形控制字
amp_out:out std_logic_vector(9 downto 0));
--正弦波幅度輸出
end dds;
architecture Behavioral of dds is
component fcwld--接口同步模塊
Port(reset:in std_logic;
clk:in std_logic;
fre:in std_logic_vector(7 downto 0);
fwwrn:in std_logic;
syncfreq:out std_logic_vector(31 downto 0));
--合成頻率控制字
end component;
component accumulator--流水線累加器塊
Port(reset:in STD_LOGIC;
clk:in STD_LOGIC;
syncfreq:in STD_LOGIC_VECTOR(31 downto 0);
phase:out STD_LOGIC_VECTOR(7 downto 0));
--相位高八位輸出
end component;
component rom--波形存儲器模塊
Port(phase:in STD_LOGIC_VECTOR(7 downto 0);
gen:in STD_LOGIC_VECTOR(0 downto 0);
amp_out:out STD_LOGIC_VECTOR(9 downto 0));
end component;
為了對DDS進行評估,將以上設計在Xilinx公司的開發軟件中進行了設計及優化,目標器件為其最新的90nm工藝器件Spartan3E中最小器件XC3S100E-4VQ100C,該設計所占用的FPGA資源如表2所示。

由表2可以看出,本文給出的DDS設計占用資源很少,由于XC3S100E的市場價格在2美金左右,故本設計所占的硬件成本可以縮減到0.2美金左右。同時在ISE8.2中該設計的系統時鐘最大達到159.6MHz。以上的設計性能幾乎和現有的專用芯片相當,但成本下降很多。
為了進一步驗證本文給出的DDS設計系統在功能和時序上的正確性,對其進行了時序仿真,使用的仿真軟件為Modelsim6.1。仿真結果表明,該DDS系統可以運行在較高的工作頻率下。
本文在對DDS的基本原理進行深入理解的基礎上,通過采用三種優化與設計技術:(1)使用流水線累加器在不過多增加門數的條件下,大幅提高了芯片的工作速度;(2)壓縮成正弦查找表,在保證芯片使用精度的情況下減少了近3/4面積,大大節約了ROM的容量。(3)采用同步接口電路設計方案,消除了系統的接口不穩定性。同時使用VHDL語言實現了優化,并把該設計適配到Xilinx公司的最新90nm工藝的Spartan3E系列的FPGA中,實際結果表明了本文給出的DDS設計方案在硬件開銷方面的優勢.

Source:電子發燒友
本文地址:http://m.qingdxww.cn/thread-75743-1-1.html     【打印本頁】

本站部分文章為轉載或網友發布,目的在于傳遞和分享信息,并不代表本網贊同其觀點和對其真實性負責;文章版權歸原作者及原出處所有,如涉及作品內容、版權和其它問題,我們將根據著作權人的要求,第一時間更正或刪除。
您需要登錄后才可以發表評論 登錄 | 立即注冊

廠商推薦

  • Microchip視頻專區
  • 想要避免發生災難,就用MPLAB® SiC電源仿真器!
  • 無線充電基礎知識及應用培訓教程2
  • 安靜高效的電機控制——這才是正確的方向!
  • 5分鐘詳解定時器/計數器E和波形擴展!
  • 貿澤電子(Mouser)專區

相關視頻

關于我們  -  服務條款  -  使用指南  -  站點地圖  -  友情鏈接  -  聯系我們
電子工程網 © 版權所有   京ICP備16069177號 | 京公網安備11010502021702
快速回復 返回頂部 返回列表
主站蜘蛛池模板: 欧美三级一区二区 | 4虎影院在线观看 | 国产日韩网站 | 国产精品人伦久久 | 色天天综合色天天碰 | 亚洲欧美日韩一区超高清 | 91专区在线观看 | 国产馆在线观看 | 亚洲欧美日韩高清一区二区三区 | 婷婷综合国产激情在线 | 久久国产精品免费一区二区三区 | 成年美女黄网站色 | mm视频在线观看 | 99热国内精品 | 热99在线观看 | 久久久久这里只有精品 | 欧美日韩高清不卡一区二区三区 | 色爱五月天 | 欧美成人免费高清二区三区 | 手机看高清特黄a大片 | 国产高清免费不卡观看 | 欧美超强性xxxxx | 一级毛片一级黄片 | 亚洲日韩aⅴ在线视频 | 亚洲成人一区二区 | 日本国产在线视频 | 欧美精品久久久久久久久大尺度 | 女人与禽交视频免费看 | 国产午夜精品不卡观看 | 极品粉嫩在线 | 88aa四虎影成人精品 | 日本欧美大码a在线视频播放 | 热99这里有精品综合久久 | 99久久精品免费看国产一区二区 | h视频在线观看免费网站 | 国产精品一区高清在线观看 | 国产黄色在线观看 | 最近中文字幕++中文 | 4438x全国最大成人网 | 中文字幕日韩一区二区不卡 | 手机看日韩毛片福利盒子 |