dds課程設(shè)計(jì)---基于dds的波形發(fā)生器設(shè)計(jì)_第1頁(yè)
已閱讀1頁(yè),還剩29頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、<p>  課 程 設(shè) 計(jì) 說(shuō) 明 書</p><p>  學(xué)生姓名: </p><p>  學(xué) 號(hào): </p><p>  學(xué) 院: 信息與通信工程學(xué)院 </p><p>  

2、專 業(yè): 電子信息科學(xué)與技術(shù) </p><p>  題 目: 基于DDS的波形發(fā)生器設(shè)計(jì) </p><p><b>  2012年1月5日</b></p><p>  課 程 設(shè) 計(jì) 任 務(wù) 書</p><p>  課 程 設(shè) 計(jì) 任 務(wù) 書&

3、lt;/p><p><b>  目錄 </b></p><p>  1 DDS介紹 ………………………………………6</p><p>  2 AD9850簡(jiǎn)介 ………………………………………11 2.1芯片性能 ……………………………………

4、………11</p><p>  2.2AD9850的控制字及控制時(shí)序 …………………………………12</p><p>  2.3管腳定義 ………………………………………13</p><p>  3 硬件部分 ……………………………………13</p><p>  3.1基于AD9850的模塊原理

5、圖 …………………………………13 3. 2硬件電路設(shè)計(jì) ……………………………………14</p><p>  4 軟件部分 …………………………………16</p><p>  4.1軟件部分設(shè)計(jì) ………………………………………16</p><p>  4.2參考程序

6、 ………………………………………17</p><p>  5波形圖 ………………………………………26</p><p>  6結(jié)束語(yǔ) ………………………………………29 </p><p>  7參考文獻(xiàn) ………………………………………30</p><p>  基于DDS

7、、AD9850芯片波形發(fā)生器的設(shè)計(jì)</p><p>  摘 要: 基于直接數(shù)字頻率合成 (DDS) 原理,利用 AT89C52 單片機(jī)作為控制器件,采用 AD9850型DDS器件設(shè)計(jì)一個(gè)信號(hào)發(fā)生器。給出了信號(hào)發(fā)生器的硬件設(shè)計(jì)和軟件設(shè)計(jì)參數(shù),該系統(tǒng)可輸出正弦波、方波,且頻帶較寬、頻率穩(wěn)定度高,波形良好。該信號(hào)發(fā)生器具有更強(qiáng)的市場(chǎng)競(jìng)爭(zhēng)力,在跳頻技術(shù)、無(wú)線電通信技術(shù)方面具有比較廣闊的發(fā)展前景。</p>

8、<p>  關(guān)鍵詞: 信號(hào)發(fā)生器;直接數(shù)字頻率合成;AD9850 芯片;AT89C52 單片機(jī)</p><p><b>  1 DDS介紹</b></p><p><b>  一、DDS 引言</b></p><p>  頻率合成技術(shù)是將一個(gè)(或多個(gè))基準(zhǔn)頻率變換成另一個(gè)(或多個(gè))合乎質(zhì)量要求的所需頻率的技術(shù)

9、。在通信、雷達(dá)、導(dǎo)航、電子偵察、干擾與抗干擾等眾多領(lǐng)域都有應(yīng)用。隨著各種頻率合成器和頻率合成方案的出現(xiàn),頻率合成技術(shù)得到了不斷的發(fā)展。</p><p>  1971年3月美國(guó)學(xué)者J.Tierncy,C.M.Rader和B.Gold首次提出了直接數(shù)字頻率合成(DDS__Direct Digital Synthesis)技術(shù)。這是一種從相位概念出發(fā)直接合成所需要的波形的新的全數(shù)字頻率合成技術(shù)。同傳統(tǒng)的頻率合成技術(shù)相比

10、,DDS技術(shù)具有極高的頻率分辨率、極快的變頻速度,變頻相位連續(xù)、相位噪聲低,易于功能擴(kuò)展和全數(shù)字化便于集成,容易實(shí)現(xiàn)對(duì)輸出信號(hào)的多種調(diào)制等優(yōu)點(diǎn),滿足了現(xiàn)代電子系統(tǒng)的許多要求,因此得到了迅速的發(fā)展。</p><p>  目前市面上的DDS芯片,價(jià)格昂貴、功能固定單一,應(yīng)用受到限制。本綜合實(shí)驗(yàn)項(xiàng)目采用基于FPGA的EDA技術(shù)設(shè)計(jì)實(shí)現(xiàn)DDS芯片,并可以根據(jù)實(shí)際需要對(duì)其功能進(jìn)行靈活地修改,配置。</p>&

