當前位置:首頁 » 課程大全 » EDA數字跑表課程設計程序流程圖

EDA數字跑表課程設計程序流程圖

發布時間: 2021-02-10 08:57:06

A. EDA設計 數字跑表 希望有電路圖(設計圖 原件名稱 波形圖)使用Quartus II 設計操作 100分

數字周期測量器?
你可以先產生一個1s的門控信號,在這一秒內對測量信號的脈沖計數
這樣可以得到測量信號的頻率,有了頻率周期就好說了。

B. 急求EDA數字鍾設計程序,我有原理圖

功 能: 數碼管顯示的電子鍾
;------------------------------------------------------------------------------
ORG 0000H
AJMP START

ORG 000BH
AJMP TIME

ORG 0100H
START: MOV 30H, #00H ;半秒標志
MOV 31H, #00H ;狀態標志,0FFH表示設置狀態
MOV 32H, #00H ;閃爍顯示控制,位為0對應的數碼管
;在調時狀態下時閃爍
MOV 20H, #00H ;1/20秒計數
MOV 21H, #00H ;秒計數
MOV 22H, #00H ;分計數
MOV 23H, #00H ;時計數

MOV IP, #02H ;IP,IE初始化
MOV IE, #82H
MOV TMOD, #01H ;設定定時器工作方式
MOV TL0, #0B0H ;定時器初值
MOV TH0, #3CH
SETB TR0 ;啟動定時器0
MOV SP, #40H ;重設堆棧指針

MAIN: LCALL DISP ;調用顯示子程序
LCALL KEYPR ;調用按鍵處理子程序
SJMP MAIN ;循環

;定時器0中斷處理程序
TIME: PUSH ACC ;保護現場
PUSH PSW
MOV TL0, #0B4H ;賦定時初值
MOV TH0, #03CH
INC 20H ;1/20秒計數器加1
MOV A, 20H
CJNE A, #10, IRET ;未到半秒,返回
MOV 20H, #00H
MOV A, 30H ;修改半秒標志
CPL A
MOV 30H, A
JZ IRET
MOV A, 31H ;狀態標志,為0FFH停止計時
JNZ IRET
MOV 20H, #00H ;一秒鍾時間到
MOV A, 21H ;秒加1
INC A
MOV 21H, A
CJNE A, #60, IRET
MOV 21H, #00H ;一分鍾時間到
MOV A, 22H ;分加1
INC A
MOV 22H, A
CJNE A, #60, IRET
MOV 22H, #00H ;一小時時間到
MOV A, 23H ;小時加1
INC A
MOV 23H, A
CJNE A, #24, IRET
MOV 23H, #00H ;24小時到,小時清零
IRET: POP PSW ;恢復現場
POP ACC
RETI ;中斷返回

;顯示子程序 ;顯示緩沖區2AH - 2FH
DISP: MOV A, 21H ;處理秒 21H-->2FH,2EH
MOV B, #10
DIV AB
MOV 2FH, B
MOV 2EH, A
MOV A, 22H ;處理分鍾22H-->2CH,2DH
MOV B, #10
DIV AB
MOV 2DH, B
MOV 2CH, A
MOV A, 23H ;處理小時23H-->2AH,2BH
MOV B, #10
DIV AB
MOV 2BH, B
MOV 2AH, A

MOV DPTR, #DISPTAB ;段碼表首地址
MOV R0, #2AH ;緩沖區首地址
MOV R6, #20H ;數碼管位選擇
DISP1: MOV A, @R0
MOVC A, @A+DPTR
MOV P2, #00H
MOV B, A
MOV A, 30H ;半秒標志
JNZ VIS1 ;半秒標志不為0,處理閃爍
MOV A, B
JMP VIS3 ;半秒標志為0,不處理閃爍
VIS1: MOV A, B
MOV B, A
MOV A, R6
ANL A, 32H
JNZ VIS2 ;當前位不閃爍
MOV A, #00H ;當前位閃爍
JMP VIS3
VIS2: MOV A, B
VIS3: MOV B, A
MOV A, R6
ANL A, #14H ;處理點的位置,點用來分隔時,分,秒
JNZ D1 ;顯示點
MOV A, B
JMP D2 ;不顯示點
D1: MOV A, B
ORL A, #80H ;顯示點
D2: MOV P0, A
MOV P2, R6
CALL DELAY ;延時
DISP2: INC R0
MOV A, R6
RRC A
MOV R6, A
JNZ DISP1 ;R6不為0,繼續顯示
MOV P2, #00H
RET

