搜索
bottom↓
回复: 0

求原因?AVR16捕获调试的原因。TIMER1输入捕获频率计例程

[复制链接]

出0入4汤圆

发表于 2014-2-20 16:33:46 | 显示全部楼层 |阅读模式
本帖最后由 SCREA 于 2014-2-20 16:35 编辑

求怎么回事,第1、3、4个频率正常,唯独频率从1K到5K左右不正常
  1. //-----------------------------------------------------------------
  2. //  名称: 用TIMER1输入捕获功能设计的频率计
  3. //-----------------------------------------------------------------
  4. //  说明: 本例运行时,切换不同的频率输入,然后按下K1按键,数码管上将
  5. //        显示当前频率值.两次捕获的时间差值即为当前输入频率的周期,
  6. //        周期倒数即可得到当前频率.
  7. //
  8. //-----------------------------------------------------------------
  9. #define  F_CPU  1000000UL //1M晶振
  10. #include <avr/io.h>
  11. #include <avr/interrupt.h>
  12. #include <util/delay.h>
  13. #define INT8U   unsigned char
  14. #define INT16U  unsigned int

  15. //共阴数码管0-9的数字编码,最后一位为黑屏
  16. const INT8U SEG_CODE[] =
  17. {0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x00};

  18. //分解后的待显示数位
  19. INT8U Display_Buffer[] = {0,0,0,0};

  20. //连续两次捕获计数变量
  21. INT16U CAPi=0,CAPj=0;

  22. volatile        INT16U Buffer[6] = {0};
  23. volatile  unsigned long SS = 0;
  24. volatile INT8U j=0;
  25. //-----------------------------------------------------------------
  26. // 数码管显示频率
  27. //-----------------------------------------------------------------
  28. void Show_FRQ_ON_DSY()
  29. {
  30.         INT8U i=0;
  31.         for( i =0;i<4;i++)
  32.         {
  33.                 PORTB = ~_BV(i);
  34.                 PORTA = SEG_CODE[ Display_Buffer[i] ];
  35.                 if(i==0)PORTA |= 0x80;       
  36.                 _delay_ms(2);               
  37.         }
  38. }

  39. //------------------------------------------------------------------
  40. // 主程序
  41. //------------------------------------------------------------------
  42. int main()
  43. {
  44.         INT8U LastKey = 0xff;
  45.         DDRA = 0xff;       
  46.         DDRB = 0xff;       
  47.         DDRC = 0x00;        PORTC = 0xff;
  48.         DDRD = 0x00;        PORTD = 0xff;

  49.         TCCR1B = _BV(ICNC1) | _BV(ICES1);  //输入捕获噪声音消除,ICP上升沿触发捕获,分频系数1(1MHz,1us触发一次)
  50.         sei();
  51.         while(1)
  52.         {
  53.                 if( LastKey != PINC)
  54.                 {
  55.                         TIMSK = _BV(TICIE1);
  56.                         TCCR1B |= 0x01;
  57.                         LastKey = PINC;
  58.                 }
  59.                 Show_FRQ_ON_DSY();
  60.         }

  61. }

  62. //------------------------------------------------------------------
  63. // T1输入捕获中断子程序
  64. //------------------------------------------------------------------
  65. ISR (TIMER1_CAPT_vect)
  66. {
  67.         INT8U i,k;
  68.         INT16U temp=0;
  69.         if(CAPi == 0 )CAPi = ICR1;
  70.         else
  71.         {
  72.                 CAPj = ICR1 - CAPi;
  73.                 Buffer[j] =1000000UL/ CAPj;
  74.                 j++;
  75.                 if(j==6)
  76.                 {
  77.                         j=0;
  78.                         TIMSK = 0x00;
  79.                         TCCR1B &= 0xf8;
  80.                         for(k=0;k<6;k++)                                                //采样6次,取中间4个值求平均
  81.                         {
  82.                                 for(i=0;i<5-k;i++)
  83.                                 {
  84.                                         if(Buffer[i]>Buffer[i+1])
  85.                                         {
  86.                                                 temp = Buffer[i];
  87.                                                 Buffer[i] = Buffer[i+1];
  88.                                                 Buffer[i+1] = temp;       
  89.                                         }
  90.                                 }       
  91.                         }
  92.                         SS = (Buffer[1] + Buffer[2] + Buffer[3]+ Buffer[4] )/4;
  93.                         for(i=3;i!= 0xff;i--)
  94.                         {
  95.                                 Display_Buffer[i] = SS%10;
  96.                                 SS /= 10;
  97.                         }
  98.                 }
  99.                 TCNT1 = CAPi = CAPj = 0;
  100.         }


  101. }
复制代码

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有帐号?注册

x

阿莫论坛20周年了!感谢大家的支持与爱护!!

曾经有一段真挚的爱情摆在我的面前,我没有珍惜,现在想起来,还好我没有珍惜……
回帖提示: 反政府言论将被立即封锁ID 在按“提交”前,请自问一下:我这样表达会给举报吗,会给自己惹麻烦吗? 另外:尽量不要使用Mark、顶等没有意义的回复。不得大量使用大字体和彩色字。【本论坛不允许直接上传手机拍摄图片,浪费大家下载带宽和论坛服务器空间,请压缩后(图片小于1兆)才上传。压缩方法可以在微信里面发给自己(不要勾选“原图),然后下载,就能得到压缩后的图片。注意:要连续压缩2次才能满足要求!!】。另外,手机版只能上传图片,要上传附件需要切换到电脑版(不需要使用电脑,手机上切换到电脑版就行,页面底部)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

手机版|Archiver|amobbs.com 阿莫电子技术论坛 ( 粤ICP备2022115958号, 版权所有:东莞阿莫电子贸易商行 创办于2004年 (公安交互式论坛备案:44190002001997 ) )

GMT+8, 2024-8-26 17:28

© Since 2004 www.amobbs.com, 原www.ourdev.cn, 原www.ouravr.com

快速回复 返回顶部 返回列表