通過改變單片機的DA輸出電壓,可以得到各種各樣的電壓波形輸出,下面介紹產生正弦波形需送DA的數據是如何計算的。
首先既然是正弦波,那么就要確定要輸出一個周期正弦波的采樣點數point,即由多少點組成了一周期的正弦波,還要知道單片機輸出DA的數字值maxnum是多少,比如
8位DA,maxnum=256。10位DA,maxnum=1024。
知道以上兩個值后,就開始計算需要得到的正弦波DA數據了,我設置一個正弦波由61個點組成,所選DA最大數字輸入值為1024,那么我的正弦波數據數組就有61個數據,即sin_tab[61],也就是把一個正弦波360度,分成了61份,那么每份就是360÷61=5.901度,這樣就可以計算出61點中每個點對應的角度值jiaodu,有了角度值就可以算出來角度對應的正弦值,利用正弦值和輸出DA的數字值maxnum,就可以計算出對應DA輸入的數值了。
公式為:
sin_tab=(maxnum/2)*sin(x)+(maxnum/2); // i代表某點 x為某角度對應的弧度 弧度=角度*(π/180); //(maxnum/2)為正弦波零點處對應DA輸入值;即DA滿量程的一半;
在51單片機運行了以下函數,DA輸出波形完美,驗證產生的DA數據無誤。
- #include<math.h> //注意需添加此頭文件,包含了求正弦值函數sin(弧度值);
- //獲取不同點數的正弦波數據
- //point: 一周期內的取樣點數
- //maxnum: 一周期內對應DA輸出最大值
- void getSinTab(uchar point,uint maxnum)
- {
- uchar i=0;
- float x; //弧度
- float jiao;//角度 分度角
- jiao=360.000/point;
- for(i=0;i<point;i++)
- {
- x=jiao*i; //得到角度值
- x=x*0.01744; //角度轉弧度 弧度=角度*(π/180)
- sin_tab[i]=(maxnum/2)*sin(x)+(maxnum/2);
- }
- }
- // sin_tab[i] 為得到的正弦波數據,用于送給DA輸出。
復制代碼
|