




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、課 程 設(shè) 計題 目溫度控制系統(tǒng)設(shè)計學(xué) 院自動化學(xué)院專 業(yè)自動化專業(yè)班 級姓 名指導(dǎo)教師2014年6月24日課程設(shè)計任務(wù)書題 目: 溫度控制系統(tǒng)設(shè)計 要求完成的主要任務(wù): 被控對象為電爐,采用熱阻絲加熱,利用大功率可控硅控制器控制熱阻絲兩端所加的電壓大小,來改變流經(jīng)熱阻絲的電流,從而改變電爐爐內(nèi)的溫度??煽毓杩刂破鬏斎霝?5伏時對應(yīng)電爐溫度0300,溫度傳感器測量值對應(yīng)也為05伏,對象的特性為二階慣性系統(tǒng),慣性時間常數(shù)為t120秒,滯后時間常數(shù)為10秒。 1)設(shè)計溫度控制系統(tǒng)的計算機硬件系統(tǒng),畫出框圖; 2)編寫積分分離pid算法程序,從鍵盤接受kp、ti、td、t及的值; 3)通過數(shù)據(jù)分析t
2、i改變時對系統(tǒng)超調(diào)量的影響。 4)撰寫設(shè)計說明書。時間安排:6月9日 查閱和準備相關(guān)技術(shù)資料,完成整體方案設(shè)計6月10日6月12日完成硬件設(shè)計6月13日6月15日編寫調(diào)試程序6月16日6月17日撰寫課程設(shè)計說明書 6月18日 提交課程設(shè)計說明書、圖紙、電子文檔指導(dǎo)教師簽名: 年 月 日系主任(或責(zé)任教師)簽名: 年 月 日摘要本次課程設(shè)計我設(shè)計的題目是溫度控制系統(tǒng)。通過專業(yè)課程的學(xué)習(xí),我將引入計算機,單片機,傳感器,以及pid算法來實現(xiàn)電爐溫度的自動控制,完成課程設(shè)計的任務(wù)。計算機的自動控制是機器和儀表的發(fā)展趨勢,它不僅解放了勞動力,也比以往的人為監(jiān)控更準確,更及時。一旦溫度發(fā)生變化,計算機監(jiān)
3、控系統(tǒng)可以立即檢測到并通過模擬量數(shù)字通道傳送到計算機。計算機接收到信號后通過與給定值進行比較后,計算出偏差,再通過pid控制算法給出下一步將要執(zhí)行的指令。最后通過模擬量輸出通道將指令傳送到生產(chǎn)過程,實現(xiàn)機器儀表的智能控制。本次課程設(shè)計用到了matlab這一軟件,通過編寫程序,將被控系統(tǒng)離散化。再通過matlab中的simulink仿真功能,可以看到隨著ki,kp,kd改變波形發(fā)生的改變,從而可以通過波形直觀地看出pid參數(shù)對系統(tǒng)動態(tài)性能的影響。關(guān)鍵字:溫度控制 a/d轉(zhuǎn)換 d/a轉(zhuǎn)換 simulink仿真目錄1.設(shè)計任務(wù)及分析12.方案設(shè)計23.系統(tǒng)硬件設(shè)計33.1 系統(tǒng)硬件結(jié)構(gòu)33.2系統(tǒng)硬
4、件的選擇33.3 系統(tǒng)硬件連接圖44 系統(tǒng)軟件設(shè)計64.1 確定程序流程64.2 程序控制算法介紹84.3 pid控制算法105系統(tǒng)仿真115.1 仿真程序及圖形設(shè)計11心得體會13參考文獻14附錄1芯片資料15附錄2 程序清單17本科生課程設(shè)計成績評定表27 溫度控制系統(tǒng)設(shè)計1.設(shè)計任務(wù)及分析被控對象為電爐,采用熱阻絲加熱,利用大功率可控硅控制器控制熱阻絲兩端所加的電壓大小,來改變流經(jīng)熱阻絲的電流,從而改變電爐爐內(nèi)的溫度??煽毓杩刂破鬏斎霝?5伏時對應(yīng)電爐溫度0300,溫度傳感器測量值對應(yīng)也為05伏,對象的特性為二階慣性系統(tǒng),慣性時間常數(shù)為t120秒,滯后時間常數(shù)為10秒。 1)設(shè)計溫度控制
5、系統(tǒng)的計算機硬件系統(tǒng),畫出框圖; 2)編寫積分分離pid算法程序,從鍵盤接受kp、ti、td、t及的值; 3)通過數(shù)據(jù)分析ti改變時對系統(tǒng)超調(diào)量的影響。 4)撰寫設(shè)計說明書。本次設(shè)計是對電爐的溫度控制,而電爐的溫度是通過放在其中的熱阻絲來控制的,而熱阻絲的電流由可控硅控制器控制熱阻絲兩端所加電壓來控制。對電爐溫度的控制是個動態(tài)的過程,不可能一下子就達到我們想要的溫度,需要用到一些儀器比如熱電偶來測量電路的溫度,通過傳感器將爐溫轉(zhuǎn)換成電壓信號,送入a/d轉(zhuǎn)換器,通過采樣和模數(shù)轉(zhuǎn)換,所檢測到的電壓信號和爐溫給定值的電壓信號送入計算機程序中作比較,得出給定值與實際值之間的偏差,單片機對偏差進行運算,
6、將運算結(jié)果送給晶閘管調(diào)壓器來調(diào)節(jié)熱阻絲的電流,以此來調(diào)節(jié)電電爐的溫度。2.方案設(shè)計電爐的溫度控制是個動態(tài)的控制過程,需要借助計算機,單片機等很多器件的硬件連接來實現(xiàn)。而電爐溫度的直接控制是通過熱阻絲的加熱來實現(xiàn)的,熱阻絲的加熱是由流經(jīng)熱阻絲的電流來控制的,而熱阻絲的電流是通過可控硅控制器控制熱阻絲兩端所加電壓來控制,電壓的調(diào)節(jié)是通過可控制硅控制。需要用到熱電偶時刻監(jiān)測電爐的溫度,通過傳感器將溫度信號轉(zhuǎn)化為電壓信號,而電壓信號通過模數(shù)轉(zhuǎn)換送入到計算機進行控制,計算機將轉(zhuǎn)換結(jié)果送到晶閘管來控制加到熱阻絲兩端的電壓,這樣達到調(diào)節(jié)電爐溫度的目的。 傳感器 電爐 數(shù)據(jù)采集 控制電路 d/a轉(zhuǎn)換 a/d轉(zhuǎn)
7、換 計算機 顯示電路 鍵盤控制圖2-1 溫度控制系統(tǒng)框圖3.系統(tǒng)硬件設(shè)計爐溫信號t通過溫度檢測及變送,變成電信號,與溫度設(shè)定值進行比較,計算溫度偏差e和溫度的變化率de/dt,再由智能控制算法進行推理,并得控制量u,可控硅輸出部分根據(jù)調(diào)節(jié)電加熱爐的輸出功率,即改變可控硅管的接通時間,使電加熱爐輸出溫度達到理想的設(shè)定值。3.1 系統(tǒng)硬件結(jié)構(gòu)adc0809的int0端口所連接的電阻起到給定預(yù)定值的作用,通過調(diào)節(jié)滑動變阻器劃片的位置,改變int0端口的電壓,該電壓通過0809轉(zhuǎn)換為數(shù)字量被計算機讀取。將一個0-5v的電壓表連接到可變電阻上,測量其電壓,再將其表盤改裝為溫度表盤,即將原來的0-5v的刻
8、度均勻分為300份,每一份代表1,則可以讀取預(yù)定的溫度值。adc0809的int1端口與熱電偶相連。由8051構(gòu)成的核心控制器按智能控制算法進行推算,得出所需要的控制量。由單片機的輸出通過調(diào)節(jié)可控硅管的接通時間,改變電爐的輸出功率,起到調(diào)溫的作用 。 3.2系統(tǒng)硬件的選擇微型計算機的選擇:選擇8051單片機構(gòu)成爐溫控制系統(tǒng)。它具有8位cpu,3 2根i/o線,4 kb片內(nèi)rom存儲器,128 kb的ram存儲器。8051對溫度是通過可控硅調(diào)節(jié)器實現(xiàn)的。在系統(tǒng)開發(fā)過程中修改程序容易,可以大大縮短開發(fā)周期。同時,系統(tǒng)工作過程中能有效地保存一些數(shù)據(jù)信息,不受系統(tǒng)掉電或斷電等突發(fā)情況的影響。8051單
9、片機內(nèi)部有128 b的ram存儲器,不夠本系統(tǒng)使用,因此,采用6264(8 kb)的ram作為外部數(shù)據(jù)存儲器。 熱電偶的選擇:本設(shè)計采用熱電偶-鎳絡(luò)-銅硅熱電偶(線性度較好,熱電勢較大,靈敏度較高,穩(wěn)定性和復(fù)現(xiàn)性較好,抗氧化性強,價格便宜)對溫度進行檢測。鎳鉻-銅鎳熱電偶在300時的熱點勢21.033mv,為滿足0-5v的要求,需將其放大238倍,再通過0809將其轉(zhuǎn)換為數(shù)字量被計算機讀取,通過軟件程序?qū)?shù)據(jù)進行處理,將處理的結(jié)果經(jīng)0832輸出,輸出量控制可控硅控制器,從而改變電阻絲兩端的電壓,使?fàn)t溫得到控制。3.3 系統(tǒng)硬件連接圖 綜合以上分析,可以得出系統(tǒng)的硬件連接圖如圖3-1所示:圖3-
10、1 系統(tǒng)硬件連接圖4 系統(tǒng)軟件設(shè)計4.1 確定程序流程在微分控制中,控制器的輸出與輸入誤差信號的微分(即誤差的變化率)成正比關(guān)系。 自動控制系統(tǒng)在克服誤差的調(diào)節(jié)過程中可能會出現(xiàn)振蕩甚至失穩(wěn)。其原因是由于存在有較大慣性組件(環(huán)節(jié))或有滯后組件,具有抑制誤差的作用,其變化總是落后于誤差的變化。解決的辦法是使抑制誤差的作用的變化“超前”,即在誤差接近零時,抑制誤差的作用就應(yīng)該是零。這就是說,在控制器中僅引入“比例”項往往是不夠的,比例項的作用僅是放大誤差的幅值,而目前需要增加的是“微分項”,它能預(yù)測誤差變化的趨勢,這樣,具有比例+微分的控制器,就能夠提前使抑制誤差的控制作用等于零,甚至為負值,從而避
11、免了被控量的嚴重超調(diào)。所以對有較大慣性或滯后的被控對象,比例+微分(pd)控制器能改善系統(tǒng)在調(diào)節(jié)過程中的動態(tài)特性。在一般的pid控制中,當(dāng)有較大的擾動或大幅度改變給定值時,由于此時有較大的偏差,以及系統(tǒng)有慣性和滯后,故在積分項的作用下,往往會產(chǎn)生較大的超調(diào)和長時間的波動。特別對于溫度等變化緩慢的過程,這一現(xiàn)象更為嚴重,為此,可采用積分分離措施,即偏差較大時,取消積分作用;當(dāng)偏差較小時才將積分作用投入。亦即當(dāng)時,采用pd控制;當(dāng)時,采用pid控制。積分分離閾值應(yīng)根據(jù)具體對象及控制要求。若值過大時,則達不到積分分離的目的;若值過小,則一旦被控量無法跳出個積分分離區(qū),只進行pd控制,將會出現(xiàn)殘差,為
12、了實現(xiàn)積分分離,編寫程序時必須從數(shù)字pid差分方程式中分離出積分項,進行特殊處理。根據(jù)設(shè)計要求及所選硬件,程序流程如圖4-1所示:開始系統(tǒng)初始化設(shè)置數(shù)據(jù)采集a/d轉(zhuǎn)換求出溫度值信號比較pid調(diào)節(jié)可控硅調(diào)節(jié)加熱爐圖4-1 程序主流程圖4.2 程序控制算法介紹 由以上分析,本次設(shè)計采用的是積分分離pid控制算法,pid調(diào)節(jié)時連續(xù)系統(tǒng)中技術(shù)中最成熟的,應(yīng)用廣泛的一種調(diào)節(jié)控制方式。在模擬控制系統(tǒng)中,pid算法的表達為: u:調(diào)節(jié)器的輸出信號;e:偏差信號;k:調(diào)節(jié)器的比例系數(shù);ti:調(diào)節(jié)器的積分時間;td:調(diào)節(jié)器的微分時間。 在計算機控制中,為實現(xiàn)數(shù)字控制,必須對式上式進行離散化處理。用數(shù)字形式的差分
13、方程代替連續(xù)系統(tǒng)的微分方程。設(shè)系統(tǒng)的采樣周期為t,在t=kt時刻進行采樣,式中e(k):根據(jù)本次采樣值所得到的偏差; e(k-1):由上次采樣所得到的偏差。由以上可得: 式中,t為采樣時間,項為積分項的開關(guān)系數(shù)積分積分分離pid控制算法程序框圖如圖4-2所示: 開始 初始化 數(shù)據(jù)采集 y n pid控制 pd控制 控制器輸出 更新參數(shù) 返回圖4-2 積分分離pid控制算法圖4.3 pid控制算法實際運行的經(jīng)驗和理論的分析都表明,運用這種控制規(guī)律對許多工業(yè)過程控制時,都能得到滿意的效果。不過用計算機實現(xiàn)pid控制,不是簡單得把模擬pid控制規(guī)律數(shù)字化,而是進一步與計算機的邏輯判斷功能結(jié)合,使pi
14、d控制更加靈活,更能滿足生產(chǎn)過程提出的要求。pid算法推倒如下: u:調(diào)節(jié)器的輸出信號;e:偏差信號;k:調(diào)節(jié)器的比例系數(shù);ti:調(diào)節(jié)器的積分時間;td:調(diào)節(jié)器的微分時間。對應(yīng)的模擬pid調(diào)節(jié)器的傳遞函數(shù) 其中為比例增益,與比例帶成倒數(shù)關(guān)系即=1/,ti為積分時間常數(shù),td為微分時間常數(shù),u(t)為控制量,e(t)為偏差。在計算機控制中,為實現(xiàn)數(shù)字控制,必須對式上式進行離散化處理。用數(shù)字形式的差分方程代替連續(xù)系統(tǒng)的微分方程。設(shè)系統(tǒng)的采樣周期為t,在t=kt時刻進行采樣,式中e(k):根據(jù)本次采樣值所得到的偏差;e(k-1):由上次采樣所得到的偏差。t為采樣周期k為采樣序號由以上可得: 式中,t
15、為采樣時間,項為積分項的開關(guān)系數(shù)5系統(tǒng)仿真5.1 仿真程序及圖形設(shè)計被控對象為:g(s)= 采用simulink仿真,通過simulink模塊實現(xiàn)積分分離pid控制算法。選擇合適的kp,ki,kd是系統(tǒng)的仿真效果趨于理想狀態(tài)。matlab編寫程序如下:clear all;close all;ts=2; %采樣時間2ssys=tf(1,400,40,1);dsys=c2d(sys,ts,'zoh'); %將sys離散化num,den=tfdata(dsys,'v'); %求sys多項式模型參數(shù)kp=10;ki=0.25;kd=5;simulink仿真圖如圖5-1所
16、示:圖5-1 simulink仿真圖心得體會本次計算機控制技術(shù)課程設(shè)計我的題目是電爐溫度控制系統(tǒng)。通過本學(xué)期專業(yè)課程的學(xué)習(xí),我打算通過傳感器,單片機,計算機來實現(xiàn)爐溫的自動控制系統(tǒng)。最后通過simulink仿真波形,觀察pid參數(shù)變化對系統(tǒng)結(jié)果的影響,從而對計算機控在技術(shù)中的pid控制有更深刻的理解和認識。拿到題目后,首先我綱舉目張地初步將我的整個報告完成過程分為了六個步驟:分析題目要求,列出報告提綱,查找資料,設(shè)計硬件和軟件,進行matlab仿真,撰寫課程設(shè)計說明書。通過計算機控制技術(shù)這門專業(yè)課的學(xué)習(xí),已經(jīng)對整個控制系統(tǒng)的組成和原理有了初步認識,所以題目理解起來并不困難,主要就是用到了a/d
17、和d/a轉(zhuǎn)換,以及單片機編程實現(xiàn)。接下來就是查閱資料和列提綱了,這兩步基本是同時進行。緊接著就是根據(jù)手頭上已有的課本和網(wǎng)絡(luò)上找到的資源進行軟硬件設(shè)計,在理解了課本上的知識后,設(shè)計起來也并不復(fù)雜。整個爐溫控制系統(tǒng)大致工作流程是這樣的:采集當(dāng)前溫度數(shù)據(jù)進行a/d轉(zhuǎn)換后送至計算機系統(tǒng),與給定標準溫度進行偏差計算,通過控制算法給出下一步執(zhí)行決策,并通過d/a轉(zhuǎn)換器送出至控制系統(tǒng),控制系統(tǒng)根據(jù)指令進行人為或自動控制處理,這樣整個控制流程就比較清晰了。下一步是進行simulink仿真。不得不說對simulink的學(xué)習(xí)仍需加強,對整個軟件不是很了解的情況下就去做仿真的結(jié)果就是浪費大量時間做無用功,而且還得不
18、出結(jié)果。最后是撰寫課程設(shè)計報告。其實這個過程考驗的是自己的細心和耐心,格式方面的修改有時候確實讓人頭疼,但一旦你這一次做到了這些,下次再寫報告的時候就會事半功倍,為人處世也會學(xué)著更加細致謹慎。參考文獻1李建忠.單片機原理及應(yīng)用.西安:西安電子科技大學(xué)出版社,2001.2潘新民.王燕芳.微型計算機控制技術(shù).北京:高等教育出版社,2001. 3何立民.單片機應(yīng)用系統(tǒng)設(shè)計.北京:北京航空航天大學(xué)出版社,2000.4韓志軍,沈晉源,王振波.單片機應(yīng)用系統(tǒng)設(shè)計.北京:機械工業(yè)出版社,2005.5周航慈.單片機程序設(shè)計基礎(chǔ).北京:北京航空航天大學(xué)出版社,2000.附錄1芯片資料adc0809芯片圖 adc
19、0809芯片adc0809各腳功能如下: d7-d0:8位數(shù)字量輸出引腳。in0-in7:8位模擬量輸入引腳。vcc:+5v工作電壓。gnd:地。ref(+):參考電壓正端。ref(-):參考電壓負端。start:a/d轉(zhuǎn)換啟動信號輸入端。ale:地址鎖存允許信號輸入端。(以上兩種信號用于啟動a/d轉(zhuǎn)換)eoc:轉(zhuǎn)換結(jié)束信號輸出引腳,開始轉(zhuǎn)換時為低電平,當(dāng)轉(zhuǎn)換結(jié)束時為高電平。oe:輸出允許控制端,用以打開三態(tài)數(shù)據(jù)輸出鎖存器。clk:時鐘信號輸入端(一般為500khz)。a、b、c:地址輸入線。dac0832芯片:圖 dac0832芯片dac0832芯片為20引腳,雙列直插式封裝。其引腳排列如圖
20、6所示。(1)數(shù)字量輸入線d7d0(8條) (2)控制線(5條) (3)輸出線(3條) (4)電源線(4條)dac0832的技術(shù)指標(1)分辨率:8位(2)電流建立時間:1µs(3)線性度(在整個溫度范圍內(nèi))8、9或10位(4)增益溫度系數(shù):00002 fs/(5)低功耗:20mw(6)單一電源:+5 +15v 附錄2 程序清單積分分離pid控制算法子程序:start:mov 68h,kp ;分別將kp ,ti ,td, t,送入指定的存儲單元mov 54h,timov 55h,tdmov 56h,tmov 57h,mov a,68h ;計算ki=kp*t/timov b,56hmu
21、l abmov b,54hdiv abmov 69h,amov a,68h ;計算kd=kp*td/tmov b,55hmul abmov b,56hdiv abmov 6ah,aloop0: mov dptr #7ff0h ;讀取預(yù)定溫度值,送adc0809的in0口地址 mov dptr,a ;啟動a/d轉(zhuǎn)換loop1 jb p3.3,loop1 ;等待轉(zhuǎn)換數(shù)據(jù) movx a,dptr ;讀取adc0809的in0口轉(zhuǎn)換后的數(shù)據(jù) mov 5ch,a ;將預(yù)定值數(shù)據(jù)放入指定的存儲單元mov dptr,#7ff1h ;讀取采樣溫度值,送adc0809的in1口地址 movx dptr,a ;啟
22、動a/d轉(zhuǎn)換loop2: jb p3.3,loop2 ;等待轉(zhuǎn)換數(shù)據(jù) movx a,dptr ;讀取adc0809的in1口轉(zhuǎn)換后的數(shù)據(jù) mov 49h,a ;將采樣值數(shù)據(jù)放入指定的存儲單元 mov a,5ch ;計算e(i),先取溫度給定值 clr c subb a,50h ;溫度給定值-采樣值 jnc aa0 ;判斷e(i)的正負,如果為正,跳至aa0 cpl a ;e(i)為負,下兩條指令求補 add a,#01haa0: mov r0,57h subb a,57h ;|e(i)|- jnc aa1 ;|e(i)|>跳至aa1 sjmp aa2 ;|e(i)|<跳至aa2aa
23、1: lcall pd ;調(diào)用pd算法aa2: lcall pid ;調(diào)用pid算法 mov a,7ch ;將ui通過dac0832輸出 mov dptr,#7ff2h movx dptr,a inc dptr movx dptr,a lcall delay ;調(diào)用延時子程序,等待下一次采樣計算 sjmp loop0 ;進入下一次控制計算delay proc neardl0: mov r6,#ffhdl1: mov r7,#ffhdl2: mov r5,#ffhdls: djnz r5,dlsdjnz r7,dl2djnz r6 dl1retdelay endppid proc nearpid
24、:mov a,5ch ;計算e(i),先取溫度給定值clr csubb a,50h ;溫度給定值-溫度檢測值jnc pid1 ;判斷e(i)正負,如果為正,跳至pid1cpl a ;e(i)為負,下兩條指令求補add a,#01hsetb 30h ;e(i)為負,符號位置1sjmp pid2pid1:clr 30h ;e(i)為正,符號位置0pid2:mov 6bh,a ;e(i)值存放在6bh單位元中mov r1,6bh ;計算ei-ei-1,先將ei值,送r1mov c,30h ;將ei的符號位值送20h位mov 20h,cmov r2,6ch ;將ei-1值送r2mov c,31h ;將
25、 ei-1的符號位值送21h位mov 21h,clcall djf ;調(diào)用單字節(jié)帶符號的減法子程序mov 6eh,r3 ;將差值ei-ei-1送6eh單元mov c,22h ;將差值ei-ei-1的符號位送33h位mov 33h,cmov r1,6ch ;計算ei-1-ei-2,先將ei-1值送r1mov c,31h ;將ei-1符號位送20h位mov 20h,cmov r2,6dh ;將ei-2的值送r2mov c,32h ;將 ei-2的符號位值送21h位mov 21h,clcall djf ;調(diào)用單字節(jié)帶符號的減法子程序mov 6fh,r3 ;將差值ei-1-ei-2送6fh單元mov
26、c,22h ;將差值ei-1-ei-2的符號位送34h位mov 34h,cmov r1,6eh ;計算(ei-ei-1)-(ei-1-ei-2),將ei-ei-1值送r1mov c,33h ;將ei-ei-1符號位送20h位mov 20h,cmov r2,6fh ;將ei-1-ei-2值送r2mov c,34h ;將ei-1-ei-2符號位送21h位mov 21h,clcall djf ;調(diào)用單字節(jié)帶符號的減法子程序mov 70h,r3 ;將差值(ei-ei-1)-(ei-1-ei-2)送70h單元mov c,22h ;將差值(ei-ei-1)-(ei-1-ei-2)的符號位值送35h位mov
27、 35h,cmov a,68h ;計算kp*(ei-ei-1),將kp值送amov b,6eh ;將ei-ei-1值送bmul ab ;兩數(shù)相乘mov 71h,b ;kp*(ei-ei-1)值存71h,72h單元mov 72h.amov a,69h ;計算ki*ei,將ki值送amov b,6bh ;將ei值送bmul ab ;兩數(shù)相乘mov 73h,b ;ki*ei值存73h,74h單元mov 74h,amov a,6ah ;計算kd*(ei-ei-1)-(ei-1-ei-2),將kd送amov b,70h ;將(ei-ei-1)-(ei-1-ei-2)值送bmul ab ;兩數(shù)相乘mov
28、75h,b ;kd*(ei-ei-1)-(ei-1-ei-2)值存75h,76h單元mov 76h,amov r1,71h ;計算kp*(ei-ei-1)+ki*ei,將kp*(ei-ei-1)值送r1,r2mov r2,72hmov c,33h ;將kp*(ei-ei-1)的符號位值送23h位mov 23h,cmov r3,73h ;將ki*ei值送r3,r4mov r4,74h mov c,30h ;將ki*ei值的符號位懂24h位mov 24h,clcall sjf ;調(diào)用雙字節(jié)帶符號加法子程序mov 77h,r5 ;將kp*(ei-ei-1)+ki*ei值送77h,78hmov 78h
29、,r6mov c,25h ;將kp*(ei-ei-1)+ki*ei值的符號位送36h位mov 36h,cmov r1,77h ;計算ui,將將kp*(ei-ei-1)+ki*ei值送r1,r2mov r2,78h mov c,36h ;將kp*(ei-ei-1)+ki*ei值的符號位送23h位mov 23h,cmov r3,75h ;將kd*(ei-ei-1)-(ei-1-ei-2)的值送r3,r4mov r4,76hmov c,35h ;將kd*(ei-ei-1)-(ei-1-ei-2)的符號位送23h位mov 24h,clcall sjf ;調(diào)用雙字節(jié)帶符號加法子程序mov 79h,r5
30、;將ui值送79h,7ahmov 7ah,r6mov c,25h ;將ui值的符號位送37hmov 37h,cmov r1,7dh ;計算ui,將ui-1值送r1,r2mov r2,7ehclr 23h ;ui-1值的符號位值恒為0mov r3,79h ;將ui值送r3,r4mov r4,7ahmov c,37h ;將ui值的符號位送24hmov 24h,clcall sjf ;調(diào)用雙字節(jié)帶符號加法子程序jnb 25h,pid3 ;判斷計算結(jié)果是否為負mov 7bh,#00h ;如果是負數(shù),則輸出電壓為0mov 7ch,#00hsjmp pid4pid3:mov 7bh,r5 ;否則,將計算得
31、到的ui值置7bh,7chmov 7ch,r6pid4:mov 6dh,6ch ;數(shù)據(jù)迭代,ei-1值送ei-2存儲單元mov 6ch,6bh ;ei值送ei-1存儲單元mov 7dh,7bh ;ui值送ui-1存儲單元mov 7eh,7chretpid endppd proc nearpd:mov a,5ch ;計算ei,先取溫度給定值clr csubb a,50h ;溫度給定值-溫度檢測值jnc pd1 ;判斷ei正負,如果為正,跳至pid1cpl a ;ei為負,下兩條指令求補add a,#01hsetb 30h ;ei為負,符號位置1sjmp pd2pd1:clr 30h ;ei為正,
32、符號位置0pd2:mov 6bh,a ;ei值存放在6bh單位元中mov r1,6bh ;計算ei-ei-1,先將ei值,送r1mov c,30h ;將ei的符號位值送20h位mov 20h,c;mov r2,6ch ;將ei-1值送r2mov c,31h ;將 ei-1的符號位值送21h位mov 21h,clcall djf ;調(diào)用單字節(jié)帶符號的減法子程序mov 6eh,r3 ;將差值ei-ei-1送6eh單元mov c,22h ;將差值ei-ei-1的符號位送33h位mov 33h,cmov r1,6ch ;計算ei-1-ei-2,先將ei-1值送r1mov c,31h ;將ei-1符號位
33、送20h位mov 20h,cmov r2,6dh ;將ei-2的值送r2mov c,32h ;將 ei-2的符號位值送21h位mov 21h,clcall djf ;調(diào)用單字節(jié)帶符號的減法子程序mov 6fh,r3 ;將差值ei-1-ei-2送6fh單元mov c,22h ;將差值ei-1-ei-2的符號位送34h位mov 34h,cmov r1,6eh ;計算(ei-ei-1)-(ei-1-ei-2),將ei-ei-1值送r1mov c,33h ;將ei-ei-1符號位送20h位mov 20h,cmov r2,6fh ;將ei-1-ei-2值送r2mov c,34h ;將ei-1-ei-2符號位送21h位mov 21h,clcall djf ;調(diào)用單字節(jié)帶符號的減法子程序mov 70h,r3 ;將差值(ei-ei-1)-(ei-1-ei-2)送70h單元mov c,22h ;將差值(ei-ei-1)-(ei-1-ei-2)的符號位值送35h位mov 35h,cmov
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 建筑工程違約合同條款
- 合作協(xié)議要求交保證金
- 醫(yī)務(wù)勞動合同范本
- 企業(yè)預(yù)存消費合同范本
- 養(yǎng)羊協(xié)議合同范本
- 公司柴油采購合同范本
- 出書授權(quán)合同范本
- 口罩廠勞動合同范本
- 2025周黑鴨合作伙伴關(guān)系管理策劃書
- 醫(yī)用鋼釘采購合同范例
- 【幼兒園園本教研】幼兒表征的教師一對一傾聽策略
- 人教版新教材高一上學(xué)期期末考試數(shù)學(xué)試卷及答案(共五套)
- 采血知情同意書模板
- Mysql 8.0 OCP 1Z0-908 CN-total認證備考題庫(含答案)
- 教科版二年級科學(xué)下冊 (磁鐵能吸引什么) 課件
- 學(xué)習(xí)探究診斷 化學(xué) 必修二
- 冀教2011版九年級英語全一冊《Lesson9ChinasMostFamous“Farmer”》教案及教學(xué)反思
- 三年級下冊音樂教學(xué)計劃含教學(xué)進度安排活動設(shè)計word表格版
- 無極繩絞車檢修技術(shù)規(guī)范
- 雷鋒生平事跡簡介
- 市政工程施工安全檢查標準
評論
0/150
提交評論