当前位置:首页 > 单片机 > 单片机
[导读] #defineucharunsignedchar#defineuintunsignedint#defineuiVref_preset2560ucharconstSEG7[10]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90}; ucharconstACT[8]={0xf7,0xfb,0xfd,0xfe};uintad

#defineucharunsignedchar
#defineuintunsignedint
#defineuiVref_preset2560
ucharconstSEG7[10]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90};

ucharconstACT[8]={0xf7,0xfb,0xfd,0xfe};
uintadc_val,dis_val;
unsignedchartime2_cmp_i=128;//TIME2比较中断i=采样率*AD通道数
unsignedintuiadc_value_temp;//ADC中断的采样值
unsignedintuitime2_adc0_value_sum,uiadc0_value;//TIME2ADC016个采样值的加和值,电压输出值=Vref*uitime2_adc0_value_sum/16/1024
unsignedintuitime2_adc1_value_sum,uiadc1_value;//TIME2ADC116个采样值的加和值,电压输出值
unsignedintuitime2_adc2_value_sum,uiadc2_value;//TIME2ADC216个采样值的加和值,电压输出值
unsignedintuitime2_adc3_value_sum,uiadc3_value;//TIME2ADC316个采样值的加和值,电压输出值
unsignedintuitime2_adc4_value_sum,uiadc4_value;//TIME2ADC416个采样值的加和值,电压输出值
unsignedlonguladc_data,uladc_data2,time2_count;//ADC的转换数据,TIME2中断计数N,0.1S计数(可作长时间定时器136年)
unsignedcharucADC_select;//五通道AD选择
unsignedintuiADC_value_sum[5];//五通道AD,64个数据加和值
//uintuiadc[5];//参考电压=2665mV
uintf;
unsignedchari;
voidport_init(void)
{
DDRB=0xFF;
PORTB=0xFF;
DDRC=0x00;
PORTC=0x00;//m103outputonly
DDRD=0xFF;
PORTD=0xFF;
}
//***********ADC的设定及函数****************
//ADCinitialize
//Conversiontime:128KHz(系统位4.096MHz,32分频)
voidadc_init(void)
{
ADCSRA=0x00;//dISAbleadc
ACSR=(1ADCSRA=(1<}
//***********ADC的设定及函数**************end**

//TIMER2initialize-prescale:1024
//WGM:CTC
//actualvalue:32*2*10Hz(0.0%)=采样率*AD通道数*工频50Hz的倍数
voidtimer2_init(void)
{
TCCR2=0x00;//stop
ASSR=0x00;//关闭异步方式
TCNT2=0x00;//setup
OCR2=0XEA;//设置TIME2比较中断频率10ms
TCCR2=(1unsignedintcal_VD(unsignedintuiAD_16sum_data)
{
uladc_data=uiAD_16sum_data;
return((unsignedint)((uladc_data*uiVref_preset)>>12));//输出ADC0的电压值VD0=Vref*uitime2_adc0_value_sum/16/2的8次方
}
#pragmainterrupt_handlertimer2_comp_isr:4
voidtimer2_comp_isr(void)//TIME2做四通道ADC0、ADC1、ADC2、ADC3的积分滤波10Hz,16采样率
{
CLI();
f++;
if((time2_cmp_i&0x07)==0x00)ADCSRA|=(1if(time2_cmp_i==0)
{
uitime2_adc0_value_sum=uiADC_value_sum[0];//16个数据加和值
uiadc0_value=cal_VD(uitime2_adc0_value_sum);//输出ADC0的电压值VD0=Vref*uitime2_adc0_value_sum/16/1024
uiADC_value_sum[0]=0;//清零
uitime2_adc1_value_sum=uiADC_value_sum[1];//16个数据加和值
uiadc1_value=cal_VD(uitime2_adc1_value_sum);//输出ADC0的电压值VD0=Vref*uitime2_adc0_value_sum/16/1024
uiADC_value_sum[1]=0;//清零
uitime2_adc2_value_sum=uiADC_value_sum[2];//16个数据加和值
uiadc2_value=cal_VD(uitime2_adc2_value_sum);//输出ADC0的电压值VD0=Vref*uitime2_adc0_value_sum/16/1024
uiADC_value_sum[2]=0;//清零
uitime2_adc3_value_sum=uiADC_value_sum[3];//16个数据加和值
uiadc3_value=cal_VD(uitime2_adc3_value_sum);//输出ADC0的电压值VD0=Vref*uitime2_adc0_value_sum/16/1024
uiADC_value_sum[3]=0;//清零
uitime2_adc4_value_sum=uiADC_value_sum[4];//16个数据加和值
uiadc4_value=cal_VD(uitime2_adc4_value_sum);//输出ADC0的电压值VD0=Vref*uitime2_adc0_value_sum/16/1024
uiADC_value_sum[4]=0;
time2_cmp_i=128;
SEI();
}
}
//******定时器T2中断*************************end*/
/********由定时器T2中断启动连续转换四个ADC通道的值**********/
#pragmainterrupt_handleradc_isr:15
voidadc_isr(void)
{CLI();
uiadc_value_temp=ADCH;
//uiadc_value_temp|=(unsignedint)ADCH<<8;

switch(ucADC_select)
{
case0://ADC0通道数据处理
{
ADMUX=0xe1;//切换到ADC1通道,内部Vref
uiADC_value_sum[ucADC_select]+=uiadc_value_temp;//加和值
ADCSRA|=(1break;
}
case1://ADC1通道数据处理
{
ADMUX=0xe2;//切换到ADC2通道,内部Vref
uiADC_value_sum[ucADC_select]+=uiadc_value_temp;//加和值
ADCSRA|=(1break;
}
case2://ADC2通道数据处理
{
ADMUX=0xe3;//切换到ADC3通道,内部Vref
uiADC_value_sum[ucADC_select]+=uiadc_value_temp;//加和值
ADCSRA|=(1break;
}
case3://ADC3通道数据处理
{
ADMUX=0xe4;//切换到ADC0通道,内部Vref,但不启动,等待定时器T2启动
uiADC_value_sum[ucADC_select]+=uiadc_value_temp;//加和值
ADCSRA|=(1break;
}
case4://ADC3通道数据处理
{
ADMUX=0xe0;//切换到ADC0通道,内部Vref,但不启动,等待定时器T2启动
uiADC_value_sum[ucADC_select]+=uiadc_value_temp;//加和值
//ADCSRA|=(1break;
}
default:
{
ADMUX=0xe0;//切换到ADC0通道,内部Vref,但不启动,等待定时器T2启动
ucADC_select=0;//切换到ADC0通道,但不启动,等待定时器T2启动
break;
}
SEI();
}//switchend
}//AD中断处理end
/********由定时器T2中断启动连续转换四个ADC通道的值******end*/
voidinit_devICes()
{port_init();
adc_init();
timer2_init();
SEI();
}

voidmain(void)
{uintj,k,n;
init_devices();
while(1)
{//if(f<1000)dis_val=uiadc0_value;
//elseif(f<2000)dis_val=uiadc1_value;
//elseif(f<3000)dis_val=uiadc2_value;
//elseif(f<4000)dis_val=uiadc3_value;
//elseif(f<5000)dis_val=uiadc4_value;
//elsef=0;
dis_val=uiadc2_value;
if(++i>3)i=0;
switch(i)
{
case0:PORTB=SEG7[dis_val%10];PORTD=ACT[i];
break;
case1:PORTB=SEG7[(dis_val/10)%10];PORTD=ACT[i];
break;
case2:PORTB=SEG7[(dis_val/100)%10];PORTD=ACT[i];
break;
case3:PORTB=SEG7[dis_val/1000];PORTD=ACT[i];
break;
default:break;
}
}
}

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

AD18使用的简单介绍,添加库,添加PCB封装库,快速添加引脚,绘制器件

关键字: ad pcb封装库

如何用Altium Designer从PCB图中导出元件封装库?

关键字: ad 封装

我们经常遇到从AD转到Allegro的情况,但是之前非常麻烦且不容易转换。现在好了,从065号补丁开始,Cadence的Capture CIS可以导入AD软件的原理图,而Cadence的Allegro PCB Edito...

关键字: ad 封装 cadence

PCB学习笔记——AD17如何添加新的封装

关键字: ad 封装库 添加

Altium Designer 封装 库文件导入 基础库设计 PCB设计 原理图设计

关键字: ad 封装库 导入

Altium Designer AD 2019最新封装库下载,原理图库PCB库

关键字: ad 封装

STC系列单片机中的STC89LE516AD/X2提供了8路8位精度的高速A/D转换器,位于P1口上,从而省去了片外ADC的麻烦。这8路ADC为电压输入型,可做按键扫描,电池电压检测,频谱检测等。ADC转换过程需要17个...

关键字: ad C KEIL

来源:Java日知录软件设计模式是解决软件设计中常见问题的通用、可复用的解决方案。设计模式让我们可以分享通用词汇并使用经实战检验的方案,以免重复造轮子。现在,我将介绍一系列设计模式来实现这些最佳实践。微服务架构的设计模式...

关键字: 5G ad abi

作者:vivo互联网服务器团队-YangYijun一、Kafka应用本文主要总结当Kafka集群流量达到 万亿级记录/天或者十万亿级记录/天 甚至更高后,我们需要具备哪些能力才能保障集群高可用、高可靠、高性能、高吞吐、安...

关键字: 6G ad AC

本文主要是了解LDO和开关电源在实际电路中的使用,后续具体细节慢慢在添加和修正。

关键字: 开关电源 DC-DC PCB ad
关闭