专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
51单片机
请教 msp430 launchpad AD 测量峰峰值
2019-07-15 18:59
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
51单片机
4257
3
954
从网上找到一个用AD测量峰峰值的,但一直都不明白为什么 jisuan那部分要算两遍,而且按我的理解,aver那个数组每个元素都是0,怎么后来乘3.56又显示的不是0了。。。。。。。。。。问题好多,希望大神给解
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
3条回答
blue___land
1楼-- · 2019-07-16 00:00
这是计算和初始化的程序
#include <msp430g2553.h>
#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'); //强烈不懂,为什么要了两遍??
}
加载中...
blue___land
2楼-- · 2019-07-16 05:19
这是主程序
#include <msp430g2553.h>
#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();
}
加载中...
blue___land
3楼-- · 2019-07-16 10:03
附带的计算和一些初始化程序
#include <msp430g2553.h>
#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');
//强烈不懂,为什么要了两遍??
}
加载中...
一周热门
更多
>
相关问题
【东软载波ESF0654 PDS开发板活动】开箱
1 个回答
东软载波ESF0654 PDS开发板外部中断
1 个回答
东软载波ESF0654 PDS开发板高级控制定时器AD16C4T
1 个回答
用串口调试助手为什么只能在hex模式接收发送而在文本模式不行
9 个回答
触摸芯片SC02B/SC04B在地砖灯的设计方案
1 个回答
东软载波ESF0654 PDS开发板串口USART0代码分享
1 个回答
普通32位单片机使用linux的应用代码
5 个回答
东软载波ESF0654 PDS开发板AT24C04的调试
9 个回答
相关文章
51单片机与蓝牙模块连接
0个评论
51单片机的硬件结构
0个评论
基于51单片机的无线遥控器制作
0个评论
51单片机 AD转换
0个评论
51单片机数码管递增显示
0个评论
如何实现对单片机寄存器的访问
0个评论
基于51单片机的指纹密码锁
0个评论
×
关闭
采纳回答
向帮助了您的网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
51单片机
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
关闭
您已邀请
15
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
#include <msp430g2553.h>
#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 <msp430g2553.h>
#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 <msp430g2553.h>
#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');
//强烈不懂,为什么要了两遍??
}
一周热门 更多>