Đồ án Điều khiển robot dò đƣờng

Ngày nay điều khiển tự động đã trở thành một nhu cầu không thể thiếu đƣợc của con ngƣời, dƣới sự xuất hiện của các học thuyết và các ứng dụng cụ thể trong đời sống hằng ngày, có thể nói điều khiển tự động đang chi phối dần cuộc sống của chúng ta. con ngƣời đang cố gắng sáng tạo ra các con robot có khả năng làm việc thay cho con ngƣời, chúng ta thƣờng bắt gặp các con robot trong các dây chuyền công nghiệp sản xuất tự động hay robot giúp việc trong gia đình. Để tìm ra các ý tƣởng sáng tạo hay hàng năm đề diễn ra cuộc thi robocon châu á thái bình dƣơng đó là tiền đề để tạo ra những con robot có khả năng áp dụng vào thực tế. Cũng chính vì mục đích đó mà chúng em thực hiện đồ án điều khiển robot dò đƣờng, nó lại là bƣớc khởi đầu trong lập trình robot để robot có thể thực hiện các công việc tiếp theo. Đây chỉ là một công việc nhỏ của lập trình điều khiển robot nhƣng qua quá trình thiết kế và thi công đề tài chúng em đã rút ra đƣợc rất nhiều kinh nghiệm thực tiễn quý báu. Mục đích của đề tài hƣớng đến là tạo ra bƣớc đầu cho sinh viên thử nghiệm những ứng dụng của vi điều khiển trong thực tiễn để rồi từ đó tìm tòi, phát triển nhiều ứng dụng khác trong đời sống hằng ngày cần đến. Mặc dù đã cố gắng hết sức mình để hoàn thành xong đồ án môn học bằng các kiến thức đã học, một số sách tham khảo và một số nguồn tài liệu khác nhƣng cũng không tránh khỏi những thiếu sót. Do vậy, chúng em rất mong đƣợc sự góp ý quý báu của thầy cô và các bạn để đề tài có thể hoàn thiện ở mức cao nhất. Nhân đây cho chúng em xin gữi lời cám ơn chân thành đến Thầy Phạm Duy Dƣởng và các Thầy bộ môn đã tận tình hƣớng dẫn để chúng em hoàn thành tốt đề tài của mình!

