Nghiên cứu, thiết kế, chế tạo điều tốc cho các trạm thủy điện

MỤC LỤC Trang Đặt vấn đề 1 Phần I Lý thuyết cơ bản của thiết bị điều tốc 3 I.1. Sự điều chỉnh tua bin và sự đièu chỉnh tua bin và phân loại máy điều. 3 I.1.1. Sơ l−ợc về lý thuyết về điều chỉnh tua bin thuỷ lực 3 I.1.2. Giới thiệu các loại máy điều tốc trong trạm thuỷ điện 5 I.2. NHU CầU CáC LOạI MáY đIềU TẩC TRONG TRạM THUÛ đIệN 9 I.3. XU H−ÍNG CHế TạO CáC LOạI MáY DIềU TẩC TRêN THế GIÍI 9 I.4 Chế tạo máy điều tốc ở Việt Nam 11 Phần II. Nghiên cứu, chế tạo điều tốc điều chỉnh l−u l−ợng và điều tốc điều chỉnh phụ tải 13 II.1 Nghiên cứu xử dụng các bộ vi xử lý (P), â thông dụng vào việc chế tạo máy điều tốc 13 II.1.1 Lựa chọn sử dụng vi xử lý 13 II.1.2. ứng dụng vi xử lý 8051 13 II.1.3 Nghiên cứu ứng dụng vi xử lý tại trung tâm nghiên cứu thuỷ điện nhỏ – Viện Khoa học Thuỷ lợi 15 II.1.4. Thông tin từ n−ớc ngoài 17 II.2. Nghiên cứu mở rộng bộ điều khiển điều tốc l−u l−ợng thành bộ điều khiển đa tác dụng 19 II.3. Xác định ph−ơng pháp điều chỉnh tua bin 20 II.3.1. Sơ đồ điều khiển 20 II.3.2. Sơ đồ khối chức năng 23 II.4 Thiết kế phần cứng 23 II.4.1 CPU 23 II.4.2 Khối hiển thị 24 II.4.3 Khối đo l−ờng tần số 25 II.4.4 Khối báo hiệu mực n−ớc 26 II.4.5 Tín hiệu đóng máy sự cố bên ngoài 26 II.4.6 Các công tác thiết lập giá trị vận hành 27 II.4.7 Khối điều khiển 27 II.4.8 Khối cấp nguồn 28 II.5. Xây dựng phần mềm điều khiển 28 II.5.1 Lựa chọn ngôn ngữ 28 II.5.2 Sơ đồ khối tính toán chính 29 II.6 Chế tạo hoàn chỉnh bộ điều tốc 37 II.7 Xây dựng qui trình vận hành, sửa chữa, bảo d−ỡng 38 II.8 Đề xuất nâng cao chất l−ợng thiết bị 38 II.9 Bản vẽ nguyên lý 39 Phần III Nghiên cứu bộ điều tốc điều khiển phụ tải 40 III.1 Tổng quan 40 III.1.1 Thông tin từ n−ớc ngoài 40 III.1.2 Lựa chọn ph−ơng án thiết kế 42 III.2 Thiết kế phần cứng 50 III.2.1 CPU 50 III.2.2 Khối đo l−ờng tần số 51 III.2.3 Công tác thiết lập giá trị vận hành 51 III.2.4 Khối điều khiển tải 53 III.2.5 Đièu khiển kiểu Rơle 53 III.2.6 Khối cấp nguồn 53 III.3 Xây dựng phần mềm điều khiển 54 III.3.1 Lựa chọn ngôn ngữ 54 III.3.2 Sơ đồ khối tính toán chính 54 III.4 Chế tạo hoàn chỉnh bộ điều khiển 59 III.5 Đề xuất nâng cao chất l−ợng thiết bị 60 III.6 Bản vẽ nguyên lý 61 Phụ lục I Phần mềm điều khiển l−u tốc điều chỉnh l−u l−ợng 63a Phụ lục II Phầm mềm điều khiển điều tốc điều chỉnh phu tải 102

