下面給出一個設計實例,在實例中通過定時器中斷和DAC0832結合的方式來產生1~100KHZ的正弦波,幅度為0-Vcc/2。
首先按照下面的公式建立一個正弦波樣本表,樣表中將一個正弦波周期分成128個點,每個點按7位量化(127對應最高幅度Vcc/2):
f(x) = 64 + 63 * sin(2πx/180) x∈[0…127]
程序中使用16位定時器0產生取樣中斷,及定時器0的中斷時間即為正弦波的采樣周期。(T=1/(f*64))。本例中將正弦波分成64個采樣點輸出,及每隔兩個點要從采樣樣本中取出一個數DAC0832的輸入。
單片機源程序:
- #define SIN_GLOBAL 1
- #include "sin.h"
- //正弦波128個采樣點寄存數組
- code uchar Sin[128] = {
- 64,67,70,73,76,79,82,85,88,91,94,96,99,102,104,106,
- 109,111,113,115,117,118,120,121,123,124,125,126,126,
- 127,127,127,127,127,127,127,126,126,125,124,123,121,
- 120,118,117,115,113,111,109,106,104,102,99,96,94,91,
- 88,85,82,79,76,73,70,67,64,60,57,54,51,48,45,42,39,
- 36,33,31,28,25,23,21,18,16,14,12,10,9,7,6,4,3,2,1,
- 1,0,0,0,0,0,0,0,1,1,2,3,4,6,7,9,10,12,14,16,18,21,23,
- 25,28,31,33,36,39,42,45,48,51,54,57,60
- };
- /**********************************************************
- *函數名稱:Timer0_init(double timer0Delay)
- *函數功能:定時器0初始化
- *函數入口:timer0Delay,定時器定時時間,單位為毫秒
- *函數出口:無
- **********************************************************/
- void Timer0_init(double timer0Delay)
- {
- double time;
- double timeTemp;
- timer0TH0=0x00;
- timer0TL0=0x00;
- timeTemp=0x00;
- time=(double)(((double)12)/((F_CPU)/1000000));
- if(((double)255)*time>timer0Delay)
- {
- timer0TH0=0x00;
- timer0TL0=(uchar)(256ul-timer0Delay/time);
- }
- else
- {
- while(timeTemp>timer0Delay)
- {
- timeTemp+=time;
- timer0TH0++;
- }
- timer0TH0--;
- timeTemp=timeTemp-((double)timer0TH0)*time;
- timer0TL0=(uchar)(256ul-timeTemp/time);
- }
- TMOD|=0x01; //GATE=0,TR=1運行;C/T=1,counter,0,timer;01十六進制
- TH0=timer0TH0;
- TL0=timer0TL0;
- TR0=1; //timer0 控制位,為1時啟動timer0
- ET0=1; //timer0 中斷使能
- }
- /**********************************************************
- *函數名稱:dac0832_init(void)
- *函數功能:D/A轉換芯片dac0832初始化
- *函數入口:無
- *函數出口:無
- **********************************************************/
- void dac0832_init(void)
- {
- sinCodeCount=0;
- DAC0832=Sin[0];
- }
- /**********************************************************
- *函數名稱:writeDAC0832(uchar dacDate)
- *函數功能:向D/A轉換芯片dac0832數據口寫數據
- *函數入口:dacDate
- *函數出口:無
- **********************************************************/
- void writeDAC0832(uchar dacDate)
- {
- DAC0832=dacDate;
- }
復制代碼
下載:
正弦波發生器.rar
(20.14 KB, 下載次數: 182)
2017-3-17 22:57 上傳
點擊文件名下載附件
|