11、lt;p>  二、DDS 工作原理</p><p>  一個(gè)純凈的單頻信號(hào)可表示為:</p><p><b> ?。?-1)</b></p><p>  只要它的幅度U和初始相位不變,它的頻譜就是位于的一條譜線。為了分析簡(jiǎn)化起見,可令U=1,=0,這將不會(huì)影響對(duì)頻率的研究。即:</p><p><b> 

12、?。?-2)</b></p><p>  如果對(duì)(2-2)的信號(hào)進(jìn)行采樣,采樣周期為(即采樣頻率為),則可得到離散的波形序列:</p><p><b> ?。?-3)</b></p><p>  相應(yīng)的離散相位序列為:</p><p><b> ?。?-4)</b></p>

13、<p><b>  式中:</b></p><p><b> ?。?-5)</b></p><p>  是連續(xù)兩次采樣之間的相位增量。根據(jù)采樣定理:</p><p><b> ?。?-6)</b></p><p>  只要從(2-3)出來(lái)的離散序列即可唯一的恢復(fù)出(

14、2-2)的模擬信號(hào)。從(2-2)可知,是相位函數(shù)的斜率決定了信號(hào)的頻率;從(2-5)可知,決定相位函數(shù)斜率的是兩次采樣之間的相位增量。因此,只要控制這個(gè)相位增量,就可以控制合成信號(hào)的頻率?,F(xiàn)將整個(gè)周期的相位2分成M份,每一份為,若每次的相位增量選擇為的K倍,即可得到信號(hào)的頻率:</p><p><b> ?。?-7)</b></p><p><b>  相應(yīng)

15、的模擬信號(hào)為:</b></p><p><b> ?。?-8)</b></p><p>  式中K和M都是正整數(shù),根據(jù)采樣定理的要求,K的最大值應(yīng)小于M的1/2。</p><p>  綜上所述,在采樣頻率一定的情況下,可以通過(guò)控制兩次采樣之間的相位增量(不得大于π)來(lái)控制所得離散序列的頻率,經(jīng)保持、濾波之后可唯一的恢復(fù)出此頻率的模擬

16、信號(hào)。</p><p>  DDS工作原理框圖如圖2.1所示:</p><p>  圖2.1 DDS原理框圖</p><p>  其實(shí)質(zhì)是以基準(zhǔn)頻率源(系統(tǒng)時(shí)鐘)對(duì)相位進(jìn)行等間隔的采樣。由圖2.1見,DDS 由相位累加器和波形存儲(chǔ)器(即,ROM查詢表)構(gòu)成的數(shù)控振蕩器(NCO_ Numerically Controlled Oscillators)、數(shù)模轉(zhuǎn)換器(DA

17、C)以及低通濾波器(LPF)三部分組成。在每一個(gè)時(shí)鐘周期,N位相位累加器與其反饋值進(jìn)行累加,其結(jié)果的高L位作為查詢表的地址,然后從ROM中讀出相應(yīng)的幅度值送到DAC。再由DAC將其轉(zhuǎn)換成為階梯模擬波形,最后由具有內(nèi)插作用的LPF將其平滑為連續(xù)的正弦波形作為輸出。因此,通過(guò)改變頻率控制字K就可以改變輸出頻率。</p><p><b>  在這里</b></p><p>

18、<b>  ,。</b></p><p>  由上面的分析可得DDS的輸出頻率:</p><p><b>  (2-9)</b></p><p>  由上式可知,DDS的最小輸出頻率為:</p><p><b>  (2-10)</b></p><p>

19、  DDS的頻率分辨率為:</p><p><b> ?。?-11)</b></p><p>  DDS頻率輸入字的計(jì)算:</p><p>  FW(N-1:0) = 2Nf0/fc (2-12)</p><p><b>  DDS基本結(jié)構(gòu)組成</b><

