Ⅰ 51單片機電子頻率計
建議你去"幸福校園"看看 裡面有些樣子 你可以參考
前言
傳統的數字頻率計都是採用純硬體方式組成(純數字電路)。它的集成電路(IC)用量較大,因而產品的體積、功耗都較大,生產成本較高。產品定型後不能升級(加入新功能)。而採用單片機和相關可編程智能集成器件製成的現代數字頻率計方式情況就不同了,單片機的內核CPU可完成多項工作如計數、讀入、解碼、驅動和時基的產生等。和純硬體方式比,它減少了很大一部分的集成電路的用量,還可加入許多的智能操作,這更是純硬體方式所望塵莫及的。
目前市場上的頻率計產品很多,但基本上都是採用專用計數晶元(如ICM7240 , ICM7216) 和數字邏輯電路組成,由於這些晶元本身的工作頻率不高(如ICM7240 僅有15MHz 左右) ,從而限制了產品的工作頻率的提高, 遠不能達到在一些特殊的場合需要測量很高的頻率的要求,而且測量精度也受到晶元本身極大的限制。
自從80年代單片機引入我國之後,單片機已廣泛地應用於各行各業的電子設計中,使頻率計智能化水平在廣度和深度上產生了質的飛躍,數字化也成為了電子設計的必由之路. 運用單片機和高速計數器的組合設計頻率計,並採用適當的演算法取代傳統電路,次方法不僅能解決傳統頻率計結構復雜、穩定性差、精度不高的弊端,而且性能也將大有提高,可實現精度較高、等精度和寬范圍頻率計的要求;隨著單片機技術的不斷發展,可以用單片機通過軟體設計直接用十進制數字顯示被測信號頻率。本設計正是基於此技術進行的傳統頻率計技術改進。
Ⅱ CPLD和單片機的等精度頻率計模擬怎麼做只用軟體可以模擬嗎CPLD晶元需要畫嗎
完全可以自己去做,遇到問題再問、再討論。現在根本就一點都不去想,直接要就完了。這不能怪罪於學生,而是我國教育的失敗!(當然不排除花父母錢去學校玩的,這種人也大有人在)
Ⅲ 做用51單片機做一個頻率計,測量范圍為0.1Hz~10kHz
在不改變定時時間的前提下,也就是0.5秒定時,是不能實現0.1~2Hz頻率的測量的。
你所謂2Hz~10KHz易實現也是基於這個道理。但這個也是理論情況。
當你0.5s內剛好檢測到一個脈沖,你認為這個時候是2Hz而不是2.5hz或者3.9hz?
這中間存在一個測量精度的問題。實際上你所測到的信號是在2hz到4hz之間。
實際上我們在測量信號的時候,低頻一般會採用測周期,高頻用測頻才能提高測量的准確性。
至於高低頻的臨界點,跟你的計數頻率有關,感興趣的話可以去看《電子測量原理》。
下面我來講下測周實現的方法,可以使用邊沿觸發的D觸發器輸出作為單片機的外部定時控制,測量信號作為觸發時鍾,計數值作為該信號的周期。
Ⅳ 單片機頻率計
1.實驗任務
利用51單片機的T0、T1的定時計數器功能,來完成對輸入的信號進行頻率計數,計數的頻率結果通過8位動態數碼管顯示出來。要求能夠對0-250KHZ的信號頻率進行准確計數,計數誤差不超過±1HZ。
2.電路原理圖
見插圖
3.程序設計內容
(1).定時/計數器T0和T1的工作方式設置,由圖可知,T0是工作在計數狀態下,對輸入的頻率信號進行計數,但對工作在計數狀態下的T0,最大計數值為fOSC/24,由於fOSC=12MHz,因此:T0的最大計數頻率為250KHz。對於頻率的概念就是在一秒只數脈沖的個數,即為頻率值。所以T1工作在定時狀態下,每定時1秒中到,就停止T0的計數,而從T0的計數單元中讀取計數的數值,然後進行數據處理。送到數碼管顯示出來。
(2).T1工作在定時狀態下,最大定時時間為65ms,達不到1秒的定時,所以採用定時50ms,共定時20次,即可完成1秒的定時功能。
4.C語言源程序
/******************************************************************************
*定時器+計數器測頻
*
*file:frequency.c
*name:zhzhchang
*time:2010.3.17
*V1.0
*blog:http://blog.csdn.net/zhzht19861011
*Nots:本程序定義6個數碼管,經過實測,在200HZ~50KHZ時結果較准確,誤差小於0.4%,
*50KHZ以上頻率未進行測量.據資料表明,可以測量到120KHZ,本程序未證明.
*********************************************************************************/
#include<reg52.h>
bitint_flag;//定時器01S到標志位
unsignedcharvolatileint_count;//定時器0中斷次數
unsignedcharvolatileT1count;//定時器1中斷次數
unsignedcharcodedofly[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};//顯示段碼值0123456789
unsignedlongsum;//1S內脈沖總個數
unsignedcharled[6];//LED顯示緩存
///////////////軟體延時/////////////
voiddelay(unsignedintcnt)
{
while(--cnt);
}
///定時器0初始化
voidinit_t0(void)
{
TMOD=(TMOD&0xF0)||0x01;//定時器0工作於方式1
TH0=(65536-50000)/256;//定時50ms
TL0=(65535-50000)%256;
}
//定時器1初始化
voidinit_t1(void)
{
TMOD=(TMOD&0x0F)|0x50;//timer1forcount
TH1=0x00;
TL1=0x00;
}
//顯示
voiddisp(void)
{
unsignedchari;
for(i=0;i<6;i++)
{
P0=dofly[(led[i])];//取顯示數據
P2=5-i;//取段碼
delay(100);//掃描間隙延時,根據單片機調整,延時1ms即可
}
}
///////////////////////////////////////////////////////
voidmain(void)
{
EA=1;//開總中斷
init_t0();//初始化定時器
init_t1();
TR0=1;//定時器開始工作
TR1=1;
ET0=1;//開T0中斷
while(1)
{
if(int_flag==1)
{
int_flag=0;
sum=TL1+TH1*256+T1count*65536;//計算1秒內的脈沖個數
//以下將數據格式化,轉成LED可顯示的BCD碼
led[0]=sum%10;//最低位
sum=sum/10;
led[1]=sum%10;//第二位
sum=sum/10;
led[2]=sum%10;
sum=sum/10;
led[3]=sum%10;
sum=sum/10;
led[4]=sum%10;
led[5]=sum/10;
int_count=0x00;
T1count=0;
TH1=0x00;
TL1=0x00;
TR1=1;
}
disp();
}
}
//定時器0中斷服務程序
voidint_t0(void)interrupt1
{
TH0=(65535-50000)/256;
TL0=(65535-50000)%256;
int_count++;
if(int_count==20)
{
TR1=0;
int_flag=1;
int_count=0x00;
}
}
//定時器1中斷服務程序
voidint_t1(void)interrupt3
{
T1count++;
}
別說你的設計要求用匯編啊!!!
不過既然是課程設計,我這個只是給你參考,你自己一定要弄懂,變成自己的。我實測過,程序沒問題,但用到你的硬體上可能需要改一下,因為你的硬體數碼管不一定和我的硬體接法一樣,但整體思路我都給你了。