pdf47 trang | Chia sẻ: oanh_nt | Lượt xem: 2098 | Lượt tải: 1download
Bạn đang xem trước 20 trang tài liệu Đồ án Điều khiển robot dò đƣờng, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
ĐỒ ÁN TỐT NGHIỆP GVHD KS. PHẠM DUY DƯỞNG LỜI NÓI ĐẦU Ngày nay điều khiển tự động đã trở thành một nhu cầu không thể thiếu đƣợc của con ngƣời, dƣới sự xuất hiện của các học thuyết và các ứng dụng cụ thể trong đời sống hằng ngày, có thể nói điều khiển tự động đang chi phối dần cuộc sống của chúng ta. con ngƣời đang cố gắng sáng tạo ra các con robot có khả năng làm việc thay cho con ngƣời, chúng ta thƣờng bắt gặp các con robot trong các dây chuyền công nghiệp sản xuất tự động hay robot giúp việc trong gia đình. Để tìm ra các ý tƣởng sáng tạo hay hàng năm đề diễn ra cuộc thi robocon châu á thái bình dƣơng đó là tiền đề để tạo ra những con robot có khả năng áp dụng vào thực tế. Cũng chính vì mục đích đó mà chúng em thực hiện đồ án điều khiển robot dò đƣờng, nó lại là bƣớc khởi đầu trong lập trình robot để robot có thể thực hiện các công việc tiếp theo. Đây chỉ là một công việc nhỏ của lập trình điều khiển robot nhƣng qua quá trình thiết kế và thi công đề tài chúng em đã rút ra đƣợc rất nhiều kinh nghiệm thực tiễn quý báu. Mục đích của đề tài hƣớng đến là tạo ra bƣớc đầu cho sinh viên thử nghiệm những ứng dụng của vi điều khiển trong thực tiễn để rồi từ đó tìm tòi, phát triển nhiều ứng dụng khác trong đời sống hằng ngày cần đến. Mặc dù đã cố gắng hết sức mình để hoàn thành xong đồ án môn học bằng các kiến thức đã học, một số sách tham khảo và một số nguồn tài liệu khác nhƣng cũng không tránh khỏi những thiếu sót. Do vậy, chúng em rất mong đƣợc sự góp ý quý báu của thầy cô và các bạn để đề tài có thể hoàn thiện ở mức cao nhất. Nhân đây cho chúng em xin gữi lời cám ơn chân thành đến Thầy Phạm Duy Dƣởng và các Thầy bộ môn đã tận tình hƣớng dẫn để chúng em hoàn thành tốt đề tài của mình! Nhóm sinh viên thực hiện : Bùi Xuân Dũng Trần Văn Thọ Bùi Phúc Hát SVTH: BÙI XUÂN DŨNG Trang 1 ĐỒ ÁN TỐT NGHIỆP GVHD KS. PHẠM DUY DƯỞNG CHƢƠNG I TỔNG QUAN VỀ VI ĐIỀU KHIỂN 8051 1. Tổng quan 1.1. Giới thiệu chung MCS-51 là họ vi điều khiển của hãng Intel. Vi mạch tổng quát của họ MCS-51 là chip 8051. Chip 8051 có một số đặc trƣng cơ bản sau: – Bộ nhớ chƣơng trình bên trong: 4 KB (ROM). – Bộ nhớ dữ liệu bên trong: 128 byte (RAM). – Bộ nhớ chƣơng trình bên ngoài: 64 KB (ROM). – Bộ nhớ dữ liệu bên ngoài: 64 KB (RAM). – 4 port xuất nhập (I/O port) 8 bit. – 2 bộ định thời 16 bit. – Mạch giao tiếp nối tiếp. – Bộ xử lý bit (thao tác trên các bit riêng lẻ). – 210 vị trí nhớ đƣợc định địa chỉ, mỗi vị trí 1 bit. – Nhân / Chia trong 4 µs. Ngoài ra, trong họ MCS-51 còn có một số chip vi điều khiển khác có cấu trúc tƣơng đƣơng nhƣ: Bảng 1 Bảng 1: Cấu trúc tương ứng của họ 8051 1.2. Các phiên bản của chip vi điều khiển 8051 1.2.1. Bộ vi điều khiển 8052 8052 là một phiên bản của họ 8051. 8052 có tất cả các thông số kỹ thuật của 8051, ngoài ra còn có thêm 128 byte RAM, 4KB ROM và một bộ định thời nữa. Nhƣ vậy, 8052 có tổng cộng 256 byte RAM, 8KB ROM và ba bộ định thời. SVTH: BÙI XUÂN DŨNG Trang 2 ĐỒ ÁN TỐT NGHIỆP GVHD KS. PHẠM DUY DƯỞNG Bảng 2 Đặc tính kỹ thuật 8031 8051 8052 ROM trên chip(KB) 0 4 8 RAM trên chip(byte) 128 128 256 Bộ định thời 2 2 3 Chân vào/ra 32 32 32 Cổng nối tiếp 1 1 1 Nguồn ngắt 5 5 6 Bảng 2:Các phiên bản của 8051 Nhƣ bảng thông số trên ta thấy 8051 là một trƣờng hợp riêng của 8052. Mọi chƣơng trình viết cho 8051 đều có thể chạy đƣợc trên 8052 nhƣng điều nguợc lại có thể là không đúng. 1.2.2. Bộ vi điều khiển AT8951 của Atmel Corporation AT8951 là phiên bản 8051 có ROM trên chip là bộ nhớ Flash. Phiên bản này rất thích hợp cho các ứng dụng nhanh vì bộ nhớ Flash có thể đƣợc xóa trong vài giây. Dĩ nhiên là để dùng AT8951 cần phải có thiết bị lập trình PROM hỗ trợ bộ nhớ Flash nhƣng không cần đến thiết bị xóa ROM vì bộ nhớ Flash đƣợc xóa bằng thiết bị lập trình PROM. Để tiện sử dụng, hiện nay hãng Atmel đang nghiên cứu một phiên bản của AT8951 có thể đƣợc lập trình qua cổng COM của máy tính PC và Nhƣ vậy sẽ không cần đến thiết bị lập trình PROM. Bảng 3 Ký hiệu ROM RAM I/O Timer Ngắt Vcc Số chân IC AT89C51 4KB 128 32 2 5 5V 40 AT89LV51 4KB 128 32 2 5 3V 40 AT89C1051 1KB 64 15 1 3 3V 20 AT89C2051 2KB 128 15 2 5 3V 20 AT89C52 8KB 256 32 3 6 5V 40 AT89LV52 8KB 256 32 3 6 3V 40 Bảng 3: Cấu trúc bộ vi điều khiển 8051 1.2.3. Bộ vi điều khiển DS5000 của Dallas Semiconductor Một phiên bản phổ biến khác nữa của 8051 là DS5000 của hãng Dallas Semiconductor. Bộ nhớ ROM trên chip của DS5000 là NV-RAM. DS5000 có khả năng nạp chƣơng trình vào ROM trên chip trong khi nó vẫn ở trong hệ thống mà không cần phải lấy ra. Cách thực hiện là dùng qua cổng COM của máy tính PC. Đây là điểm mạnh đƣợc ƣa chuộng,Ngoài ra NV-RAM còn có nhiều ƣu việt là cho phép thay đỏi nội dung RAM theo từng byte mà không phải xóa hết trƣớc khi lập trình nhƣ bộ nhớ EPROM. SVTH: BÙI XUÂN DŨNG Trang 3 ĐỒ ÁN TỐT NGHIỆP GVHD KS. PHẠM DUY DƯỞNG Bảng 4 Ký hiệu ROM RAM I/O Timer Ngắt Vcc Số chân IC DS5000-8 8KB 128 32 2 6 5V 40 DS5000-32 32KB 128 32 2 6 5V 40 DS5000T-8 8KB 128 32 2 6 5V 40 DS5000T-32 32KB 128 32 2 6 5V 40 Đây là một phiên bản cải tiến sử dụng CPU là bộ vi điều khiển 80C51 với nhiều tính năng vuợt trội: dung lƣợng ROM/RAM trên chip rất lớn, 3 Timer 16 bit + 1 Watch-dog Timer, 2 thanh ghi DPTR, 8 nguồn ngắt, PWM (Pulse Width Modulator), SPI (Serial Peripheral Interface) và đặc biệt là bộ nhớ chƣơng trình trên chip có tính năng ISP (In-System Programming) và IAP (In-Application Programming),… 2. Các chân của chip 8051 2.1 . Sơ đồ khối và chức năng các khối của chip 8051 Hình 1: Sơ đồ khối của chíp 8051 Chức năng các khối: – CPU (Central Processing Unit): Đơn vị xử lý trung tâm tính toán và điều khiển quá trình hoạt động của hệ thống. – OSC (Oscillator): Mạch dao động tạo tín hiệu xung clock cung cấp cho các khối trong chip hoạt động. – Interrupt control: Điều khiển ngắt nhận tín hiệu ngắt từ bên ngoài (INT0\, INT1\), từ bộ định thời (Timer 0, Timer 1) và từ cổng nối tiếp (Serial port), lần luợt đua các tín hiệu ngắt này đến CPU để xử lý. SVTH: BÙI XUÂN DŨNG Trang 4 ĐỒ ÁN TỐT NGHIỆP GVHD KS. PHẠM DUY DƯỞNG – Other registers: Các thanh ghi khác Lƣu trữ dữ liệu của các port xuất/nhập, trạng thái làm việc của các khối trong chip trong suốt quá trình hoạt động của hệ thống. – RAM (Random Access Memory): Bộ nhớ dữ liệu trong chip lƣu trữ các dữ liệu. – ROM (Read Only Memory): Bộ nhớ chƣơng trình trong chip lƣu trữ chƣơng trình hoạt động của chip. – I/O ports (In/Out ports): Các port xuất/nhập điều khiển việc xuất nhập dữ liệu duới dạng song song giữa trong và ngoài chip thông qua các port P0, P1, P2, P3. – Serial port: Port nối tiếp điều khiển việc xuất nhập dữ liệu duới dạng nối tiếp giữa trong và ngoài chip thông qua các chân TxD, RxD. – Timer 0, Timer 1: Bộ định thời 0, 1 dùng để định thời gian hoặc đếm sự kiện (đếm xung) thông qua các chân T0, T1. – Bus control: Điều khiển bus điều khiển hoạt động của hệ thống bus và việc di chuyển thông tin trên hệ thống bus. – Bus system: Hệ thống bus liên kết các khối trong chip lại với nhau. 2.2 . Sơ đồ chân và chức năng các chân của chip 8051 Hình 2: Sơ đồ chân chíp 8051 SVTH: BÙI XUÂN DŨNG Trang 5 ĐỒ ÁN TỐT NGHIỆP GVHD KS. PHẠM DUY DƯỞNG 2.2.1. Port 0 Port 0 (P0.0 – P0.7) có số chân từ 32 – 39. Port 0 có hai chức năng: – Port xuất nhập dữ liệu (P0.0 - P0.7) không sử dụng bộ nhớ ngoài. – Bus địa chỉ byte thấp và bus dữ liệu đa hợp (AD0 – AD7) có sử dụng bộ nhớ ngoài. Lƣu ý: Khi Port 0 đóng vai trò là port xuất nhập dữ liệu thì phải sử dụng các điện trở kéo lên bên ngoài. Ở chế độ mặc định (khi reset) thì các chân Port 0 (P0.0 - P0.7) đƣợc cấu hình là port xuất dữ liệu. Muốn các chân Port 0 làm port nhập dữ liệu thì cần phải lập trình lại, bằng cách ghi mức logic cao (mức 1) đến tất cả các bit của port truớc khi bắt đầu nhập dữ liệu từ port (vấn đề này đƣợc trình bày ở phần kế tiếp). Khi lập trình cho ROM trong chip thì Port 0 đóng vai trò là ngõ vào của dữ liệu (D0-D7). 2.2.2. Port 1 Port 1 (P1.0 – P1.7) có số chân từ 1 – 8. Port 1 có một chức năng: – Port xuất nhập dữ liệu (P1.0 – P1.7) sử dụng hoặc không sử dụng bộ nhớ ngoài. – Ở chế độ mặc định (khi reset) thì các chân Port 1 (P1.0 – P1.7) đƣợc cấu hình là port xuất dữ liệu. Muốn các chân Port 1 làm port nhập dữ liệu thì cần phải lập trình lại, bằng cách ghi mức logic cao (mức 1) đến tất cả các bit của port truớc khi bắt đầu nhập dữ liệu từ port (vấn đề này đƣợc trình bày ở phần kế tiếp). Khi lập trình cho ROM trong chip thì Port 1 đóng vai trò là ngõ vào của địa chỉ byte thấp (A0 – A7). 2.2.3. Port 2 Port 2 (P2.0 – P2.7) có số chân từ 21 – 28. Port 2 có hai chức năng: – Port xuất nhập dữ liệu (P2.0 – P2.7)không sử dụng bộ nhớ ngoài. – Bus địa chỉ byte cao (A8 – A15) có sử dụng bộ nhớ ngoài. Ở chế độ mặc định (khi reset) thì các chân Port 2 (P2.0 – P2.7) đƣợc cấu hình là port xuất dữ liệu. Muốn các chân Port 2 làm port nhập dữ liệu thì cần phải lập trình lại, bằng cách ghi mức logic cao (mức 1) đến tất cả các bit của port truớc khi bắt đầu nhập dữ liệu từ port (vấn đề này đƣợc trình bày ở phần kế tiếp). Khi lập trình cho ROM trong chip thì Port 2 đóng vai trò là ngõ vào của địa chỉ byte cao (A8 – A11) và các tín hiệu điều khiển. SVTH: BÙI XUÂN DŨNG Trang 6 ĐỒ ÁN TỐT NGHIỆP GVHD KS. PHẠM DUY DƯỞNG 2.2.4. Port 3 Port 3 (P3.0 – P3.7) có số chân từ 10 – 17. Port 3 có hai chức năng: – Port xuất nhập dữ liệu (P3.0 – P3.7) không sử dụng bộ nhớ ngoài hoặc các chức năng đặc biệt. – Các tín hiệu điều khiển có sử dụng bộ nhớ ngoài hoặc các chức năng đặc biệt. Ở chế độ mặc định (khi reset) thì các chân Port 3 (P3.0 – P3.7) đƣợc cấu hình là port xuất dữ liệu. Muốn các chân Port 3 làm port nhập dữ liệu thì cần phải lập trình lại, bằng cách ghi mức logic cao (mức 1) đến tất cả các bit của port truớc khi bắt đầu nhập dữ liệu từ port (vấn đề này đƣợc trình bày ở phần kế tiếp). Khi lập trình cho ROM trong chip thì Port 3 đóng vai trò là ngõ vào của các tín hiệu điều khiển (xem sách “Họ vi điều khiển 8051” trang 333-352). Chức năng của các chân Port 3: Bảng 5 Bit Tên Địa chỉ bit Chức năng P3.0 RxD B0H Chân nhận dữ liệu của port nối tiếp. P3.1 TxD B1H Chân phát dữ liệu của port nối tiếp. P3.2 INT0\ B2H Ngõ vào ngắt ngoài 0. P3.3 INT1\ B3H Ngõ vào ngắt ngoài 1. P3.4 T0 B4H Ngõ vào của bộ định thời/đếm 0. P3.5 T1 B5H Ngõ vào của bộ định thời/đếm 1. P3.6 WR\ B6H Điều khiển ghi vào RAM ngoài. P3.7 RD\ B7H Điều khiển ñọc từ RAM ngoài. Bảng 5: Chức năng của các chân Port 3 2.2.5Chân PSEN\ PSEN (Program Store Enable): cho phép bộ nhớ chƣơng trình, chân số 29. Chức năng: – Là tín hiệu cho phép truy xuất (đọc) bộ nhớ chƣơng trình (ROM) ngoài. – Là tín hiệu xuất, tích cực mức thấp. PSEN\ = 0 trong thời gian CPU tìm - nạp lệnh từ ROM ngoài. PSEN\ = 1 CPU sử dụng ROM trong (không sử dụng ROM ngoài). Khi sử dụng bộ nhớ chƣơng trình bên ngoài, chân PSEN\ thƣờng đƣợc nối với chân OE\ của ROM ngoài để cho phép CPU đọc mã lệnh từ ROM ngoài. 2.2.6. Chân ALE ALE (Address Latch Enable): cho phép chốt địa chỉ, chân số 30. Chức năng: – Là tín hiệu cho phép chốt địa chỉ để thực hiện việc giải đa hợp cho bus địa chỉ byte thấp và bus dữ liệu đa hợp (AD0 – AD7). – Là tín hiệu xuất, tích cực mức cao. ALE = 0 trong thời gian bus AD0 - AD7 đóng vai trò là bus D0 - D7. ALE = 1 trong thời gian bus AD0 - AD7 đóng vai trò là bus A0 - A7. Khi lập trình cho ROM trong chip thì chân ALE đóng vai trò là ngõ vào của xung lập trình (PGM\). SVTH: BÙI XUÂN DŨNG Trang 7 ĐỒ ÁN TỐT NGHIỆP GVHD KS. PHẠM DUY DƯỞNG Lƣu ý: fALE = fOSC/6 có thể dùng làm xung clock cho các mạch khác. (MHz): tần số xung tại chân ALE. f (MHz): tần số dao động trên chip (tần số thạch anh). Khi lệnh lấy dữ liệu từ RAM ngoài (MOVX) đƣợc thực hiện thì một xung ALE bị bỏ qua. 2.2.7. Chân EA\ EA (External Access): truy xuất ngoài, chân số 31. Chức năng: – Là tín hiệu cho phép truy xuất (sử dụng) bộ nhớ chƣơng trình (ROM) ngoài. – Là tín hiệu nhập, tích cực mức thấp. EA\ = 0 Chip 8051 sử dụng chƣơng trình của ROM ngoài. EA\ = 1 Chip 8051 sử dụng chƣơng trình của ROM trong. Khi lập trình cho ROM trong chip thì chân EA đóng vai trò là ngõ vào của điện áp lập trình(Vpp = 12V – 12,5V cho họ 89xx; 21V cho họ 80xx, 87xx). Lƣu ý: Chân EA\ phải đƣợc nối lên Vcc (nếu sử dụng chƣơng trình của ROM trong) hoặc nối xuống GND (nếu sử dụng chƣơng trình của ROM ngoài), không bao giờ đƣợc phép bỏ trống chân này. 2.2.8. Chân XTAL1, XTAL2 XTAL (Crystal): tinh thể thạch anh, chân số 18-19. Chức năng: – Dùng để nối với thạch anh hoặc mạch dao động tạo xung clock bên ngoài, cung cấp tín hiệu xung clock cho chip hoạt động. – XTAL1 ngõ vào mạch tạo xung clock trong chip. – XTAL2 ngõ ra mạch tạo xung clock trong chip Lƣu ý: fTYP = 12MHz fTYP (MHz): tần số danh định. 2.2.9. Chân RST RST (Reset): thiết lập lại, chân số 9. Chức năng: – Là tín hiệu cho phép thiết lặp (đặt) lại trạng thái ban đầu cho hệ thống. – Là tín hiệu nhập, tích cực mức cao. RST = 0 Chip 8051 hoạt động bình thƣờng. RST = 1 Chip 8051 đƣợc thiết lặp lại trạng thái ban đầu. SVTH: BÙI XUÂN DŨNG Trang 8 ĐỒ ÁN TỐT NGHIỆP GVHD KS. PHẠM DUY DƯỞNG Lƣu ý: tReset ≥ 2 × TMachine TMachine = 12/fOSC. tReset(µs): thời gian reset. fOSC = (MHz): tần số thạch anh. TMACHINE(µs): chu kỳ máy. Hình 3: Sơ đồ nguyên lý chân Reset 2.2.10. Chân Vcc, GND Vcc, GND: nguồn cấp điện, chân số 40 và 20. Chức năng: – Cung cấp nguồn điện cho chip 8051 hoạt động. – Vcc = +5V, 10% và GND = 0V 3. Tổ chức bộ nhớ của chip 8051 Bộ vi xử lý có không gian bộ nhớ chung cho dữ liệu và chƣơng trình. 3.1. Bộ nhớ chƣơng trình (ROM) Dùng để lƣu trữ chƣơng trình điều khiển cho chip 8051 hoạt động. Chip 8051 có 4 KB ROM trong, địa chỉ truy xuất: 000H – FFFH. 3.2. Bộ nhớ dữ liệu (RAM) Dùng để lƣu trữ các dữ liệu và tham số. Chip 8051 có 128 byte RAM trong, địa chỉ truy xuất: 00H – 7FH. RAM trong của chip 8051 đƣợc chia ra: – RAM đa chức năng: SVTH: BÙI XUÂN DŨNG Trang 9 ĐỒ ÁN TỐT NGHIỆP GVHD KS. PHẠM DUY DƯỞNG – RAM định địa chỉ bit: Cho phép xử lý từng bit dữ liệu riêng lẻ mà không ảnh hƣởng đến các bit khác trong cả byte. 3.3. Thanh ghi chức năng đặc biệt 3.3.1. Thanh ghi A 3.3.2. Thanh ghi B Phép nhân 2 số 8 bit không dấu -> kết quả là số 16 bit. – Byte cao -> chứa vào thanh ghi B. – Byte thấp -> chứa vào thanh ghi A. – Phép chia 2 số 8 bit -> thƣơng số và số dƣ là số 8 bit. – Thƣơng số -> chứa vào thanh ghi A. – Số dƣ -> chứa vào thanh ghi B. 3.3.3.Thanh ghi ngăn xếp (Stack Pointer) Con trỏ stack SP (stack pointer) là 1 thanh ghi 8 bit ở địa chỉ 81H. SP chứa địa chỉ của dữ liệu hiện đang ở đỉnh của stack. Các lệnh liên quan đến satck bao gồm lệnh cất dữ liệu vào stack và lệnh lấy dữ liệu ra khỏi stack. Việc cất vào stack làm tăng SP trƣớc khi ghi dữ liệu và việc lấy dữ liệu ra khỏi stack sẽ giảm SP. Vùng stack của 8051 đƣợc giữ trong RAM nội và đƣợc giới hạn đến các địa chỉ truy xuất đƣợc bởi kiểu định địa chỉ gián tiếp. Các lệnh PUSH và POP sẽ cất dữ liệu vào stack và lấy dữ liệu từ stack, các lệnh gọi chƣơng trình con (ACALL, LCALL) và lệnh trở về (RET, RETI) cũng cất và phục hồi nội dung của bộ đếm chƣơng trình PC (Program counter). 3.3.4. Con trỏ dữ liệu DPTR Con trỏ dữ liệu DPTR (data pointer) đƣợc dùng để truy xuất bộ nhớ chƣơng trình ngoài hoặc bộ nhớ dữ liệu ngoài. DPTR là một thanh ghi 16 bit có địa chỉ là 82H (DPL, byte thấp) và 83H (DPH, byte cao). SVTH: BÙI XUÂN DŨNG Trang 10 ĐỒ ÁN TỐT NGHIỆP GVHD KS. PHẠM DUY DƯỞNG 3.3.5. Thanh ghi bộ đệm truyền thông nối tiếp (Serial Data Buffer) Bộ đệm truyền thông đƣợc chia thành hai bộ đệm, bộ đệm truyền dữ liệu và bộ đệm nhận dữ liệu. Khi dữ liệu đƣợc chuyển vào thanh ghi SBUF, dữ liệu sẽ đƣợc chuyển vào bộ đệm truyền dữ liệu và sẽ đƣợc lƣu giữ ở đó cho đến khi quá trình truyền dữ liệu qua truyền thông nối tiếp kết thúc. Khi thực hiện việc chuyển dữ liệu từ SBUF ra ngoài, dữ liệu sẽ đƣợc lấy từ bộ đệm nhận dữ liệu của truyền thông nối tiếp. 3.3.6. Thanh ghi của bộ định thời/bộ đếm 8051 có 2 bộ đếm/định thời (counter/timer) 16 bit để định các khoảng thời gian hoặc để đếm các sự kiện. Các cặp thanh ghi (TH0, TL0) và (TH1, TL1) là các thanh ghi của bộ đếm thời gian. Bộ định thời 0 có địa chỉ 8AH (TL0, byte thấp) và 8CH (TH0, byte cao). Bộ định thời 1 có địa chỉ 8BH (TL1, byte thấp) và 8DH (TH1, byte cao).Hoạt động của bộ định thời đƣợc thiết lập bởi thanh ghi chế độ định thời TMOD (Timer Mode Register) ở địa chỉ 88H. Chỉ có TCON đƣợc định địa chỉ từng bit. 3.3.7. Các thanh ghi điều khiển Các thanh ghi điều khiển đặc biệt nhƣ IP, IE, TMOD, TCON, SCON và PCON là các thanh ghi điều khiển và ghi nhận trạng thái của hệ thống ngắt, bộ đếm/định thời, truyền thông nối tiếp. 4. Ứng dụng Vi điều khiển là một IC lập trình, vì vậy Vi điều khiển cần đƣợc lập trình trƣớc khi sử dụng. Mỗi phần cứng nhất định phải có chƣơng trình phù hợp kèm theo, do đó trƣớc khi viết chƣơng trình đòi hỏi ngƣời viết phải nắm bắt đƣợc cấu tạo phần cứng và các yêu cầu mà mạch điện cần thực hiện. Ứng dụng của vi điều khiển rất rộng rãi trong đời sống va trong công nghiệp.Tất cả những thiết bị điện tử có phần điều khiển tự động đều có thể có mặt vi điều khiển,trong nhu cầu công nghiệp hóa thì vi điều khiển trong vai trò quan trọng bậc nhất trong chuyên nghành tự động và điều khiển. Những ứng dụng đơn giản của vi điều khiển 8051: – VĐK giao tiếp led đơn và phím nhấn – Kết nối VĐK với Rơle – Kết nối VĐK với LCD – Kết nối VĐK với ma trận led.… Chƣơng trình là tập hợp các lệnh đƣợc tổ chức theo một trình tự hợp lí để giải quyết các yêu cầu của ngƣời lập trình.Tập hợp tất cả các lệnh gọi là tập lệnh. Họ Vi điều khiển MSC-51 đều có chung một tập lệnh, các Vi điều khiển đƣợc cải tiến sau này thƣờng ít thay đổi hoặc mở rộng tập lệnh mà chú trọng phát triển phần cứng.Vì các lệnh của Vi điều khiển có dạng số nhị phân quá dài và khó nhớ, hơn nữa việc gỡ lỗi khi chƣơng trình phát sinh lỗi rất phức tạp và khó khăn. Khó khăn này đƣợc giải quyết với sự hỗ trợ của máy vi tính, ngƣời viết chƣơng trình có thể viết chƣơng trình cho vi điều khiển bằng các ngôn ngữ lập trình cấp cao, sau khi việc viết chƣơng trình đƣợc SVTH: BÙI XUÂN DŨNG Trang 11 ĐỒ ÁN TỐT NGHIỆP GVHD KS. PHẠM DUY DƯỞNG hoàn tất, các trình biên dịch sẽ chuyển các câu lệnh cấp cao thành mã máy một cách tự động. Các mã máy này sau đó đƣợc đƣa (nạp) vào bộ nhớ ROM của Vi điều khiển, Vi điều khiển sẽ tìm đến đọc các lệnh từ ROM để thực hiện chƣơng trình . Bản thân máy tính không thể thực hiện các mã máy này vì chúng không phù hợp với phần cứng máy tính, muốn thực hiện phải có các chƣơng trình mô phỏng dành riêng.Chƣơng trình cho Vi điều khiển có thể viết bằng C++,C,Visual Basic, hoặc băng các ngôn ngữ cấp cao khác. Tuy nhiên hợp ngữ Assembler đƣợc đa số ngƣời dùng Vi điều khiển sử dụng để lập trình, vì lí do này chúng tôi chọn Assembly để hƣớng dẫn viết chƣơng trình cho Vi điều khiển. Assembly là một ngôn ngữ cấp thấp, trong đó mỗi câu lệnh chƣơng trình tƣơng ứng với một chỉ lệnh mà bộ xử lý có thể thực hiện đƣợc. Ƣu điểm của hợp ngữ Assembly là: mã gọn,ít chiếm dung lƣợng bộ nhớ, hoạt động với tốc độ nhanh, và nó có hiệu suất tốt hơn so với các chƣơng trình viết bằng ngôn ngữ bậc cao khác. SVTH: BÙI XUÂN DŨNG Trang 12 ĐỒ ÁN TỐT NGHIỆP GVHD KS. PHẠM DUY DƯỞNG CHƢƠNG II TỔNG QUAN VỀ ROBOT GIỚI THIỆU VỀ ROBOT DÕ ĐƢỜNG 1. Tổng quan về robot 1.1. Lịch sử Robot đã và đang xuất hiện trong cuộc sống của chúng ta từ lâu và ngày càng trở thành