20、;/p><p>  一個(gè)基本的DDS系統(tǒng)由數(shù)控振蕩器(NCO)、數(shù)模轉(zhuǎn)換器(DAC)和低通濾波器(LPF)三部分構(gòu)成,如圖3.1所示:</p><p>  圖3.1 DDS的基本結(jié)構(gòu)</p><p>  數(shù)控振蕩器(NCO)產(chǎn)生頻率可控制的數(shù)字正弦載波,通過(guò)數(shù)模轉(zhuǎn)換器(DAC)得到模擬正弦波,最后經(jīng)過(guò)低通濾波器(LPF)除去各種干擾信號(hào)。</p><

21、;p>  本實(shí)驗(yàn)項(xiàng)目中的設(shè)計(jì)主要針對(duì)數(shù)控振蕩器(NCO)部分,DAC部分直接采用實(shí)驗(yàn)系統(tǒng)箱提供的數(shù)/模轉(zhuǎn)換電路。</p><p><b>  四、DDS的設(shè)計(jì)</b></p><p>  在DDS的設(shè)計(jì)中其最基本的構(gòu)件是相位累加器和波形存貯器。通常也可在波形存貯器前面加一個(gè)相位調(diào)制器,使其具有相位調(diào)制的功能,為了防止頻率控制字、相位控制字改變時(shí)干擾相位累加器和相

22、位調(diào)制器的正常工作,分別在這兩個(gè)模塊前面加入了兩組寄存器,從而靈活且穩(wěn)定地控制頻率字和相位字的輸入。如圖4.1所示:</p><p>  圖中相位累加器(phasea)是整個(gè)DDS的核心,在這里完成相位累加功能,其輸入是相位增量,又可稱為頻率控制字,由于與輸出頻率是簡(jiǎn)單的線性關(guān)系:</p><p><b> ?。?-1)</b></p><p>

23、;  事實(shí)上當(dāng)基準(zhǔn)時(shí)鐘是時(shí), 就等于。</p><p>  相位調(diào)制器(phasemod)接收相位累加器的相位輸出,在這里加一個(gè)相位偏移值,主要用于實(shí)現(xiàn)信號(hào)的相位調(diào)制,如PSK(相移鍵控)等,在不使用時(shí)可以去掉該部分,或加一個(gè)固定的相位控制字。</p><p>  波形存儲(chǔ)器(即,正弦ROM查找表)(sinlup)把存儲(chǔ)在相位累加器中的抽樣值轉(zhuǎn)換成正弦波幅度的數(shù)字量函數(shù),可理解為相位到幅度

24、的轉(zhuǎn)換。它的輸入是相位調(diào)制器輸出的高M(jìn)位(而并非全部N位)值,將其作為正弦ROM查找表的地址值;查詢表把輸入的地址相位信息映射成正弦波幅度信號(hào);輸出送往DAC,轉(zhuǎn)化為模擬信號(hào)。</p><p>  2 AD9850簡(jiǎn)介</p><p><b>  2.1芯片性能</b></p><p>  隨著數(shù)字技術(shù)的飛速發(fā)展,用數(shù)字控制方法從一個(gè)參考

25、頻率源產(chǎn)生多種頻率的技術(shù),即直接數(shù)字頻率合成(DDS)技術(shù)異軍突起。美國(guó)AD公司推出的高集成度頻率合成器AD9850便是采用DDS技術(shù)的典型產(chǎn)品之一。AD9850采用先地蝗CMOS工藝,其功耗在3.3V供電時(shí)僅為155mW,擴(kuò)展工業(yè)級(jí)溫度范圍為-40~80℃,采用28腳SSOP表面封裝形式。AD9850的引腳排列,圖2為其組成框圖。圖2中層虛線內(nèi)是一個(gè)完整的可編程DDS系統(tǒng),外層虛線內(nèi)包含了AD9850的主要組成部分。AD9850內(nèi)含可

26、編程DDS系統(tǒng)和高速比較器,能實(shí)現(xiàn)全數(shù)字編程控制的頻率合成??删幊藾DS系統(tǒng)的核心是相位累加器,它由一個(gè)加法器和一個(gè)N位相位寄存器組成,N一般為24~32。每來(lái)一個(gè)外部參考時(shí)鐘,相位寄存器便以步長(zhǎng)M遞加。相位寄存器的輸出與相位控制字相加后可輸入到正弦查詢表地址上。正弦查詢表包含一個(gè)正弦波周期的數(shù)字幅度信息,每一個(gè)地址對(duì)應(yīng)正弦波中0°~360°范圍的一個(gè)相位點(diǎn)。查詢表把輸入地址的相位信息映射成正弦波幅度信號(hào),然后驅(qū)動(dòng)D

