|
之前寫了一篇關(guān)于波形識別的文章(2019年5月24日),原文章被吞,F(xiàn)在改進(jìn)后重新發(fā)文。主要修改了一些拼寫錯誤
ATMEGA328P-AU,一種集成電路 (IC),核心處理器是AVR,閃存容量為32KB。本問題提出一種用Atmega 328實現(xiàn) 方波三角波波形識別的代碼。代碼主要通過AVR單片機(jī)內(nèi)部中斷實現(xiàn)。開發(fā)板為ardino。主要參考資料
www點xjishu點com/zhuanli/54/201711478206_2.html
注意開頭需要加入加入頭文件math,因為涉及math運算
static int min = 0x0F;
static int max = 0;
static int prev_data;
int low = 768;//5V 以內(nèi)
int up = 1024;
static up_count;
int peak_count;
char disp;//用字符串格式顯示
ISR(ADC_vect) {//設(shè)置ADC比較中斷
int adc_data = ADCW;//ADCW是讀取所有數(shù)據(jù)
if (adc_data > max) max = adc_data;//更新最大最小值
if (adc_data < min) min = adc_data;
if (adc_data > up) peak_count =peak_count +1;
if (adc_data > low)up_count =upcount+1;
else if (prev_data > thresh_low && up_count > 65) {
//計算方波三角波的占空比值來區(qū)分方波三角波。三角波約為0.4,正弦波約為0.57,方波大于0.8
ratio =peak_count/up_count;
up_count = 0;
peak_count = 0;
//按照比例計算電壓幅值
amplitude = (5/(double)1024)*(max - min);
amplitude =round(amplitude*10);
frequency = (1/(up_count * 0.001))*7.8;//注意頻率的計算方法
frequency = round(frequency);
thresh_low = round((max-min)/2 + min);
thresh_up = round((max-min)*0.67 + min);
max = 0;
min = 1023;
}
prev_data = adc_data;
}
ISR(TIMER0_COMPA_vect){//注意這里使用即使器比較模式
ADCSRA |= 1<<ADSC; //這里是用了計時器的比較模式
}
注意,本程序只包含中斷程序,在主程序中需要對ADC和timer0的寄存器進(jìn)行定義。這里將寄存器定義為ADC 32分頻,timer0 256分頻。當(dāng)timer0 置為4時,觸發(fā)ADC中斷。判斷波形后,可以用ratio這種方法驅(qū)動LED燈,來指示波形。頻率可以用LCD1602顯示.這里可以參考
www點elecfans點com/xianshi/20171018566270.html
|
評分
-
查看全部評分
|