完善资料让更多小伙伴认识你,还能领取20积分哦, 立即完善>
扫一扫,分享给好友
`从网上找到一个用AD测量峰峰值的,但一直都不明白为什么 jisuan那部分要算两遍,而且按我的理解,aver那个数组每个元素都是0,怎么后来乘3.56又显示的不是0了。。。。。。。。。。问题好多,希望大神给解 ` |
|
相关推荐
3个回答
|
|
这是计算和初始化的程序
#include #include "lcd1602.h" uint aver[64]={0}; //这个aver在这儿有问题,是六四个0,应该说也不错下面有用 uchar flag=0; uchar zifu[14]={"0123456789ux=z"}; uint maxaver=0; long dis=0; double max=0,maxr=0; void delay(unsigned char ms) { unsigned char i,j; for(i=ms;i>0;i--) for(j=120;j>0;j--); } void Sys_clock_init(void) //时钟初始化 { uint i=0; BCSCTL1 |= CALBC1_16MHZ; //基础时钟控制—— DCOCTL |= CALDCO_16MHZ; //弄成16MHZ? for(i=0;i<65535;i++); BCSCTL2 |= SELM_0; //DCOCLK BCSCTL2 |= DIVS_0; //不分频 } void AD_init(void) { ADC10CTL0 = ADC10ON + ADC10IE +MSC + ADC10SHT_3; //打开,使能,1st上升沿触发,采样时间64倍ADC0clk ADC10CTL1 |= CONSEQ_3 + INCH_1;; //单道多次,A1 ADC10AE0 |= BIT0+BIT1; //对应使能控制,A1,A0 ADC10DTC1 = 0x40; //第6口置1 } void jisuan() { uchar j; maxr=0; //跟上面重复了啊 maxaver=0; //也是 for(j=0;j<64;j+=2) { if(aver[j]>maxaver && aver[j]<1024) //显然不会啊,上面64个0怎么大于Max,看看再说 maxaver=aver[j]; //存取的这个aver值就给了最大的 } maxr=(maxaver*3.56)/1023; //这是转化的采样,出来数据了 max=maxr*10000; //方便显示?转化成10进制?把数据给max dis=max; //上面max只是个狗腿子,dis最后出来显示 //lcd_pos(2,2); //12864的位置设置,1602不用 Disp1Char(1,0,zifu[dis/10000]); //write_dat(zifu[dis/10000]); //这以后就是12864显示了,1602代替 Disp1Char(2,0,'.'); //write_dat('.'); Disp1Char(3,0,zifu[dis/1000%10]); //write_dat(zifu[dis/1000%10]); Disp1Char(4,0,zifu[dis/100%10]); //write_dat(zifu[dis/100%10]); Disp1Char(5,0,zifu[dis/10%10]); //write_dat(zifu[dis/10%10]); Disp1Char(6,0,zifu[dis%10]); //write_dat(zifu[dis%10]); Disp1Char(7,0,'v'); // write_dat('V'); maxr=0; //又来一遍? maxaver=0; for(j=1;j<64;j+=2) { if(aver[j]>maxaver && aver[j]<1024) maxaver=aver[j]; } maxr=(maxaver*3.56)/1023; max=maxr*10000; dis=max; // lcd_pos(4,2); Disp1Char(1,1,zifu[dis/10000]); //write_dat(zifu[dis/10000]); Disp1Char(2,1,'.'); //write_dat('.'); Disp1Char(3,1,zifu[dis/1000%10]); //write_dat(zifu[dis/1000%10]); Disp1Char(4,1,zifu[dis/100%10]); //write_dat(zifu[dis/100%10]); Disp1Char(5,1,zifu[dis/10%10]); // write_dat(zifu[dis/10%10]); Disp1Char(6,1,zifu[dis%10]); //write_dat(zifu[dis%10]); Disp1Char(7,1,'v'); // write_dat('V'); //强烈不懂,为什么要了两遍?? } |
|
|
|
这是主程序
#include #include "lcd1602.h" #include "lcd1602.c" #include "adchushi.h" #include "adchushi.c" #include "intrinsics.h" void main(void) { P1DIR = 0XFF;P1OUT = 0XFF; P2DIR = 0XFF;P2OUT = 0XFF; WDTCTL = WDTPW + WDTHOLD; //关闭看门狗 P2SEL = 0X00; // IO口初始化,需要P2SEL置零 LcdReset(); //显示初始化,1602Reset() delay(100); Sys_clock_init(); //时钟系统的初始化 Disp1Char(10,0,zifu[10]); //u Disp1Char(11,0,zifu[11]); //x Disp1Char(9,0,zifu[12]); //= Disp1Char(10,1,zifu[10]); //u Disp1Char(11,1,zifu[13]); //z Disp1Char(9,1,zifu[12]); //= P2REN |= 0X00; AD_init(); //打开,使能,1st上升沿触发,64倍ADC0clk,单道多次,A1,对应使能控制,A1,A0,第6口置1 // jisuan(); while(1) { //jisuan(); ADC10CTL0&=~ENC; //使能转换,关 while(ADC10CTL1&ADC10BUSY); //有活跃的转换采样的时候 ADC10CTL0|=ENC+ADC10SC; //打开使能,开始转换 ADC10SA=(unsigned int)aver; //将数据放在寄存器A中 __bis_SR_register(CPUOFF+GIE);//关闭cpu,开启中断 //LPM0; // GIE; jisuan(); } } #pragma vector=ADC10_VECTOR __interrupt void ADC10_ISR(void) { jisuan(); __bic_SR_register_on_exit(CPUOFF+GIE); // __bic_SR_register_on_exit(unsigned short); // _DINT(); } |
|
|
|
附带的计算和一些初始化程序
#include #include "lcd1602.h" uint aver[64]={0}; //这个aver在这儿有问题,是六四个0,应该说也不错下面有用 uchar flag=0; uchar zifu[14]={"0123456789ux=z"}; uint maxaver=0; long dis=0; double max=0,maxr=0; void delay(unsigned char ms) { unsigned char i,j; for(i=ms;i>0;i--) for(j=120;j>0;j--); } void Sys_clock_init(void) //时钟初始化 { uint i=0; BCSCTL1 |= CALBC1_16MHZ; //基础时钟控制—— DCOCTL |= CALDCO_16MHZ; //弄成16MHZ? for(i=0;i<65535;i++); BCSCTL2 |= SELM_0; //DCOCLK BCSCTL2 |= DIVS_0; //不分频 } void AD_init(void) { ADC10CTL0 = ADC10ON + ADC10IE +MSC + ADC10SHT_3; //打开,使能,1st上升沿触发,采样时间64倍ADC0clk ADC10CTL1 |= CONSEQ_3 + INCH_1;; //单道多次,A1 ADC10AE0 |= BIT0+BIT1; //对应使能控制,A1,A0 ADC10DTC1 = 0x40; //第6口置1 } void jisuan() { uchar j; maxr=0; //跟上面重复了啊 maxaver=0; //也是 for(j=0;j<64;j+=2) { if(aver[j]>maxaver && aver[j]<1024) //显然不会啊,上面64个0怎么大于Max,看看再说 maxaver=aver[j]; //存取的这个aver值就给了最大的 } maxr=(maxaver*3.56)/1023; //这是转化的采样,出来数据了 max=maxr*10000; //方便显示?转化成10进制?把数据给max dis=max; //上面max只是个狗腿子,dis最后出来显示 Disp1Char(1,0,zifu[dis/10000]); Disp1Char(2,0,'.'); Disp1Char(3,0,zifu[dis/1000%10]); Disp1Char(4,0,zifu[dis/100%10]); Disp1Char(5,0,zifu[dis/10%10]); Disp1Char(6,0,zifu[dis%10]); Disp1Char(7,0,'v'); maxr=0; //又来一遍? maxaver=0; for(j=1;j<64;j+=2) { if(aver[j]>maxaver && aver[j]<1024) maxaver=aver[j]; } maxr=(maxaver*3.56)/1023; max=maxr*10000; dis=max; Disp1Char(1,1,zifu[dis/10000]); Disp1Char(2,1,'.'); Disp1Char(3,1,zifu[dis/1000%10]); Disp1Char(4,1,zifu[dis/100%10]); Disp1Char(5,1,zifu[dis/10%10]); Disp1Char(6,1,zifu[dis%10]); Disp1Char(7,1,'v'); //强烈不懂,为什么要了两遍?? } |
|
|
|
你正在撰写答案
如果你是对答案或其他答案精选点评或询问,请使用“评论”功能。
442 浏览 0 评论
嵌入式学习-飞凌嵌入式ElfBoard ELF 1板卡-内核编译之初次编译
222 浏览 0 评论
315 浏览 0 评论
164 浏览 0 评论
《DNESP32S3使用指南-IDF版_V1.6》 第十六章 WATCH_DOG实验
494 浏览 0 评论
【youyeetoo X1 windows 开发板体验】少儿AI智能STEAM积木平台
11972 浏览 31 评论
小黑屋| 手机版| Archiver| 电子发烧友 ( 湘ICP备2023018690号 )
GMT+8, 2024-12-19 07:10 , Processed in 0.541401 second(s), Total 77, Slave 59 queries .
Powered by 电子发烧友网
© 2015 bbs.elecfans.com
关注我们的微信
下载发烧友APP
电子发烧友观察
版权所有 © 湖南华秋数字科技有限公司
电子发烧友 (电路图) 湘公网安备 43011202000918 号 电信与信息服务业务经营许可证:合字B2-20210191 工商网监 湘ICP备2023018690号