27、AC以輸出模式量。相位寄存器每過(guò)2N/M個(gè)外部參考時(shí)鐘后返回到初始狀態(tài)一次,相位地正弦查詢表</p><p>  2 .2 AD9850 的控制字及控制時(shí)序</p><p>  AD9850 的控制字有 40 位 ,其中 32 位是頻率控制位 ,5 位是相位控制位 ,1 位是電源休眠控制位 ,2 位是工作方式選擇控制位。在應(yīng)用中 ,工作方式選擇位設(shè)為00 ,因?yàn)?01 ,10 ,11 已經(jīng)

28、預(yù)留作為工廠測(cè)試用。頻率控制位可通過(guò)下式計(jì)算得到:f out = ( f r ×W) / 232其中: f out 要輸出的頻率值; f r 為參考時(shí)鐘頻率;W 為相應(yīng)的十進(jìn)制頻率控制字, 然后轉(zhuǎn)換為十六進(jìn)制即可。AD9850 有串行和并行兩種控制命令字寫入方式。其中串行寫入方式是采用 D7 作</p><p>  為數(shù)據(jù)輸入端 ,每次W_CL K的上升沿把一個(gè)數(shù)據(jù)串行移入到輸入寄存器40 位數(shù)據(jù)都移入

29、后 ,FQ_UD 上升沿完成輸出信號(hào)頻率和相位的更新。串行控制字的寫入時(shí)序如圖 3 所示。但是要注意的是 ,此時(shí)數(shù)據(jù)輸入端的三個(gè)管腳不可懸空 ,其中D0 ,D1 腳接高電平 ,D2 腳要接地。</p><p><b>  圖(2)</b></p><p><b>  圖(3)</b></p><p><b>  

30、2.3管腳定義</b></p><p><b>  3 硬件部分</b></p><p>  3.1基于AD9850的模塊原理圖</p><p><b> ?。常灿布娐吩O(shè)計(jì)</b></p><p>  AD9850 控制字的寫入方式有串行和并行兩種。并行寫入方式的優(yōu)點(diǎn)是數(shù)據(jù)傳輸?shù)乃俣?/p>

31、快 ,能夠提升整個(gè)系統(tǒng)的處理速度 ,但占用的單片機(jī)的 I/ O 口資源太多。與并行方式相比 ,串行寫入方式在數(shù)據(jù)傳輸?shù)乃俣壬弦?,但它更大優(yōu)點(diǎn)是能節(jié)省很多 I/ O 口資源[8 ]。所以 ,本系統(tǒng)采用A T89S52 單片機(jī)作為控制核心 ,通過(guò)串行寫入控制字的方式控制 AD9850 芯片 ,加上鍵盤和L ED 顯示部分等外圍電路 ,構(gòu)成整個(gè)系統(tǒng)電路。為了詳細(xì)介紹 AD9850 的用法 ,這里重點(diǎn)給出本系統(tǒng)中A T89S52 單片機(jī)與

32、 AD9850 芯片連接電路 ,如圖 4 所示 ,其中 R1 = 1 kΩ, R2 = 10kΩ, R3 = 1kΩ,單片機(jī)晶振選用12 MHz ,電容采用 30 p F 經(jīng)典值。單片機(jī)采用12 MHz晶振時(shí) ,它的高電平時(shí)間能夠滿足 AD9850 。</p><p><b>  圖(4)</b></p><p><b>  4軟件部分</b>&

33、lt;/p><p>  4.1   軟件部分設(shè)計(jì)</p><p>  軟件程序的功能就是通過(guò)程序使整個(gè)系統(tǒng)按照人們的設(shè)想要求工作起來(lái) ,本系統(tǒng)中最主要的部分就是將AD9850 的 40 位控制字通過(guò)單片機(jī)寫入到 AD9850 芯片內(nèi) ,系統(tǒng)的程序流程圖如圖 4 所示。要根據(jù)寫入控制字方式的不同嚴(yán)格按照 AD9850 的時(shí)序圖來(lái)編寫控制字寫入子程序。本文主要給出串行寫入方式的C源程序以供讀者調(diào)試

