微波EDA网,见证研发工程师的成长!
首页 > 研发问答 > 嵌入式设计讨论 > MCU和单片机设计讨论 > 请教 msp430 launchpad AD 测量峰峰值

请教 msp430 launchpad AD 测量峰峰值

时间:10-02 整理:3721RD 点击:
从网上找到一个用AD测量峰峰值的,但一直都不明白为什么 jisuan那部分要算两遍,而且按我的理解,aver那个数组每个元素都是0,怎么后来乘3.56又显示的不是0了。问题好多,希望大神给解



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

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top