標題: 匯編語言延時程序具體應該怎么計算? [打印本頁]
作者: 滿腹經綸 時間: 2017-3-2 09:26
標題: 匯編語言延時程序具體應該怎么計算?
二重循環模型:
DEL: MOV R6,#y
DEL1:MOV R5,#X
DEL2:DJNZ R5,DEL2
DJNZ R6,DEL1
RET
我知道T=2XY+3Y+3
可是,如果我要實現一個200000uS,該如何計算出X和Y的數值 ,一個方程有兩個未知數,怎么求呢?
三重循環模型:
DEL: MOV R7,#Z
DEL1:MOV R6,#Y
DEL2:MOV R5,#X
DEL3:DJNZ R5,DEL3
DJNZ R6,DEL2
DJNZ R7,DEL1
RET
我知道T=2XYZ+3YZ+3Z+3
該如何計算出X、Y和Z的數值 ,一個方程有3個未知數,怎么求呢?
作者: ahshmj 時間: 2017-3-2 18:19
這3個都是未知數?
先確定兩個然后計算求出第3個。
作者: zl2168 時間: 2017-3-2 19:58
"一個方程有兩個未知數,怎么求呢?" 那就有無數個解。先設定一個未知數,然后就有對應的解了?磥順侵鲾祵W未學好!
作者: zl2168 時間: 2017-3-2 20:02
本帖最后由 zl2168 于 2017-3-2 20:35 編輯
【例3-24】 延時程序是單片機應用系統常用的模塊程序。試按下列要求編寫延時子程序:
⑴ 延時1ms,fOSC=6MHz;
⑵ 延時10ms,fOSC=12MHz;
⑶ 延時0.5s,fOSC=12MHz。
解:⑴ 延時1ms。fOSC =6MHz,一個機器周期為2ms,DJNZ指令為2個機器周期。
DY1ms: MOV R7,#250 ;置循環次數(指令為1個機器周期)
LOP: DJNZ R7,LOP ;250×2機周=500機周
RET ;子程序返回(單獨Keil調試時,需用END替代RET)
上述子程序實際延時(500 +1)機周×2ms/機周=1002ms。
⑵ 延時10ms。fOSC =12MHz,一個機器周期為1ms。
DY10ms: MOV R6,#20 ;置外循環次數
DY1: MOV R7,#250 ;置內循環次數
DY2: DJNZ R7,DY2 ;250×2機周=500機周
DJNZ R6,DY1 ;500機周×20=10000機周
RET ;子程序返回(單獨Keil調試時,需用END替代RET)
實際延時[(500+2+1)×20+1]機周×1ms /機周=10061ms。
⑶ 延時0.5s。fOSC=12MHz,一個機器周期為1ms。
DY05s: MOV R5,#5 ;置外循環次數
DY0: MOV R6,#200 ;置中循環次數
DY1: MOV R7,#250 ;置內循環次數
DY2: DJNZ R7,DY2 ;250×2機周=500機周
DJNZ R6,DY1 ;500機周×200 =100000機周
DJNZ R5,DY0 ;100000機周×5=500000機周
RET ;子程序返回(單獨Keil調試時,需用END替代RET)
實際延時{[(2×250+2+1)×200+2+1]×5+1}機周×1ms/機周=503016ms。
以上摘自張志良編著
《80C51單片機實用教程——基于Keil C和Proteus》高等教育出版社ISBN 978-7-04-044532-9, 用于學習51單片機原理,程序(c和匯編)語句條條有注解,便于閱讀理解,便于自學。
作者: angmall 時間: 2017-3-2 20:12
以某晶振為12MHz的單片機為例,晶振為12MHz即一個機器周期為1us。
計算分析:
X:R5=150 Y:R6=132 Z:R7=5
程序共有三層循環
一層循環n:R5*2 = 150*2 = 300us (DJNZ 2us)
二層循環m:R6*(n+3) = 132*303 = 39996us (DJNZ 2us + R5賦值 1us = 3us)
三層循環: R7*(m+3) = 5*39999 = 199995us (DJNZ 2us + R6賦值 1us = 3us)
循環外: 5us 子程序調用 2us + 子程序返回 2us + R7賦值 1us = 5us
延時總時間 = 三層循環 + 循環外 = 199995+5 = 200000us =200ms
計算公式:延時時間=[(2*R5+3)*R6+3]*R7+5
作者: yzwzfyz 時間: 2017-3-4 02:11
不計算的方法:用軟件仿真運行,可以在運行結果中找到答案。不對再改。
作者: 滿腹經綸 時間: 2017-5-19 08:48
用哪個軟件仿真?
| 歡迎光臨 (http://m.raoushi.com/bbs/) |
Powered by Discuz! X3.1 |