pdf120 trang | Chia sẻ: lvcdongnoi | Lượt xem: 2778 | Lượt tải: 1download
Bạn đang xem trước 20 trang tài liệu Nghiên cứu, thiết kế, chế tạo điều tốc cho các trạm thủy điện, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
mmand X05af: ret ;============================================================= ;X05B0:Nap gia tri 1Ah vao cac o nho (23h),(22h),(21h),(20h) ; Khi hien thi, ROM 31Ah=00 -> Tat het cac LED 7 thanh ;============================================================= KhongHienSo: mov r0,#24h mov r2,#4 X05b4: dec r0 mov @r0,#1ah djnz r2,X05b4 ret ;============================================================== X05e6: ;Tien bo xung - Phuc vu X028b mov r2,#80h jb Acc.4, X05f1 mov r2,#60h jb Acc.5, X05f1 mov r2,#98h X05f1: ret ; 05f1 - 83 . ;=============================================================== ; Giam dan o nho chi ra trong R0, neu = 0 thi gan gia tri 1 ;=============================================================== X0617: mov a,r6 jb Acc.6, X062e ; d=0 - Trong luoi jb Acc.5, X062e ; Doc lap & x=0 Mode 1,2 mov a,r6 ; Doc lap & mode 3 swap a ; A=0D0N.0dxn anl a,#3 ; A=xn=11,10,01 add a,#0f8h mov r3,a ; R3=FBh,FAh,F9h mov r2,#6 X0626: call X073a jb Acc.7, X062e djnz r2,X0626 ret X062e: clr a ret X0661: mov a,r6 jb Acc.6, X066e ; Neu chay doc lap mov r0,#7eh mov a,@r0 jz X066e mov r1,#W_level mov @r1,#2 X066e: mov r0,#67h ret Nap1: mov @r0,#3 ; 3 -> (71h) mov r0,#28h ; mov @r0,#4 ; 4 -> (28h) inc r0 ; mov @r0,#5 ; 5 -> (29h) ret ; B¸o c¸o khoa häc §Ò tµi KC07- 04 80 ; X0689: mov r0,#Flags mov a,@r0 mov r0,#29h jb Acc.0, X0691 dec r0 X0691: inc @r0 setb f0 ret X0696: mov r0,#28h mov a,@r0 add a,#0fdh jc X06a3 inc r0 mov a,@r0 add a,#0fdh jnc X06b3 X06a3: mov a,r6 jb Acc.6, X06b3 mov r0,#6ah mov @r0,#0ah dec r0 jb Acc.5, X06b3 mov @r0,#6 dec r0 mov @r0,#0ch X06b3: ret ;(Quay tro lai X016f) X06b4: mov r2,#20h mov r3,#0e1h jb Acc.5, X06c2 mov r2,#0 jb Acc.4, X06c2 mov r2,#0eah dec r3 X06c2: ret ;============================================================== R3R2_Add_7978: ; Kiem tra o nho (79h.78h) so voi tri so R3.R2 mov r0,#78h mov a,@r0 add a,r2 inc r0 mov a,@r0 addc a,r3 ret ;=============================================================== ; Doan chuong trinh dong Role qua cong P1 ;=============================================================== Dong_Role: cjne R4,#1Dh,Next1 call Ngat_Role ; Ngat Toan bo role ajmp EndNext Next1: cjne R4,#69h,Next2 setb p2.4 ; Close ON clr p2.5 setb p3.4 ; Over ON clr p3.5 clr p2.6 ; Open OFF setb p2.7 setb p3.0 ; Sync OFF clr p3.1 ajmp EndNext Next2: cjne R4,#59h,Next3 B¸o c¸o khoa häc §Ò tµi KC07- 04 81 setb p2.4 ; Close ON clr p2.5 setb p3.5 ; Over OFF clr p3.4 clr p2.6 ; Open OFF setb p2.7 setb p3.0 ; Sync OFF clr p3.1 ajmp EndNext Next3: cjne R4,#95h,X06df setb p2.6 ; Open ON clr p2.7 clr p2.4 ; Close OFF setb p2.5 setb p3.0 ; Sync OFF clr p3.1 clr p3.4 ; Over Speed OFF setb p3.5 EndNext: nop nop djnz r3,Dong_Role djnz r2,Dong_Role ; R2=0A (X06e0) X06df: ret X06e0: mov r0,#1dh mov @r0,#0feh mov r0,#72h mov @r0,#0dch inc r0 mov @r0,#0dch mov r0,#2ah mov @r0,#8 mov r2,#0ah mov r0,#29h mov @r0,#5 ret X0700: mov r0,#38h mov r1,#36h call X074c jb Acc.7, X0711 mov r1,#38h mov r0,#36h call X074c jb Acc.7, X072e X0711: mov r0,#3ah mov r1,#3ch call SubR0_R1 call Cpl2Nor mov a,r2 rr a rr a nop anl a,#3fh mov r2,a jz X072e X0722: mov a,r7 ; R7 chua dia chi 69h hoac 6ah mov r0,a mov r3,#0fbh X0726: mov a,@r0 add a,r3 jnc X072e ; @R7 < 5 call DecToOne djnz r2,X0726 X072e: mov a,r7 B¸o c¸o khoa häc §Ò tµi KC07- 04 82 mov r0,a call DecToOne ; Giam noi dung @R7 ret X0735: call X0041 mov r2,a ret X073a: mov a,@r1 add a,@r0 mov r4,a inc r0 inc r1 mov a,@r1 addc a,@r0 mov r5,a inc r0 inc r1 mov a,r4 add a,r3 mov a,r5 addc a,#0ffh ret X074c: mov r2,#4 mov r3,#0fbh X0750: call X073a jb Acc.7, X0756 djnz r2,X0750 X0756: ret X0757: mov r2,#0beh mov r3,#0d8h call R3R2_Add_3F3E ; Neu Ts may phat > 39,8 thi bit 7=1 ret X0764: mov r2,#6 mov r3,#0ffh X0768: call X073a jb Acc.7, X078a djnz r2,X0768 mov r0,#34h mov r1,#3ch call SubR0_R1 call Cpl2Nor X0776: mov r0,#7bh mov a,@r0 anl a,#0f8h jz X077f call DecToOne X077f: mov r0,#7ch mov a,@r0 anl a,#0f8h jz X0788 call DecToOne X0788: djnz r2,X0776 X078a: ret ;============================================================== X078d: mov r0,#40h mov a,@r0 add a,r2 inc r0 mov a,@r0 addc a,#0 ret X0797: mov r0,#40h mov a,@r0 add a,r2 inc r0 mov a,@r0 addc a,#0ffh ret B¸o c¸o khoa häc §Ò tµi KC07- 04 83 Ngat_Role: clr p2.4 ; Close OFF setb p2.5 clr p2.6 ; Open OFF setb p2.7 setb p3.0 ; Sync OFF clr p3.1 clr p3.4 ; Over Speed OFF setb p3.5 nop nop ret ; Tong cong 16 chu ky may (8039) X07b0: mov r0,#1dh ; 2 ck mov @r0,#70h ; 2 ck (1Dh)=70h mov r2,#50h ; 2 ck X07b6: call Ngat_Role nop nop ; 16 + 4 =20 ck djnz r3,X07b6 djnz r2,X07b6 ret ;============================================================== ; Doc ROM ;=============================================================== ROM_MODE: mov a,r6 ; R6=0dxn0D0N swap a ; A =0D0N0dxn anl a,#7 ; A =00000dxn orl a,#38h ; A =00111dxn mov dptr,#ROM_DB ; Doc ROM tu 39h,3Ah,3Bh,3Dh,3Eh,3Fh movc a,@a+dptr ; FA(MODE3),FB(MODE2),FC(MODE1),FD(MODE3),B2(MODE2),10(MODE1) mov r0,#7ah mov @r0,#4 ; 4 -> (7ah) inc r0 ; mov @r0,a ; So doc tu rom -> (7Bh) inc r0 mov @r0,a ; So doc tu rom -> (7Ch) inc r0 mov @r0,a ; So doc tu rom -> (7Dh) ret X07e2: mov a,r6 jb Acc.0, X07ee ;Neu HOA thi ket thuc call ROM_MODE mov r0,#7ch mov @r0,#4 dec r0 mov @r0,#4 X07ee: mov r0,#7ah mov @r0,#4 ret X07f3: mov @r0,#2 ; r0 = 6ch or 6dh ; truoc khi goi doan nay hai op nay deu giam toi 1 mov a,@r1 ; r1 tro toi dia chi 70h or 71h anl a,#7 ; giu lai 3 bit cuoi mov @r1,a add a,#0fbh ; so sanh voi 5 (nho hon) jc X07fe inc @r1 X07fe: ret ;============================================================== XuLy: call X0083 ; 14 83 call Dem_Chu_Ky ; 14 60 call X0c00 ; 94 00 call Tinh_Tan_So ; 54 83 call X0b00 ; 74 00 B¸o c¸o khoa häc §Ò tµi KC07- 04 84 call ChuanBiHienThi ; 34 00 call X0a00 ; 54 00 call Tinh_PD ; 54 a0 call X0972 ; 34 72 nop nop ret ;==================================================================== X0083: mov r1,#Count ; 2Fh mov a,@r1 ; (Count) -> ACC nop anl a,#0fh ; Xet 4 bit cuoi jnz X0092 ; Neu 4 bit cuoi khac 0 mov r0,#50h ; Neu 4 bit cuoi bang 0 - Chia het cho 16 call DecToOne ; Giam o nho 50h sau 16 lan dem tan so inc r0 call DecToOne ; Giam o nho 51h sau 16 lan dem tan so X0092: ;call SW12ToR6 ; Dua gia tri bien SW12 -> ACC -> R6 mov r0,#SW12 mov a,@r0 mov r6,a ;ret mov r3,a ; R3 = SW12 mov r0,#Flags mov a,@r0 mov r7,a ; ret nop nop anl a,#64h ; Xet bit 6,5,2 jnz X00d9 ; 0 -> Ket thuc clr TR0 call Doc_Cong_Tac mov r0,#Flags mov a,@r0 jb Acc.7, X00af ; Neu bit 7 = 1, jb Acc.3, X00af ; Neu bit 3 = 0 (bang 1 sau khi da dao) mov a,r3 ; Neu bit 3 = 1 (bang 0 sau khi da dao), A=R3=SW12 xrl a,r6 ; R6=0dxn.0D0N XOR SW12 (=0dxn.0D0N) jb Acc.0, X00af ; =1-> N=0 (Cong tac co su thay doi o vi tri HOA) call X07b0 ; Neu khong doi-> Ngat ROLE trong R3*R2 lan =SW12*50h (0,075 ms) X00af: mov a,r2 ; Trong Doc_Cong_Tac r2=0000ldcn mov r0,#27h X07d2: jb Acc.1, X07dc ; Neu cong tac thay doi gia tri call DecToOne ; Neu co tin hieu CloseCommand thi giam o nho (27h) jnz X07de mov a,#2 orl a,r7 ; R7=Flags mov r7,a ; set bit 1 X07dc: mov a,#2 X07de: anl a,#7 ; lay 3 bit thap mov @r0,a nop mov a,R7 jb Acc.7, X00c2 mov a,r6 ; A=0dxn.0D0N anl a,#70h ; A=0dxn.0000 (Che do dieu tan - Normal) jb Acc.6, X00c0 ; d=1 -> Doc lap mov a,#50h ; Neu trong luoi ->A=0101.0000 ->Dieu tan, mode3, doclap X00c0: nop mov r6,a ; Nap A tro lai R6, =0dxn.0000 hoac 0101.0000 X00c2: mov r0,#7eh mov a,@r0 jnz X00cd ; (7Eh) FFh mov a,r6 ; Neu (7Eh)=FFh anl a,#45h ; A=0d00.0D0N jz X00d1 ; = 0 -> Normal + Luoi B¸o c¸o khoa häc §Ò tµi KC07- 04 85 X00cd: mov r0,#2dh ; Nguoc lai (2Dh)=1 mov @r0,#1 X00d1: mov r0,#SW12 mov a,r6 mov @r0,a ; R6 -> (SW12) mov r0,#Flags mov a,r7 mov @r0,a ; R7 -> Flags X00d9: ret ; End X0083 ;======================================================================== Dem_Chu_Ky: mov r1,#48h mov r2,#8 ; So lan lap cho XoaSoHienThi clr a ; A=00h XoaSoHienThi: mov @r1,a ; 00 -> (48h) inc r1 djnz r2,XoaSoHienThi ; Dien 00 vao (49h,4Ah,4Bh,4Ch,4Dh,4Eh,4Fh) mov r0,#Count ; (2Fh) mov a,@r0 ; A=(Count) inc @r0 ; (Count)+1 anl a,#3 ; Lay 2 bit cuoi cua Count jnz Tieptuc2 ; Count khong chia het cho 4 khong KTLP call KiemTraLechPha ; 4 lan Dem_Chu_Ky, 1 lan KTLP Tieptuc2: clr f1 ; F1=0, Chua dem Tan so X0ee5: ; mov r0,#Flags mov a,@r0 jb Acc.7,TanSoMay ; Neu bit 7=1 chi kiem tra tan so may phat ; Neu bit 7 cua (Flags)=0 mov a,r6 ; Neu cong tac HOA khong o vi tri HOA nop jb Acc.0,TanSoMay ; chi kiem tra tan so may phat TanSoLuoi: setb p3.3 ; Cau hinh cong Input mov TL1,#0 mov TH1,#0 jnb p3.3,$ ; Neu luoi=0 thi cho khi luoi=1 jb p3.3,$ ; Neu luoi=1 thi cho khi luoi=0 call X0d00 ; Tre R2*0.250 ms = (3Fh)*0,250 ms mov @r0,#17h ; 17h ~ 23 ms, TS luoi qua thap -> Reset jnb p3.3,$ ; Neu luoi=0 thi cho khi luoi=1 jb p3.3,$ ; Neu luoi=1 thi cho khi luoi=0 setb TR1 ; Khoi dong Timer1 de dem tan so setb TR0 jnb p3.3,$ ; Neu luoi=0 thi cho khi luoi=1 jb p3.3,$ ; Neu luoi=1 thi cho khi luoi=0 clr TR1 ; Dung timer dem tan so clr a Wait4ChuKy: mov @r0,#17h ; 2Eh ~ 46 ms, TS luoi qua thap -> Reset jnb p3.3,$ ; Neu luoi=0 thi cho khi luoi=1 jb p3.3,$ ; Neu luoi=1 thi cho khi luoi=0 djnz R5,Wait4ChuKy ; R5 =4 trong X0D00 clr TR0 mov p0,#0ffh ; Tat den LED call X0d1e ; So dem duoc la gia tri 2 byte: R3R2 mov r5,#6 ; mov r0,#58h ; mov r1,#5ah ; mov r0,#5eh ; call NapR3R2ToR0 ; Tai dia chi 5Fh.5Eh chua gia tri 2 byte cua tan so luoi dien mov r0,#77h ; B¸o c¸o khoa häc §Ò tµi KC07- 04 86 call DecToOne mov r1,#LED1 X08ec: mov @r1,#1ah ; 1Ah -> LED1, khong hien so -> Nhap nhay so cuoi mov r0,#Flags mov a,@r0 jb acc.3,X08f6 ; neu bit Flags.3=0 thi thoi (HOA) call KhongHienSo ; Neu khong o che do HOA -> Tat het LED ( Nhap nhay?) X08f6: TanSoMay: mov TL1,#0 mov TH1,#0 setb p3.2 jnb p3.2,$ ; Cho den khi T1=1 (May phat) jb p3.2,$ ; Cho den khi T1=0 (May phat) call X0d00 ; (Trong doan nay stop Timer) mov @r0,#40h ; (Doan X0d3a cu)~ 14.5 Hz jnb p3.2,$ ; Cho den khi T1=1 (May phat) jb p3.2,$ ; Cho den khi T1=0 (May phat) setb TR1 setb TR0 mov @r0,#40h ; jnb p3.2,$ ; Cho den khi T1=1 (May phat) jb p3.2,$ ; Cho den khi T1=0 (May phat) clr TR1 ; Dung timer dem tan so clr a Wait4ChuKy2: mov @r0,#40h ; 45h ~ 14.5 Hz, TS luoi qua thap -> Reset jnb p3.2,$ ; Neu luoi=0 thi cho khi luoi=1 jb p3.2,$ ; Neu luoi=1 thi cho khi luoi=0 djnz R5,Wait4ChuKy2 ; R5 =4 trong X0D00 clr TR0 clr a mov p0,#0ffh ; Tat den LED call X0d1e mov r5,#0eh mov r0,#30h mov r1,#32h mov r0,#3eh call NapR3R2ToR0 cpl f1 ; F1=1 Dem xong tan so ret ; END OF Dem_Chu_Ky ;=================================================================== X0d00: mov a,3fh ; A=(3Fh) Byte cao cua so dem chu ky may phat mov r2,a ; Dua noi dung (3Fh) vao R2 X0d04: mov r1,#7Dh X0d06: djnz r1,X0d06 ; Tre 7Dh=125 x 2 chu ky=250chu ky= 0,250 ms djnz r2,X0d04 ; Tre R2 x 0,250 ms (50 Hz - R2=1Fh=31) mov r0,#Dsp_Count ; R0=(1Dh) mov r1,#1ah ; R1=1Ah mov r5,#4 ; R5=4 CLR TR0 ; Dung Timer call Ngat_Role clr a mov @r0,a ; 00 -> (Dsp_Count R5-rb1) ret ;============================================================== X0d1e N1: mov @r0,#0 ; 0 -> (1Dh) mov R3,TH1 mov R2,TL1 mov r3,a SETB tr0 ret ; R3.R2 = 1F40h (8000) N2: mov R3, #0Bh mov R2, #0DBh B¸o c¸o khoa häc §Ò tµi KC07- 04 87 mov a, TL1 add a,R2 mov a, TH1 addc a, R3 jb acc.7,N1 mov TH1,#0F4h mov TL1,#24h ret ;============================================================== ; Kiem tra do lech pha 2 may la (0,5 x R4) ms ;============================================================== So_Pha1: mov r4,#1 ; Lan dau R4=1 So_Pha: mov r1,#Dsp_Count ; mov @r1,#0d6h ; 1101.0110 -> (Dsp_Count) setb p3.2 ; (1Dh)=D6=214 setb p3.3 T0_Duong: mov a,@r1 ; jb acc.5,Ketthuc1 ; Neu (1D.5)=1, da qua 22 chu ky hien thi jb p3.3,T0_Duong ; (1Dh) = 1011.1111 = BFh= 191 T0_Am: mov a,@r1 ; den khi T0=0, kiemtra tiep jb acc.5,Ketthuc1 ; Neu (1D.5)=1 thi ket thuc, (Dsp_Count)=FAh jnb p3.3,T0_Am ; (1D.5)=0 -> Neu T0=0 tiep tuc kiem tra (1D.5) call Doi_nua_ms ; khi T0=1 doi sau 0,5*R4 ms jnb p3.3,Ketthuc2 ; jnt1 Neu T1=0 thi ket thuc, A=4Eh jb p3.3,$ ; Neu T1=1, (T0=1) cho doi call Doi_nua_ms ; khi T0=0, doi sau 0,5*R4 ms jb p3.2,Ketthuc2 ; jt1 Neu T1=1 thi ket thuc, A=4Eh ; T1 khong cham pha so voi T0 qua 0,5*r4 ms jnb p3.2,$ ; jnt1 Neu T1=0, cho den khi T1=1 call Doi_nua_ms ; Tre sau 0,5*R4 ms jnb p3.3,Ketthuc2 ; jnt0 Neu T0=0 thi ket thuc, A=4Eh jb p3.2,$ ; jt1 Neu T0=1 cho den khi T1=0 call Doi_nua_ms ; Doi 0,5*R4 ms clr a ; jnb p3.3,Ketthuc1 ; jnt0 Neu T0=0 thi ket thuc (Dsp_Count)=FAh ; T0 khong cham pha so voi T1 qua 0,5*r4 ms: A=0 Ketthuc2: mov a,#4eh ; Neu T0=1 thi ket thuc A=4Eh va (Dsp_Count)=FAh ; T0 cham pha so voi T1 qua 0,5*r4 ms: A=4Ef=0100 1110 Ketthuc1: mov @r1,#0fah ; Neu bit5 cua (Dsp_Count)=1 thi FAh=11111010 -> (Dsp_Count) ret ; Doi_nua_ms: mov a,r4 ; A=R4 1 ck rl a ; Neu R4<8F: A=R4*2 1 ck add a,r4 ; A=3*R4 1 ck mov r3,a ; R3=3*R4 1 ck Lap3: mov r2,#52h ; R2=82 2 ck djnz r2,$ ; X0eb2 82*2 ck = 164 ck djnz r3,Lap3 ; 2 ck ret ; ;==================================================== ; Kiem tra do lech pha ;==================================================== KiemTraLechPha: mov r0,#7eh ; R0=7Eh clr c mov a,@r0 ; (7Eh) -> A =3F=0011.1111 (Truoc khi goi KTLP) rlc a ; A*2=7E, C = bit MSB cua (7Eh)=0 mov @r0,a ; A=7E -> (7Eh) nop call So_Pha1 ; Kiem tra do lech pha 2 may < 0,5*R4 ms ; Neu lech pha lon hon 0,5*R4 ms A= 4E =0100 1110 B¸o c¸o khoa häc §Ò tµi KC07- 04 88 ; Neu lech pha nho hon 0,5*R4 ms A= 00 =0000 0000 jb acc.5,X0ef8 ; Neu ACC.5 = 1 (Truong hop f < 22 Hz) jb acc.6,KThuc_So_Lech ; Neu lech lon (A=4E -> ACC.6=1) -> Ket thuc inc @r0 ; Neu lech nho (A=0 -> ACC.6=0) mov a,@r0 ; (7Eh) -> A jnz Xoa_A ; Neu a0 (tuc la (7Eh) FF) thi xoa A=0 X0ef8: mov r0,#Flags ; Neu ACC=0, tuc ban dau (7Eh)=FF mov a,@r0 ; Dua (Flags) - >A orl a,#8 ; Bat bit thu 3 trong 2 t/hop: ACC.5=1 mov @r0,a ; Tan so < 22 Hz (Chu ky = 44 ms) Xoa_A: clr a KThuc_So_Lech: ret ;========================================================================== X0c00: mov a,r6 ; A=0dxn.0D0N -> N=1 Hoa dien jb Acc.0,X0c0b ; Neu Hoa X0e17: mov r4,#28h call Add_3F3E_E0C0 ; Cong gia tri 2 byte (3Fh.3Eh) voi E0C0h jb Acc.7,X0e1f ; Neu (3F.3E) khi cong voi E0C0h bit 7 bang 1 mov r4,#3ch ; f<= 50 Hz R4=28h X0e1f: nop ; ret f> 50 R4= 3Ch X0cf3: mov r0,#3eh mov r1,#3ch call SubR0_R1 ; Gia tri hien tai - Gia tri truoc do mov a,r2 add a,r4 mov a,r3 addc a,#0 ; (R3.R2) + R4 jb Acc.7,X0c0b ; bit 7 = 1 -> Delta F < +0,2 Hz mov r0,#7ah mov @r0,#4 X0c0b: ;call Flags2ACC mov r0,#Flags mov a,@r0 jb Acc.7,X0c16 mov r6,#70h ; R6=0111.0000 Dieu tan-mod1-doclap (Flags.7=0) mov r0,#68h nop X0c16: nop X0630: mov a,r6 anl a,#61h ; A=0dx0.000N xrl a,#20h ; A=0 khi d=0,x=1,N=0 (Luoi,khong HOA) jnz X065f ; Neu khong phai (Luoi,mode1&2,khong HOA) thi ket thuc mov r2,#65h mov r3,#0e1h mov a,r6 jb Acc.4,X0640 ; Mode1 R3R2=E165 - 1E9B: 51 Hz mov r2,#0fch ; Neu mode 2 R3R2=E10F - 1EF1: 52 Hz X0640: call R3R2_Add_3F3E jb Acc.7,X0656 mov r2,#50h ; Neu tan so nho hon mov r3,#0e0h mov a,r6 jb Acc.4,X064e ; thi neu mode 2 R3R2=E050 -1FB0:49 Hz mov r2,#72h ; Mode 1 R3R2=DF72 - 208E:48 Hz dec r3 X064e: call R3R2_Add_3F3E jb Acc.7,X065f mov r0,#2ah ; Neu Tan so nho hon mov @r0,#3 ; (2Ah)=3 X0656: mov r6,#30h ; R6=0011.0000 (Luoi-Mode1-Normal) mov r0,#69h mov @r0,#1 ; (69h)=1 inc r0 mov @r0,#1 ; (6Ah)=1 X065f: ;sel mb1 B¸o c¸o khoa häc §Ò tµi KC07- 04 89 ;ret mov a,r6 jb Acc.0, X0c2c jb Acc.6, X0c45 call Giam2Dh ; X0b85 xrl a,#8 jnz X0c35 mov r0,#68h mov @r0,#1 mov r0,#7ah mov @r0,#1 X0c2c: mov r0,#68h mov a,@r0 add a,#0fbh jnc X0c35 mov @r0,#4 X0c35: mov r0,#69h mov a,#1 nop mov @r0,a inc r0 ; 6Ah mov @r0,a mov r0,#7bh ; 7Bh mov @r0,a inc r0 ; 7Ch mov @r0,a X0e47: ;call X0e47 inc r0 ; 7Dh mov @r0,a mov r0,#2ah mov a,@r0 dec a jnz X0e53 mov r0,#2dh mov @r0,#1 X0e53: ret ; End X0C00 ;======================================================================= ; Doc ROM khi o che do doc lap ;======================================================================= X0c45: swap a ; A=R6 -> A=0D0N0dxn anl a,#7 ; A=00000dxn orl a,#38h ; A=00111dxn =3D - 3F mov dptr,#ROM_DB ; Doc ROM tu 3Dh,3Eh,3Fh movc a,@a+dptr mov r2,a mov r0,#7dh mov r3,#3 X0c50: mov a,r2 add a,@r0 jnc X0c57 mov @r0,#4 X0c57: dec r0 djnz r3,X0c50 ; Thuc hien 3 lan ret ;================================================================== Tinh_Tan_So: mov r0,#3eh mov r1,#48h ; Doi so dem tu 3F3E thanh Gia tri tan so * 100 call Chuky2TanSo ; Nap vao 49h.48h mov a,r6 jb Acc.0,X0a9f ; Neu khong hoa thi ket thuc mov r0,#5eh ; Neu hoa, tinh hieu tan so mov r1,#4ah call Chuky2TanSo ; Doi so dem tu 5F5E thanh gia tri tan so * 100 mov r0,#48h mov r1,#4ah call SubR0_R1 ; Hieu 2 tan so B¸o c¸o khoa häc §Ò tµi KC07- 04 90 call Cpl2Nor ; Doi sang dang binh thuong mov r0,#42h call NapR3R2ToR0 ; Nap gia tri hieu tan so vao 43h.42h (bit 16 chi dau) X0a9f: ret ; End TinhTanSo ;========================================================================== Chuky2TanSo: mov r2,#5ah mov r3,#62h mov r4,#2 ; Chu y : 2625A00h=40000000=1/0,000000025 mov r7,#18h X0bdd: ;call X0bdd ;ret mov r5,#0 ;======================================================== CplR0_To_R1: ;call CplR0_To_R1 mov a,@r0 cpl a add a,#1 mov @r1,a inc r0 inc r1 mov a,@r0 cpl a addc a,#0 mov @r1,a dec r0 dec r1 ;ret X0be1: clr c mov a,r2 rlc a mov r2,a mov a,r3 rlc a mov r3,a mov a,r4 rlc a mov r4,a mov a,r5 rlc a mov r5,a ;======================================================== R5R4_Add_R1: ; call R5R4_Add_R1 mov a,@r1 add a,r4 mov r4,a inc r1 mov a,@r1 addc a,r5 mov r5,a ;ret dec r1 inc r2 jc X0bf8 dec r2 ;======================================================== R5R4_Add_R0: ; call R5R4_Add_R0 mov a,@r0 add a,r4 mov r4,a inc r0 mov a,@r0 addc a,r5 B¸o c¸o khoa häc §Ò tµi KC07- 04 91 mov r5,a ;ret dec r0 X0bf8: djnz r7,X0be1 mov a,r2 mov @r1,a inc r1 mov a,r3 mov @r1,a ret ; End TinhTanSo ;======================================================================= X0b7f_j: jmp X0b7f ;======================================================================= X0b00: mov a,r6 anl a,#7Fh ; Xoa bit 7 mov r6,a mov r1,#44h mov @r1,#3eh inc r1 mov @r1,#1fh ; (45h.44h)=1F3Eh (50,01 Hz) mov r0,#Flags mov a,@r0 jb Acc.1,X0b65 jb Acc.7,X0b7f_j ; Ket thuc mov @r1,#1dh dec r1 mov @r1,#7ah ; (45h.44h)=1D7Ah ( 53 Hz) mov r0,#5eh call SubR0_R1 ; R3.R2=(5Fh.5Eh)-(45h.44h) jb Acc.7,X0b37 mov r1,#45h mov @r1,#23h dec r1 mov @r1,#93h ; R5.R4=2393h (43,9 Hz) mov r0,#5eh call SubR0_R1 ; R3.R2=(5Fh.5Eh)-(45h.44h) jb Acc.7,X0b37 mov r0,#5eh call NapR3R2FromR0 ; R3.R2=(5Fh.5Eh) mov r0,#44h call NapR3R2ToR0 ; (45h.44h)=(5Fh.5Eh) mov a,r6 orl a,#80h ; Bat bit 7 mov r6,a X0b37: mov a,r6 mov r0,#SW12 ; Nap R6 -> SW12 mov @r0,a jb Acc.0,X0b7f mov r2,#40h mov r3,#1fh jb Acc.6,X0b55 mov r0,#2dh mov a,@r0 dec a jnz X0b4d mov a,r6 jb Acc.2,X0b55 X0b4d: call Doc7Eh ; A=NOT(7Eh) jnz X0b55 mov r2,#69h mov r3,#1ch X0b55: mov r0,#44h call NapR3R2ToR0 ;(45h.44h)=1C69h (55Hz) hoac 1F40 (50Hz) mov a,r6 jb Acc.6,X0b7f ; B¸o c¸o khoa häc §Ò tµi KC07- 04 92 jb Acc.2,X0b7f mov r0,#W_level mov a,@r0 jb Acc.0,X0b7f X0b65: mov r0,#44h mov r2,#60h mov r3,#0ffh call Add_R2_R3 ;============================================================== CplR3R2: ;call CplR3R2 ; Lay so bu 2 cua (R3.R2) mov a,r2 cpl a add a,#1 mov r2,a mov a,r3 cpl a addc a,#0 mov r3,a ;ret call R3R2_Add_3F3E jb Acc.7, X0b7f mov r2,#0c0h mov r3,#1 mov r0,#3eh call Add_R2_R3 mov r0,#44h call NapR3R2ToR0 X0b7f: ret ; End X0B00 ;============================================================== ChuanBiHienThi: X0F22: ;call X0F22 , vi dang mb1) ; Tien bo xung mov a,r6 ; A=0dxn0D0N jb Acc.5,X0f30 mov r0,#26h call DecToOne ; X0e10 jnz X0f30 mov r0,#7bh mov @r0,#1 X0f30: mov r0,#Flags mov a,@r0 jb Acc.7,X0f3d mov a,r6 jb Acc.6,X0f3d mov r0,#2ah mov @r0,#0ah X0f3d: ;ret mov r0,#42h ; Chua chenh lech tan so luoi va may phat mov a,@r0 mov r2,a ; R2=(42h) inc r0 ; R0 =43h mov a,@r0 anl a,#7Fh mov r3,a ; Xoa bit dau jnz X0916 ; Neu 0 mov a,r2 ; Neu = 0 Kiem tra R2 co lon hon 2 khong add a,#0fdh jc X0916 mov r2,#0 ; Neu khong lon hon 4 -> Delta F < 0,02 mov @r0,#0 ; ->gan gia tri Delta F =0,00 X0916: mov a,r6 jb Acc.0,DoiHe ; N=1 HOA -> Hien thi chenh tan so (chi co 3 chu so) mov r0,#48h ; Neu khong phai HOA -> Hien thi tan so may phat call NapR3R2FromR0 ; R3.R2=(49h.48h) gia tri cua tan so may phat mov a,r6 ; a=0dxn.0D0N jb Acc.6,LamTron ; Chay doc lap d=1 -> Lam tron, hien thi 3 so jb Acc.2,DoiHe ; Neu chay trong luoi & Dieu toc-> Hien thi 4 chu so B¸o c¸o khoa häc §Ò tµi KC07- 04 93 LamTron: mov a,r2 ; Neu trong luoi & W_L -> Lam tron so add a,#5 ; + 5 vao so tan so may phat ( De lam tron) mov r2,a mov a,r3 addc a,#0 mov r3,a DoiHe: mov r0,#SoDonvi ;(SoDonvi=(4Dh)+10h (so co dau thap phan 310h-319h) mov @r0,#10h dec r0 ; R0=SoChuc (4Ch) Chia1000: mov a,r2 ; Cong R3.R2 + FC18h -> R3.R2 add a,#18h mov r2,a mov a,r3 addc a,#0fch ; FFFF-FC18=3E7h=999 mov r3,a jnc Hoiphucsodu1 ; Neu R3.R2 < 1000 thi khi cong FC18 khong co Carry inc @r0 ; Neu R3.R2 >= 1000, tang (So Chuc) jmp Chia1000 Hoiphucsodu1: inc r0 ; R0=SoDonvi(4Dh), Neu R3.R2 < 1000 mov a,r2 ; Cong R3.R2 +1000 nop add a,#0e8h mov r2,a mov a,r3 addc a,#3 mov r3,a ; R3.R2 +1000 (3E8h) -> R3.R2 Chia100: mov a,r2 ; Cong R3.R2 + FF9C -> R3.R2 add a,#9ch mov r2,a mov a,r3 addc a,#0ffh mov r3,a jnc Hoiphucsodu2 ; Neu R3.R2 < 100 thi khi cong voi FF9C khong co Carry inc @r0 ; Neu R3.R2 >=100, tang (So Don vi) jmp Chia100 Hoiphucsodu2: inc r0 ; R0=4Eh=So phan Chuc, Neu R3.R2 < 100 mov a,r2 add a,#64h ; Cong Byte thap R2 + 100 Chia10: add a,#0f6h jnc Hoiphucsodu3 ; Neu R2 < 10 thi khi cong voi F6 khong co Carry inc @r0 ; Neu R3.R2 >=10, tang (SophanChuc) jmp Chia10 Hoiphucsodu3: inc r0 ; R0=4Fh=So phan tram, ; Neu R2 < 10 add a,#0ah mov @r0,a ; (50h) ;ret ; Quay ve DoiHe mov a,r6 ; a=0dxn.0D0N jb Acc.0,HienSoHoa ; Neu che do HOA N=1 call Hien3Chuso jmp NapLED HienSoHoa: mov r0,#SoChuc ; Luc nay la Chuc cua Delta F mov a,@r0 jnz XetDau ; Neu tri so hang chuc 0 -> DeltaF > 10,00 Hz mov @r0,#1ah ; Neu Chuc = 0 -> 1Ah -> (SoChuc) -> tat LED4 (so chuc) XetDau: mov r1,#43h ; Byte cao cua Delta F mov a,@r1 jb Acc.7,NapLED ; Neu Delta F la so duong thi nap LED ngay B¸o c¸o khoa häc §Ò tµi KC07- 04 94 mov a,@r0 ; Neu la so am, xet tiep Delta F Chuc xrl a,#1ah ; (neu Chuc = 0 -> Chuc=1Ah(tat LED) -> (Chuc XOR jz DauTru ; Chuc = 0: Khong dich phai, hien dau (-)o LED4 call DichPhaiSoHienThi ; Neu Chuc 0 Dich chuyen du lieu DauTru: mov r0,#SoChuc ; SoChuc->SoDonvi->SophanChuc->SophanTram mov @r0,#42h ; ROM(442h)=20h -> Hien dau tru (-) o vi tri LED4 (Chuc) ;=================================================================== NapLED: mov r0,#SoChuc mov r1,#LED4 mov r2,#4 clr TR0 X0953: mov a,@r0 ; Nap cac gia tri (SoChuc),(SoDonvi), mov @r1,a ; (SophanChuc),(SophanTram) vao LEDs inc r0 inc r1 djnz r2,X0953 mov r0,#Count mov a,@r0 jb Acc.0,X0970 mov r1,#Flags mov a,@r1 jb Acc.7,X0970 jb Acc.1,X096a ; Neu bit Flags.7=1, xet bit 1=0 (binh thuong) mov r0,#LED4 ; Bit 1=1 -> CloseCommand hien nua tren so 8 (blink) mov @r0,#1bh ; ROM(31Bh)=72h=0111.0010=fgba -> Nua tren so 8 X096a: mov r0,#LED2 ; luc nay LED2 hien thi hang Donvi mov a,@r0 anl a,#0fh ; Lay 4 bit duoi -> Xoa dau (.) thap phan mov @r0,a X0970: setb TR0 ; Khoi dong Timer de hien thi ret ; End of ChuanBiHienThi ;============================================================= DichPhaiSoHienThi: mov r0,#SophanChuc mov r1,#SophanTram mov r2,#3 X0d76: mov a,@r0 mov @r1,a dec r0 dec r1 djnz r2,X0d76 ret ;============================================================ Hien3Chuso: ;call Hien3Chuso neu khong phai che do HOA mov r1,#SophanTram jb Acc.2,HienWL mov a,r6 jb Acc.6,X0f0c call DichPhaiSoHienThi ; Dich chuyen du lieu hien thi 3 chu so X0f0a: mov @r1,#1ah ; R1=So chuc khong hien X0f0c: ret ;=========================================================== HienWL: mov r0,#Count mov a,@r0 jb Acc.2,X0f0a call Doc7Eh ; A=NOT(7Eh) jz X0f1b mov a,r6 jb Acc.6,X0f0a X0f1b: mov r0,#W_level ; R0 = ul, Thap ul=11 -> 43h mov a,@r0 ; Trung binh ul=10 -> 42h orl a,#40h ; Cao ul=00 -> 40h mov @r1,a ; Chuan bi LED1 the hien Water Level ret ; Quay ve NapLED ;========================================================================== X0a00: mov a,r6 B¸o c¸o khoa häc §Ò tµi KC07- 04 95 anl a,#5 jz X0a12 ; Neu Dieu tan mov r0,#6ch mov @r0,#4 inc r0 mov @r0,#4 inc r0 mov @r0,#1 inc r0 mov @r0,#1 X0a12: mov r0,#6fh call DecToOne jz X0a24 call Add_3F3E_E0C0 ; Cong gia tri 2 byte (3Fh.3Eh) voi E0C0h jb Acc.7, X0a24 ; Neu Tanso > 50 Hz mov r0,#6fh mov @r0,#1 mov r0,#71h call DecToOne X0a24: mov r0,#6eh call DecToOne jz X0a37 call Add_3F3E_E0C0 ; Cong gia tri 2 byte (3Fh.3Eh) voi E0C0h jb Acc.7,X0a37 ; Neu Tanso < 50 Hz mov r0,#6eh mov @r0,#1 mov r0,#70h call DecToOne X0a37: mov r2,#0a2h mov r3,#0e0h call R3R2_Add_3F3E ; So sanh voi 49,8 Hz jb Acc.7,X0a47 ; Neu Tanso > 49,8 Hz mov r2,#6fh mov r3,#0e0h call R3R2_Add_3F3E ; So sanh voi 49,4 Hz jb Acc.7,X0a4b ; Neu Tanso > 49,4 Hz X0a47: mov r0,#6ch mov @r0,#3 X0a4b: mov r2,#0fh mov r3,#0e1h call R3R2_Add_3F3E ; So sanh voi 50,5 Hz jb Acc.7,X0a5b ; Neu Tanso > 50,5 Hz mov r2,#0deh mov r3,#0e0h call R3R2_Add_3F3E jb Acc.7,X0a5f ; Neu Tanso > 50,2 Hz X0a5b: mov r0,#6dh mov @r0,#3 X0a5f: mov r2,#44h mov r3,#0e3h call R3R2_Add_3F3E jb Acc.7,X0a6c ; Neu Tanso < 54,4 Hz mov a,#8 call Change_Flags ; Bat bit 3 cua Flags X0a6c: call Giam2Dh ; (X0b85) jz X0a74 mov r0,#72h mov @r0,#0ffh X0a74: nop ;jmp X0800 X0800: ;call Flags2ACC mov r0,#Flags mov a,@r0 mov r1,#73h jb Acc.1,X0809 mov @r1,#0ffh B¸o c¸o khoa häc §Ò tµi KC07- 04 96 X0809: mov a,@r0 ; R0=Flags jb Acc.7,X081b call Doc7Eh ; A=NOT(7Eh) jnz X081b mov a,r6 jb Acc.6,X081b ; (Doc lap) jb Acc.2,X082b ; Khong W_Level mov @r1,#0ffh dec r1 mov @r1,#0ffh X081b: mov r0,#2dh mov @r0,#1 mov r2,#90h mov r3,#0e2h ; E290 - 1D70:53 Hz call R3R2_Add_3F3E jb Acc.7,X0829 ; Neu tan so > 53 Hz jmp X0b9f ; Neu < 53 Hz X0829: jmp X0b92 X082b: mov r2,#58h mov r3,#0e1h ; E158 - 1EA8:51 Hz call R3R2_Add_3F3E jb Acc.7,X081b ; Neu tan so > 51 Hz jmp X0b9f ; Neu > 51 Hz X0b92: mov r0,#Flags mov a,@r0 jb Acc.4,X0b9f dec r0 ; Theo X081B R0=2Dh -> R0= 2Ch mov a,@r0 jnz X0b9f mov a,#80h call Change_Flags ; Bat bit 7 cua Flags X0b9f: mov r4,#80h call Doc7Eh ; A=NOT(7Eh) jnz X0bb0 mov a,r6 jb Acc.6,X0bb0 ; Doc lap jb Acc.0,X0bb0 ; hoa mov r4,#1 jb Acc.2,X0bb7 ; Wlevel mov r4,#0 X0bb0: mov r0,#50h mov @r0,#2 inc r0 mov @r0,#2 X0bb7: ;call Flags2ACC mov r0,#Flags mov a,@r0 jb Acc.1,X0bcb mov a,r4 jb Acc.0,X0bcb jnz X0bc4 call Giam2Dh ; X0b85 jnz X0bcb X0bc4: mov r1,#72h call Load_AC_to_R1 ; Nap ACh vao @R1, neu @R1=FF inc r1 call Load_AC_to_R1 ; Nap ACh vao @R1, neu @R1=FF X0bcb: ret ;========================================================================== Tinh_PD: mov r0,#3eh mov r1,#38h mov a,r6 nop jb Acc.0,X0aaa ; Neu hoa dien R1= 38h mov r1,#30h ; Neu Khong phai che do hoa R1=30h B¸o c¸o khoa häc §Ò tµi KC07- 04 97 X0aaa: call SubR0_R1 ; R2=(3Eh)-@R1 va R3=(3Fh)-@(R1+1) mov r0,#62h call NapR3R2ToR0 ; 63h.62h=3Fh.3Eh-39h.38h (Hoa) mov a,r6 ; 63h.62h=3Fh.3Eh-31h.30h (Khong hoa) jb Acc.0,X0ac4 mov r0,#5eh mov r1,#58h call SubR0_R1 ; R3.R2=(5Fh.5Eh)-(59h.58h) mov r0,#46h call NapR3R2ToR0 ; (47h.46h)=(5Fh.5Eh)-(59h.58h) mov r0,#62h mov r1,#46h call SubR0_R1 ; R3,R2=(63h.62h)-(47h.46h) X0ac4: mov r0,#40h call NapR3R2ToR0 ; (41h.40h)=(63h.62h)-(47h.46h) mov r0,#3eh call NapR3R2FromR0 ; R3,R2=(3Fh.3Eh) mov a,r6 mov r1,#6 jb Acc.0,X0add ; HOA R1=6 mov r1,#7 ; Khong HOA jb Acc.5,X0add ; Mode 1,2 R1=7 nop jb Acc.6,X0add ; Trong luoi mov r1,#7 ; Doc lap R1=7 nop nop X0add: mov r0,#62h call Add_R2_R3 ; R3.R2=R3.R2+(R0+1).R0 djnz r1,X0add mov r0,#64h call NapR3R2ToR0 ; (65h.64h)= ? call X0d7d mov r0,#64h mov r1,#44h call SubR0_R1 ; R3R2=(65h.64h)-(45h.44h) mov r0,#66h mov r1,#78h mov a,r2 mov @r0,a add a,#40h mov @r1,a inc r0 inc r1 mov a,r3 mov @r0,a addc a,#1fh mov @r1,a ret ; End of Tinh_PD ;================================================================ X0d7d: mov a,r6 jb Acc.0,X0d90 ; Neu HOA (N=1) thi Ret call Doc7Eh ; A=NOT(7Eh) mov r0,#2ch jnz X0d8e ; Neu A=NOT(7Eh) 0 -> (2Ch)=0 call DecToOne ; Neu a=0 tuc la (7Eh)=FF thi A=(2Ch)-1 jnz X0d90 ; Neu (2ch) 0 thi thoi mov a,#10h ; Neu A=0 (Luc nay (2Ch)=1) -> A=10h jmp Change_Flags ; Bat bit 4 cua Flags X0d8e: mov @r0,#0 X0d90: ret ;===================================================================== X0972: mov r0,#Flags mov a,@r0 anl a,#9bh ; And 1001.1011 ? mov @r0,a ; Xoa bit 2,5,6 cua Flags (lien quan X0092) B¸o c¸o khoa häc §Ò tµi KC07- 04 98 jb Acc.7,X097b jb Acc.1,X09b2 X097b: mov a,r6 jb Acc.0,X0981 ; N=0 Khong phai HOA jmp CheDoHOA ; Che do HOA ; X0981: mov a,r6 jb Acc.6,X09a8 ; Chay doc lap mov r2,#0fch mov r3,#0e1h X0eb7: jb Acc.2,X0ec6 ; call X0eb7 jb Acc.4,X0ec6 mov r2,#0a0h mov r3,#0e3h jb Acc.5,X0ec6 mov r2,#65h mov r3,#0e1h X0ec6: ;ret call R3R2_Add_3F3E jb Acc.7,X09a8 ; Neu Tan so may phat > cac gia tri tren thi X09a8 mov a,r6 ; Neu nho hon jb Acc.2,X09b6 ; Neu che do W_Lwvel - X09b6 call Giam2Dh ; Neu khong phai W_Level jnz X09b6 mov a,r6 ; Neu (2Dh)=0 jb Acc.5,X09a4 ; Neu mode 3 jb Acc.4,X09a4 ; Neu mode2 mov r2,#1dh ; Neu mode 1 R3R2=E01D - 49 Hz mov r3,#0e0h call R3R2_Add_3F3E jb Acc.7,X09b6 ; Neu tan so < 49 Hz X09a4: ;call X0cee ; Neu lon hon 4-> (7Ah) X0cee: mov r0,#7ah mov @r0,#4 ;ret jmp X09b6 X09a8: mov r2,#60h mov r3,#0e0h mov r4,#3ch call X0f3e jb Acc.7,X09b9 X09b2: mov a,#40h call Change_Flags ; Bat bit 6 cua Flags X09b6: ;call Flags2ACC mov r0,#Flags mov a,@r0 ret ;==================================================== X09b9: mov r2,#70h mov r3,#0e2h mov r4,#28h call X0f3e jb Acc.7,X09e1 mov r3,#0e5h mov r2,#0fh call R3R2_Add_6564 jb Acc.7,X09ce X09ce: mov r3,#0e4h X0857: mov r2,#19h ; Tien bo sung - Phuc vu X09CE mov a,r6 jb Acc.5,X085e ; Mode 1,2 R2=19h mov r2,#0ffh ; mode 3 R2=FF call R3R2_Add_3F3E jb Acc.7,X09b6 ;call X0d91 X0d91: mov r0,#34h B¸o c¸o khoa häc §Ò tµi KC07- 04 99 mov r1,#32h mov r5,#6 X0b8a: mov r4,#5 mov a,r6 jb Acc.5, X0b91 mov r4,#0ah X0b91: nop ;ret X09db: call X0da5 jb Acc.7,X09e3 djnz r5,X09db X09e1: jmp X09b2 X09e3: mov r0,#34h mov r1,#6 X09e7: mov r2,#0f5h mov r3,#0e5h call Add_R2_R3 inc r0 jb Acc.7,X09b6 djnz r1,X09e7 mov r0,#3eh mov r1,#3ch mov r4,#0f0h call X0d9a jb Acc.7,X09b2 X0c95: call Doc7Eh ; A=NOT(7Eh) jnz X0cd5 mov a,r6 jb Acc.6,X0cd5 jb Acc.2,X0ca4 mov r0,#W_level mov a,@r0 jb Acc.0,X0cd5 X0ca4: mov a,r6 swap a anl a,#3 mov r2,a rl a add a,r2 mov r0,#OpenRate ; Open Rate add a,@r0 add a,#0f7h jc X0cb3 clr a X0cb3: mov r0,#WL_Rate ; W_LRate rl a nop mov @r0,a mov r7,a jz X0cd5 ;call X0d91 mov r0,#34h mov r1,#32h mov r5,#6 ;ret X0cbd: mov a,#0d8h call X0d98 jb Acc.7,X0cd9 djnz r5,X0cbd mov r2,#8 mov r3,#0deh ; R3.R2=2270 X0cc9: call R3R2_Add_6564 jb Acc.7,X0cd5 mov r0,#Flags mov a,@r0 jb Acc.7,X0cd5 B¸o c¸o khoa häc §Ò tµi KC07- 04 100 orl a,#20h mov @r0,a X0cd5: mov r0,#Flags mov a,@r0 ret ;============================================================ X0cd9: mov r0,#34h mov r1,#32h mov r5,#6 ;ret X0cdb: mov a,#0e6h call X0d98 jb Acc.7,X0cd5 djnz r5,X0cdb mov r2,#7dh mov r3,#0dch X0d98: add a,r7 mov r4,a X0d9a: call SubR0_R1 inc r0 inc r1 mov a,r2 ; Cong 2 byte R3.R2 + R4 add a,r4 mov a,r3 addc a,#0ffh ret ;============================================================== X0da5: call SubR0_R1 inc r0 inc r1 mov a,r2 ; Cong 2 byte R3.R2 + R4 add a,r4 ; Sau do nghich dao gia tri mov a,r3 addc a,#0 ret ;============================================================== SubR0_R1: mov a,@r1 cpl a add a,#1 mov r2,a inc r1 mov a,@r1 cpl a addc a,#0 mov r3,a call Add_R2_R3 ret ;============================================================== Add_R2_R3: mov a,@r0 add a,r2 mov r2,a inc r0 mov a,@r0 addc a,r3 mov r3,a ret ;============================================================== Cpl2Nor: mov a,r3 ; Dua R3 vao A, cpl a ; Dao gia tri jb Acc.7,X0de4 ; Neu bit 7=1 ( bit 7 cua R3=0) -> Gia tri 2 byte trong R2 (L) ; va R3 (H) la so duong (+) thi ket thuc mov a,r2 ; Nguoc lai R2.R3 la so Am (-) B¸o c¸o khoa häc §Ò tµi KC07- 04 101 cpl a add a,#1 mov r2,a mov a,r3 cpl a addc a,#80h ; Tien hanh doi sang so duong, bat bit dau =1 (<0) mov r3,a X0de4: ret ;======================================================== NapR3R2ToR0: mov a,r2 ; R2=5Eh mov @r0,a inc r0 mov a,r3 mov @r0,a ret ;======================================================== NapR3R2FromR0: mov a,@r0 mov r2,a inc r0 mov a,@r0 mov r3,a ret ;============================================================== R3R2_Add_6564: mov r0,#64h mov a,@r0 add a,r2 inc r0 mov a,@r0 addc a,r3 ret ;============================================================== R3R2_Add_3F3E: mov r0,#3eh mov a,@r0 add a,r2 inc r0 mov a,@r0 addc a,r3 ret ;======================================================== DecToOne: mov a,@r0 ; X0610 dec a mov @r0,a jnz DecEnd ; inc @r0 ; DecEnd: ret ;================================================================== Load_AC_to_R1: mov a,@r1 cpl a jnz X0e45 mov @r1,#0ach X0e45: ret ;============================================================== Add_3F3E_E0C0: mov r0,#3eh mov a,@r0 add a,#0c0h inc r0 mov a,@r0 addc a,#0e0h ret ;===================================================================== Doc7Eh: mov r0,#7eh B¸o c¸o khoa häc §Ò tµi KC07- 04 102 mov a,@r0 cpl a ret ;================================================================= Giam2Dh: mov r0,#2dh mov a,@r0 dec a ret ;============================================================== Change_Flags: mov r0,#Flags orl a,@r0 mov @r0,a ret ;===================================================================== X0f3e: call R3R2_Add_3F3E jb Acc.7, X0f4f mov r0,#3ah mov r1,#38h mov r5,#3 X0f49: call X0da5 jb Acc.7, X0f4f djnz r5,X0f49 i X0f4f: ret ;===================================================================== ; HOA DIEN ;===================================================================== CheDoHOA: ;call Flags2ACC mov r0,#Flags mov a,@r0 nop jb Acc.4,X0f5d mov r0,#LED4 ; Neu bit 4 =1 mov @r0,#1fh ; ROM(31Fh)=53h=0101.0011=fbap - Dau cham hoi ? clr a ret ;=========================================================== X0f5d: mov r0,#2ah mov @r0,#8 mov r0,#40h call NapR3R2FromR0 ; R2=(40h), R3=(41h) call Cpl2Nor ; Doi dang so bu sang Binh thuong mov a,#0ceh add a,r2 mov a,r3 addc a,#0ffh jb Acc.6,X0f91 mov r0,#42h call NapR3R2FromR0 ; R2=(42h), R3=(43h) mov a,r2 add a,#0e8h mov a,r3 addc a,#0ffh jb Acc.6,X0f91 mov r0,#7ah mov @r0,#4 mov r0,#77h mov a,@r0 dec a jnz X0f91 mov r4,#2 call So_Pha ; 0f8a ( R4=2 - Tre pha 1 ms) jb Acc.5, X0f91 jnz X0f94 ; Ngoai bit 5, neu A 0 -> lech pha lon call Doc7Eh ; Doc 7Eh, dao gia tri ; A=NOT(7Eh) B¸o c¸o khoa häc §Ò tµi KC07- 04 103 X0f91: clr a ret X0f93: inc r4 X0f94: mov a,r4 add a,#0fbh ; (R4) + FBh=251 jc X0f91 call So_Pha ; Neu Carry=0 -> R4 <= 4, goi So_Pha jb Acc.5,X0f91 ; Sau khi so pha, neu bit 5 =1 (???) -> Xoa ACC jnz X0f93 ; Ngoai bit 5, neu A 0 -> lech pha lon, tang R4 cho toi 4 mov a,r4 ; Neu A=0, tuc la lech pha nho add a,#0fch ; A= (R4) + (FCh=252) jb Acc.7,X0fa6 ; Neu bit (A.7)=1, tuc la r4 < 4 mov r4,#3 ; Neu R4 >= 4, thi R4=3 X0fa6: dec r4 mov a,r4 dec a nop jnz X0f94 mov r4,#7 jmp HOA_DIEN Chuan_Bi_Hoa: mov r0,#2dh ; R0=2Dh mov @r0,#0bh ; 0Bh=0000.1011 -> (2Dh) mov a,r6 ; R6=0dxn.0D0N jb Acc.6,Doc_Lap ; d=1 -> day do = 5v-> Che do chay doc lap mov r0,#2ah ; Che do chay trong luoi mov @r0,#6 ; 6 -> (2Ah) =0000.0110 Doc_Lap: mov r0,#77h mov @r0,#10h ; 10h -> (77h) mov r0,#7eh mov @r0,#0ffh ; FFh -> (7Eh) ;========================================================== ; Doc cong tac xac dinh co o vi tri HOA khong ;========================================================== mov p1,#0ffh nop mov a,p1 jb Acc.0,Khong_Hoa ; Day Nau = 5 V -> Khong phai che do hoa dien jb Acc.1,Khong_Hoa ; Sau khi dao, neu P4.1=1 -> Closedown call So_Pha ; Con lai, chinh la HOA DIEN jz HOA_DIEN ; Neu do lech pha nho Khong_Hoa: djnz r5,Chuan_Bi_Hoa ; Lap lai cho toi khi xay ra ngat Timer, chuong trinh se mov r3,#9ch ; duoc re sang nhanh khac. Ngat_Role2: call Ngat_Role djnz r2,Ngat_Role2 djnz r3,Ngat_Role2 clr a ; ACC=0 ret ;================================================================== HOA_DIEN: mov r1,#1dh mov @r1,#0 ; 0 -> (1Dh), chuan bi cho lan goi So pha sau mov LED4,#1Ch ; H mov LED3,#0 ; O mov LED2,#0Ah ; A mov LED1,#1Dh ; ! mov r3,#8 DongMachHoa: setb p3.1 ; Sync ON clr p3.0 clr p2.4 ; Close OFF setb p2.5 clr p2.6 ; Open OFF B¸o c¸o khoa häc §Ò tµi KC07- 04 104 setb p2.7 clr p3.4 ; Over Speed OFF setb p3.5 djnz r2,DongMachHoa djnz r3,DongMachHoa ; Thuc hien Hoa R3 = 8 lan djnz r4,HOA_DIEN ; (Truoc doan nay R4=7) mov r4,#2 ; mov r5,#2 ; jmp Chuan_Bi_Hoa ; Kiem tra lai trang thai cong tac MODE end B¸o c¸o khoa häc §Ò tµi KC07- 04 105 PHỤ LỤC II PHẦN MỀM ĐIỀU KHIỂN ĐIỀU TỐC ĐIỀU CHỈNH PHỤ TẢI ;*********************************************** ;* Chuong trinh dieu chinh tan so luoi doc lap * ;* dung tai gia Dummy load * ;* Dung thuat toan dieu khien theo PI * ;**************** Byte Address ***************** frq_counter equ 50h frq_counter1 equ 51h frq_counter2 equ 52h Err_frq equ 53h Pre_alpha1 equ 54h Pre_alpha2 equ 55h delay_T equ 56h Temp1 equ 57h Temp2 equ 58h Temp3 equ 59h Kp equ 60h ; cac thong so bo dieu khien Ki equ 61h T equ 62h Dload1_alp1 equ 66h ; Gia tri alpha tai 1 Dload1_alp2 equ 67h Dload2_alp1 equ 68h ; Gia tri alpha tai 2 Dload2_alp2 equ 69h Ketqua_PI equ 6Ah Ketqua_P equ 6Bh Ketqua_I equ 6Ch TongSaiLech equ 6Dh pulse_width1 equ 70h pulse_width2 equ 71h ;**************** Bit Address ****************** F_level bit 20h B¸o c¸o khoa häc §Ò tµi KC07- 04 106 F_edge bit 21h F_open1 bit 22h F_open2 bit 23h F_level_ bit 24h F_edge_ bit 25h F_frq_c bit 26h F_result bit 27h Err_sign bit 28h F_cut1 bit 29h F_cut2 bit 2ah SignTong bit 2bh Sign_PI bit 2ch ;************************************************ ORG 0000h ljmp MainProg ORG 000bh ljmp Isr_Timer0 ORG 001bh ljmp Isr_Timer1 ;************************************************ ;Isr_Timer0: dem tan so ( Tan so ngat 0.125ms) ;************************************************ Isr_Timer0: push psw push acc push dph push dpl jb P3.2,continue00 jb F_level,continue01 setb F_level setb F_edge mov frq_counter1,frq_counter mov frq_counter,#00h B¸o c¸o khoa häc §Ò tµi KC07- 04 107 jnb F_frq_c,continue01 ; mov a,frq_counter1 jz continue01 clr F_frq_c setb F_result mov frq_counter2,frq_counter1 ajmp continue01 continue00: clr F_level continue01: jnb F_edge,continue02 clr c inc frq_counter jnc continue02 mov frq_counter,#255 continue02: jb F_cut1,continue04 mov a,frq_counter clr c subb a,Dload1_alp1 jnz continue03 setb F_open1 ajmp continue04 continue03: mov a,frq_counter clr c subb a,Dload1_alp2 jnz continue04 setb F_open1 ajmp continue05 continue04: jb F_cut2,continue06 mov a,frq_counter clr c subb a,Dload2_alp1 B¸o c¸o khoa häc §Ò tµi KC07- 04 108 jnz continue05 setb F_open2 ajmp continue06 continue05: jb F_cut2,continue06 mov a,frq_counter clr c subb a,Dload2_alp2 jnz continue06 setb F_open2 continue06: jnb F_open1,continue07 inc pulse_width1 clr c mov P2.5,c nop mov a,pulse_width1 cjne a,#2,continue07 nop setb c mov P2.5,c clr F_open1 mov pulse_width1,#00h continue07: jnb F_open2,Esc_Timer0 inc pulse_width2 clr c mov P2.6,c nop mov a,pulse_width2 cjne a,#2,Esc_Timer0 nop setb c mov P2.6,c clr F_open2 B¸o c¸o khoa häc §Ò tµi KC07- 04 109 mov pulse_width2,#00h Esc_Timer0: pop dpl pop dph pop acc pop psw reti ;================================================ ;Isr_Timer1: chu ky do tan so ( thoi gian 20ms) ;================================================ Isr_Timer1: mov TH1,#0B1h mov TL1,#0DFh push psw push acc push dph push dpl jnb F_result,delay_circ clr F_result mov a,frq_counter2 clr c subb a,#160 jc con00 mov Err_frq,a setb Err_sign ajmp con01 con00: mov a,#160 clr c subb a,frq_counter2 mov Err_frq,a clr Err_sign con01: lcall PI_controller delay_circ: B¸o c¸o khoa häc §Ò tµi KC07- 04 110 inc delay_T mov a,delay_T clr c subb a,T jnz Esc_Timer1 setb F_frq_c mov delay_T,#00 Esc_Timer1: pop dpl pop dph pop acc pop psw reti ;************************************************************************* ;PI_controller: ;************************************************************************* PI_controller: mov a, #16 clr c subb a,Err_frq jnc Err_adj mov Err_frq,#16 ajmp PI_tinhtoan Err_adj: mov a,Err_frq clr c subb a,#01 jc Err_nho jz Err_nho ajmp PI_tinhtoan Err_nho: ajmp Ket_thuc PI_tinhtoan: B¸o c¸o khoa häc §Ò tµi KC07- 04 111 mov r5,Kp mov a,#0 LapP: add a,Err_frq djnz r5,LapP mov Ketqua_P,a TinhTongSaiLech: mov a,TongSaiLech jb SignTong,TongDuong jb Err_sign,Tru1 ajmp Cong1 TongDuong: jnb Err_sign,Tru1 Cong1: clr c add a,Err_frq mov TongSaiLech,a clr c subb a,#24 jc Tran1 ajmp ThanhPhan_I Tran1: mov TongSaiLech,#24 ajmp ThanhPhan_I Tru1: clr c subb a,Err_frq jc DoiDauTong mov TongSaiLech,a ajmp ThanhPhan_I DoiDauTong: mov a,Err_frq subb a,TongSaiLech mov TongSaiLech,a cpl SignTong B¸o c¸o khoa häc §Ò tµi KC07- 04 112 ThanhPhan_I: mov r5,Ki mov a,#0 LapI: add a,TongSaiLech djnz r5,LapI mov Ketqua_I,a TongPI: mov a,Ketqua_P jb Err_sign,TruP CongP: clr Sign_PI jb SignTong,TruI ajmp CongI TruP: setb Sign_PI jnb SignTong,TruI CongI: clr c add a,Ketqua_I mov Ketqua_PI,a ajmp DieuKhien TruI: clr c subb a,Ketqua_I jc Doidau mov Ketqua_PI,a ajmp DieuKhien Doidau: mov a,Ketqua_I subb a,Ketqua_P mov Ketqua_PI,a cpl Sign_PI DieuKhien: B¸o c¸o khoa häc §Ò tµi KC07- 04 113 mov a,frq_counter2 mov Temp2,a mov Temp1,a mov a,Temp2 rrc a mov Temp3,a jb Err_sign,GiamTai2 TangTai1: mov a,Pre_Alpha1 clr c subb a,Ketqua_PI jc MoHoanToan1 mov Pre_Alpha1,a clr c subb a,#03 jc MoHoanToan1 ajmp TangTai2 MoHoanToan1: mov Pre_Alpha1,#3 TangTai2: clr F_Cut2 mov a,Temp3 clr c subb a,Pre_Alpha1 jc HetTangTai mov a,Pre_Alpha2 clr c subb a,Ketqua_PI jc MoHoanToan2 mov Pre_Alpha2,a clr c subb a,#03 jc MoHoanToan2 ajmp Alpha_charge B¸o c¸o khoa häc §Ò tµi KC07- 04 114 HetTangTai: mov Pre_Alpha2,Temp1 setb F_cut2 ajmp Alpha_charge MoHoanToan2: mov Pre_Alpha2,#3 ajmp Alpha_charge GiamTai2: clr F_cut2 mov a,Pre_Alpha2 clr c add a,KetQua_PI jc DongHoanToan2 mov Pre_Alpha2,a clr c subb a,Temp1 jnc DongHoanToan2 ajmp GiamTai1 DongHoanToan2: mov Pre_Alpha2,Temp1 setb F_cut2 GiamTai1: mov a,Pre_Alpha2 clr c subb a,Temp3 jc Alpha_charge mov a,Pre_Alpha1 clr c add a,KetQua_PI jc DongHoanToan1 mov Pre_Alpha1,a clr c B¸o c¸o khoa häc §Ò tµi KC07- 04 115 subb a,Temp1 jnc DongHoanToan1 clr F_cut1 ajmp Alpha_charge DongHoanToan1: mov Pre_Alpha1,Temp1 setb F_cut1 Alpha_charge: jb F_cut1,cont01 mov a,Pre_Alpha1 clr c add a,temp2 mov Dload1_alp2,a mov Dload1_alp1,Pre_Alpha1 cont01: jb F_cut2,Ket_thuc mov a,Pre_Alpha2 clr c add a,temp2 mov Dload2_alp2,a mov Dload2_alp1,Pre_Alpha2 ajmp Ket_thuc Ket_thuc: ret ;=============================================== ;Doc_Sw: ;=============================================== Doc_Sw: clr c mov P3.6,c mov P3.7,c nop nop B¸o c¸o khoa häc §Ò tµi KC07- 04 116 nop nop mov a,P1 cpl a add a,#1 mov T,a clr c mov P3.6,c setb c mov P3.7,c nop nop nop nop mov a,P1 cpl a add a,#1 mov Kp,a mov P0,a setb c mov P3.6,c clr c mov P3.7,c nop nop nop nop mov a,P1 cpl a mov Ki,a ret ;*********************************************** ; Main program ;*********************************************** MainProg: mov P2,#0 setb c mov P2.5,c ; Tat tat ca tai (Load-off) B¸o c¸o khoa häc §Ò tµi KC07- 04 117 mov P2.6,c mov P1,#0FFh mov frq_counter,#00h ; Khoi tao cac bien clr F_level ; Khoi tao cac flag clr F_edge clr F_result setb F_cut1 ; Cam tai setb F_cut2 ; setb F_frq_c ; Cho phep do tan so mov Pre_alpha1,#77 mov Pre_alpha2,#77 mov Dload1_alp1,#75 mov Dload1_alp2,#155 mov Dload2_alp1,#75 mov Dload2_alp2,#155 lcall Doc_sw mov IE,#8Ah ; Khoi tao ngat Timer 0, Timer 1 mov TMOD,#12h mov TH0,#131 ; Dinh timer0 0.125ms mov TL0,#131 mov TH1,#0B1h ; Dinh timer1 20ms mov TL1,#0DFh setb PT0 ; Uu tien ngat Timer0 clr PT1 setb TR0 setb TR1 ; Vong lap chuong trinh Mainloop: nop ljmp Mainloop End

Các file đính kèm theo tài liệu này:

  • pdfNghiên cứu, thiết kế, chế tạo điều tốc cho các trạm thủy điện.pdf