計數器課程設計
1. 產品成品計數器課程設計
你不會也是銅陵學院的吧?
2. 單片機課程設計,製作一個手動加計數器。
#include<reg51.h> sbit key1=P3^5; unsigned char XX[6]={0xa4,0Xb0,0X99,0x92,0x82,0Xf8}; unsigned char i=0; /****************延時程序******************/ void delay(unsigned int x) // 延時子函數 { unsigned int i,k; // 變數定專義 for(i=x;i>0;i--) // for語句循環體 for(k=125;k>0;k--); } /************開關控制屬程序********************/ key() { if(key1==0) { delay(10); if(key1==0) { i++; if(i>5)i=0; while(key1==0); } } } /************主函數********************/ void main(void) { P0=i; while(1) { key(); //調用開關程序 P0=XX[i]; delay(10); } }
3. 課程設計題目:電子計數器
單片機C51計數器要求:編寫一個計數器程序,將T0作為計數器來使用,對外部信號計數,將所計數字顯示在數碼管上。
該部分的硬體電路如圖所示,U1的P0口和P2口的部份引腳構成了6位LED數碼管驅動電路,數碼管採用共陽型,使用PNP型三極體作為片選端的驅動,所有三極體的發射極連在一起,接到正電源端,它們的基極則分別連到P2.0…P2.5,當P2.0…P2.5中某引腳輸是低電平時,三極體導通,給相應的數碼管供電,該位數碼管點亮哪些筆段,則取決於筆段引腳是高或低電平。圖中看出,所有6位數碼管的筆段連在一起,通過限流電阻後接到P0口,因此,哪些筆段亮就取決於P0口的8根線的狀態。
編寫程序時,首先根據硬體連線寫出LED數碼管的字形碼、位驅動碼,然後編寫程序如下:
#include "reg51.h"#define uchar unsigned char#define uint unsigned int uchar code BitTab[]={0x7F,0xBF,0xDF,0xEF,0xF7,0xFB};//位驅動碼uchar code DispTab[]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0x88,0x83,0xC6,0xA1,0x86,0x8E,0xFF};//字形碼uchar DispBuf[6]; //顯示緩沖區 void Timer1() interrupt 3{ uchar tmp;uchar Count; //計數器,顯示程序通過它得知現正顯示哪個數碼管TH1=(65536-3000)/256;TL1=(65536-3000)%256; //重置初值tmp=BitTab[Count]; //取位值P2=P2|0xfc; //P2與11111100B相或P2=P2&tmp; //P2與取出的位值相與tmp=DispBuf[Count];//取出待顯示的數 tmp=DispTab[tmp]; //取字形碼P0=tmp;Count++;if(Count==6)Count=0; }void main(){ uint tmp;P1=0xff;P0=0xff;TMOD=0x15; //定時器0工作於計數方式1,定時器1工作於定時方式1TH1=(65536-3000)/256;TL1=(65536-3000)%256; //定時時間為3000個周期TR0=1; //計數器0開始運行TR1=1;EA=1;ET1=1;for(;;){ tmp=TL0|(TH0<<8);//取T0中的數值DispBuf[5]=tmp%10;tmp/=10;DispBuf[4]=tmp%10; tmp/=10;DispBuf[3]=tmp%10;tmp/=10;DispBuf[2]=tmp%10;DispBuf[1]=tmp/10;DispBuf[0]=0;}} 這個程序中用到了一個新的知識點,即數組,首先作一個介紹。 數組是C51的一種構造數據類型,數組必須由具有相同數據類型的元素構成,這些數據的類型就是數組的基本類型,如:數組中的所有元素都是整型,則該數組稱為整型數組,如所有元素都是字元型,則該數組稱為字元型數組。 數組必須要先定義,後使用,這里僅介紹一維數組的定義,其方式為: 類型說明符數組名[整型表達式] 定義好數組後,可以通過:數組名[整型表達式]來使用數組元素。 在定義數組時,可以對數組進行初始化,即給其賦予初值,這可用以下的一些方法實現:
1.在定義數組時對數組的全部元素賦予初值:例:int a[5]={1,2,3,4,5};
2.只對數組的部分元素初始化;例:int a[5]={1,2}; 上面定義的a數組共有5個元素,但只對前兩個賦初值,因此a[0]和a[1]的值是1、2,而後面3個元素的值全是0。
3.在定義數組時對數組元素的全部元素不賦初值,則數組元素值均被初始化為0
4.可以在定義時不指明數組元素的個數,而根據賦值部分由編譯器自動確定例:uchar BitTab[]={0x7F,0xBF,0xDF,0xEF,0xF7,0xFB};則相當於定義了一個BitTab[6]這樣一個數組。
5.可以為數組指定存儲空間,這個例子中,未指定空間時,將數組定義在內部RAM中,可以用code關鍵字將數組元素定義在ROM空間中。uchar code BitTab[]={0x7F,0xBF,0xDF,0xEF,0xF7,0xFB}; 用這兩種定義分別編譯,可以看出使用了code關鍵字後系統佔用的RAM數減少了,這種方式用於編程中不需要改變內容的場合,如顯示數碼管的字形碼等是很合適的。
6.C語言並不對越界使用數組進行檢測,例如上例中數組的長度是6,其元素應該是從BitTab[0]~BitTab[5],但是如果你在程序中寫上BitTab[6],編譯器並不會認為這有語法錯誤,也不會給出警告(其他語言如BASCI等則有嚴格的規定,這種情況將視為語法錯誤),因此,編程者必須自己小心確認這是否是你需要的結果。
程序分析:程序中將定時器T1用作數碼管顯示,通過interrupt 3關鍵字定義函數Timer1()為定時器1中斷服務程序,在這個中斷服務程序中,使用 TH1=(65536-3000)/256;TL1=(65536-3000)%256;
來重置定時器初值,這其中3000即為定時周期,這樣的寫法可以直觀地看到定時周期數,是常用的一種寫法。其餘程序段分別完成取位碼以選擇數碼管、從顯示緩沖區獲得待顯示數值、根據該數值取段碼以點亮相應筆段等任務。其中使用了一個計數器,該計數器的值從0~5對應第1到第6位的數碼管。
主程序的第一部分是做一些初始化的操作,設置定時器工作模式、開啟定時器T1、開啟計數器T0、開啟T1中斷及總中斷,隨後進入主循環,主循環首先用unsigned int型變數tmp取出T0中的數值,這里使用了「tmp=TL0|(TH0<<8);」這樣的形式,這相當於tmp=TH0*256+TL0,但比之於後一種形式,該方式可以得到更高的效,其後就是將tmp值不斷地除10取整,這樣將int型數據的各位分離並送入相應的顯示緩沖區
4. 數字邏輯課程設計-12分鍾倒計時計數器。
我剛好有你要的,現成的,。拿去參考,是姐姐自己的
數字邏輯課程設計-12分鍾倒計時計數器。
5. 機電控制與plc應用課程設計(計數器 光電開關)
你沒有用上升沿指令。你必須要用上升沿指令才能只計數一次。因為光電開關導通一次的時間里,實際上CPU已經執行了幾個掃描周期了,所以這個計數其實是光電開關導通時間里掃描周期的執行個數。
6. 求EDA頻率計數器課程設計報告
EDA技術是以大規模可編程邏輯器件為設計載體,以硬體語言為系統邏輯描述的主要方式,以計算機、大規模可編程邏輯器件的開發軟體及實驗開發系統為設計工具,通過有關的開發軟體,自動完成用軟體設計的電子系統到硬體系統的設計,最終形成集成電子系統或專用集成晶元的一門新技術。其設計的靈活性使得EDA技術得以快速發展和廣泛應用。
本文以Max+PlusⅡ軟體為設計平台,採用VHDL語言實現數字頻率計的整體設計。
1 工作原理
眾所周知,頻率信號易於傳輸,抗干擾性強,可以獲得較好的測量精度。因此,頻率檢測是電子測量領域最基本的測量之一。頻率計的基本原理是用一個頻率穩定度高的頻率源作為基準時鍾,對比測量其他信號的頻率。通常情況下計算每秒內待測信號的脈沖個數,即閘門時間為1 s。閘門時間可以根據需要取值,大於或小於1 s都可以。閘門時間越長,得到的頻率值就越准確,但閘門時間越長,則每測一次頻率的間隔就越長。閘門時間越短,測得的頻率值刷新就越快,但測得的頻率精度就受影響。一般取1 s作為閘門時間。
數字頻率計的關鍵組成部分包括測頻控制信號發生器、計數器、鎖存器、解碼驅動電路和顯示電路,其原理框圖如圖1所示。
2 設計分析
2.1 測頻控制信號發生器
測頻控制信號發生器產生測量頻率的控制時序,是設計頻率計的關鍵。這里控制信號CLK取為1 Hz,2分頻後就是一個脈寬為1 s的時鍾信號FZXH,用來作為計數閘門信號。當FZXH為高電平時開始計數;在FZXH的下降沿,產生一個鎖存信號SCXH,鎖存數據後,還要在下次FZXH上升沿到來之前產生清零信號CLEAR,為下次計數做准備,CLEAR信號是上升沿有效。
2.2 計數器
計數器以待測信號FZXH作為時鍾,在清零信號CLEAR到來時,非同步清零;FZXH為高電平時開始計數。本文設計的計數器計數最大值是99 999 999。2.3 鎖存器
當鎖存信號SCXH上升沿到來時,將計數器的計數值鎖存,這樣可由外部的七段解碼器解碼並在數碼管上顯示。設置鎖存器的好處是顯示的數據穩定,不會由於周期性的清零信號而不斷閃爍。鎖存器的位數應跟計數器完全一樣,均是32位。
2.4 解碼驅動電路
本文數碼管採用動態顯示方式,每一個時刻只能有一個數碼管點亮。數碼管的位選信號電路是74LS138晶元,其8個輸出分別接到8個數碼管的位選;3個輸入分別接到EPF10K10LC84-4的I/O引腳。
2.5 數碼管顯示
本文採用8個共陰極數碼管來顯示待測頻率的數值,其顯示範圍從O~ 以下是數碼管段選的程序:
2.6 程序
綜合以上模塊分析,可以得到如下程序:3 結 語
本文採用EDA設計方法,把數字頻率計系統組建分解成若干個功能模塊進行設計描述,選用Altera公司生產的FPGA產品FLEX10K系列的EPF10K10LC84-4晶元,下載適配後,便可以在數碼管上顯示出待測頻率的數值。實驗證明,其軟體設計思想清晰,硬體電路簡單,具有一定的實用性。
7. 求光敏計數器mistisim10設計圖課程設計。 要求完成光敏電阻計數器的詳細
計數原理:利用光敏電阻,在受光照前後的電阻的不同,產生電脈沖,送入計數器進行計數。
關於這個建議去硬之城官網看看哦,能快速解決問題 服務態度又好這個很多地方都做不到的。
8. 單片機課程設計,產品計數器
51單片機,模擬設計,
懂事電子設計 Vgz