34、參考。</p><p><b> ?。?lt;/b></p><p><b>  4.2參考程序</b></p><p>  /******************************************* </p><p>  函數(shù):關(guān)于AD9850的DDS調(diào)頻</p><p

35、>  ********************************************/</p><p>  #include <reg52.h></p><p>  #include <intrins.h></p><p>  #include <string.h></p><p>  #d

36、efine uchar unsigned char </p><p>  #define uint unsigned int</p><p>  #define WRITE_DATA_IO P1 //定義AD9850數(shù)據(jù)端口</p><p>  #define LED_DATA_IO P0 //定義LED燈數(shù)據(jù)端口</p><p

37、>  Unsigned char code duanma[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x80};//設(shè)置數(shù)碼管段碼0-9</p><p>  unsigned char code weima[]={0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f};//設(shè)置數(shù)碼管位碼</p&g

38、t;<p>  uchar WRITE_DATA[5]; //9850頻率和控制字,WRITE_DATA[5]為控制字,其他32位為頻率字</p><p>  uchar display_data[8]; //8位數(shù)碼管的數(shù)值</p><p>  unsigned long frequence; //無(wú)符號(hào)長(zhǎng)整形數(shù)值,我們需要輸入的頻率</p><

39、;p>  uint MHZ, KHZ , HZ; //將需要的頻率分解為MHZ,KHZ,HZ</p><p>  uchar AD9850_temp; //AD9850工作標(biāo)志位</p><p>  sbit W_SLK = P2^0; //AD9850字節(jié)輸入,上升沿有效</p><p>  sbit DQ_VD = P2^1;

40、//AD9850四字節(jié)輸入后,上升沿有效</p><p>  sbit key_unit = P2^2; //按鍵的個(gè)位</p><p>  sbit key_decade = P2^3; //按鍵的十位</p><p>  sbit key_power = P2^4; //按鍵的十次冪 </p><p>  sbit key_sure

41、 = P2^5; //按鍵確認(rèn)</p><p>  sbit weila = P2^6;//LED數(shù)碼管的位碼</p><p>  sbit duanla = P2^7;//LED數(shù)碼管的段碼</p><p>  /*******************************************</p><p>  函

42、 數(shù):延時(shí)函數(shù),延時(shí)tms</p><p><b>  入口函數(shù):無(wú)</b></p><p><b>  出口頻率:無(wú)</b></p><p>  ********************************************/</p><p>  void delay1ms(uchar

43、t)</p><p><b>  {</b></p><p><b>  uchar tt;</b></p><p>  while(t--)</p><p><b>  {</b></p><p><b>  tt= 125;</b&

44、gt;</p><p>  while(tt--);</p><p><b>  }</b></p><p><b>  }</b></p><p>  /*************************LED顯示函數(shù)**************************************/&

45、lt;/p><p>  /*******************************************</p><p>  函 數(shù):初始化定時(shí)器0</p><p><b>  入口函數(shù):無(wú)</b></p><p><b>  出口頻率:無(wú)</b></p><p>

46、  ********************************************/</p><p>  void INIT_time0()</p><p><b>  {</b></p><p>  TMOD |= 0x01;</p><p>  TH0 = -2000 / 256;</p>&

47、lt;p>  TL0 = -2000 % 256;</p><p><b>  EA = 1;</b></p><p><b>  ET0 = 1;</b></p><p><b>  TR0 = 1;</b></p><p><b>  }</b>

