打印

MSP430定时器A捕获功能测脉冲宽度问题

[复制链接]
1319|10
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
Stannis|  楼主 | 2018-2-23 12:26 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
MSP430F149 定时器A捕获功能测脉冲宽度 各位大神帮忙看看哪出了问题?程序:
/****测脉冲宽度并用1602显示出来****/

#include <msp430x14x.h>
#include "cry1602.c"

#define  uint     unsigned int
#define  uchar    unsigned char

uint pwm_star,pwm_end;

uint width;

uint i=0;

uchar *s="The width is :";

uchar b[]={'0','1','2','3','4','5','6','7','8','9'};

uint m,n,p,q;

void main(void)

{
    WDTCTL=WDTPW+WDTHOLD;
   
    P6DIR |= BIT2;P6OUT |= BIT2;        //关闭电平转换
   
    P6DIR |= BIT3;P6OUT |= BIT3;        
   
    BCSCTL1 &= ~XT2OFF;                 //打开XT2高频晶体振荡器
    do
    {
        IFG1 &= ~OFIFG;                 //清除晶振失败标志
        for (i = 0xFF; i > 0; i--);     //等待8MHz晶体起振
    }
    while ((IFG1 & OFIFG));             //晶振失效标志仍然存在?
    BCSCTL2 |= SELM_2 + SELS;           //MCLK和SMCLK选择高频晶振
   
    P1DIR|=BIT2;
    P1SEL|=BIT2;   //捕获源为P1.2
   
    TACTL=TACLR;   //定时器清零
    TACTL |= TASSEL_2 + ID_3; //计数时钟选择SMLK=8MHz,1/8分频后为1MHz
   
    TACCTL1 =CM_3+SCS+CAP+CCIS_0+CCIE; //上升沿下降沿都同步捕获
      
    TACTL = MC_2; //定时器计数开始 连续计数模式
   
    _EINT();
   
    LcdReset();
   
    DispStr(0,0,s);     
     
   while(1)
    {           
   
     m=width/1000;
     n=(width/100)%10;
     p=(width/10)%10;
     q=width%10;
   
     Disp1Char(4,1,b[m]);
     Disp1Char(5,1,b[n]);
     Disp1Char(6,1,b[p]);
     Disp1Char(7,1,b[q]);
     
    }
}
   
/******定时器TA的CCR1的中断 用于检测脉冲上升沿和下降沿******/

#pragma vector=TIMERA1_VECTOR
__interrupt void Timer_A1(void)
{
  switch(TAIV)
  { case 0x02:
            if(CCI==1)
            {
              pwm_star = TACCR1;
              break;
            }
            else
            {
              pwm_end = TACCR1;
              break;
            }
         
         default:
            break;
  }
  
  width = pwm_end-pwm_star;
   
}

相关帖子

沙发
Brand2| | 2018-2-23 12:39 | 只看该作者
为什么你要用TACCR1而不是TA0R?

使用特权

评论回复
板凳
Soraka| | 2018-2-23 13:42 | 只看该作者
哪个在计数,到底是哪个才能确定时间?怎么确定你三次捕获的上升沿和下降沿和上升沿,或者下降沿和上升沿和下降沿是紧紧的靠在一起的而没有错位,而不是第一个上升沿和第二个下降沿和第三个上升沿

使用特权

评论回复
地板
Garen2| | 2018-2-23 13:49 | 只看该作者
单片机的捕获也不是100%的准确,如何减小误差就需要好好思考

使用特权

评论回复
5
Ryze| | 2018-2-23 13:57 | 只看该作者
在捕获模式,当满足捕获条件时,硬件不是自动将计数器TAR中的数据写到TACCRx中吗?

使用特权

评论回复
6
Varus| | 2018-2-23 14:07 | 只看该作者
关于减小误差,建议你试试状态机

使用特权

评论回复
7
Snow7| | 2018-2-23 14:39 | 只看该作者
输入的方波必须要满足3V到5V的峰峰值,如果给我500mv的信号,肯定是捕获不到的,再者就是看中断是不是进去了,怎么看

使用特权

评论回复
8
android2| | 2018-2-23 14:46 | 只看该作者
参考一下
#pragma vector = TIMER0_A1_VECTOR
__interrupt void TIMER0_A1_ISR (void)
{
  switch(__even_in_range(TA0IV,0x0A))
  {
      case  TA0IV_NONE: break;              // Vector  0:  No interrupt
      case  TA0IV_TACCR1:                   // Vector  2:  TACCR1 CCIFG
        if (TA0CCTL1 & CCI)                 // Capture Input Pin Status
        {
            // Rising Edge was captured
            if (!Count)
            {
                REdge1 = TA0CCR1;
                Count++;
            }
            else
            {
                REdge2 = TA0CCR1;
                Count=0x0;
                __bic_SR_register_on_exit(LPM0_bits + GIE);  // Exit LPM0 on return to main
            }

            if (First_Time)
                First_Time = 0x0;
        }
        else
        {
            // Falling Edge was captured
            if(!First_Time)
            {
                FEdge = TA0CCR1;
            }
        }
        break;
      case TA0IV_TACCR2: break;             // Vector  4:  TACCR2 CCIFG
      case TA0IV_6: break;                  // Vector  6:  Reserved CCIFG
      case TA0IV_8: break;                  // Vector  8:  Reserved CCIFG
      case TA0IV_TAIFG: break;              // Vector 10:  TAIFG
      default:         break;
  }
}

使用特权

评论回复
9
拉克丝| | 2018-2-23 14:56 | 只看该作者
楼主这个程序完善了吗,可不可以解析一下啊

使用特权

评论回复
10
lefeng| | 2018-2-23 15:07 | 只看该作者
楼主这段程序好像并没有计脉冲数啊~

使用特权

评论回复
11
baimiaocun2015| | 2018-2-23 23:59 | 只看该作者
定时器的脉冲捕获功能的很不错的

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

176

主题

721

帖子

1

粉丝