找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開始

搜索
查看: 2869|回復(fù): 1
打印 上一主題 下一主題
收起左側(cè)

基于msp430F149單片機(jī)的頻測(cè)量+最高頻率12MH

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:896677 發(fā)表于 2021-12-12 10:37 | 只看該作者 回帖獎(jiǎng)勵(lì) |倒序?yàn)g覽 |閱讀模式
最高可采集到12MHZ,經(jīng)過測(cè)試精度極高,可以精確到小數(shù)點(diǎn)后三位

單片機(jī)源程序如下:
  1. /*********************************************************************
  2. 程 序 名:基于msp430F149單片機(jī)的頻率計(jì)
  3. 版   本 :PLj
  4. 時(shí)   間 :2015.11.17~2015.11.24
  5. 班   級(jí)        :電子1302班
  6. 功   能 :頻率計(jì)                                                                       
  7. 使用說明:被測(cè)信號(hào)輸入p1.0口;LCD12864顯示;頻率測(cè)量范圍:1hz~12.5MHZ;
  8.           1hz~10MHZ 誤差萬分之一以內(nèi);
  9. *********************************************************************/
  10. #include <msp430x14x.h>
  11. #include "set_clock.h"
  12. #include "lcd12864.h"
  13. #include "delay.h"

  14. #define uchar unsigned char
  15. #define uint  unsigned int

  16. uchar xianshi1[]; //  定義顯示數(shù)組
  17. long int pinlvzhi;  //  頻率計(jì)數(shù)常量
  18. int number;         //  中斷計(jì)數(shù)常量
  19. uint old_pinlvzhi,new_pinlvzhi;// 計(jì)數(shù)器原始值、計(jì)數(shù)器更新值

  20. void set_TimerA_TACTL(void);  //設(shè)置定時(shí)器A的寄存器TACTL,TAR清零,開啟溢出中斷,使用外部引腳TACLK輸入。
  21. void fenchai();               //把頻率的數(shù)值分拆放入顯示數(shù)和去掉高位為0的數(shù)值

  22. /*********************************************************************
  23. 函數(shù)名:void main()
  24. 功能:  主函數(shù);                                                                               
  25. *********************************************************************/
  26. void main()
  27. {
  28.     WDTCTL=WDTPW+WDTHOLD;
  29.     set_clock();                 //設(shè)置MSP430工作時(shí)鐘;
  30.     lcd12864_init();             //LCD12864初始化函數(shù);
  31.     set_TimerA_TACTL();          //設(shè)置定時(shí)器A的寄存器TACTL,TAR清零,開啟溢出中斷,使用外部引腳TACLK輸入。
  32.     number=0;                    //中計(jì)數(shù)常量初始化;
  33.     P1DIR=0x00;                  //P1 I/O模式為輸入;
  34.     P1SEL=0xff;                  //P1 I/O選擇第二功能;外部引腳輸入;
  35.     IE1 |= WDTIE;                //開啟看門狗定時(shí)器中斷;
  36.     _EINT();                     // 總中斷開
  37.     lcd12864_display(1,3,"測(cè)頻率");   
  38.     TACTL|=MC_2;                //連續(xù)計(jì)數(shù)模式 ;
  39.     Delay_ms(1);                //給MCU反應(yīng)時(shí)間;
  40.     WDTCTL=0x5a1c;              //看門狗定時(shí)器定時(shí)一秒(WDTPW+WDTTMSEL+WDTCNTCL+WDTSSEL);
  41.     old_pinlvzhi=TAR;           //讀取TAR計(jì)數(shù)器原始值;
  42.     while(1)
  43.     {
  44.         fenchai();
  45.         lcd12864_display(2,1,xianshi1);
  46.     }
  47. }

  48. /*********************************************************************
  49. *函數(shù)名:void set_TimerA_TACTL(void)
  50. *功  能:設(shè)置Timer_A的TACTL控制寄存器、
  51. **********************************************************************/
  52. void set_TimerA_TACTL(void)
  53. {  
  54.   TACTL|=TACLR;           //Timer_A計(jì)數(shù)器清零位
  55. /********************  選擇Timer_A的輸入時(shí)鐘源  *********************/
  56.    TACTL|=TASSEL_0;        //Timer_A時(shí)鐘源選擇:TACLK(使用外部引腳輸入)
  57.     TACTL|=TAIE;            //Timer_A溢出中斷使能允許位
  58. }
  59. /*********************************************************************/


  60. /*********************************************************************
  61. *函數(shù)名:void fenchai()
  62. *功  能:把頻率的數(shù)值分拆放入顯示數(shù)和去掉高位為0的數(shù)值
  63. **********************************************************************/
  64. void fenchai()
  65. {          xianshi1[0]=pinlvzhi/10000000+'0';  //頻率值高位
  66.           xianshi1[1]=pinlvzhi/1000000%10+'0';
  67.           xianshi1[2]=pinlvzhi/100000%10+'0';
  68.           xianshi1[3]=pinlvzhi/10000%10+'0';
  69.           xianshi1[4]=pinlvzhi/1000%10+'0';
  70.           xianshi1[5]=pinlvzhi/100%10+'0';
  71.           xianshi1[6]=pinlvzhi/10%10+'0';
  72.           xianshi1[7]=pinlvzhi%10+'0';
  73.           xianshi1[8]='H';                    //頻率值低位
  74.           xianshi1[9]='z';                    //頻率值低位
  75.           xianshi1[10]=0x20;  
  76.           xianshi1[11]=0x20;         
  77.          
  78.           if(xianshi1[0]=='0')                  //去掉最高位的0
  79.         {
  80.                 xianshi1[0]=0x20;
  81.                 if(xianshi1[1]=='0')
  82.                 {
  83.                         xianshi1[1]=0x20;
  84.                         if(xianshi1[2]=='0')
  85.                         {
  86.                                 xianshi1[2]=0x20;
  87.                                 if(xianshi1[3]=='0')
  88.                                 {
  89.                                         xianshi1[3]=0x20;
  90.                                         if(xianshi1[4]=='0')
  91.                                         {
  92.                                                 xianshi1[4]=0x20;
  93.                                                 if(xianshi1[5]=='0')
  94.                                                 {
  95.                                                         xianshi1[5]=0x20;
  96.                                                         if(xianshi1[6]=='0')
  97.                                                        {
  98.                                                             xianshi1[6]=0x20;
  99.                                                         
  100.                                                        }
  101.                                                 }
  102.                                         }
  103.                                 }
  104.                         }
  105.                 }
  106.         }  
  107. }
  108. /*********************************************************************/

  109. /********************************************************************
  110. *函數(shù)名:void set_TimerA_TACTL(void)
  111. *功  能:設(shè)置Timer_A的TACTL控制寄存器、
  112. ***************  TimerA CCR2的捕獲中斷  ****************************/
  113. #pragma vector=TIMERA1_VECTOR
  114. __interrupt void TimerA_I(void)
  115. {
  116.     switch(TAIV)
  117.         {
  118.             case 2:
  119.                     break;
  120.             case 4:
  121.                     break;
  122.             case 10:
  123.                     number++;//中斷計(jì)數(shù)常量溢出加一
  124.                     break;
  125.         }
  126. }
  127. /********************************************************************/


  128. /********************************************************************
  129. 看門狗中斷服務(wù)子程序
  130. ********************************************************************/      
  131. #pragma vector = WDT_VECTOR
  132. __interrupt void WDT_IRQ(void)
  133. {
  134.     new_pinlvzhi=TAR;//得到計(jì)數(shù)器計(jì)數(shù)后的值
  135.     if(number==0)////中斷計(jì)數(shù)常量溢小于1
  136.     {
  137.        pinlvzhi=new_pinlvzhi-old_pinlvzhi;//得到頻率值=計(jì)數(shù)器現(xiàn)在的值-計(jì)數(shù)器原始值
  138.     }
  139.     else
  140.     {
  141.       pinlvzhi=new_pinlvzhi+number*65536-old_pinlvzhi;//得到頻率值;
  142.     }   
  143.     number=0; //清零;
  144.     old_pinlvzhi=new_pinlvzhi;//把上一次計(jì)數(shù)器的計(jì)數(shù)值作為下一次的計(jì)數(shù)初值;
  145. }
  146. /*************************************END*******************************/
復(fù)制代碼

代碼下載: 代碼.7z (92.24 KB, 下載次數(shù): 18)

評(píng)分

參與人數(shù) 1黑幣 +10 收起 理由
admin + 10 共享資料的黑幣獎(jiǎng)勵(lì)!

查看全部評(píng)分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏1 分享淘帖 頂 踩1
回復(fù)

使用道具 舉報(bào)

沙發(fā)
ID:1027664 發(fā)表于 2022-5-18 20:47 | 只看該作者
牛哇,寫的很整齊。
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

手機(jī)版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表