48、</p><p>  /*******************************************</p><p>  函 數(shù):LED數(shù)碼管在start位開始顯示num數(shù)據(jù)</p><p>  入口函數(shù):start是數(shù)據(jù)從第幾位顯示,num是顯示多少位</p><p><b>  出口頻率:無(wú)</b>&

49、lt;/p><p>  ********************************************/</p><p>  void LED_display(uchar start, uchar num)</p><p><b>  {</b></p><p>  static unsigned char i =

50、 0;</p><p>  uchar delay = 15;</p><p>  if(AD9850_temp == 1)</p><p><b>  {</b></p><p>  display_data[0] = MHZ / 10; //將頻率分解讓數(shù)碼管顯示</p><p>  d

51、isplay_data[1] = MHZ % 10;</p><p>  display_data[2] = KHZ / 100;</p><p>  display_data[3] = KHZ % 100 / 10;</p><p>  display_data[4] = KHZ % 10;</p><p>  display_data[5

52、] = HZ / 100;</p><p>  display_data[6] = HZ % 100 / 10;</p><p>  display_data[7] = HZ % 10;</p><p><b>  }</b></p><p>  LED_DATA_IO = 0xed; //顯示兩個(gè)小數(shù)點(diǎn)<

53、/p><p>  weila = 1; //位碼鎖存</p><p>  weila = 0;</p><p>  LED_DATA_IO = duanma[10];</p><p>  duanla = 1;</p><p>  duanla = 0;</p><

54、p>  while(delay--);</p><p>  LED_DATA_IO = weima[i+start];</p><p>  weila = 1;</p><p>  weila = 0;</p><p>  LED_DATA_IO = duanma[display_data[i]];</p><p&g

55、t;  duanla = 1;</p><p>  duanla = 0;</p><p><b>  i++;</b></p><p>  if(i == num)</p><p>  i = 0; </p><p><b>  }</b></p>&l

56、t;p>  /*******************************************</p><p>  函 數(shù):中斷函數(shù)</p><p><b>  入口函數(shù):無(wú)</b></p><p><b>  出口頻率:無(wú)</b></p><p>  **************

57、******************************/</p><p>  void INT_time0() interrupt 1</p><p><b>  {</b></p><p>  TH0 = -2000 / 256;</p><p>  TL0 = -2000 % 256;</p>&

58、lt;p>  LED_display(0, 8);</p><p><b>  }</b></p><p>  /*************************按鍵函數(shù)*************************************/</p><p>  /**********************************

59、*********</p><p>  函 數(shù):按鍵初始化,確定頻率的大小</p><p><b>  入口函數(shù):無(wú)</b></p><p><b>  出口頻率:無(wú)</b></p><p>  ********************************************/<

60、/p><p>  void INIT_key()reentrant //可從入函數(shù)</p><p><b>  {</b></p><p>  uchar unit = 0,decade = 0, power = 0, i;</p><p>  AD9850_temp = 0;//AD9850開始標(biāo)志

61、位關(guān)閉</p><p>  memset(display_data, 0, 8);</p><p><b>  while(1)</b></p><p><b>  {</b></p><p>  if(key_unit == 0)//個(gè)位鍵</p><p><

62、;b>  {</b></p><p>  delay1ms(20); //延時(shí),防抖動(dòng)</p><p>  if(key_unit == 0)</p><p><b>  {</b></p><p>  while(key_unit == 0);</p><p>&l

63、t;b>  unit++;</b></p><p>  if(unit == 10 )</p><p><b>  unit = 0;</b></p><p>  display_data[6] = unit;</p><p><b>  }</b></p><

64、p><b>  }</b></p><p>  if(key_decade == 0)//十位鍵</p><p><b>  {</b></p><p>  delay1ms(20);</p><p>  if(key_decade == 0)</p><p&g

65、t;<b>  {</b></p><p>  while(key_decade == 0);</p><p><b>  decade++;</b></p><p>  if(decade == 10)</p><p>  decade = 0;</p><p>  dis

66、play_data[5] = decade;</p><p><b>  }</b></p><p><b>  }</b></p><p>  if(key_power == 0) //10次冪鍵</p><p><b>  {</b></p>

67、<p>  delay1ms(20);</p><p>  if(key_power == 0)</p><p><b>  {</b></p><p>  while(key_power == 0);</p><p><b>  power++;</b></p><p

68、>  if(power == 7)</p><p>  power = 0;</p><p>  display_data[7] = power;</p><p><b>  }</b></p><p><b>  }</b></p><p>  if(key_sure

69、 == 0) //確定鍵</p><p><b>  {</b></p><p>  delay1ms(20);</p><p>  if(key_sure == 0)</p><p><b>  {</b></p><p>  while(key_sure =

70、= 0);</p><p><b>  break;</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p>  frequence = u

71、nit + 10*decade; //將按鍵得到的數(shù)值進(jìn)行變換,得到我們需要的頻率</p><p>  for(i = 1; i <= power; i++)</p><p>  frequence *= 10;</p><p>  if(frequence >= 20000000) //由于AD9850的頻率范圍是1——20MHZ,所