;按鍵判斷程序
KEYPR: SETB P3.5 ;檢測S31
JB P3.5, EXITKEY
LCALL DISP
JB P3.5, EXITKEY
MOV 21H, #00H ;進入設定狀態
MOV 31H, #0FFH
MOV 32H, #33H
KW1: LCALL DISP
JNB P3.5, KW1
SETMIN: LCALL DISP
SETB P3.5
JB P3.5, SETMIN1
LCALL DISP
JB P3.5, SETMIN1
KW2: LCALL DISP
JNB P3.5, KW2
JMP SETHR ;進入小時設定狀態
SETMIN1:SETB P3.6 ;設定分鍾
JB P3.6, SETMIN
LCALL DISP
JB P3.6, SETMIN
KW3: LCALL DISP
JNB P3.6, KW3
MOV A, 22H
INC A
CJNE A, #60, INCMIN
MOV A, #00H
INCMIN: MOV 22H, A
JMP SETMIN
SETHR: MOV 32H, #0FH
LCALL DISP
SETB P3.5
JB P3.5, SETHR1
LCALL DISP
JB P3.5, SETHR1
KW4: LCALL DISP
JNB P3.5, KW4
JMP EXITKEY ;退出設定狀態
SETHR1: SETB P3.6 ;設定小時
JB P3.6, SETHR
LCALL DISP
JB P3.6, SETHR
KW5: LCALL DISP
JNB P3.6, KW5
MOV A, 23H
INC A
CJNE A, #24, INCHR
MOV A, #00H
INCHR: MOV 23H, A
JMP SETHR
EXITKEY:MOV 31H, #00H
MOV 32H, #3FH
RET

DELAY: MOV R7, #0FFH
DJNZ R7, $
RET

;共陰數碼管顯示代碼,最低位對應段a
;0,1,2,3,4,5,6,7,8,9
DISPTAB:DB 3FH, 06H, 5BH, 4FH, 66H
DB 6DH, 7DH, 07H, 7FH, 6FH

END

C. EDA數字跑表具體設計方法 以及組成電路講解

幫你組成電路

D. 求用VHDL語言編寫一個數字跑表程序

http://blog.csdn.net/wangjun403/article/details/6269258
參考下

E. 求eda數字鍾設計程序

1.Topclock(元件例化 頂層文件)
Library ieee;
Use ieee.std_logic_1164.all;
Use ieee.std_logic_arith.all;
Use ieee.std_logic_unsigned.all;
Entity topclock is
Port(clk,clr,en,m1,h1:in std_logic;
alarm:out std_logic;
secs,secg,mins,ming,hours,hourg:buffer std_logic_vector(3 downto 0));
End;
2. 秒模塊程序
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
entity SECOND is
port(clk,clr:in std_logic;
sec1,sec0:out std_logic_vector(3 downto 0);
co:out std_logic);
end SECOND;

architecture SEC of SECOND is
begin
process(clk,clr)
variable cnt1,cnt0:std_logic_vector(3 downto 0);
begin
if clr='1' then
cnt1:="0000";
cnt0:="0000";
elsif clk'event and clk='1' then
if cnt1="0101" and cnt0="1000" then
co<='1';
cnt0:="1001";
elsif cnt0<"1001" then
cnt0:=cnt0+1;
else
cnt0:="0000";

if cnt1<"0101" then
cnt1:=cnt1+1;
else
cnt1:="0000";
co<='0';
end if;
end if;
end if;
sec1<=cnt1;
sec0<=cnt0;

end process;
end SEC;

3.分模塊程序
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
entity MINUTE is
port(clk,en:in std_logic;
min1,min0:out std_logic_vector(3 downto 0);
co:out std_logic);
end MINUTE;

architecture MIN of MINUTE is
begin
process(clk)
variable cnt1,cnt0:std_logic_vector(3 downto 0);
begin
if clk'event and clk='1' then
if en='1' then
if cnt1="0101" and cnt0="1000" then
co<='1';
cnt0:="1001";
elsif cnt0<"1001" then
cnt0:=cnt0+1;
else
cnt0:="0000";

if cnt1<"0101" then
cnt1:=cnt1+1;
else
cnt1:="0000";
co<='0';
end if;
end if;
end if;
end if;
min1<=cnt1;
min0<=cnt0;

end process;
end MIN;

4.時模塊程序

library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
entity HOUR is
port(clk,en:in std_logic;
h1,h0:out std_logic_vector(3 downto 0));
end HOUR;

architecture hour_arc of HOUR is
begin
process(clk)
variable cnt1,cnt0:std_logic_vector(3 downto 0);
begin
if clk'event and clk='1' then
if en='1' then
if cnt1="0010" and cnt0="0011" then
cnt1:="0000";
cnt0:="0000";
elsif cnt0<"1001" then
cnt0:=cnt0+1;
end if;
end if;
end if;
h1<=cnt1;
h0<=cnt0;

