基于CPLD的DDS正弦信號發(fā)生器的設計簡介
這幾天終于實現(xiàn)了DDS正弦信號的發(fā)生,限于CPLD的128宏單元不夠用也不知道怎么優(yōu)化,后來就干脆把按鍵、頻率顯示、頻率控制字交給單片機控制產(chǎn)生,再由單片機講頻率控制字傳送給CPLD,這樣就實現(xiàn)了頻率的控制。最終產(chǎn)生的正弦信號頻率范圍為1HZ~30KHZ,頻率可步進1HZ也可通過單片機預置,也可以自動掃頻信號。起先出來的頻最大誤差達到2HZ多,覺得不對勁出來的頻率應該很精確不會有這么大的誤差,后來發(fā)現(xiàn)原來是晶振不準有點誤差,后來經(jīng)程序修改使輸出最大頻率誤差在0.1HZ以內(nèi),經(jīng)過這幾天的努力總算感到了一點的欣慰。
本文引用地址:http://butianyuan.cn/article/190973.htm這是VHDL頂層模塊:
這是當k=001111111111111時的仿真波形:
單片機控制6個數(shù)碼管顯示當前的頻率,P1口接4個功能按鍵,分別是+、-、選擇和掃頻,再用兩片574向CPLD輸出頻率控制字。限于時間暫時做到這么多。
再說一點吧,由于是用DAC0832轉換的(轉換時間1us)所以晶振就限制在1M之內(nèi)了,出來的最大頻率,根據(jù)奈奎斯特采樣定理也就限制在0.5MHZ之內(nèi)了(不過失真很大的,取小點好了),最后對出來的波形再做濾波就可以了。
評論