基于DSP的高精度數字頻率計的設計
鍵盤定時中斷掃描
為滿足系統實時性要求、完成鍵盤操作的實時響應,本系統設置了一個5ms的時基,采用事件管理器的EVB的time4定時周期中斷來完成。對鍵盤掃描、命令形成與標志位設置功能,都在定時器中斷服務子程序完成。鍵盤定時中斷掃描流程圖如圖5所示。
本文引用地址:http://www.104case.com/article/163945.htm
|
捕獲中斷測頻
本系統使用TMS320F2812事件管理器模塊的捕獲單元來測頻,捕捉被測信號的有效電平跳變沿,由內部的計數器記錄一個周波內標頻脈沖個數,并通過相應的運算來得到被測頻率的大小。此模塊主要包括捕獲與定時的初始化設置與捕獲中斷子程序兩部分。
捕獲中斷測頻子程序的部分代碼如下:
(1)void InitEv1(void)//捕獲1初始化設置
{
EALLOW;
SysCtrlRegs.HISPCP.all = 0x00;// 外設高速時鐘
EDIS;
EvaRegs.CAPCONA.bit.CAP1EDGE=1; //檢測上升沿,計算周期脈沖寬度
EvaRegs.CAPFIFOA.bit.CAP1FIFO=0; //CAP1FIFO空
EvaRegs.CAP1FBOT=0;//棧底清零
EvaRegs.CAP1FIFO=0;
EvaRegs.EVAIFRC.bit.CAP1INT=1;//清捕獲中斷1標志位
EvaRegs.EVAIMRC.bit.CAP1INT=1; //捕獲1中斷使能
}
(2)interrupt void CAPINT1_isr(void)//捕獲中斷1子程序
{
CAP1_t1=EvaRegs.CAP1FIFO;//
CAP2_t1=EvaRegs.CAP1FIFO;
if(CAP2_t1>CAP1_t1)
temp1=CAP2_t1-CAP1_t1;
else
temp1=CAP2_t1+EvaTimer1InterruptCount*65535-CAP1_t1;
f1= 1171875.0/(float)temp1;
value=f1;
fpart = modf(value, ipart);
a1=(long)ipart;//獲得頻率的32位整數
*(Uint16 *)0x80008=a10x0ffff;//獲的低16位
*(Uint16 *)0x80009=(a10xffff0000)>>16;//獲的高16位
EvaRegs.EVAIFRC.bit.CAP1INT=1;//清捕獲中斷1標志位
EvaRegs.EVAIMRC.bit.CAP1INT=1; //捕獲1中斷使能
PieCtrlRegs.PIEACK.bit.ACK3 = 1;//開外設中斷應答
}
LCD顯示處理
LCD的顯示分為信息區與顯示區兩部分。其中信息區包括固定信息(顯示煙臺大學DSP實驗室等),顯示區包括通道號信息與各通道的頻率值信息的顯示。本模塊主要包括LCD的初始化設置與頻率值的顯示等子程序。
實驗結果
本系統測試了如表1中的6組數據,并做出了誤差分析。輸入信號頻率與實測信號頻率如表1所示。
|
誤差分析:本系統的誤差主要來自如下兩個方面,即計數脈沖和門控信號不同步以及晶振不穩定。
結束語
本文設計了一種具有高精度和簡單結構特點的測頻系統,由于在實現上簡單,可以滿足低成本的要求,使測頻電路大為簡化,便于工程應用,具有較大的應用價值。
經過反復測試后得出:系統的測頻誤差可達到0.1%,由于采用了實時的鍵盤定時中斷掃描,可以較好地滿足實時性要求。
評論