请教 msp430 launchpad AD 测量峰峰值
这是计算和初始化的程序
#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');
//强烈不懂,为什么要了两遍?
}