MỤC LỤC
LỜI MỞ ĐẦU. 1
CHưƠNG 1. TỔNG QUAN VỀ CÁC PHẦN TỬ . 2
1.1. TỔNG QUAN VỀ PIC16F877A . 2
1.1.1. Chức năng và sơ đồ chân vi điều khiển PIC16F877A. 2
1.1.2. Một vài thông số về vi điều khiển PIC16877A . 3
1.1.3. Sơ đồ khối vi điều khiển PIC16F877A. 4
1.1.4. Tổ chức bộ nhớ . 5
1.1.5. Các cổng xuất nhập của PIC16F877A. 9
1.1.6. Timer0. 11
1.1.7. Timer1. 13
1.1.8. Timer2. 15
1.2. THIẾT BỊ LCD . 16
1.2.1. Hình dáng kích thước. 17
1.2.2. Các chân chức năng . 18
1.2.3. Sơ đồ khối của HD44780. 19
1.2.4. Tập lệnh của LCD. 22
1.2.5. Đặc tính của các chân giao tiếp . 27
CHưƠNG 2. THIẾT KẾ HỆ THỐNG ĐIỀU KHIỂN ĐỘNG CƠ DC
THEO NHIỆT ĐỘ . 28
2.1. SƠ ĐỒ KHỐI. 28
2.2. THIẾT KẾ CÁC KHỐI . 28
2.2.1. Mạch đo nhiệt độ . 28
2.2.2. Khối xử lý . 30
2.2.3. Khối ADC (tích hợp trong PIC16F877A) . 31
2.2.4. Khối khuếch đại hiệu chỉnh . 32
2.2.5. Khối công suất . 33
2.2.6. Khối hiển thị . 382.2.7. Motor DC. 38
2.2.8. Sơ đồ mạch nguyên lý hệ thống. 43
CHưƠNG 3. CHưƠNG TRÌNH ĐIỀU KHIỂN. 45
3.1. LưU ĐỒ THUẬT TOÁN. 45
3.2. CHưƠNG TRÌNH ĐIỀU KHIỂN. 46
KẾT LUẬN . 56
TÀI LIỆU THAM KHẢO . 58
67 trang |
Chia sẻ: tranloan8899 | Lượt xem: 1502 | Lượt tải: 2
Bạn đang xem trước 20 trang tài liệu Đồ án Thiết kế và xây dựng hệ thống điều khiển động cơ theo nhiệt độ, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
giá trị các pin trong PORTB.
- TRISB (địa chỉ 86h, 186h): điều khiển xuất nhập.
- OPTION_REG (địa chỉ 81h, 181h): điều khiển ngắt ngoại vi và bộ
Timer0.
1.1.5.3. Cổng PORTC
PORTC (RPC) gồm 8 pin I/O. Thanh ghi điều khiển xuất nhập tƣơng
ứng là TRISC. Bên cạnh đó PORTC còn chứa các chân chức năng của bộ so
sánh, bộ Timer1, bộ PWM và các chuẩn giao tiếp nối tiếp I2C, SPI, SSP,
USART.
Các thanh ghi điều khiển liên quan đến PORTC:
- PORTC (địa chỉ 07h): chứa giá trị các pin trong PORTC.
- TRISC (địa chỉ 87h): điều khiển xuất nhập.
11
1.1.5.4. Cổng PORTD
PORTD (RPD) gồm 8 chân I/O, thanh ghi điều khiển xuất nhập tƣơng
ứng là TRISD. PORTD còn là cổng xuất dữ liệu của chuẩn giao tiếp PSP
(Parallel Slave Port).
Các thanh ghi liên quan đến PORTD gồm:
- Thanh ghi PORTD: chứa giá trị các pin trong PORTD.
- Thanh ghi TRISD : điều khiển xuất nhập.
- Thanh ghi TRISE: điều khiển xuất nhập PORTE và chuẩn giao tiếp
PSP.
1.1.5.5. PORTE
PORTE (RPE) gồm 3 chân I/O. Thanh ghi điều khiển xuất nhập tƣơng
ứng là TRISE. Các chân của PORTE có ngõ vào analog. Bên cạnh đó PORTE
còn có các chân điều khiển của chuẩn giao tiếp PSP.
Các thanh ghi liên quan đến PORTE gồm:
- PORTE: chứa giá trị các chân trong PORTE.
- TRISE: điều khiển xuất nhập và xác lập các thông số cho chuẩn giao
tiếp PSP.
- SDCON1: thanh ghi điều khiển khối ADC.
1.1.6. Timer0
Đây là một trong ba bộ đếm hoặc bộ định thời của vi điều khiển
PIC16F877A. Timer0 là bộ đếm 8 bit đƣợc kết nối với bộ chia tần số
(prescaler) 8 bit. Cấu trúc của Timer0 cho phép ta lựa chọn xung clock tác
động và cạnh tích cực của xung clock. Ngắt Timer0 sẽ xuất hiện khi Timer0
bị tràn. Bit TMR0IE (INTCIN) là bit điều khiển của Timer0. TMR0IE=1
cho phép ngắt Timer0 tác động, TMR0IF=0 không cho phép ngắt Timer0 tác
động. Sơ đồ khối của Timer0 nhƣ sau:
12
Hình 1.5: Sơ đồ khối của Timer0.
Muốn Timer0 hoạt động ở chế độ Timer ta clear bit TOSC
(OPTION_REG), khi đó giá trị thanh ghi TMR0 sẽ tăng theo từng chu kì
xung đồng hồ (tần số vào Timer0 bằng ¼ tần số oscillator). Khi giá trị thanh
ghi TMR0 từ FFh trở về 00h, ngắt Timer0 sẽ xuất hiện. Thanh ghi TMR0 cho
phép ghi và xóa đƣợc giúp ta ấn định thời điểm ngắt Timer0 xuất hiện một
cách linh động.
Muốn Timer0 hoạt động ở chế độ counter ta set bit TOSC
(OPTION_REG). Khi đó xung tác động lên bộ đếm đƣợc lấy từ chân
RA4/TOCK1. Bit TOSE (OPTION_REG) cho phép lựa chọn cạnh tác
động vào bộ đếm. Cạnh tác động sẽ là cạnh lên nếu TOSE=0 và cạnh tác động
sẽ là cạnh xuống nếu TOSE=1.
Khi thanh ghi TMR0 bị tràn, bit TMR0IF (INTCON) sẽ đƣợc set.
Đây chính là cờ ngắt của Timer0. Cờ ngắt này phải đƣợc xóa bằng chƣơng
13
trình trƣớc khi bộ đếm bắt đầu thực hiện lại quá trình đếm. Ngắt Timer0
không thể “đánh thức” vi điều khiển từ chế độ sleep.
Bộ chia tần số (prescaler) đƣợc chia sẻ giữa Timer0 và WDT (Watchdog
Timer). Điều đó có nghĩa là nếu prescaler đƣợc sử dụng cho Timer0 thì WDT
sẽ không có đƣợc hỗ trợ của prescaler và ngƣợc lại. Prescaler đƣợc điều khiển
bởi thanh ghi OPTION_REG. Bit PSA (OPTION_REG) xác định đối
tƣợng tác động của prescaler. Các bit PS2:PS0 (OPTION_REG) xác
định tỉ số chia tần số của prescaler. Xem lại thanh ghi OPTION_REG để xác
định lại một cách chi tiết về các bit điều khiển trên.
Các lệnh tác động lên giá trị thanh ghi TMR0 sẽ xóa chế độ hoạt động
của prescaler. Khi đối tƣợng tác động là Timer0, tác động lên giá trị thanh ghi
TMR0 sẽ xóa prescaler nhƣng làm thay đổi đối tƣợng tác động của prescaler.
Khi đối tƣợng là WDT, lệnh CLRWDT sẽ xóa prescaler, đồng thời prescaler
sẽ ngƣng tác vụ hỗ trợ cho WDT.
Các thanh ghi điều khiển liên quan đến Timer0 bao gồm:
- TMR0 (địa chỉ 01h, 101h): chứa giá trị đếm của Timer0.
- INTCON (địa chỉ 0Bh, 8Bh, 10Bh, 18Bh): cho phép ngắt hoạt động
(GIE và PEIE).
- OPTION_REG (địa chỉ 81h, 181h): điều khiển prescaler.
1.1.7. Timer1
Timer1 là bộ định thời 16 bit, giá trị của Timer1 sẽ đƣợc lƣu trong hai
thanh ghi (TMR1H:TMR1L). Cờ ngắt của Timer1 là bit TMR1IF(PIR1).
Bit điều khiển của Timer1 sẽ là TMR1IE (PIE).
Tƣơng tự nhƣ Timer0, Timer1 cũng có hai chế độ hoạt động: chế độ định
thời (timer) với xung kích là xung clock của oscillator (tần số của timer bằng
¼ tần số của oscillator) và chế độ đếm (counter) với xung kích là xung phản
ánh các sự kiện cần đếm lấy từ bên ngoài thông qua chân
RC0/T1OSO/T1CKI (cạnh tác động là cạnh lên). Việc lựa chọn xung tác
14
động (tƣơng ứng với việc lựa chọn chế độ hoạt động là timer hay counter)
đƣợc điều khiển bởi bit TMR1CS (TICON). Sau đây là sơ đồ khối của
Timer1:
Hình 1.6: Sơ đồ khối của Timer1.
Ngoài ra Timer1 còn có chức năng reset input bên trong đƣợc điều khiển
bởi một trong hai khối CCP(Capture/Compare/PWM).
Khi bit T1OSCEN (T1CON) đƣợc set, Timer1 sẽ lấy xung clock từ
hai chân RC1/T1OSI/CCP2 và RC0/T1OSO/T1CKI làm xung đếm. Timer sẽ
bắt đầu đếm sau cạnh xuống đầu tiên của xung ngõ vào. Khi đó PORTC sẽ bỏ
qua sự tác động của hai bit TRISC và PORTC đƣợc gán giá trị 0.
Khi clear bit T1OSCEN Timer1 sẽ lấy xung đếm từ oscillator hoặc từ chân
RC0/T1OSO/T1CKI.
Timer1 có hai chế độ đếm là đồng bộ (Synchronous) và bất đồng bộ
(Asynchronous). Chế độ đếm đƣợc quyết định bởi bit điều khiển T1SYNC
(T1CON).
Khi T1SYNC=1 xung đếm lấy từ bên ngoài sẽ không đƣợc đồng bộ hóa
với xung clock bên trong, Timer1 sẽ tiếp tục quá trình đếm khi vi điều khiển
đang ở chế độ sleep và ngắt do Timer1 tạo ra khi bị tràn có khả năng “đánh
thức” vi điều khiển. Ở chế độ đếm đồng bộ, Timer1 không thể đƣợc sử dụng
15
để làm nguồn xung clock cho khối CCP (Capture/Compare/Pulse width
modulation).
Khi T1SYNC=0 xung đếm vào Timer1 sẽ đƣợc đồng bộ hóa với xung
clock bên trong. Ở chế độ này Timer1 sẽ không hoạt động khi vi điều khiển
đang ở chế độ sleep.
Các thanh ghi liên quan đến Timer1 gồm:
- INTCON (địa chỉ 0Bh, 8Bh, 10Bh, 18Bh): cho phép ngắt hoạt động
(GIE và PEIE).
- PIR1 (địa chỉ 0Ch): chứa cờ ngắt Timer1 (TMR1IF).
- PIE1 (địa chỉ 8Ch): cho phép ngắt Timer1 (TMR1IE).
- TMR1L (địa chỉ 0Eh): chứa giá trị 8 bit thấp của bộ đếm Timer1.
- TMR1H (địa chỉ 0Eh): chứa giá trị 8 bit cao của bộ đếm Timer1.
- T1CON (địa chỉ 10h): xác lập các thông số cho Timer1.
1.1.8. Timer2
Timer2 là bộ định thời 8 bit và đƣợc hỗ trợ bởi hai bộ chia tần số
prescaler và postcaler. Thanh ghi chứa giá trị đếm của Timer2 là TMR2. Bit
cho phép ngắt Timer2 tác động là TMR2ON (T2CON). Cờ ngắt của
Timer2 là bit TMR2IF (PIR1). Xung ngõ vào (tần số bằng ¼ tần số
oscillator) đƣợc đƣa qua bộ chia tần số prescaler 4 bit (với các tỉ số chia tần số
là 1:1, 1:4 hoặc 1:6 và đƣợc điều khiển bởi các bit T2CKPS1:T2CKPS0
(T2CON)).
Timer2 còn đƣợc hỗ trợ thanh ghi PR2. Giá trị đếm trong thanh ghi
TMR2 sẽ tăng từ 00h đến giá trị chứa trong thanh ghi PR2, sau đó đƣợc reset
về 00h. Khi reset thanh ghi PR2 đƣợc nhận giá trị mặc định FFh.
Ngõ ra của Timer2 đƣợc đƣa qua bộ chia tần số postcaler với các mức
chia từ 1:1 đến 1:16. Postcaler đƣợc điều khiển bởi 4 bit T2OUTPS3:
T2OUTPS0. Ngõ ra của postcaler đóng vai trò quyết định trong việc điều
khiển cờ ngắt.
16
Hình 1.7:Sơ đồ khối Timer2.
Ngoài ra ngõ ra của Timer2 còn đƣợc kết nối với khối SSP, do đó
Timer2 còn đóng vai trò tạo ra xung clock đồng bộ cho khối SSP.
Các thanh ghi liên quan đến Timer2 gồm:
- INTCON (địa chỉ 0Bh, 8Bh, 10Bh, 18Bh): cho phép toàn bộ các ngắt
(GIE và PEIE).
- PIR1 (địa chỉ 0Ch): chứa cờ ngắt Timer2 (TMR2IF).
- PIE1 (địa chỉ 8Ch): chứa bit điều khiển Timer2 (TMR2IE).
- TMR2 (địa chỉ 11h): chứa giá trị đếm của Timer2.
- T2CON (địa chỉ 12h): xác lập các thông số cho Timer2.
- PR2 (địa chỉ 92h): thanh ghi hỗ trợ cho Timer2.
1.2. THIẾT BỊ LCD
Ngày nay, thiết bị hiển thị LCD (Liquid Crystal Display) đƣợc sử dụng
trong rất nhiều các ứng dụng của VĐK. LCD có rất nhiều ƣu điểm so với các
dạng hiển thị khác nhƣ nó có khả năng hiển thị kí tự đa dạng, trực quan (chữ,
số và kí tự đồ họa), dễ dàng đƣa vào mạch ứng dụng theo nhiều giao thức giao
tiếp khác nhau, tốn rất ít tài nguyên hệ thống và giá thành rẻ ... Trong đề tài
này em sử dụng HD44780 của Hitachi, một loại thiết bị hiển thị LCD rất
thông dụng ở nƣớc ta.
17
1.2.1. Hình dáng kích thƣớc
Có rất nhiều loại LCD với nhiều hình dáng và kích thƣớc khác nhau, trên
hình 1.8 là hai loại LCD thông dụng.
Hình 1.8: Hình hai loại LCD thông dụng.
Hình 1.9: Sơ đồ chân của LCD.
Hình 1.10: LCD loại DM 1602A.
Khi sản xuất LCD, nhà sản xuất đã tích hợp chíp điều khiển (HD44780)
bên trong lớp vỏ và chỉ đƣa các chân giao tiếp cần thiết. Các chân này đƣợc
đánh số thứ tự và đặt tên nhƣ hình 1.9.
18
1.2.2.Các chân chức năng
Bảng 1.1: Các chân chức năng của HD44780.
Chân
số
Tên Chức năng
1 Vss
Chân nối đất cho LCD, khi thiết kế mạch ta nối chân
này với GND của mạch điều khiển.
2 Vdd
Chân cấp nguồn cho LCD, khi thiết kế mạch ta nối
chân này với 5V của mạch điều khiển.
3 Vo
Chân này dùng để điều chỉnh độ tƣơng phản của
LCD.
4 RS
Chân chọn thanh ghi (Register select). Nối chân RS
với logic “0” (GND) hoặc logic “1” (Vcc) để chọn
thanh ghi.
+ Logic “0”: Bus DB0-DB7 sẽ nối với thanh ghi lệnh
IR của LCD (ở chế độ “ghi” - write) hoặc nối với bộ
đếm địa chỉ của LCD (ở chế độ “đọc” -read).
+ Logic “1”: Bus DB0-DB7 sẽ nối với thanh ghi dữ
liệu DR bên trong LCD.
5 RW
Chân chọn chế độ đọc/ghi (Read/Write). Nối chân
R/W với logic “0” để LCD hoạt động ở chế độ ghi,
hoặc nối với logic “1” để LCD ở chế độ đọc.
6 E
Chân cho phép (Enable). Sau khi các tín hiệu đƣợc
đặt lên bus DB0-DB7, các lệnh chỉ đƣợc chấp nhận
khi có 1 xung cho phép của chân E.
+ Ở chế độ ghi: Dữ liệu ở bus sẽ đƣợc LCD chuyển
vào (chấp nhận) thanh ghi bên trong nó khi phát hiện
một xung (low-to-high transition) của tín hiệu chân
E.
+Ở chế độ đọc: Dữ liệu sẽ đƣợc LCD xuất ra DB0-
DB7 khi phát hiện sƣờn lên (low-to-high transition) ở
chân E và đƣợc LCD giữ ở bus đến khi nào chân E
xuống mức thấp.
7÷14 DB0÷DB7
8 đƣờng của bus dữ liệu dùng để trao đổi thông tin
với MPU. Có 2 chế độ sử dụng 8 đƣờng bus này:
+ Chế độ 8 bit: Dữ liệu đƣợc truyền trên cả 8 đƣờng,
với bit MSB là bit DB7.
+ Chế độ 4 bit: Dữ liệu đƣợc truyền trên 4 đƣờng từ
DB4 tới DB7, bit MSB là DB7.
15 A 15 là Catot, điện áp khoảng Uak=4,2V
16 K Chân nối đất của đèn Back light.
19
1.2.3. Sơ đồ khối của HD44780
Để hiểu rõ hơn chức năng các chân và hoạt động của chúng, ta tìm hiểu
sơ qua chíp HD44780 thông qua các khối cơ bản của nó.
a) Các thanh ghi:
Chíp HD44780 có 2 thanh ghi 8 bit quan trọng là: Thanh ghi lệnh IR
(Instructor Register) và thanh ghi dữ liệu DR (Data Register).
- Thanh ghi IR: Để điều khiển LCD, ngƣời dùng phải “ra lệnh” thông
qua tám đƣờng bus DB0-DB7. Mỗi lệnh đƣợc nhà sản xuất LCD đánh địa chỉ
rõ ràng. Ngƣời dùng chỉ việc cung cấp địa chỉ lệnh bằng cách nạp vào thanh
ghi IR. Nghĩa là, khi ta nạp vào thanh ghi IR một chuỗi 8 bit, chíp HD44780
sẽ tra bảng mã lệnh tại địa chỉ mà IR cung cấp và thực hiện lệnh đó.
Ví dụ: Lệnh “hiển thị màn hình” có địa chỉ lệnh là 00001100 (DB7DB0).
Hình 1.11:Sơ đồ khối của HD44780.
20
- Thanh ghi DR: Thanh ghi DR dùng để chứa dữ liệu 8 bit để ghi vào
vùng RAM, DDRAM hoặc CGRAM (ở chế độ ghi) hoặc dùng để chứa dữ
liệu từ 2 vùng RAM này gửi ra cho MPU (ở chế độ đọc). Nghĩa là, khi MPU
ghi thông tin vào DR, mạch nội bên trong chíp sẽ tự động ghi thông tin này
vào DDRAM hoặc CGRAM. Hoặc khi thông tin về địa chỉ đƣợc ghi vào IR,
dữ liệu ở địa chỉ này trong vùng RAM nội của HD44780 sẽ đƣợc chuyển ra
DR để truyền cho MPU. Vậy bằng cách điều khiển chân RS và R/W chúng
ta có thể chuyển qua lại giữa 2 thanh ghi này trong khi giao tiếp với MPU.
Bảng 1.2 tóm tắt lại các thiết lập đối với hai chân RS và R/W theo mục đích
giao tiếp.
Bảng 1.2: Bảng chức năng chân RS và R/W theo mục đích sử dụng.
RS RW Ý nghĩa
0
0
Ghi vào thanh ghi IR
để ra lệnh cho LCD
(VD: cần display
clear,...).
0 1
Đọc cờ bận ở DB7 và
giá trị của bộ đếm địa
chỉ ở DB0-DB6.
1 0 Ghi vào thanh ghi DR.
1 1 Đọc dữ liệu từ DR.
b) Cờ báo bận BF (Busy Flag):
Khi thực hiện các hoạt động bên trong chíp, mạch nội bên trong cần một
khoảng thời gian để hoàn tất. Khi đang thực thi các hoạt động bên trong chíp
nhƣ thế, LCD bỏ qua mọi giao tiếp với bên ngoài và bật cờ BF (thông qua
chân DB7 khi có thiết lập RS=0, R/W=1) lên để báo cho MPU biết nó đang
“bận”. Dĩ nhiên, khi xong việc, nó sẽ đặt cờ BF lại mức 0.
c) Bộ đếm địa chỉ AC (Address Counter):
Nhƣ trong sơ đồ khối, thanh ghi IR không trực tiếp kết nối với vùng
RAM (DDRAM và CGRAM) mà thông qua bộ đếm địa chỉ AC. Bộ đếm này
lại nối với 2 vùng RAM theo kiểu rẽ nhánh. Khi một địa chỉ lệnh đƣợc nạp
21
vào thanh ghi IR, thông tin đƣợc nối trực tiếp cho 2 vùng RAM nhƣng việc
chọn lựa vùng RAM tƣơng tác đã đƣợc bao hàm trong mã lệnh. Sau khi ghi
vào (hoặc đọc từ) RAM, bộ đếm AC tự động tăng lên (hoặc giảm đi) 1 đơn vị
và nội dung của AC đƣợc xuất ra cho MPU thông qua DB0-DB6 khi có thiết
lập RS=0 và R/W=1 (xem bảng 1.2). Lƣu ý: Thời gian cập nhật AC không
đƣợc tính vào thời gian thực thi lệnh mà đƣợc cập nhật sau khi cờ BF lên mức
cao (not busy), cho nên khi lập trình hiển thị, bạn phải delay một khoảng
tADD khoảng 4µS-5µS (ngay sau khi BF=1) trƣớc khi nạp dữ liệu mới.
d) Vùng RAM hiển thị DDRAM (Display Data RAM):
Đây là vùng RAM dùng để hiển thị, nghĩa là ứng với một địa chỉ của
RAM là một ô kí tự trên màn hình và khi bạn ghi vào vùng RAM này một mã
8 bit, LCD sẽ hiển thị tại vị trí tƣơng ứng trên màn hình một kí tự có mã 8 bit
đã cung cấp nhƣ hình 1.12.
Hình 1.12: Mối liên hệ giữa địa chỉ của DDRAM và vị trí hiển thị của LCD.
Vùng RAM này có 80x8 bits nhớ, nghĩa là chứa đƣợc 80 kí tự mã 8 bits.
Những vùng RAM còn lại không dùng cho hiển thị có thể dùng nhƣ vùng
RAM đa mục đích. Lƣu ý là để truy cập vào DDRAM, ta phải cung cấp địa
chỉ cho AC theo mã HEX.
e) Vùng ROM chứa kí tự CGROM (Character Generator ROM):
22
Vùng ROM này dùng để chứa các mẫu kí tự loại 5x8 hoặc 5x10 điểm
ảnh/kí tự, và định địa chỉ bằng 8 bit. Tuy nhiên, nó chỉ có 208 mẫu kí tự 5x8
và 32 mẫu kí tự kiểu 5x10 (tổng cộng là 240 thay vì 256 mẫu kí tự). Ngƣời
dùng không thể thay đổi vùng ROM này.
Hình 1.13: Mối liên hệ giữa địa chỉ của ROM và dữ liệu tạo mẫu kí tự.
f) Vùng RAM chứa kí tự đồ họa CGRAM (Character Generator RAM):
Nhƣ trên bảng mã kí tự, nhà sản xuất dành vùng có địa chỉ byte cao là
0000h để ngƣời dùng có thể tạo các mẫu kí tự đồ họa riêng. Tuy nhiên dung
lƣợng vùng này rất hạn chế: Ta chỉ có thể tạo 8 kí tự loại 5x8 điểm ảnh, hoặc
4 kí tự loại 5x10 điểm ảnh. Để ghi vào CGRAM, xem hình1.13.
1.2.4. Tập lệnh của LCD
Trƣớc khi tìm hiểu tập lệnh của LCD, sau đây là một vài chú ý khi giao
tiếp với LCD:
Tuy trong sơ đồ khối của LCD có nhiều khối khác nhau, nhƣng khi lập
trình điều khiển LCD ta chỉ có thể tác động trực tiếp đƣợc vào 2 thanh ghi DR
23
và IR thông qua các chân DBx, và ta phải thiết lập chân RS, R/W phù hợp để
chuyển qua lại giữa 2 thanh ghi này (xem bảng1.2).
Hình 1.14: Mối liên hệ giữa địa chỉ của CGRAM, dữ liệu CGRAM,
và mã kí tự.
Với mỗi lệnh, LCD cần một khoảng thời gian để hoàn tất, thời gian này
có thể khá lâu đối với tốc độ của MPU, nên ta cần kiểm tra cờ BF hoặc đợi
(delay) cho LCD thực thi xong lệnh hiện hành mới có thể ra lệnh tiếp theo.
Địa chỉ của RAM (AC) sẽ tự động tăng (giảm) 1 đơn vị, mỗi khi có lệnh
ghi vào RAM (Điều này giúp chƣơng trình gọn hơn).
Các lệnh của LCD có thể chia thành 4 nhóm nhƣ sau:
- Các lệnh về kiểu hiển thị. VD : Kiểu hiển thị (1 hàng/2 hàng), chiều dài
dữ liệu (8 bit/4 bit),
- Chỉ định địa chỉ RAM nội.
- Nhóm lệnh truyền dữ liệu trong RAM nội.
- Các lệnh còn lại.
24
Bảng 1.3: Các tập lệnh của LCD.
Tên lệnh Hoạt động
Thời gian
chạy
Clear
Display
Mã lệnh: DBx=DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
DBx= 0 0 0 0 0 0 0 1
Lệnh Clear Display (xóa hiển thị) sẽ ghi một khoảng trống
(mã hiển thị kí tự 20H) vào tất cả ô nhớ trong DDRAM,
sau đó trả bộ đếm địa chỉ AC=0, trả lại hiển thị gốc nếu nó
bị thay đổi, nghĩa là: Tắt hiển thị, con trỏ dời về góc trái
(hàng đầu tiên), chế độ tăng AC.
Return
home
Mã lệnh:DBx=DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
DBx= 0 0 0 0 0 0 0 *
1.52ms
Entry
mode set
Mã lệnh:DBx=DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
DBx= 0 0 0 0 0 1 [I/D] [S]
I/D: Tăng (I/D=1) hoặc giảm (I/D=0) bộ đếm địa chỉ hiển
thị AC 1 đơn vị mỗi khi có hành động ghi hoặc đọc vùng
DDRAM. Vị trí con trỏ cũng di chuyển theo sự tăng giảm
này.
S: Khi S=1 toàn bộ nội dung hiển thị bị dịch sang phải
(I/D=0) hoặc sang trái (I/D=1) mỗi khi có hành động ghi
vùng DDRAM. Khi S=0: không dịch nội dung hiển thị.
Nội dung hiển thị không dịch khi đọc DDRAM hoặc
đọc/ghi vùng CGRAM.
Hình 1.15: Hoạt động dịch trái và dịch phải nội dung hiển
thị.
37µs
Display
on/off
control
Mã lệnh:DBx=DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
DBx= 0 0 0 0 1 [D] [C] [B]
D: Hiển thị màn hình khi D=1 và ngƣợc lại. Khi tắt hiển
thị, nội dung DDRAM không thay đổi.
C: Hiển thị con trỏ khi C=1 và ngƣợc lại. Vị trí và hình
dạng con trỏ, xem hình1.16.
B: Nhấp nháy kí tự tại vị trí con trỏ khi B=1 và ngƣợc lại.
Chu kì nhấp nháy khoảng 409,6ms khi mạch dao động
nội LCD là 250kHz.
37µs
25
Hình 1.16: Kiểu con, kiểu kí tự và nhấp nháy kí tự.
Cursor
or
display
shift
Mã lệnh:DBx=DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
DBx= 0 0 0 1 [S/C][R/L] * *
Lệnh Cursor or display shift dịch chuyển con trỏ hay dữ
liệu hiển thị sang trái mà không cần hành động ghi/đọc dữ
liệu. Khi hiển thị kiểu 2 dòng, con trỏ sẽ nhảy xuống dòng
dƣới khi dịch qua vị trí thứ 40 của hàng đầu tiên. Dữ liệu
hàng đầu và hàng 2 dịch cùng một lúc. Chi tiết sử dụng
xem hình sau:
Hình 1.17: Chi tiết sử dụng lệnh.
37µs
Funtion
set
Mã lệnh:DBx=DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
DBx= 0 0 1 [DL] [N] [F] * *
DL: Khi DL=1, LCD giao tiếp với MPU bằng giao thức 8
bit (từ bit DB7 đến DB0). Ngƣợc lại, giao thức giao tiếp là
4 bit (từ bit DB7 đến bit DB0). Khi chọn giao thức 4 bit,
dữ liệu đƣợc truyền/nhận 2 lần liên tiếp với 4 bit cao
gửi/nhận trƣớc, 4 bit thấp gửi/nhận sau.
N: Thiết lập số hàng hiển thị. Khi N=0: hiển thị 1 hàng,
N=1: hiển thị 2 hàng.
F: Thiết lập kiểu kí tự. Khi F=0: kiểu kí tự 5x8 điểm ảnh,
F=1: kiểu kí tự 5x10 điểm ảnh.
* Chú ý:
• Chỉ thực hiện thay đổi Function set ở đầu chƣơng trình.
Và sau khi đƣợc thực thi 1 lần, lệnh thay đổi Function set
không đƣợc LCD chấp nhận nữa ngoại trừ thiết lập
chuyển đổi giao thức giao tiếp.
Không thể hiển thị kiểu kí tự 5x10 điểm ảnh ở kiểu hiển
37µs
26
thị 2 hàng.
Set
CGRAM
address
Mã lệnh:DBx=DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
DBx=0 1[ACG][ACG][ACG][ACG][ACG][ACG][ACG]
Lệnh này ghi vào AC địa chỉ của CGRAM. Kí hiệu [ACG]
chỉ 1 bit của chuỗi dữ liệu 6 bit. Ngay sau lệnh này là lệnh
đọc/ghi dữ liệu từ CGRAM tại địa chỉ đã đƣợc chỉ định.
Set
DDRAM
address
Mã lệnh:DBx=DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
DBx= 1 [AD][AD][AD][AD] [AD] [AD] [AD]
Lệnh này ghi vào AC địa chỉ của DDRAM, dùng khi cần
thiết lập tọa độ hiển thị mong muốn. Ngay sau lệnh này là
lệnh đọc/ghi dữ liệu từ DDRAM tại địa chỉ đã đƣợc chỉ
định. Khi ở chế độ hiển thị 1 hàng, địa chỉ có thể từ 00H
đến 4FH. Khi ở chế độ hiển thị 2 hàng, địa chỉ từ 00h đến
27H cho hàng thứ nhất, và từ 40h đến 67h cho hàng thứ 2.
37µs
Read BF
and
address
Mã lệnh:DBx=DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
DBx= [BF][AD][AD][AD][AD][AD][AD][AD]
RS=0; R/W=1
Nhƣ đã đề cập trƣớc đây, khi cờ BF bật, LCD đang làm
việc và lệnh tiếp theo (nếu có) sẽ bị bỏ qua nếu cờ BF
chƣa về mức thấp. Cho nên, khi lập trình điều khiển, bạn
phải kiểm tra cờ BF trƣớc khi ghi dữ liệu vào LCD. Khi
đọc cờ BF, giá trị của AC cũng đƣợc xuất ra các bit [AC].
Nó là địa chỉ của CG hay DDRAM là tùy thuộc vào lệnh
trƣớc đó.
0µs
Write
data to
CG or
DDRAM
Mã lệnh:DBx=DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
DBx= [Write data] (RS=1, R/W=0)
Khi thiết lập RS=1, R/W=0, dữ liệu cần ghi đƣợc đƣa vào
các chân DBx từ mạch ngoài sẽ đƣợc LCD chuyển vào
trong LCD tại địa chỉ đƣợc xác định từ lệnh ghi địa chỉ
trƣớc đó. Sau khi ghi, bộ đếm địa chỉ AC tự động
tăng/giảm 1 tùy theo thiết lập Entry mode. Lƣu ý là thời
gian cập nhật AC không tính vào thời gian thực thi lệnh.
37µs
tADD
4µs
Read
data
from CG
or
DDRAM
Mã lệnh:DBx=DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0
DBx= [Read data] (RS=1, R/W=1)
Khi thiết lập RS=1, R/W=1, dữ liệu từ CG/DDRAM đƣợc
chuyển ra MPU thông qua các chân DBx (địa chỉ và vùng
RAM đã đƣợc xác định bằng lệnh ghi địa chỉ trƣớc đó).
Sau khi đọc, AC tự động tăng/giảm 1 tùy theo thiết lập
Entry mode, tuy nhiên nội dung hiển thị không bị dịch bất
chấp chế độ Entrymode.
37µs
tADD
4µs
27
1.2.5. Đặc tính của các chân giao tiếp
LCD sẽ bị hỏng nghiêm trọng, hoặc hoạt động sai lệch nếu bạn vi phạm
khoảng đặc tính điện sau đây:
Bảng 1.4: Đặc tính làm việc điển hình.
Đặc tính điện làm việc điển hình: (Đo trong điều kiện hoạt động Vcc =
4.5V đến 5.5V, T = -30 đến +750C).
Bảng 1.5: Miền làm việc bình thƣờng.
28
CHƢƠNG 2.
THIẾT KẾ HỆ THỐNG ĐIỀU KHIỂN ĐỘNG CƠ DC THEO
NHIỆT ĐỘ
2.1. SƠ ĐỒ KHỐI
Với yêu cầu của đề tài là thiết kế hệ thống điều khiển động cơ DC theo
nhiệt độ, tức là từ nhiệt độ đo đƣợc trong môi trƣờng, hệ thống điều khiển
tốc độ động cơ DC quay nhanh hay chậm. Ta có sơ đồ khối hệ thống trong
hình 2.1.
Hình 2.1: Sơ đồ khối hệ thống điều khiển động cơ DC theo nhiệt độ.
Với sơ đồ này ta sử dụng cảm biến đo nhiệt độ môi trƣờng. Điện áp ra
của cảm biến đƣợc khuếch đại, hiệu chỉnh để phù hợp với đầu vào của ADC.
Khối ADC làm nhiệm vụ chuyển đổi tín hiệu tƣơng tự thành tín hiệu số đƣa
vào khối xử lý. Khối xử lý làm nhiệm vụ nhận giá trị đo, từ đó điều khiển
động cơ DC quay với tốc độ phù hợp. Trên sơ đồ sử dụng khối hiển thị để
ngƣời sử dụng có thể theo dõi đƣợc các thông số và thao tác thực hiện.
2.2. THIẾT KẾ CÁC KHỐI
2.2.1. Mạch đo nhiệt độ
Nhiệt độ là một đại lƣợng vật lý vô hƣớng. Để đo đạc và tính toán giá
29
trị của nó ta phải dùng các bộ cảm biến. Cảm biến đo nhiệt độ ở đây em
chọn loại phổ biến là LM335. Bộ cảm biến LM335 đƣa ra điện áp 10mV
cho mỗi sự thay đổi 1oK.
Thông số kĩ thuật:
- Là cảm biến nhiệt độ cho ra các mức điện áp tƣơng ứng với độ
Kelvin
Sai số +/- 10C
- Hoạt động trong dải từ 400uA - 5 mA
- Trở kháng nội < 1 Ω
- Dải nhiệt độ đo đƣợc -550C đến 1500C
Sơ đồ chân và mạch đo:
Hình 2.2: Sơ đồ chân của LM335.
ADJ - Chân hiệu chuẩn.
V+ - Chân cấp nguồn 15V.
V- - Chân GND.
Hình 2.3: Kết nối VĐK.
R2
R1
6K
77.0
SENSOR
LM335
E+
30
- Nhiệt độ tính theo độ Kelvin T = Vout /(10mV).
Từ độ Kelvin ta có thể đổi ra độ C theo công thức:
T(độ C) = T(độ Kenvin) - 273,15 .
2.2.2. Khối xử lý
Đây là khối quan trọng và quản lý toàn bộ hoạt động của mạch. Nhiệm
vụ chính của khối là nhận về giá trị nhiệt độ, điều khiển động cơ. Giá trị đo từ
LM335 đƣợc cho qua bộ ADC, mạch này ta có thể dùng IC ngoài hoặc đƣợc
tích hợp trong một số dòng vi điều khiển. Ở đây em dùng PIC16F877A, vừa
chuyển đổi ADC, hiển thị LCD, vừa điều khiển động cơ bằng phƣơng pháp
PWM.
Hình 2.4: Sơ đồ nguyên lý của PIC16F877A trong mạch.
31
2.2.3. Khối ADC (tích hợp trong PIC16F877A)
ADC (Analog to Digital Converter) là bộ chuyển đổi tín hiệu giữa hai
dạng tƣơng tự và số. PIC16F877A có 8 ngõ vào analog (RA4:RA0 và
RE2:RE0). Hiệu điện thế chuẩn VREF có thể đƣợc lựa chọn là VDD, VSS hay
hiệu điện thế chuẩn đƣợc xác lập trên hai chân RA2 và RA3. Kết quả chuyển
đổi từ tín hiệu tƣơng tự sang tín hiệu số là 10 bit số tƣơng ứng và đƣợc lƣu
trong hai thanh ghi ADRESH : ADRESL. Khi không sử dụng bộ chuyển đổi
ADC, các thanh ghi này có thể đƣợc sử dụng nhƣ các thanh ghi thông thƣờng
khác. Khi quá trình chuyển đổi hoàn tất, kết quả sẽ đƣợc lƣu vào hai thanh ghi
ADRESH : ADRESL, bit GO/DONE (ADCON0) đƣợc xóa về số 0 và cờ
ngắt ADIF đƣợc set.
Quá trình chuyển đổi từ tƣơng tự sang số bao gồm các bƣớc:
+ Thiết lập các thông số cho bộ chuyển đổi ADC:
- Chọn ngõ vào analog, chọn điện áp lấy mẫu (dựa trên các thông số của
thanh ghi ADCON1).
- Chọn kênh chuyển đổi AD (thanh ghi ADCON0).
- Chọn xung clock cho kênh chuyển đổi AD (thanh ghi ADCON0).
- Cho phép bộ chuyển đổi AD hoạt động (thanh ghi ADCON0).
+ Thiết lập các cờ ngắt cho AD:
- Clear bit ADIF.
- Set bit ADIE.
- Set bit PEIE.
- Set bit GIE.
+ Đợi cho tới khi quá trình lấy mẫu hoàn tất.
+ Bắt đầu quá trình chuyển đổi (set bit GO/DONE ).
+ Đợi cho tới khi quá trình chuyển đổi hoàn tất bằng cách :
- Kiểm tra bit GO/DONE . Nếu GO/DONE =0, quá trình chuyển đổi đã
hoàn tất.
32
- Kiểm tra cờ ngắt.
+ Đọc kết quả chuyển và xóa cờ ngắt, set bi
Các file đính kèm theo tài liệu này:
- 7_KieuCongHoa_DC1701.pdf