72、以超過(guò)了就重新輸入</p><p><b>  {</b></p><p>  frequence = 0;</p><p>  INIT_key();</p><p><b>  }</b></p><p>  MHZ = frequence / 1000000;

73、//將頻率分解位MHZ,KHZ,HZ,主要是為了在中斷中計(jì)算量少些,以免影響中斷效果</p><p>  KHZ = frequence % 1000000 / 1000;</p><p>  HZ = frequence %1000;</p><p>  AD9850_temp = 1; //AD9850開始標(biāo)志位開啟</p><

74、p><b>  }</b></p><p>  /*************************AD9850函數(shù)**************************************/</p><p>  /*******************************************</p><p>  函 數(shù):

75、進(jìn)行9850的DDS函數(shù)發(fā)生,寫入控制字,寫入頻率字</p><p><b>  從高字往低字寫</b></p><p>  入口函數(shù):需要的頻率</p><p><b>  出口頻率:無(wú)</b></p><p>  *****************************************

76、***/</p><p>  void AD9850_WRITE()</p><p><b>  { </b></p><p>  unsigned long temp;</p><p><b>  char i;</b></p><p>  W_SLK = 0;<

77、;/p><p>  DQ_VD = 0;</p><p>  temp = (unsigned long)(34.359738368 * frequence);</p><p>  for(i = 0; i < 4; i++)</p><p>  WRITE_DATA[i] = temp >> (i * 8);</p>

78、;<p>  for(i = 4; i >= 0; i--)</p><p><b>  {</b></p><p>  W_SLK = 0;</p><p>  WRITE_DATA_IO = WRITE_DATA[i];</p><p>  W_SLK = 1;</p><p&

79、gt;<b>  _nop_();</b></p><p><b>  }</b></p><p>  DQ_VD = 1; </p><p><b>  }</b></p><p>  /*************************主函數(shù)****************

80、**********************/</p><p>  /*******************************************</p><p>  函 數(shù):主函數(shù),完成對(duì)全局的操控</p><p><b>  入口函數(shù):無(wú)</b></p><p><b>  出口頻率:無(wú)&l

81、t;/b></p><p>  ********************************************/</p><p>  void main()</p><p><b>  {</b></p><p>  INIT_time0();//初始化時(shí)間中斷</p><p&g

82、t;<b>  while(1)</b></p><p><b>  { </b></p><p>  if(key_sure == 0)</p><p><b>  {</b></p><p>  delay1ms(20);</p><p>  if

83、(key_sure == 0)</p><p><b>  {</b></p><p>  while(key_sure == 0);</p><p>  INIT_key();</p><p>  AD9850_WRITE();</p><p><b>  }</b><

84、;/p><p><b>  }</b></p><p><b>  }</b></p><p><b>  }</b></p><p><b>  5波形圖</b></p><p><b>  1.9MHZ正弦波</b&

85、gt;</p><p><b>  1HZ方波</b></p><p><b>  1HZ正弦波</b></p><p><b>  1MHZ方波</b></p><p><b> ?。保停龋趯?shí)物</b></p><p><b

86、> ?。保停龋谡也?lt;/b></p><p><b>  6結(jié)束語(yǔ)</b></p><p>  本模塊學(xué)習(xí)是基于AD9850的DDS信號(hào)發(fā)生器的基礎(chǔ)上,通過(guò)了解AD9850的工作原理和工作要求來(lái)完成正弦波.矩形波等波形在系統(tǒng)時(shí)鐘125M的條件下的學(xué)習(xí)。</p><p>  本次學(xué)習(xí)得到了精度很高的正弦波和矩形波,其占空比為46

87、.5%已經(jīng)很接近預(yù)期的結(jié)果。</p><p><b>  7參考文獻(xiàn)</b></p><p>  [1 ] 張迎春.單片微型計(jì)算機(jī)原理、 應(yīng)用及接口技術(shù)[M] .北京:</p><p>  國(guó)防工業(yè)出版社 ,2004.</p><p>  [2] 陳小忠.單片機(jī)接口技術(shù)實(shí)用子程序[M] . 北京:人民郵電</p&g

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 眾賞文庫(kù)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論