end process;
end hour_arc;

----5.掃描模塊程序

library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
use ieee.std_logic_arith.all;
entity SELTIME is
port(
clk:in std_logic;
sec1,sec0,min1,min0,h1,h0:in std_logic_vector(3 downto 0);
ut:out std_logic_vector(3 downto 0);
sel:out std_logic_vector(2 downto 0));
end SELTIME;
architecture fun of SELTIME is
signal count:std_logic_vector(2 downto 0);
begin
sel<=count;
process(clk)
begin
if(clk'event and clk='1') then
if(count>="101") then
count<="000";
else
count<=count+1;
end if;
end if;
case count is
when"000"=>ut<= sec0;
when"001"=>ut<= sec1;
when"010"=>ut<= min0;
when"011"=>ut<= min1;
when"100"=>ut<=h0;
when others =>ut<=h1;
end case;
end process;
end fun;

6.顯示模塊程序

library ieee;
use ieee.std_logic_1164.all;
entity DISPLAY is
port(d:in std_logic_vector(3 downto 0);
q:out std_logic_vector(6 downto 0));
end DISPLAY;
architecture disp_are of DISPLAY is
begin
process(d)
begin

case d is
when"0000" =>q<="0111111";
when"0001" =>q<="0000110";
when"0010" =>q<="1011011";
when"0011" =>q<="1001111";
when"0100" =>q<="1100110";
when"0101" =>q<="1101101";
when"0110" =>q<="1111101";
when"0111" =>q<="0100111";
when"1000" =>q<="1111111";
when others =>q<="1101111";
end case;
end process;
end disp_are;

-----7.定時鬧鍾模塊程序

library ieee;
use ieee.std_logic_1164.all;
entity ALERT is
port(m1,m0,s1,s0:in std_logic_vector(3 downto 0);
clk:in std_logic;
q500,qlk:out std_logic);
end ALERT;

architecture sss_arc of ALERT is
begin
process(clk)
begin

if clk'event and clk='1' then
if m1="0101" and m0="1001" and s1="0101" then
if s0="0001" or s0="0011" or s0="0101" or s0="0111" then
q500<='1';
else
q500<='0';
end if;
end if;

if m1="0101" and m0="1001" and s1="0101" and s0="1001" then
qlk<='1';
else
qlk<='0';
end if;
end if;
end process;
end sss_arc;
Architecture one of topclock is
Component second1
Port( clks,clr:in std_logic;
secs,secg: buffer std_logic_vector(3 downto 0);
cout1: out std_logic);
End Component;
Component min1
Port(clkm,clr:in std_logic;
mins,ming:buffer std_logic_vector(3 downto 0);
enmin,alarm: out std_logic);
End Component;
Component hour1
Port(clkh,clr:in std_logic;
hours,hourg:buffer std_logic_vector(3 downto 0));
End Component;
Component madapt
Port(en,m1,clk,secin:in std_logic;
minset:out std_logic);
End Component;
Component hadapt
Port(en,h1,clk,minin:in std_logic;
hourset:out std_logic);
End Component;
signal a,b,c,d: std_logic;
begin
u1:second1 port map(clr=>clr,
secs=>secs,secg=>secg,clks=>clk, cout1=>a);
u2:min1 port map(clr=>clr,alarm=>alarm,
mins=>mins,ming=>ming,clkm=>b,enmin=>c);
u3:hour1 port map(clr=>clr,
hours=>hours,hourg=>hourg,clkh=>d);
u4:madapt port map(en=>en,m1=>m1,clk=>clk,secin=>a,minset=>b);
u5:hadapt port map(en=>en,h1=>h1,clk=>clk,minin=>c,hourset=>d);
end;

F. 求EDA數字秒錶(顯示99秒)設計 0~99,99~0,的程序

自己修改下,使其符合版你所需的要求
library ieee;
use ieee.std_logic_1164.all;
use ieee.std_logic_unsigned.all;
entity year is
port(clk:in std_logic;
權y1,y2:out std_logic_vector(3 downto 0));
end year;
architecture one of year is
signal q1,q2:std_logic_vector(3 downto 0);
begin
process(clk)
begin
if clk'event and clk='1' then
q1<=q1+1;
if q1=9 then q1<=(others=>'0');
q2<=q2+1;
end if;
if q2=9 and q1=9 then
q2<="0000";q1<="0000";cout<='1';
else cout<='0';
end if;
end if;
y1<=q1;y2<=q2;
end process;
end;

G. 課程設計EDA誰能幫我做一個EDA的簡易cpu課程設計,要程序,波形圖,和block框圖

EDA是電子設計自動化(Electronic Design Automation)的縮寫,在20世紀60年代中期從計算機輔助設計(CAD)、計算機輔助製造(CAM)、計算機輔助測試(CAT)和計算機輔助工程(CAE)的概念發展而來的。
20世紀90年代,國際上電子和計算機技術較為先進的國家,一直在積極探索新的電子電路設計方法,並在設計方法、工具等方面進行了徹底的變革,取得了巨大成功。在電子技術設計領域,可編程邏輯器件(如CPLD、FPGA)的應用,已得到廣泛的普及,這些器件為數字系統的設計帶來了極大的靈活性。這些器件可以通過軟體編程而對其硬體結構和工作方式進行重構,從而使得硬體的設計可以如同軟體設計那樣方便快捷。這一切極大地改變了傳統的數字系統設計方法、設計過程和設計觀念,促進了EDA技術的迅速發展。
EDA技術就是以計算機為工具,設計者在EDA軟體平台上,用硬體描述語言VHDL完成設計文件,然後由計算機自動地完成邏輯編譯、化簡、分割、綜合、優化、布局、布線和模擬,直至對於特定目標晶元的適配編譯、邏輯映射和編程下載等工作。EDA技術的出現,極大地提高了電路設計的效率和可操作性,減輕了設計者的勞動強度。

H. eda進行秒錶設計程序

;**** IC=AT89S52 F=12MHz T=1uS *****************************************
;**** WRITER:COCO.LI *************
; 定時器、T1溢出周期為50MS(10MS),T0為秒計數用,T1為調整時閃爍用,
;**** P1.0、P1.1、P1.2為調整按鈕,P0口為字元輸出口,採用共陽顯示管。
;********** 中斷程序入口 ****************
ORG 0000H ;程序執行開始地址
LJMP START ;跳到標號START執行
ORG 0003H ;外中斷0中斷程序入口
RETI ;外中斷0中斷返回
ORG 000BH ;定時器T0中斷程序入口
LJMP INTT0 ;跳到標號INTT0執行
ORG 0013H ;外中斷1中斷程序入口
RETI ;外中斷1中斷返回
ORG 001BH ;定時器T1中斷程序入口
LJMP INTT1 ;跳到標號INTT1執行
ORG 0023H ;串列口中斷程序入口
RETI ;串列口中斷程序返回
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; 主程序 ;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
ORG 0030H ;
START:LCALL ST ;上電顯示年月日及班級學號
MOV R0,#70H ;清70H~7AH共11個內存單元
MOV R7,#0BH ;
CLEARDISP:
MOV @R0,#00H
INC R0
DJNZ R7,CLEARDISP
MOV 20H,#00H ;清20H , 標志用
MOV 7AH,#0AH ;放入「熄滅符」數據
MOV TMOD,#11H ;設T0、T1為16位定時器
MOV TL0,#0B0H ;50MS定時初值,T0計時用
MOV TH0,#3CH ;50MS定時初值
MOV TL1,#0B0H ;50MS定時初值,T1閃爍定時用
MOV TH1,#3CH ;50MS定時初值
SETB EA ;總中斷開放
SETB ET0 ;允許T0中斷
SETB TR0 ;開啟T0定時器
MOV R4,#14H ;1 S定時用初值50MS*20
START1:
LCALL DISPLAY ;調用顯示子程序
JNB P3.3,SETMM1 ;P3.3口為0時,轉時間調整程序
JNB P3.4,FUNSS ;秒錶功能,P3.4按鍵調時時作減1操作
JNB P3.5,FUNPT ;STOP,PUSE,CLR
SJMP START1 ;P3.3口為1時跳回START1
SETMM1:
LJMP SETMM ;轉到時間調整程序SETMM
FUNSS:
LCALL DS20MS ;
JB P3.4,START1 ;
WAIT11: ;
JNB P3.4,WAIT11 ;
CPL 03H ;
MOV 70H,#00H ;
MOV 70H,#00H ;
MOV 70H,#00H
MOV 70H,#00H ;
MOV 70H,#00H ;
MOV 70H,#00H ;
AJMP START1 ;
FUNPT: ;
LCALL DS20MS ;
JB P3.5,START1 ;
WAIT22: ;
JNB P3.5,WAIT21 ;
CLR ET0 ;
CLR TR0 ;
WAIT33: ;
JB P3.5,WAIT31 ;
LCALL DS20MS ;
JB P3.5,WAIT33 ;
WAIT66:
JNB P3.5,WAIT61
MOV R0,#70H ;清70H~79H共10個內存單元
MOV R7,#0AH
CLEARP:
MOV @R0,#00H
INC R0
DJNZ R7,CLEARP
WAIT44:
JB P3.5,WAIT41
LCALL DS20MS
JB P3.5,WAIT44
WAIT55:
JNB P3.5,WAIT51
SETB ET0
SETB TR0
AJMP START1
WAIT21:
LCALL DISPLAY
AJMP WAIT22
WAIT31:
LCALL DISPLAY
AJMP WAIT33
WAIT41:
LCALL DISPLAY
AJMP WAIT44
WAIT51:
LCALL DISPLAY
AJMP WAIT55
WAIT61:
LCALL DISPLAY
AJMP WAIT66
;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;; 1 s計時程式 ;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; T0中斷服務程序
INTT0:
PUSH ACC ;累加器入棧保護
PUSH PSW ;狀態字入棧保護
CLR ET0 ;關T0中斷允許
CLR TR0 ;關定時器T0
JB 03H,FSS ;標志為1轉秒錶處理程序,,10MS定時
MOV A,#0B7H ;中斷響應時間同步修正
ADD A,TL0 ;低8位初值修正
MOV TL0,A ;重裝初值,,低8位修正值
MOV A,#3CH ;高8位初值修正
ADDC A,TH0
MOV TH0,A ;重裝初值,, 高8位修正值
SETB TR0 ;開啟定時器T0
DJNZ R4,OUTT0;20次中斷未到中斷退出
ADDSS:
MOV R4,#14H ;20次中斷到,重賦初值,,1S
MOV R0,#71H ;指向秒計時單元..71H~72H
ACALL ADD1 ;調用加1程序,,加1S操作.
MOV A,R3 ;秒數據放入A,,R3為2位十進制數組合
CLR C ;清進位標志
CJNE A,#60H,ADDMM
ADDMM:
JC OUTT0 ;短於60S時中斷退出
ACALL CLR0 ;長於或者等於60S時對秒計數單元清0
MOV R0,#77H ;指向分計時單元,,76H~77H
ACALL ADD1 ;分計時單元加1
MOV A,R3 ;分數據放入A
CLR C ;清進位標志
CJNE A,#60H,ADDHH ;秒錶時最大為99
ADDHH:
JC OUTT0 ;短於60min時中斷退出
ACALL CLR0 ;長於或者等於60min時對分計數單元清0
MOV R0,#79H ;指向分計時單元,,78H~79H
ACALL ADD1 ;小時計時單元加1h
MOV A,R3 ;時數據放入A
CLR C ;清進位標志
JB 03H,OUTT0 ;秒錶時最大為99
CJNE A,#24H,HOUR
HOUR:
JC OUTT0 ;短於24h時中斷退出
ACALL CLR0 ;長於或者等於24h時對計時單元清0
OUTT0:
MOV 72H,76H ;中斷退出時將分\時計時單元數據移
MOV 73H,77H ;入對應顯示單元
MOV 74H,78H
MOV 75H,79H
POP PSW ;恢復狀態字出棧
POP ACC ;恢復累加器
SETB ET0 ;開放T0中斷
RETI
;秒錶計時程序(10min加1),低2位為0.1、0.01秒,中間2位為秒,最高2位為分.
;最大計數值為99分59.99秒
FSS: MOV A,#0F7H
ADD A,TL0
MOV TL0,A
MOV A,#0D8H
ADDC A,TH0
MOV TH0,A
SETB TR0
MOV R0,#71H
ACALL ADD1
CLR C
MOV A,R3
JZ FSS1
SETB C
FSS1: AJMP ADDMM
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; 閃動調時程式 ;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
; T1中斷服務程序,用作時間調整單元閃爍指示
INTT1: PUSH ACC
PUSH PSW
MOV TL1,#0B0H
MOV TH1,#3CH
DJNZ R2,INTT1OUT
MOV R2,#06H
CPL 02H
JB 02H,FLASH1
MOV 72H,76H
MOV 73H,77H
MOV 74H,78H
MOV 75H,79H
INTT1OUT:
POP PSW
POP ACC
RETI
FLASH1: JB 01H,FLASH2
MOV 72H,76H
MOV 73H,77H
MOV 74H,78H
MOV 75H,79H
AJMP INTT1OUT
FLASH2: MOV 72H,76H
MOV 73H,77H
MOV 74H,78H
MOV 75H,79H
AJMP INTT1OUT
;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; 加1子程序 ;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;
;
ADD1: MOV A,@R0 ;取當前計時單元數據到A
DEC R0 ;指向前一地址
SWAP A ;A中數據高四位與低四位交換
ORL A,@R0 ;前一地址中數據放入A中低四位
ADD A,#01H ;A加1操作
DA A ;十進制調整
MOV R3,A ;移入R3中暫存數據
ANL A,#0FH ;高四位變0
MOV @R0,A ;數據放入當前地址單元中
MOV A,R3 ;返回
INC R0
SWAP A
ANL A,#0FH
MOV @R0,A
RET
;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; 分減1子程序 ;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;
SUB1: MOV A,@R0 ;取當前計時單元數據到A
DEC R0 ;指向前一地址
SWAP A ;A中數據高四位與低四位交換
ORL A,@R0 ;前一地址中數據放入A中低四位
JZ SUB11
DEC A ;A減1操作
SUB111: MOV R3,A ;移入R3中暫存數據
ANL A,#0FH ;高四位變0
CLR C ;清進位標志
SUBB A,#0AH
SUB1111:
JC SUB1110
MOV @R0,#09H ;大於等於0AH,為9
SUB110:
MOV A,R3 ;取回R3中暫存數據
INC R0 ;指向當前地址單元
SWAP A ;A中數據高四位與低四位交換
ANL A,#0FH ;高四位變0
MOV @R0,A ;數據放入當前地址單元中
RET ;返回
SUB11: MOV A,#59H
AJMP SUB111
SUB1110:
MOV A,R3 ;移入R3寄存器
ANL A,#0FH
MOV @R0,A
AJMP SUB110
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; 時減1子程序 ;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;
SUBB1: MOV A,@R0 ;取當前計時單元數據到A
DEC R0 ;指向前一地址
SWAP A ;A中數據高四位與低四位交換
ORL A,@R0 ;前一地址中數據放入A中低四位
JZ SUBB11 ;00減1為23H
DEC A ;A減1操作
SUBB111:MOV R3,A ;;移入R3中暫存數據
ANL A,#0FH ;高四位變0
CLR C ;清進位標志
SUBB A,#0AH ;時個位大於9為9
SUBB1111:
JC SUBB1110
MOV @R0,#09H ;大於等於0AH,為9
SUBB110:
MOV A,R3 ;取回R3中暫存數據
INC R0 ;指向當前地址單元
SWAP A ;A中數據高四位與低四位交換
ANL A,#0FH ;高四位變0
MOV @R0,A ;數據放入當前地址單元中
RET ;返回
;
SUBB11:
MOV A,#23H
AJMP SUBB111
SUBB1110:
MOV A,R3 ;時個位小於0A不處理
ANL A,#0FH ;高四位變0
MOV @R0,A ;個位移入
AJMP SUBB110
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; 清0程序 ;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;對計時單元復0用
CLR0: CLR A ;清累加器
MOV @R0,A ;清當前地址單元
DEC R0 ;指向前一地址
MOV @R0,A ;前一地址單元清0
RET ;子程序返回
;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; 時鍾調整程序 ;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;當調時按鍵按下時進入此程序
SETMM: CLR ET0 ;關定時器T0中斷
CLR TR0 ;關閉定時器T0
LCALL DL1S ;調用1S延時程序
JB P3.3,CLOSEDIS ;鍵按下時間短於1S,關閉顯示,,省電
MOV R2,#06H ;進入調時狀態,賦閃爍定時初值
SETB ET1 ;允許T1中斷
SETB TR1 ;開啟T1定時器
SET2:
JNB P3.3,SET1 ;P3.3口為0時,等待,,鍵未釋放
SETB 00H ;鍵釋放,分調整閃爍標志置1
SET4: ;等待鍵按下
JB P3.3,SET3 ;等待鍵按下
LCALL DL05S ;有鍵按下,延時0.5S
JNB P3.3,SETHH ;按下時間長於0.5S,轉調小時狀態
MOV R0,#77H ;按下時間短於0.5S,加1min操作
LCALL ADD1 ;調用加1子程序
MOV A,R3 ;取調整單元數據
CLR C ;消位標志
CJNE A,#60H,HHH ;調整單元數據與60比較
HHH: JC SET4 ;調整單元數據小於60,轉SET4循環
LCALL CLR0 ;調整單元數據大於或等於60時,清0
CLR C ;清進位0
AJMP SET4 ;跳轉到SET4循環
CLOSEDIS:
SETB ET0 ;省電狀態,開T0中斷,,LED燈不顯示
SETB TR0 ;開啟T0中斷
CLOSE:
JB P3.3,CLOSE ;無鍵按下,等待
LCALL DISPLAY ;有鍵按下,調用顯示子程序延時消抖
JB P3.3,CLOSE ;是干擾,返回CLOSE等待
WAITH:
JNB P3.3,WAITH ;等待鍵釋放
LJMP START1 ;返回主程序,,LED數據顯示亮
SETHH: CLR 00H ;分閃爍標志清除,,進入調小時狀態
SETHH1: JNB P3.3,SET5 ;等待鍵釋放
SETB 01H ;小時調整標志置1
SET6: JB P3.3,SET7 ;等待鍵按下
LCALL DL05S ;有鍵按下,延時0.5S
JNB P3.3,SETOUT ;按下時間長於0.5S,退出時間調整
MOV R0,#79H ;按下時間短於0.5S,加1h操作
LCALL ADD1 ;調用加1子程序
MOV A,R3
CLR C
CJNE A,#24H,HOUU ;計時單元數據與24比較
HOUU: JC SET6 ;小於24,轉SET6循環
LCALL CLR0 ;大於或等於24時,清0操作
AJMP SET6 ;跳到SET6處循環
SETOUT: JNB P3.3,SETOUT1 ;調時退出程序.等待鍵釋放
LCALL DISPLAY ;延時消抖
JNB P3.3,SETOUT ;是抖動,返回SETOUT再等待
CLR 01H ;清調小時標志
CLR 00H ;清調分標志
CLR 02H ;清閃爍標志
CLR TR1 ;關閉定時器T1
CLR ET1 ;關定時器T1中斷
SETB TR0 ;開啟定時器T0
SETB ET0 ;開啟定時器T0中斷,,計時開始
LJMP START1 ;跳回主程序
SET1: LCALL DISPLAY ;鍵釋放等待調時用顯示程序
AJMP SET2 ;防止鍵按下時無時鍾顯示
SET3: LCALL DISPLAY ;等待調分按鍵時時鍾顯示用
JNB P3.3,FUNSUB ;減1分操作
AJMP SET4 ;調分等待
SET5: LCALL DISPLAY ;鍵釋放等待調時用顯示程序
AJMP SETHH1 ;防止鍵按下時無時鍾顯示
SET7: LCALL DISPLAY ;等待調小時按鍵時時鍾顯示用
JNB P3.3,FUNSUBB ;小時減1操作
AJMP SET6 ;調時等待
SETOUT1:LCALL DISPLAY ;退出時鍾整時鍵釋放等待
AJMP SETOUT ;防止鍵按下時無時鍾顯示
;FUNSUB,分減1程序?
FUNSUB: LCALL DISPLAY ;延時消抖
JB P3.3,SET41 ;干擾,返回調分等待
FUNSUB1:JNB P3.3,FUNSUB1 ;等待鍵放開
MOV R0,#77H
LCALL SUB1 ;分減1程序
LJMP SET4 ;返回調分等待
;
SET41: LJMP SET4
;FUNSUB,時減1程序?
FUNSUBB:LCALL DISPLAY ;消抖動
JB P3.4,SET61 ;干擾,返回調時等待
FUNSUBB1:JNB P3.4,FUNSUBB1
MOV R0,#79H
LCALL SUBB1
LJMP SET6
;
SET61: LJMP SET6
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; 顯示程序 ;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;顯示數據在70H~75H單元內,用六位LED共陽數碼管顯示。
;掃描控制,每個LED數碼管亮1mS時間。
DISPLAY:
MOV R1,#70H ;指向顯示數據首址
MOV R5,#0DFH ;掃描控制字初值
PLAY: MOV A,R5 ;掃描字放入A
MOV P2,A ;從P2口輸出
MOV A,@R1 ;取顯示數據到A
MOV DPTR,#TAB ;取段碼表地址
MOVC A,@A+DPTR ;查顯示數據對應段碼
MOV P0,A ;段碼放入P0口
MOV A,R5
JB ACC_1,LOOP5 ;小數點處理
CLR P0.7
LOOP5: JB ACC_3,LOOP6
CLR P0.7
LOOP6: LCALL DL1MS ;顯示1MS
INC R1 ;指向下一地址
MOV A,R5 ;掃描控制字放入A
JNB ACC_0,ENDOUT ;ACC.0=0時,一次顯示結束
RR A ;A中數據循環左移
MOV R5,A ;放回R5內
MOV P0,#0FFH
AJMP PLAY ;跳回:PLAY循環.
ENDOUT: MOV P2,#0FFH ;一次顯示結束,P2口復位
MOV P0,#0FFH ;P0口復位
RET ;子程序返回
TAB: DB 0C0H,0F9H,0A4H,0B0H,99H,92H,82H,0F8H,80H,90H,0FFH,88H,0BFH
;共陽段碼表 1、 2、 3、 4、 5、 6、 7、 8、 9、不亮、A、—。
;
;SDISPLAY,上電顯示程序
;不帶小數點,有A、— 顯示功能
SDISPLAY:
MOV R5,#0DFH ;掃描控制字初值
SPLAY: MOV A,R5 ;掃描字放入A
MOV P2,A ;從P2口輸出
MOV A,@R1 ;取顯示數據到A
MOV DPTR,#TABS ;取段碼表地址
MOVC A,@A+DPTR ;查顯示數據對應段碼
MOV P0,A ;段碼放入P0口
MOV A,R5
LCALL DL1MS ;顯示1MS
INC R1 ;指向下一地址
MOV A,R5 ;掃描控制字放入A
JNB ACC_0,ENDOUTS ;ACC.0=0時,一次顯示結束
RR A ;A中數據循環左移
MOV R5,A ;放回R5內
AJMP SPLAY ;跳回:PLAY循環.
ENDOUTS:MOV P2,#0FFH ;一次顯示結束,P2口復位
MOV P0,#0FFH ;P0口復位
RET ;子程序返回
TABS: DB 0C0H,0F9H,0A4H,0B0H,99H,92H,82H,0F8H,80H,90H,0FFH,88H,0BFH
;STAB表,啟動時顯示2003-12-07、A01-2-28
;
STAB: DB 0AH,0AH,0AH,0AH,0AH,0AH,08H,02H,0CH,02H,0CH,01H,00H,0BH,0AH,0AH
DB 07H,00H,0CH
DB 07H,00H,0CH,02H,01H,0CH,03H,00H,00H,02H,0AH,0AH,0AH,0AH,0AH,0AH
;註:0A不亮,0B顯示「A」,0C顯示「-」
;ST子程序,上電時顯示年月日用,採用移動顯示
ST: MOV R0,#40H ;將顯示內容移入40H~50H單元
MOV R2,#20H
MOV R3,#00H
CLR A
MOV DPTR,#STAB
SLOOP:
MOVC A,@A+DPTR
MOV @R0,A
MOV A,R3
INC A
MOV R3,A
INC R0
DJNZ R2,SLOOP ;移入完畢
MOV R1,#5AH
MOV R3,#1BH ;顯示27個單元
SSLOOP:
MOV R2,#32H ;控制移動速度
SSLOOP1:
LCALL SDISPLAY
DJNZ R2,SSLOOP11
MOV A,R1
SUBB A,#07H ;顯示首址修正為低1個單元
MOV R1,A
DJNZ R3,SSLOOP
RET
SSLOOP11:
MOV A,R1 ;指針修正為原值
SUBB A,#06H
MOV R1,A
AJMP SSLOOP1
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;; 延時程序 ;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;1ms延時程序,LED顯示程序用
DL1MS: MOV R6,#14H
DL1: MOV R7,#19H
DL2: DJNZ R7,DL2
DJNZ R6,DL1
RET;20MS延時程序,採用調用顯示子程序,以改善LED的顯示閃爍現象
DS20MS: ACALL DISPLAY
ACALL DISPLAY
ACALL DISPLAY
RET;延時程序,用作按鍵時間的長短判斷
DL1S:
LCALL DL05S
LCALL DL05S
RET
DL05S:
MOV R3,#20H ;8ms*32=0.196s
DL05S1:
LCALL DISPLAY
DJNZ R3,DL05S1
RET;
END ;程序結束

I. 數字電子鍾的設計(用EDA來寫程序)

論文撰寫參考格式:
1. 數字電子鍾設計的背景、意義,及目前市場的一些現有設計內。
2. 數字電子鍾:(容1)描述所實現的功能;(2)設計的思路;(3)功能的實現程序;(4)功能的調試;(5)功能的模擬。
3. 數字電子鍾的功能
(1) 基本的要求:實現時、分、秒的顯示
(2) 具有秒錶功能(選做)
(3) 具有整點報時功能
(4) 具有鬧鈴功能(選做)
4. 結合所在實踐的公司生產的產品或本地電子產品市場寫出進一步的分析、體會。
5. 主要參考文獻。
6. 論文總字數5000字以上

熱點內容
武漢大學學生會輔導員寄語 發布:2021-03-16 21:44:16 瀏覽:612
七年級學生作文輔導學案 發布:2021-03-16 21:42:09 瀏覽:1
不屑弟高考成績 發布:2021-03-16 21:40:59 瀏覽:754
大學畢業證會有成績單 發布:2021-03-16 21:40:07 瀏覽:756
2017信陽學院輔導員招聘名單 發布:2021-03-16 21:40:02 瀏覽:800
查詢重慶2018中考成績查詢 發布:2021-03-16 21:39:58 瀏覽:21
結業考試成績怎麼查詢 發布:2021-03-16 21:28:40 瀏覽:679
14中醫醫師資格筆試考試成績查分 發布:2021-03-16 21:28:39 瀏覽:655
名著賞析課程標准 發布:2021-03-16 21:27:57 瀏覽:881
北京大學商業領袖高端培訓課程 發布:2021-03-16 21:27:41 瀏覽:919