Chương trình hỗ trợ đầy đủ các câu lệnh, các cấu trúc C cơ bản. Ngoài ra thì C51 còn có tất cả các cấu trúc khác mà chuẩn C có như: kiểu mảng, con trỏ, hàm. (ngoại trừ kiểu file).
Nội dung ngôn ngữ C51
1. Bộ nhớ:
- Bộ nhớ chương trình: khi các bạn lập trình trong C51 nếu không lỗi chương trình sẽ biên dịch thành file.hex và bước tiếp theo là dùng một phần mềm kèm mạch nạp chuyên dụng để nạp vào chíp. Bộ nhớ để lưu file.hex gọi là bộ nhớ chương trình 8Kbyte.
- Bộ nhớ dữ liệu: Trong chương trình các bạn có thể khai báo biến để lưu trữ dữ liệu, bộ nhớ ram nội trong AT89S52 có 256 Byte dùng cho mục đích này, khi mất điện RAM nội không lưu trữ được nội dung.
76 trang |
Chia sẻ: lylyngoc | Lượt xem: 2767 | Lượt tải: 4
Bạn đang xem trước 20 trang tài liệu Luận văn Thiết kế mạch điện điều khiển kho hàng thông minh, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
lệnh của chương trình được đọc từ ROM thông qua bus dữ liệu (Port0) và bus địa chỉ (Port0 + Port2).
Khi 8051 thi hành chương trình trong ROM nội, PSEN sẽ ở mức logic 1.
ALE/ PROG (Address Latch Enable / Program): ALE/ PROG (chân 30) cho phép tách các đường địa chỉ và dữ liệu tại Port 0 khi truy xuất bộ nhớ ngoài. ALE thường nối với chân Clock của IC chốt (74373, 74573). Các xung tín hiệu ALE có tốc độ bằng 1/6 lần tần số dao động trên chip và có thể được dùng làm tín hiệu clock cho các phần khác của hệ thống. Xung này có thể cấm bằng cách set bit 0 của SFR tại địa chỉ 8Eh lên 1. Khi đó, ALE chỉ có tác dụng khi dùng lệnh MOVX hay MOVC. Ngoài ra, chân này còn được dùng làm ngõ vào xung lập trình cho ROM nội ( /PROG ).
EA /VPP (External Access) :
EA (chân 31) dùng để cho phép thực thi chương trình từ ROM ngoài. Khi nối chân 31 với Vcc, AT89C51 sẽ thực thi chương trình từ ROM nội (tối đa 8KB), ngược lại thì thực thi từ ROM ngoài (tối đa 64KB).
Ngoài ra, chân /EA được lấy làm chân cấp nguồn 12V khi lập trình cho ROM.
RST (Reset):
RST (chân 9) cho phép reset AT89C51 khi ngõ vào tín hiệu đưa lên mức 1 trong ít nhất là 2 chu kỳ máy.
X1, X2:
Ngõ vào và ngõ ra bộ dao động, khi sử dụng có thể chỉ cần kết nối thêm thạch anh và các tụ như hình vẽ trong sơ đồ. Tần số thạch anh thường sử dụng cho AT89C51 là 12Mhz.
Hình 2.3 . Sơ đồ kết nối thạch anh
2.3. Cổng vào/ra
Tất cả các vi điều khiển 8051 đều có 4 cổng vào/ra 8 bit có thể thiết lập như cổng vào hoặc ra. Như vậy có tất cả 32 chân I/O cho phép vi điều khiển có thể kết nối với các thiết bị ngoại vi.
Hình 2.4. Cổng vào/ra
Hình 2.4 mô tả sơ đồ đơn giản của mạch bên trong các chân vi điều khiển trừ cổng P0 là không có điện trở kéo lên (pull-up).
Chân ra: Một mức logic 0 đặt vào bit của thanh ghi P làm cho transistor mở, nối chân tương ứng với đất (hình 2.5)
Hình 2.5. Chân ra xuất mức 0
Hình 2.6. Trở treo nội tại chân
Chân vào:
Một bit 1 đặt vào một bit của thanh ghi cổng, transistor đóng và chân tương ứng được nối với nguồn Vcc qua trở kéo lên (hình 2.7)
Hình 2.7. Chân vào xuất mức 1
Port 0 : có 2 chức năng ở các chân 32 – 39 của AT89C51:
- Chức năng I/O (xuất/nhập): dùng cho các thiết kế nhỏ. Tuy nhiên, khi dùng chức năng này thì Port 0 phải dùng thêm các điện trở kéo lên (pull-up), giá trị của điện trở phụ thuộc vào thành phần kết nối với Port.
- Khi dùng làm ngõ vào, Port 0 phải được set mức logic 1 trước đó.
- Chức năng địa chỉ / dữ liệu đa hợp: khi dùng các thiết kế lớn, đòi hỏi phải sử dụng bộ nhớ ngoài thì Port 0 vừa là bus dữ liệu (8 bit) vừa là bus địa chỉ (8 bit thấp).
Ngoài ra khi lập trình cho AT89C51, Port 0 còn dùng để nhận mã khi lập trình và xuất mã khi kiểm tra (quá trình kiểm tra đòi hỏi phải có điện trở kéo lên).
Port 1:
Port1 (chân 1 – 8) chỉ có một chức năng là I/O, không dùng cho mục đích khác (chỉ trong 8032/8052/8952 thì dùng thêm P1.0 và P1.1 cho bộ định thời thứ 3). Tại Port 1 đã có điện trở kéo lên nên không cần thêm điện trở ngoài.
Port 1 có khả năng kéo được 4 ngõ TTL và còn dùng làm 8 bit địa chỉ thấp trong quá trình lập trình hay kiểm tra.
Khi dùng làm ngõ vào, Port 1 phải được set mức logic 1 trước đó.
Port 2: Port 2 (chân 21 – 28) là port có 2 chức năng:
- Chức năng I/O (xuất / nhập)
- Chức năng địa chỉ: dùng làm 8 bit địa chỉ cao khi cần bộ nhớ ngoài có địa chỉ 16 bit. Khi đó, Port 2 không được dùng cho mục đích I/O.
- Khi dùng làm ngõ vào, Port 2 phải được set mức logic 1 trước đó.
Port 3: Port 3 (chân 10 – 17) là port có 2 chức năng:
Chức năng I/O. Khi dùng làm ngõ vào, Port 3 phải được set mức logic 1 trước đó.
Chức năng khác mô tả như sau:
Bảng 2.1. Chức năng các chân của Port
Bit
Tên
Chức năng
P3.0
RxD
Ngõ vào port nối tiếp
P3.1
TxD
Ngõ ra port nối tiếp
P3.2
INT0
Ngắt ngoài 0
P3.3
INT1
Ngắt ngoài 1
P3.4
T0
Ngõ vào của bộ định thời 0
P3.5
T1
Ngõ vào của bộ định thời 1
P3.6
WR
Tín hiệu điều khiển ghi dữ liệu lên bộ nhớ ngoài.
P3.7
RD
Tín hiệu điều khiển đọc từ bộ nhớ dữ liệu ngoài.
2.4. Tổ chức bộ nhớ
Bộ nhớ trong
ROM 4KB
0000h – 0FFFh
RAM 128 byte
00h – 7Fh
SFR
80h – 0FFh
Bộ nhớ ngoài
Bộ nhớ chương trình 64 KB
0000h – FFFFh
Điều khiển bằng PSEN
Bộ nhớ dữ liệu 64 KB
0000h – FFFFh
Điều khiển bằng RD và WR
Hình 2.8. Các vùng nhớ trong AT89C51
Bảng 2.2. Các thanh ghi chức năng đặc biệt
Địa
chỉ
byte
Có thể
định địa
chỉ bit
Không định địa chỉ bit
F8h
F0h
B
E8h
E0h
ACC
D8h
D0h
PSW
C8h
(T2CON)
(RCAP2L)
(RCAP2H)
(TL2)
(TH2)
C0h
B8h
IP
SADEN
B0h
P3
A8h
IE
SADDR
A0h
P2
98h
SCON
SBUF
BRL
BDRCON
90h
P1
88h
TCON
TMOD
TL0
TH0
TL1
TH1
AUXR
CKCON
80h
P0
SP
DPL
DPH
PCON
Bộ nhớ của họ MCS-51 có thể chia thành 2 phần: bộ nhớ trong và bộ nhớ ngoài. Bộ nhớ trong bao gồm 4KB ROM và 128 byte RAM (256 byte trong 8052). Các byte RAM có địa chỉ từ 00h – 7Fh và các thanh ghi chức năng đặc biệt (SFR) có địa chỉ từ 80h – 0FFh có thể truy xuất trực tiếp. Đối với 8052, 128 byte RAM cao (địa chỉ từ 80h – 0FFh) không thể truy xuất trực tiếp mà chỉ có thể truy xuất gián tiếp (xem thêm trong phần tập lệnh).
Bộ nhớ ngoài bao gồm bộ nhớ chương trình (điều khiển đọc bằng tín hiệu PSEN ) và bộ nhớ dữ liệu (điều khiển bằng tín hiệu RD hay WR để cho phép đọc hay ghi dữ liệu). Do số đường địa chỉ của MCS-51 là 16 bit (Port 0 chứa 8 bit thấp và Port 2 chứa 8 bit cao) nên bộ nhớ ngoài có thể giải mã tối đa là 64KB.
2.4.1. Tổ chức bộ nhớ trong (bảng 2.3)
Bộ nhớ trong của MCS-51 gồm ROM và RAM. RAM bao gồm nhiều vùng có mục đích khác nhau: vùng RAM đa dụng (địa chỉ byte từ 30h – 7Fh và có thêm vùng 80h – 0FFh ứng với 8052), vùng có thể địa chỉ hóa từng bit (địa chỉ byte từ 20h – 2Fh, gồm 128 bit được định địa chỉ bit từ 00h – 7Fh), các bank thanh ghi (từ 00h – 1Fh) và các thanh ghi chức năng đặc biệt (từ 80h – 0FFh).
Các thanh ghi chức năng đặc biệt (SFR – Special Function Registers Bảng 2.2)
Bảng 2.3. Địa chỉ RAM nội 8051
Địa chỉ byte
Địa chỉ bit
Chức năng
7F
Vùng RAM đa dụng
30
Vùng RAM đa dụng
2F
7F
7E
7D
7C
7B
7A
79
78
Vùng có thể định địa chỉ bit
2E
77
76
75
74
73
72
71
70
Vùng có thể định địa chỉ bit
2D
6F
6E
6D
6C
6B
6A
69
68
Vùng có thể định địa chỉ bit
2C
67
66
65
64
63
62
61
60
Vùng có thể định địa chỉ bit
2B
5F
5E
5D
5C
5B
5A
59
58
Vùng có thể định địa chỉ bit
2A
57
56
55
54
53
52
51
50
Vùng có thể định địa chỉ bit
29
4F
4E
4D
4C
4B
4A
49
48
Vùng có thể định địa chỉ bit
28
47
46
45
44
43
42
41
40
Vùng có thể định địa chỉ bit
27
3F
3E
3D
3C
3B
3A
39
38
Vùng có thể định địa chỉ bit
26
37
36
35
34
33
32
31
30
Vùng có thể định địa chỉ bit
25
2F
2E
2D
2C
2B
2A
29
28
Vùng có thể định địa chỉ bit
24
27
26
25
24
23
22
21
20
Vùng có thể định địa chỉ bit
23
1F
1E
1D
1C
1B
1A
19
18
Vùng có thể định địa chỉ bit
22
17
16
15
14
13
12
11
10
Vùng có thể định địa chỉ bit
21
0F
0E
0D
0C
0B
0A
09
08
Vùng có thể định địa chỉ bit
20
07
06
05
04
03
02
01
00
Vùng có thể định địa chỉ bit
1F
18
Bank 3
Các bank thanh ghi
17
10
Bank 2
Các bank thanh ghi
1F
08
Bank 1
Các bank thanh ghi
07
00
Bank thanh ghi 0 ( mặc định cho R0-R7)
Các bank thanh ghi
Các thanh ghi có thể định địa chỉ bit sẽ có địa chỉ bit bắt đầu và địa chỉ byte trùng nhau. Ví dụ như: thanh ghi P0 có địa chỉ byte là 80h và có địa chỉ bit bắt đầu từ 80h (ứng với P0.0) đến 87h (ứng với P0.7). Chức năng các thanh ghi này sẽ mô tả trong phần sau
RAM nội:
Chia thành các vùng phân biệt: vùng RAM đa dụng (30h – 7Fh), vùng RAM có thể định địa chỉ bit (20h – 2Fh) và các bank thanh ghi (00h – 1Fh).
b. RAM đa dụng:
RAM đa dụng có 80 byte từ địa chỉ 30h – 7Fh có thể truy xuất mỗi lần 8 bit bằng cách dùng chế độ địa chỉ trực tiếp hay gián tiếp.
Các vùng địa chỉ thấp từ 00h – 2Fh cũng có thể sử dụng cho mục đich như trên ngoài các chức năng đề cập như phần sau.
RAM có thể định địa chỉ bit:
Vùng địa chỉ từ 20h – 2Fh gồm 16 byte (= 128 bit) có thể thực hiện giống như vùng RAM đa dụng (mỗi lần 8 bit) hay thực hiện truy xuất mỗi lần 1 bit bằng các lệnh xử lý bit. Vùng RAM này có các địa chỉ bit bắt đầu tại giá trị 00h và kết thúc tại 7Fh.
Như vậy, địa chỉ bắt đầu 20h (gồm 8 bit) có địa chỉ bit từ 00h – 07h; địa chỉ kết thúc 2Fh có địa chỉ bit từ 78h – Fh.
Các bank thanh ghi:
Vùng địa chỉ từ 00h – 1Fh được chia thành 4 bank thanh ghi: bank 0 từ 00h- 07h, bank 1 từ 08h – 0Fh, bank 2 từ 10h – 17h và bank 3 từ 18h – 1Fh. Các bank thanh ghi này được đại diện bằng các thanh ghi từ R0 đến R7. Sau khi khởi động hệ thống thì bank thanh ghi được sử dụng là bank 0.
Do có 4 bank thanh ghi nên tại một thời điểm chỉ có một bank thanh ghi được truy xuất bởi các thanh ghi R0 đến R7. Việc thay đổi bank thanh ghi có thể thực hiện thông qua thanh ghi từ trạng thái chương trình (PSW). Các bank thanh ghi này cũng có thể truy xuất bình thường như vùng RAM đa dụng đã nói ở trên.
2.4.2. Tổ chức bộ nhớ ngoài
MCS-51 có bộ nhớ theo cấu trúc Harvard: phân biệt bộ nhớ chương trình và dữ liệu. Chương trình và dữ liệu có thể chứa bên trong nhưng vẫn có thể kết nối với 64KB chương trình và 64KB dữ liệu. Bộ nhớ chương trình được truy xuất thông qua chân PSEN còn bộ nhớ dữ liệu được truy xuất thông qua chân WR hay RD .
Lưu ý rằng việc truy xuất bộ nhớ chương trình luôn luôn sử dụng địa chỉ 16 bit còn bộ nhớ dữ liệu có thể là 8 bit hay 16 bit tuỳ theo câu lệnh sử dụng. Khi dùng bộ nhớ dữ liệu 8 bit thì có thể dùng Port 2 như là Port I/O thông thường còn khi dùng ở chế độ 16 bit thì Port 2 chỉ dùng làm các bit địa chỉ cao.
Port 0 được dùng làm địa chỉ thấp/ dữ liệu đa hợp. Tín hiệu /ALE để tách byte địa chỉ và đưa vào bộ chốt ngoài.
Trong chu kỳ ghi, byte dữ liệu sẽ tồn tại ở Port 0 vừa trước khi /WR tích cực và được giữ cho đến khi /WR không tích cực.Trong chu kỳ đọc, byte nhận được chấp nhận vừa trước khi /RD không tích cực.
Bộ nhớ chương trình ngoài được xử lý 1 trong 2 điều kiện sau:
- Tín hiệu /EA tích cực ( = 0).
- Giá trị của bộ đếm chương trình (PC – Program Counter) lớn hơn kích thước bộ nhớ.
PCH: Program Counter High – PCL: Program Counter Low
DPH: Data Pointer High – DPL: Data Pointer Low
Hình 2.9. Thực thi bộ nhớ chương trình ngoài
Bộ nhớ chương trình ngoài:
Quá trình thực thi lệnh khi dùng bộ nhớ chương trình ngoài có thể mô tả như hình 2.9. Thực thi bộ nhớ chương trình ngoài”. Trong quá trình này, Port 0 và Port 2 không còn là các Port xuất nhập mà chứa địa chỉ và dữ liệu. Sơ đồ kết nối với bộ nhớ chương trình ngoài mô tả như hình 2.8. Các vùng nhớ trong AT89C51”.
Trong một chu kỳ máy, tín hiệu ALE tích cực 2 lần. Lần thứ nhất cho phép 74HC573 mở cổng chốt địa chỉ byte thấp, khi /ALE xuống 0 thì byte thấp và byte cao của bộ đếm chương trình đều có nhưng ROM chưa xuất vì PSEN chưa tích cực, khi tín hiệu ALE lên 1 trở lại thì Port 0 đã có dữ liệu là mã lệnh. ALE tích cực lần thứ hai được giải thích tương tự và byte 2 được đọc từ bộ nhớ chương trình. Nếu lệnh đang thực thi là lệnh 1 byte thì CPU chỉ đọc Opcode, còn byte thứ hai bỏ qua.
Bộ nhớ dữ liệu ngoài:
Bộ nhớ dữ liệu ngoài được truy xuất bằng lệnh MOVX thông qua các thanh ghi xác định địa chỉ DPTR (16 bit) hay R0, R1 (8 bit).
Quá trình thực hiện đọc hay ghi dữ liệu được cho phép bằng tín hiệu RD hay WR (chân P3.7 và P3.6).
Bộ nhớ chương trình và dữ liệu dùng chung:
Trong các ứng dụng phát triển phần mềm xây dựng dựa trên AT89C51, ROM sẽ được lập trình nhiều lần nên dễ làm hư hỏng ROM. Một giải pháp đặt ra là sử dụng RAM để chứa các chương trình tạm thời. Khi đó, RAM vừa là bộ nhớ chương trình vừa là bộ nhớ dữ liệu. Yêu cầu này có thể thực hiện bằng cách kết hợp chân RD và chân PSEN thông qua cổng AND. Khi thực hiện đọc mà lệnh, chân /PSEN tích cực cho phép đọc từ RAM và khi đọc dữ liệu, chân RD sẽ tích cực.
Giải mã địa chỉ
Trong các ứng dụng dựa trên AT89C51, ngoài giao tiếp bộ nhớ dữ liệu, vi điều khiển còn thực hiện giao tiếp với các thiết bị khác như bàn phím, led, động cơ, … Các thiết bị này có thể giao tiếp trực tiếp thông qua các Port. Tuy nhiên, khi số lượng các thiết bị lớn, các Port sẽ không đủ để thực hiện điều khiển. Giải pháp đưa ra là xem các thiết bị này giống như bộ nhớ dữ liệu. Khi đó, cần phải thực hiện quá trình giải mã địa chỉ để phân biệt các thiết bị ngoại vi khác nhau. Quá trình giải mã địa chỉ thường được thực hiện thông qua các IC giải mã như 74139 (2 ® 4), 74138 ( 3 ® 8), 74154 (4 ® 16). Ngõ ra của các IC giải mã sẽ được đưa tới chân chọn chip của RAM hay bộ đệm khi điều khiển ngoại vi.
2.5. Các thanh ghi chức năng đặc biệt (SFRs - Special Function Registers)
2.5.1. Thanh ghi tích luỹ (Accumulator)
Thanh ghi tích luỹ là thanh ghi sử dụng nhiều nhất trong AT89C51, được ký hiệu trong câu lệnh là A. Ngoài ra, trong các lệnh xử lý bit, thanh ghi tích luỹ được ký hiệu là ACC.
Thanh ghi tích luỹ có thể truy xuất trực tiếp thông qua địa chỉ E0h (byte) hay truy xuất từng bit thông qua địa chỉ bit từ E0h đến E7h.
Ví dụ:
MOV A,#1
MOV 0E0h,#1
có cùng kết quả. Hay:
SETB ACC.4
SETB 0E4h
cũng tương tự.
Thanh ghi B
Thanh ghi B dùng cho các phép toán nhân, chia và có thể dùng như một thanh ghi tạm, chứa các kết quả trung gian.
Thanh ghi B có địa chỉ byte F0h và địa chỉ bit từ F0h – F7h có thể truy xuất giống như thanh ghi A.
2.5.2. Thanh ghi từ trạng thái chương trình (PSW - Program Status Word)
Thanh ghi từ trạng thái chương trình PSW nằm tại địa chỉ D0h và có các địa chỉ bit từ D0h – D7h, bao gồm 7 bit (1 bit không sử dụng) có các chức năng như sau:
Hình 2.10. Thanh ghi PSW
CY (Carry): cờ nhớ, thường được dùng cho các lệnh toán học không dấu (C = 1 khi có nhớ trong phép cộng hay mượn trong phép trừ)
AC (Auxiliary Carry): cờ nhớ phụ (thường dùng cho các phép toán BCD).
F0 (Flag 0): được sử dụng tuỳ theo yêu cầu của người sử dụng.
RS1, RS0: dùng để chọn bank thanh ghi sử dụng. Khi reset hệ thống, bank 0 sẽ được sử dụng.
Hình 2.11. Chọn bank thanh ghi
OV (Overflow): cờ tràn. Cờ OV = 1 khi có hiện tượng tràn số học xảy ra (dùng cho số nguyên có dấu).
F1 (Flag 1): được sử dụng tuỳ theo yêu cầu của người sử dụng.
P (Parity): kiểm tra parity (lẻ). Cờ P = 1 khi tổng số bit 1 trong thanh ghi
A là số lẻ (nghĩa là tổng số bit 1 của thanh ghi A cộng thêm cờ P là số chẵn). Ví dụ như: A = 10101010b có tổng cộng 4 bit 1 nên P = 0. Cờ P thường được dùng để kiểm tra lỗi truyền dữ liệu.
2.5.3.Thanh ghi con trỏ stack (SP – Stack Pointer)
Con trỏ stack SP nằm tại địa chỉ 81h và không cho phép định địa chỉ bit. SP dùng để chỉ đến đỉnh của stack. Stack là một dạng bộ nhớ lưu trữ dạng LIFO (Last In First Out) thường dùng lưu trữ địa chỉ trả về khi gọi một chương trình con. Ngoài ra, stack còn dùng như bộ nhớ tạm để lưu lại và khôi phục các giá trị cần thiết.
Đối với AT89C51, stack được chứa trong RAM nội (128 byte đối với 8031/8051 hay 256 byte đối với 8032/8052). Mặc định khi khởi động, giá trị của SP là 07h, nghĩa là stack bắt đầu từ địa chỉ 08h (do hoạt động lưu giá trị vào stack yêu cầu phải tăng nội dung thanh ghi SP trước khi lưu). Như vậy, nếu không gán giá trị cho thanh ghi SP thì không được sử dụng các bank thanh ghi 1, 2, 3 vì có thể làm sai dữ liệu. Đối với các ứng dụng thông thường không cần dùng nhiều đến stack, có thể không cần khởi động SP mà dùng giá trị mặc định là 07h. Tuy nhiên, nếu cần ta có thể xác định lại vùng stack cho MCS-51.
Con trỏ dữ liệu DPTR (Data Pointer)
Con trỏ dữ liệu DPTR là thanh ghi 16 bit bao gồm 2 thanh ghi 8 bit: DPH (High) nằm tại địa chỉ 83h và DPL (Low) nằm tại địa chỉ 82h. Các thanh ghi này không cho phép định địa chỉ bit. DPTR được dùng khi truy xuất đến bộ nhớ có địa chỉ 16 bit.
2.5.4. Các thanh ghi port
Các thanh ghi P0 tại địa chỉ 80h, P1 tại địa chỉ 90h, P2, tại địa chỉ A0h, P3 tại địa chỉ B0h là các thanh ghi chốt cho 4 port xuất / nhập (Port 0, 1, 2, 3). Tất cả các thanh ghi này đều cho phép định địa chỉ bit trong đó địa chỉ bit của P0 từ 80h – 87h, P1 từ 90h – 97h, P2 từ A0h – A7h, P3 từ B0h – B7h. Các địa chỉ bit này có thể thay thế bằng toán tử địa chỉ.
Ví dụ: Hai lệnh sau là tương đương:
SETB P0.0
SETB 80h
Thanh ghi port nối tiếp (SBUF - Serial Data Buffer)
Thanh ghi port nối tiếp tại địa chỉ 99h thực chất bao gồm 2 thanh ghi: thanh ghi nhận và thanh ghi truyền. Nếu dữ liệu đưa tới SBUF thì đó là thanh ghi truyền, nếu dữ liệu đươc đọc từ SBUF thì đó là thanh ghi nhận. Các thanh ghi này không cho phép định địa chỉ bit.
2.5.5. Các thanh ghi định thời (Timer Register)
Các cặp thanh ghi (TH0, TL0), (TH1, TL1) và (TH2, TL2) là các thanh ghi dùng cho các bộ định thời 0, 1 và 2 trong đó bộ định thời 2 chỉ có trong 8032/8052. Ngoài ra, đối với họ 8032/8052 còn có thêm cặp thanh ghi (RCAP2L, RCAP2H) sử dụng cho bộ định thời 2.
2.5.6. Các thanh ghi điều khiển:
Bao gồm các thanh ghi IP (Interrupt Priority), IE (Interrupt Enable), TMOD (Timer Mode), TCON (Timer Control), T2CON (Timer 2 Control), SCON (Serial port control) và PCON (Power control).
+ Thanh ghi IP tại địa chỉ B8h cho phép chọn mức ưu tiên ngắt khi có 2 ngắt xảy ra đồng thời. IP cho phép định địa chỉ bit từ B8h – BFh.
+ Thanh ghi IE tại địa chỉ A8h cho phép hay cấm các ngắt. IE có địa chỉ bit từ A8h – AFh.
+ Thanh ghi TMOD tại địa chỉ 89h dùng để chọn chế độ hoạt động cho các bộ định thời (0, 1) và không cho phép định địa chỉ bit.
+ Thanh ghi TCON tại địa chỉ 88h điều khiển hoạt động của bộ định thời và ngắt. TCON có địa chỉ bit từ 88h – 8Fh.
+ Thanh ghi T2CON tại địa chỉ C8h điều khiển hoạt động của bộ định thời 2. T2CON có địa chỉ bit từ C8h – CFh.
+ Thanh ghi SCON tại địa chỉ 98h điều khiển hoạt động của port nối tiếp. SCON có địa chỉ bit từ 98h – 9Fh.
2.5.7. Thanh ghi điều khiển nguồn PCON
Thanh ghi PCON tại địa chỉ 87h không cho phép định địa chỉ bit bao gồm các bit như sau:
Hình 2.12. Thanh ghi PCON
+ SMOD1 (Serial Mode 1): = 1 cho phép tăng gấp đôi tốc độ port nối tiếp trong chế độ 1, 2 và 3.
+ SMOD0 (Serial Mode 0 = 0): cho phép chọn bit SM0 hay FE trong thanh ghi SCON (Serial Mode 0 = 1 chọn bit FE).
+ POF (Power - off Flag): dùng để nhận dạng loại reset. POF = 1 khi mở nguồn. Do đó, để xác định loại reset, cần phải xoá bit POF trước đó.
+ GF1, GF0 (General purpose Flag): các bit cờ dành cho người sử dụng.
+ PD (Power Down): được xoá bằng phần cứng khi hoạt động reset xảy ra.
Khi bit PD = 1 thì vi điều khiển sẽ chuyển sang chế độ nguồn giảm. Trong chế độ này:
- Chỉ có thể thoát khỏi chế độ nguồn giảm bằng cách reset.
- Nội dung RAM và mức logic trên các port được duy trì.
- Mạch dao động bên trong và các chức năng khác ngừng hoạt động.
- Chân ALE và PSEN ớ mức thấp.
- Yêu cầu Vcc phải có điện áp ít nhất là 2V và phục hồi Vcc = 5V ít nhất 10 chu kỳ trước khi chân RESET xuống mức thấp lần nữa.
- IDL (Idle): được xoá bằng phần cứng khi hoạt động reset hay có ngắt xảy ra. Khi bit IDL = 1 thì vi điều khiển sẽ chuyển sang chế độ nghỉ. Trong chế độ này:
+ Chỉ có thể thoát khỏi chế độ nguồn giảm bằng cách reset hay có ngắt xảy ra.
+ Trạng thái hiện hành của vi điều khiển được duy trì và nội dung các thanh ghi không đổi.
- Mạch dao động bên trong không gửi được tín hiệu đến CPU.
- Chân ALE và PSEN ở mức cao.
Lưu ý rằng các bit điều khiển PD và IDL có tác dụng chính trong tất cả các IC họ MSC-51 nhưng chỉ có thể thực hiện được trong các phiên bản CMOS
CHƯƠNG III
THIẾT KẾ MẠCH ĐIỆN ĐIỀU KHIỂN KHO HÀNG THÔNG MINH
3.1. Yêu cầu công nghệ
Với mục đích phục vụ cho việc học tập và giảng dạy tại trường Đại học Sao đỏ chúng em đưa ra yêu cầu công nghệ của hệ thống điều khiển kho hàng thông minh như sau:
Hệ thống vận chuyển hàng từ nơi tập kết đến kho hàng đảm bảo các yêu cầu sau:
- Nhấn start hệ thống hoạt động, các cảm biến báo trong kho có hàng và vị trí đặt hàng còn trống, cơ cấu di chuyển hoạt động, đưa cơ cấu gắp vật tới vị trí kho hàng. Khi tới vị trí kho hàng, hệ thống hạ cơ cấu gắp vật, đồng thời gắp vật ra khỏi vị trí của kho. Lúc này cơ cấu di chuyển mang vật từ vị trí hàng tập kết đến nơi để hàng.
- Quá trình di chuyển được giới hạn hành trình bằng các cảm biến và công tắc hàng trình.
- Vị trí đặt hàng được ưu tiên theo quy tắc, hàng 1 cột 1, hàng 2 cột 2, hàng 3 cột 3.
- Sản phẩm sẽ tự động dừng khi kho hàng đầy.
- Quá trình lặp lại khi có một vị trí trống khác, đảm bảo có đủ chỗ cho cất giữ hàng.
3.2. Cấu tạo và nguyên lý làm việc:
Cấu tạo:
Cơ cấu đẩy hàng gồm 1 pittong khí A1, được giới hạn hành trình di chuyển bằng các swith hành trình. Hệ thống di chuyển và mang hàng gồm 1 động cơ 1 chiều 24VDC, di chuyển dọc trục bằng Vit-me và hệ thống trượt, 1 pittong điều khiển đầu hút sản phẩm bằng nguồn khí nén có áp lực âm. Các hệ thống pittong khí A2 đưa hàng đến đúng các vị trí kho hàng đã định trước. Các sensor, swith báo hành trình, báo sản phẩm, và báo nguồn hàng.
Nguyên lý làm việc:
Sản phẩm từ nhà máy được vận chuyển đến nơi tập kết, tại đây 1 pittong làm nhiệm vụ đẩy sản phẩm vào vị trí cánh tay gắp vật. Khi có sản phẩm tại vị trí và vị trí sắp xếp hàng còn trống, hệ thống mang hàng di chuyển đến nơi tập kết sản phẩm gắp sản phẩm đến vị trí trống. Khi số sản phẩm được sắp xếp đầy trong kho hàng, cánh tay dừng, đèn báo màu đỏ báo sản phẩm đã đầy kho.
3.2.1. Sơ đồ nguyên lý mạch điện điều khiển
Hình 3.1. Sơ đồ nguyên lý mạch điện điều khiển
- Khối cảm biến là các sensor và công tắc hành trình, được ghép nối qua cách ly quang trước khi làm tín hiệu đưa vào vi điều khiển.
- VĐK làm nhiệm vụ nhận tín hiệu từ các cảm biến và so sánh với các câu lệnh đã được lập trình sẵn để đưa ra các tín hiệu ở đầu ra, điều khiển tải: Motor, relay.
Ngoài ra còn có các LED báo trạng thái tín hiệu đầu vào, ra giúp chúng ta quan sát được trạng thái làm việc của vi điều khiển
3.2.2. Nguyên lý làm việc mạch điều khiển
3.2.2.1. Khối cảm biến
Hình 3.2. Mạch kết nối cảm biến với cách ly quang
Nguồn 24VDC được kết nối với cảm biến, đầu ra của cảm biến được nối với điện trở 2,2k (mục đích hạ áp 24VDC xuống 2,3VDC) trước khi đưa vào cách ly quang. Đầu ra của cách ly quang là điện áp 5VDC được đưa làm tín hiệu đầu vào VĐK.
Nguyên lý hoạt động: Ban đầu khi chưa có vật, cảm biến chưa tác động, dòng điện không đi qua trở 2,2K , LED báo trạng thái không sáng và 2 chân Anot, Ktot của cách ly quang chưa được phân cực thuận. Đầu ra của cách ly quang bị “cấm”
Khi có vật nằm trong vùng tác động của cảm biến, dòng điện 24VDC từ nguồn qua điện trở phân cực thuận cho cách ly quang, LED trạng thái sáng, đồng thời đầu ra của cách ly quang có mức logic 5VDC.
3.2.2.2. Khối điều khiển
Hình 3.3. Khối điều khiển
Khối điều khiển sử dụng chíp vi điều khiển họ 8051, nhận tín hiệu từ khối cảm biến. Đầu ra được kết nối với ULN2803 điều khiển tải. Khi vi điều khiển nhận được 1 tín hiệu đầu vào từ cảm biến, lập tức chương trình con nạp sẵn được thực thi và tùy vào điều kiện đầu vào mà đầu ra có mức logic 0 hay 1 tương ứng.
Các Post 0,1,2 được kết nối với mạch cảm biến, Post 3 được kết nối với ULN2803. Ngoài ra còn có các chân đặc biệt, reset, xtal, Enable...
3.2.2.3. Khối tải
Hình 3.4. Khối tải
Sử dụng ULN2803 để cách ly giữa vi điều khiển và phần mạch lực, nguyên lý hoạt động của khối này như sau: Khi đầu vào của ULN2803 có mức logic 0, LED báo trạng thái không sáng đầu ra của ULN2803 bị cấm, động cơ không quay. Khi đầu vào của ULN2803 có mức logic 1, LED báo trạng thái sáng. ULN2803 được phân cực, đầu ra có mức logic 0, dòng điện đi từ nguồn qua động cơ làm động cơ hoạt động.
3.3. Giới thiệu một số thiết bị sử dụng trong mạch điện điều khiển.
3.3.1. Cảm biến tiệm cận điện dung
- Cảm biến tiệm cận điện dung khi có mặt của đối tượng làm thay đổi điện dung C của bản cực.
- Cảm biến tiệm cận điện dung gồm 4 bộ phận chính: Cảm biến (các bản cực cách điện); mạch dao động; bộ phát hiện; mạch đầu ra. Tuy nhiên cảm biến điện dung không đòi hỏi đối tượng làm bằng kim loại. Đối tượng phát hiện là chất lỏng, vật liệu phi kim, thuỷ tinh, nhựa. Tốc độ chuyển mạch tương đối nhanh, có thể phát hiện đối tượng có kích thước nhỏ, phạm vi cảm nhận lớn.
- Cảm biến điện dung chịu ảnh hưởng bởi bụi và độ ẩm. Cảm biến điện dung có vùng cảm nhận lớn hơn vùng cảm nhận của cảm biến điện cảm
Hình 3.5. Cảm biến tiệm cận kiểu điện dung.
Cảm biến tiệm cận kiểu điện dung không tiếp xúc, đo những thay đổi về tính chất điện tương ứng thường gọi là cảm biến điện dung. Điện dung mô tả hai vật dẫn điện cách nhau một khoảng phản ứng lại với sự chênh thế giữa chúng. Đặt một điện thế vào hai đầu của một điện trở ta được một tụ điện giữa hai vật dẫn đó (một đầu dương, một đầu âm).
Bảng 3.1 Thông số kỹ thuật cơ bản của cảm biến tiệm cận kiểu điện dung
Thông số kỹ thuật cơ bản
Tên sản phẩm
Cảm biến tiệm cận
- Nhà sản xuất
Omron,...
- Hình dạng
Theo từng model, Z seri
- Loại tiếp điểm
SPDT
- Dòng điện
1,5A, 3A, 5A (tùy model)
- Điện áp
24VDC
- Vật liệu vỏ
Nhựa, thép
- Màu sắc
Màu đen, vàng, đỏ
- Tiêu chuẩn
IEC
- Chức năng
Dùng trong mạch điều khiển tự động
3.3.2. Công tắc hành trình
Công tác hành trình dùng để giới hạn di chuyển cho cơ cấu di chuyển cánh tay gắp vật. Thiết bị được gắn trên hành trình của cơ cấu và thực hiện chức năng ngắt dòng điện bằng tiếp điểm khi có sự tác động cơ học.
Hình 3.6. Công tắc hành trình
Bảng 3.2. Thông số kỹ thuật cơ bản của công tắc hành trình
Thông số kỹ thuật cơ bản
Tên sản phẩm
Công tắc hành trình
- Nhà sản xuất
Autonics, Omron,...
- Hình dạng
Theo từng model, Z seri
- Loại tiếp điểm
SPDT
- Dòng điện
1,5A, 3A, 5A (tùy model)
- Dòng khởi động
NC=30A, NO=15A
- Điện áp
24VDC, 480 VAC
- Tần số hoạt động
Cơ 240 lần/phút, Điện 20 lần/phút
- Vật liệu vỏ
Nhựa
- Màu sắc
Màu đen
- Tiêu chuẩn
IEC
- Chức năng
Dùng trong mạch điều khiển tự động
3.3.3. Rơ-le 24VDC
Rơle là một loại thiết bị điện tự động mà tín hiệu đầu ra thay đổi nhảy cấp khi tín hiệu đầu vào đạt những giá trị xác định. Dùng để đóng cắt mạch điện điều khiển, bảo vệ và điều khiển sự làm việc của mạch điện động lực.
Hình 3.6. Hình ảnh Rơle trong thực tế
* Hãng sản xuất OMRON, tên gọi Rơ le trung gian , số cặp tếp điểm: DPDT
- Tải trở : 10A, 110 VAC / 10A, 24 VDC
- Tải cảm ứng: 7.5A, 110 VAC / 5A, 24 VDC
- Kích thước (mm) 36x28x21.5
- Xuất xứ Japan
* Các đặc điểm khác:
Có chắn hồ quang
Công suất 15A loại LY1 và 10A lý tưởng cho nhiều ứng dụng
Chịu được điện áp tới 2000V;
Các loại tiếp điểm: SPDT, DPDT, 3PDT, 4PDT
3.3.4. ULN 2803
Hình 3.7. Hình ảnh và sơ đồ chân ULN 2803 trong thực tế
ULN 2803 là một vi mạch đệm, bản chất cấu tạo là các mảng darlington chịu được dòng điện lớn và điện áp cao, trong đó có chứa 7 cặp darlington cực góp hở với cực phát chung. Mỗi kênh trong số 7 kênh đều có thể chịu được dòng điện lớn trong một khoảng thời gian dài lên tới 500 mA với biên độ đỉnh lên tới 600 mA. Mỗi kênh có một diode chặn- diode này có thể sử dụng trong trường hợp tải có tính cảm ứng, ví dụ như cácrơle…
Ứng dụng của ULN2803 được sử dụng trong các mạch đệm điều khiển động cơ một chiều ,động cơ bước, khối hiển thị ma trận led....
Nguyên lý hoạt động:
- Nếu các chân đầu vào I1 ÷ I8 là mức 0 thì ngõ ra thả nổi.
- Nếu các chân đầu vào I1 ÷ I8 là mức 1 thì ngõ ra ở mức 0
3.3.5. JC817
JC 817 dùng để cách ly giữa phần điều khiển (có điện áp thấp) và phần tải (có điện áp cao), nhằm tránh những hư hỏng có thể xảy ra với mạch điều khiển như: dòng dò, điện áp ngược...
Hình 3.8. Hình ảnh và sơ đồ nguyên lý của JC 817
JC817 (cách ly quang) cấu tạo gồm: 2 tầng công suất cách ly với nhau bởi cặp photo transistor.
Tầng công suất thấp, cấu tạo gồm 1 diode phát quang có cấp điện áp 3~5VDC
Tầng công suất cao là 1 photo transistor npn có cực B hở, cấp điện áp lên tới 35V – 50mA.
3.3.6. Van đảo chiều 5/2
Van đảo chiều 5/2 tác động trực tiếp bằng dòng khí nén vào từ hai phía của nòng van. Đây là loại van không có vị trí “ không “, van có đặc điểm là “nhớ” vị trí hoạt động khi không còn tín hiệu tác động
Van đảo chiều 5/2 có nhiệm vụ điều khiển hoạt động của pittong theo yêu cầu công nghệ.
Hình 3.9. Hình ảnh van đảo chiều 5/2
Van khí nén 5/2 một đầu sử dụng cuộn dây điện từ một chiều cấp điện áp 24V, một đầu sử dụng lò xo tích hợp.
Nguyên lý hoạt động: Khi cấp nguồn vào 2 đầu của cuộn dây (với loại van khí 1 đầu là cuộn dây và 1 đầu là lò xo), lực từ sinh ra do dòng điện hút ti van dịch chuyển, đóng , mở cửa khí. Làm đường khí di chuyển theo hướng khác hoặc bị chặn. Khi cuộn dây mất điện, ti van được đẩy về vị trí ban đầu nhờ cơ cấu lò xo. Các đường khí trở lại trạng thái ban đầu.
3.3.7. Motor
Hình 3.10. Hình ảnh động cơ điện một chiều
Bảng 3.3 Thông số kỹ thuật cơ bản của động cơ điện một chiều
Thông số kỹ thuật cơ bản
Tên sản phẩm
Motor 24VDC
- Kiểu, loại
35C- AM – 30 - KA
- Xuất xứ
Isukasa Electric Co.ltd Japan
- Hình dạng
Theo từng model
- Điện áp
24VDC
- Dòng điện
3A
- Tốc độ
300 vòng/phút
- Vật liệu vỏ
Sắt
- Màu sắc
Màu đen, xám, bạc
- Chức năng
Dùng trong mạch điều khiển tự động
CHƯƠNG IV. THỰC NGHIỆM.
Để thiết kế được mạch điện điều khiển kho hàng thông minh chúng em đã sử dụng phần mềm Proteus và phần mềm mềm biên dịch.
4.1. Giới thiệu phần mềm Protues 7.10 Professional
Protues là phần mềm của hãng Labcenter, dùng để vẽ sơ đồ nguyên lý, mô phỏng và thiết kế mạch điện. Gói phần mềm gồm có các phần mềm chính:
- ISIS dùng để vẽ sơ đồ nguyên lý và mô phỏng.
- ARES dùng để thiết kế mạch in.
Sau khi tải về, quá trình cài đặt bình thường. Sau khi cài đặt thành công bạn sẽ thấy chương trình trong Start menu.
4.1.1. Vẽ sơ đồ nguyên lý và mô phỏng mạch
4.1.1.1. Vẽ sơ đồ nguyên lý với ISIS Professional 7.10:
- Giới thiệu giao diện sử dụng:
Để vẽ sơ đồ nguyên lý, vào Start menu Khởi động chương trình, chương trình được khởi động và có giao diện như hình 4.1
Hình 4.1: Giao diện chương trình Protues 7.10
Phía trên và phía phải của chương trình là công cụ để ta có thể thiết kế sơ đồ nguyên lý. Phần giữa có màu xám là nơi chúng ta có thể làm việc.
Section mode: Chức năng chọn linh kiện.
Component mode: Dùng để lấy linh kiện trong thư viện linh kiện.
Đặt lable cho Wire.
Bus
Terminal: Chứa Power, Ground...
Graph: Dùng để vẽ dạng sóng, datashet, trở kháng
Generator Mode: Chứa các nguồn điện, nguồn xung, nguồn dòng.
Voltage Probe Mode: Dùng để đo điện thế tại 1 điểm trên mạch, đây là dụng cụ chỉ có một chân và không có thật trong thực tế.
Curent Probe mode: Dùng để đo chiều và độ lớn của dòng điện tại 1 điểm trên Wire.
Virtual Instrument Mode: Chứa các dụng cụ đo dòng, áp và các dụng cụ này có thật trong thực tế.
Hình 4.2 Nhóm công cụ để vẽ các ký hiệu, chú thích.
- Một số tùy chọn của chương trình:
Set BOM Scrip: Dùng để xuất danh sách các loại, số lượng linh kiện có trong mạch. Để thay đổi chọn System/Set BOM Scrip.
Hình 4.3. Lựa chọn tùy chọn của chương trình
Chúng ta có thể add, edit, delete các linh kiện mà chúng ta muốn.
Hình 4.4. Giao diện khi thực hiện thêm bớt linh kiện
Với công cụ này, sau khi vẽ sơ đồ nguyên lý xong ta có thể xác định một cách nhanh chóng loại và số lượng linh kiện mà ta dùng trong mạch để tiện cho việc chọn mua linh kiện trong mạch thực.
Ví dụ ta có bảng thống kê như sau:
Bill Of Materials For OCL VISAI
Design Title : OCL VISAI
Author : NGUYEN SI LUAN 01DHLT DIEN
Revision : 1
Design Created : Sunday, Step 05, 2012
Design Last Modified : Friday, Step 24, 2012
Total Parts In Design : 50
21 Resistors
Quantity: References Value
2 R1, R2 0R22
2 R3, R5 1k
2 R6, R15 3.3k
1 R7 2.7k
3 R8, R10, R13 10k
3 R9, R22, R24 1.5k
1 R11 680
2 R12, R14 390k
1 R17 4
2 R18, R19 270
1 R21 220
1 R23 500
6 Capacitors
Quantity: References Value
1 C1 0.33uF
1 C2 3.3uF
1 C3 100u
1 C4 1200uF
2 C5, C6 33u
11 Transistors
Quantity: References Value
1 Q1 2N3773
2 Q2, Q10 MJE340
1 Q3 2N6609
2 Q4, Q11 MJE350
1 Q5 BC327
4 Q6-Q9 2N2219
7 Diodes
Quantity: References Value
6 D1-D3, D5-D7 1N4148
1 D4 LED-RED
5 Miscellaneous
Quantity: References Value
4 RV1-RV4 100
1 RV5 50k
Set Environment: Tùy chọn này cho phép bạn thay đổi:
- Số lần Undo (Ctrl+Z)
- Times auto save
- Number of file on file menu vv…
* Set Sheet Size: Cho phép người dùng có thể điều chỉnh kích thước sheet A4, A3,...
Hình 4.5. Giao diện điều chỉnh kích thước khổ giấy khi vẽ trên Proteus
* Set sheet editor: thay đổi font, size text, …..
Hình 4.6. Giao diện điều chỉnh phông chữ khi vẽ trên Proteus
* Set keyboard mapping: Cho phép Designer tạo các phím tắt để thực hiện các lệnh.
- Trước hết chọn “Command Group”
- Sau đó chọn lệnh muốn đặt phím tắt.
- Trong mục Key for command ta gõ vào Key mà ta muốn.
- Ví dụ cho lệnh Open Design là Ctrl+O
* Set Animation Option: Cho phép hiển thị chiều của dòng điện các mức logic, frame per second… khi Simulation.
Hình 4.7. Giao diện hiển thị chiều của dòng điện khi mô phỏng
* Simulation option: Thay đổi độ nhiễu môi trường, sai số.
Hình 4.8. Giao diện thay đổi độ nhiễu môi trường, sai số
Để lưu các thiết lập chọn “Save Preferrence” , ngoài ra ta còn có các mục thay đổi giao diện sử dụng cũng như màu sắc của bản vẽ, graph... (nên mặc định).
* Cách lấy linh kiện: Để lấy linh kiện ta nhấn vào phím trái của chương trình và thực hiện như sau:
- Bấm vào biểu tượng Component Mode
- Sau đó bấm vào chữ P, hoặc biểu tượng chữ P trên Keyboad.
Hình 4.9. Giao diện thực hiện lấy linh kiện (cách 1)
- Hoặc cũng có thể Right Click trên Editting Window và chọn Place.
Hình 4.10. Giao diện thực hiện lấy linh kiện (cách 2)
- Chương trình Pick Devices hiện ra như hình sau:
Hình 4.11. Giao diện Pick Devices
1. Ô tìm kiếm linh kiện, chỉ cần gõ vào từ khóa, ví dụ BJT, 2N2222 (không phân biệt chữ hoa và chữ thường).
2. Các nhóm linh kiện liên quan đến từ khóa cần tìm.
3. Nhóm con của linh kiện, ví dụ như transistor thì có BJT, FET
4. Ký hiệu Schematic trên sơ đồ nguyên lý.
5. Hình dáng trên sơ đồ mạch in PCB, ví dụ BJT có nhiều kiểu đóng gói như TO18, TO220,vv...
6. Kết quả của việc tìm kiếm linh kiện
Double Click vào linh kiện cần lấy, lập tức linh kiện sẽ được bổ sung vào “Bàn làm việc” là vùng màu trắng phía bên trái.
7. Tên nhà sản xuất
4.1.2. Vẽ và hoàn thiện mạch in
ARES Là một công cụ trong gói Protues được hãng Labcenter phát hành. Chương trình hỗ trợ vẽ sơ đồ nguyên lý, tạo thư viện, vẽ mạch in. Tuy là phần mềm đi kèm nhưng ARES hỗ trợ khá đầy đủ cho phép người dùng thiết kế sơ đồ nguyên lý và mạch in một cách nhanh chóng, thuận tiện mà không cần đến một gói phần mềm của hãng thứ 2.
Hình 4.12. Giao diện chính của chương trình ARES Professional
Vùng 1 là nơi ta thiết kế
Vùng 2 là nơi lấy linh kiện
Vùng 3 là hình ảnh, đối tượng chúng ta chọn.
Trong khuôn khổ của đồ án này chúng em xin giới thiệu các thao tác cơ bản để vẽ một sơ đồ mạch in từ sơ đồ nguyên lý sẵn có và cách xử lý tình huống “chương trình không định dạng kiểu chân linh kiện được hỗ trợ”. Các bước thực hiện như sau:
Khởi động chương trình ISIS professional từ desktop, chờ cho chương trình khởi động xong, trong giao diện của trình ISIS, hãy chọn Open và chọn đường dẫn đến thư mục chứa chương trình cn vẽ mạch in, ví dụ “DATN-01DHLT Dien”
Hình 4.12. Giao diện khi chọn đường dẫn để vẽ mạch in
Sơ đồ của “DATN-01DHLT Dien” sẽ được mở ra như sau:
Hình 4.13. Sơ đồ nguyên lý của mạch chuẩn bị vẽ mạch in
Bây giờ chúng ta sẽ nhấp chuột vào biểu tượng của trình vẽ mạch ARES nằm ở góc phải trên màn hình (đuợc hình khoanh đỏ ở trên). Lưu ý nếu sơ đồ do chúng ta tự tạo khi chuyển qua ARES trình sẽ yêu cầu bạn save sơ đồ lại.
Sau khi chuyển qua giao diện của trình ARES nếu thấy xuất hiện khung hộp thoại thông báo với tiêu đề là “Pakage selector” nguyên nhân là do trình không tìm đuợc định dạng chân linh kiện mà ISIS cung cấp nên buộc chúng ta phải tự tìm chân linh kiện theo kiểu Maual. Các bước tiến hành như sau, kích vào biểu tượng ARES trên thanh công cụ. Một hộp thoại chương trình hiện ra cho phép bạn thao tác như sau:
+ Linh kiện 1 : Sounder (loa) : chúng ta sẽ gõ vào “conn-sil2” (đế cắm 2 chân), sau đó nhấn Enter.
+ Linh kiện 2,3 : Resistor (trở) : gõ vào “res40” (chọn kiểu chân điện trở 0,6 W) Enter.
Việc chọn linh kiện khi vẽ sơ đồ nguyên lý cũng là một điều đáng chú ý, sẽ có ảnh hưởng rất lớn đến việc hoàn thành mạch in nhanh hay chậm, khi chọn linh kiện nên chú ý nhìn xem nó có đuợc hỗ trợ dạng chân cắm chưa, nếu chưa nên tìm linh kiện tương đương nhưng có hỗ trợ định dạng.
Sau khi chọn xong dạng chân cho 3 linh kiện trên thì khung “Pakage selector” biến mất, lúc này các linh kiện đuợc xếp vào ô “component”.
Bây giờ chúng ta sẽ tiến hành vẽ đường bao của panel bằng cách chọn vào công cụ “2D graphic box” trên thanh công cụ tool, tiếp đến chọn “board edge” (có màu vàng).
Hình 4.13. Cách vẽ đường bao của mạch in
Sau đó rê chuột ra giữa màn hình, kích giữ trái chuột và vẽ thành một khung (nếu muốn thay đổi size của khung, kích phải chuột vào vành khung, sau đó kéo chuột tùy chỉnh size cho phù hợp).
Hiện tại do trong danh mục của ARES không có định dạng chân cắm cho Button nên chúng ta sẽ phải tự tạo ra nó bằng cách : chọn vào “2D graphic box” chọn “topsilk” rồi vẽ một khung đúng bằng kích thước của button (căn cứ vào độ dài từ điểm tới điểm trên ma trận thì vừa nhanh vừa chuẩn), sau đó chọn “round through hole…” trên toolbar chọn kích cỡ lỗ khoan trong ô “Circus through” là “C70-30” (là kích thướcc via và lỗ khoan). Ta sẽ gắn 4 via vào topsilk để tạo thành 4 chân. Kích chuột phải vào từng chân và đánh số thứ tự chân và trong ô number. Nếu muốn đẹp hơn ta có thể vẽ thêm cái vòng tròn ở giữa button bằng mực “top silk” tượng trưng cho cái phím tròn, hoặc muốn bảo đảm tiếp xúc của button bạn có thể chọn vào “Track mode” trên toolbar & chọn “Bottom copper” sau đó nối hai đôi cặp chân lại. Các bạn save linh kiện vừa tạo bằng cách kích phải chuột vào linh kiện lại và chọn vào biểu tượng hình “con IC có dấu +” (make pakage).
Hình 4.14. Cách vẽ chân linh kiện
Tiếp theo chúng ta sẽ đặt tên cho nó là “button” , chọn library sẽ lưu trữ vào, dạng chân cắm xuyên lỗ (through) hay bề mặt (surface) cuối cùng chỉ việc save vào là xong (sau này chúng ta có thể sử dụng pakage của button vừa tạo). Chúng ta cũng có thể xóa bỏ khung hình vừa tạo, vì phần linh kiện đã được lưu trong thư viện.
Lưu ý với mạch in khi thiết kế có sử dụng LED và chân nguồn, chúng ta cũng nên khai báo chân để thuận tiện cho việc thiết kế mạch. Chúng ta sẽ quay về ISIS và đặt tên cho 2 con led, và 2 cái button + bỏ dấu check trong ô “exclude PCB layout” bằng cách kích phải chuột vào linh kiện và chọn “edit properties”. Tiếp theo đặt tên luôn cho nguồn dương là “VDD” và nguồn âm (đất) là “VSS”, nếu không thì 2 chân nguồn được “ẩn” của IC trình sẽ bỏ trống vì chẳng biết nối vào đâu.
Click chọn vào linh kiện trong ô component và click ra bên ngoài, lúc này linh kiện sẽ theo con trỏ đi đến vị trí các bạn cần đặt, nếu vừa ý chúng ta click chuột thêm lần nữa là xong, nếu không thích chúng ta có thể kích phải hai lần vào linh kiện, lập tức nó sẽ tự nhảy trở lại vào ô component. Còn muốn xoay linh kiện chúng ta click phải một lần lên linh kiện, chọn các kiểu xoay. Để tối ưu hơn trong việc đi mạch, chúng ta nên vừa đặt linh kiện vừa nhìn theo sơ đồ nguyên lý.
Tiếp theo, để đi mạch tự động chọn vào “auto route”, kế đến chọn vào “edit strategies” để thay đổi nội dung đi mạch, cụ thể ARES có chia ra hai phân vùng là “power” (đuờng nguồn) và “signal” (đuờng tín hiệu), ta lần lượt hiệu chỉnh các thông số, đầu tiên là lớp mạch, bài này ta chỉ cần sử dụng một lớp “Bottom”, ở mục “corner” (góc bo) bạn nên check luôn cả hai cái “Optimize” và “Diagonal” để mạch tự động đi góc rất đẹp. Click OK.
Quá trình hoàn tất, chúng ta có thể thao tác lựa chọn chỉnh lại bằng tay cho vừa ý, hoặc để yên. Tiếp đến là đổ đồng cho mạch và in ra giấy.
Hình 4.14. Mạch in khi hoàn tất
Chúng ta cũng có thể lựa chọn công cụ xem trước “3D visualization” để xem sản phẩm khi hoàn thành.
Hình 4.14. Mô hình thực tế 3D visualization
4.2. Giới thiệu trình biên dịch cho họ vi điều khiển 8051
Ngôn ngữ C là một ngôn ngữ lập trình thông dụng, là một trình biên dịch mạnh mẽ, sinh mã tối ưu. Đồng thời cung cấp cho người lập trình tập hợp những hàm phong phú nhằm giải quyết tất cả các yêu cầu khác nhau.
Mục đích của C51 là cung cấp cho lập trình viên công cụ để viết những chương trình bằng ngôn ngữ C thay thế cho ASSEMBLY chạy trên các chíp đơn dòng trong 8051 như AT89C2051, AT89C4051, AT89C51, AT89C52...
Lưu ý ngôn ngữ C lập trình cho 8051 :
- Ngôn ngữ C khi ra đời chỉ là một chuẩn ngôn ngữ không phụ thuộc phần cứng máy tính.
- C51 được thiết kế trên nền ngôn ngữ C và được biên dịch chỉ để sử dụng cho 8051, vì lý do này mà nó còn được gọi là trình biên dịch chéo.
- C51 khác TURBO C ở chỗ tuy chung một chuẩn C nhưng lại khác nhau về chíp thực hiện.
Giao diện chương trình C51:
Hình 4.15. Giao diện chương trình C51
Trình tự cài đặt phần mềm
Chạy file intall.exe trong thư mục cài đặt, khi quá trình cài đặt kết thúc chương trình sẽ tạo ra trong thư mục “C:\8051” , tiếp đó tiến hành xác thực bản quyền và sử dụng chương trình.
Chương trình hỗ trợ đầy đủ các câu lệnh, các cấu trúc C cơ bản. Ngoài ra thì C51 còn có tất cả các cấu trúc khác mà chuẩn C có như: kiểu mảng, con trỏ, hàm... (ngoại trừ kiểu file).
Nội dung ngôn ngữ C51
1. Bộ nhớ:
- Bộ nhớ chương trình: khi các bạn lập trình trong C51 nếu không lỗi chương trình sẽ biên dịch thành file.hex và bước tiếp theo là dùng một phần mềm kèm mạch nạp chuyên dụng để nạp vào chíp. Bộ nhớ để lưu file.hex gọi là bộ nhớ chương trình 8Kbyte.
- Bộ nhớ dữ liệu: Trong chương trình các bạn có thể khai báo biến để lưu trữ dữ liệu, bộ nhớ ram nội trong AT89S52 có 256 Byte dùng cho mục đích này, khi mất điện RAM nội không lưu trữ được nội dung.
Sử dụng chương trình:
Từ màn hình chính Desktop khởi tạo biểu tượng C51.exe giao diện chương trình hiện ra như sau:
Chương trình hỗ trợ thư viện chuẩn theo cấu trúc khóa: “ #include ”
Tiến hành viết 1 đoạn chương trình.
Tiến hành lưu đoạn chương trình vừa viết, chương trình khởi tạo có phần mở rộng file.C
Quá trình viết code hoàn thành, bấm “biên dịch” hoặc F9 để thực hiện kiểm tra lỗi và biên dịch ra file.hex nếu chương trình không có lỗi ta sẽ nhận được hộp thoại thông báo:
File.hex được khởi tạo sẽ nằm chung thư mục với chương trình vừa lưu. Nếu quá trình viết code sai, khi biên dịch chương trình sẽ báo lỗi:
Kết thúc quá trình, tiến hành nạp vào vi điều khiển và chạy thử
4.3. Lưu đồ thuật toán và chương trình điều khiển
* Lưu đồ thuật toán điều khiển
* Chương trình điều khiển
#include
// khai bao cac dau ra P2
sbit dc_thuan = P2^0; // dong co quay thuan
sbit dc_nghich= P2^1; // dong co quay nghich
sbit pt_sp1 = P2^2; // pittong day sp
sbit pt_sp2 = P2^3; // pittong day sp
sbit pt_vt1 = P2^4; // pittong vi tri
sbit pt_vt2 = P2^5; // pittong vi tri
sbit pt_ha = P2^6; // pittong nang ha de hut sp
sbit hutsp = P2^7; // hut sp
// khai bao cac bien dau vao P1
sbit sensor00 = P1^0; // bao sp vao dung opto
sbit sensor01 = P1^1; // bao sp ra dung 2 cam bien dau //
sbit sensor1 = P1^2; // vi tri cot 1 dung cam bien kim loai
sbit sensor2 = P1^3; // vi tri cot 2 dung cam bien kim loai
sbit sensor3 = P1^4; // vi tri cot 3 dung cam bien kim loai
sbit sensor6 = P1^5; // vi tri hang 1 dung cam bien ap than pt
sbit sensor7 = P1^6; // vi tri hang 2 dung cam bien ap than pt
sbit sensor8 = P1^7; // vi tri hang 3 dung cam bien ap than pt
//--------------------------
sbit CTHT1 =P3^0;
sbit CTHT2 =P3^1;
// sbit start = P0^6; // nut nhan start
sbit stop = P0^7; // nut nhan stop
//--------------------------
void delay (unsigned int t) // chuong trinh tao tre 1000 = 1s
{
unsigned int x,y;
for(x=0;x<t;x++)
{
for(y=0;y<=120;y++);
}
}
//--------------------------
void quaythuan_1 (void) // quay den vt cot 1
{
dc_nghich=0;
dc_thuan=1;
while (sensor1==1) // khi sensor cot 1 co tin hieu
{};
if (sensor1==1)
dc_thuan=0;
delay(3000);
}
//--------------------------
void quaythuan_2 (void) // quay den vt cot 2
{
dc_nghich=0;
dc_thuan=1;
while (sensor2==1) // khi sensor cot 2 co tin hieu
{};
if (sensor2==1)
dc_thuan=0;
delay(3000);
}
//--------------------------
void quaythuan_3 (void) // quay den vt cot 3
{
dc_nghich=0;
dc_thuan=1;
while (sensor3==1) // khi sensor cot 3 co tin hieu
{};
if (sensor3==1)
dc_thuan=0;
delay(3000);
}
//--------------------------
void quaynghich (void)
{
dc_thuan=0;
dc_nghich=1;
delay(100);
while (CTHT1==0)
{};
if (CTHT1==0)
dc_nghich=0;
delay(100);
}
//---------------------------
void hang1 (void) // pt_vt1 = P2^4 pittong vi tri lam viec
{
pt_vt1=0;
delay(1000);
pt_vt2=1;
while (sensor6==1) // cham vt sensor ap than pt 1
{};
if (sensor6==1)
pt_vt2=0;
delay(1000);
}
//---------------------------
void hang2 (void) // pt_vt1 = P2^4 pittong vi tri lam viec
{
pt_vt1=0;
delay(1000);
pt_vt2=1;
while (sensor7==1) // cham vt sensor ap than pt 2
{};
if (sensor7==1)
pt_vt2=0;
delay(1000);
}
//---------------------------
void hang3 (void) // pt_vt1 = P2^4 pittong vi tri lam viec
{
pt_vt1=0;
delay(1000);
pt_vt2=1;
while (sensor8==1) // cham vt sensor ap than pt 2
{};
if (sensor8==1)
pt_vt2=0;
delay(1000);
}
//---------------------------
void gapvat (void) // pt_sp1 pittong day sp, pt_ha, hutsp lam viec
{
if (sensor00==1|sensor00==1) // dieu kien co san pham
{
pt_sp1=1;
pt_sp2=0;
delay(2000);
pt_ha=1;
delay(5000);
hutsp=1;
delay(1000);
pt_sp1=0;
pt_sp2=1;
delay(1000);
pt_ha=0;
delay(1000);
}
}
//---------------------------
void nhavat (void)
{
pt_ha=1;
delay(2000);
hutsp=0;
delay(2000);
pt_ha=0;
delay(2000);
pt_vt2=0;
delay(2000);
pt_vt1=1;
delay(3000);
}
//----------------------------
void main (void)
{
P0=P1=P2=P3=0x00;
do
{
nhavat();
delay(2000);
quaynghich();
delay(2000);
gapvat();
delay(2000);
quaythuan_1();
delay(2000);
hang1();
delay(2000);
nhavat();
delay(2000);
quaynghich();
//---------------
gapvat();
delay(5000);
quaythuan_1();
delay(5000);
hang2();
delay(5000);
nhavat();
delay(5000);
quaynghich();
//---------------
gapvat();
delay(5000);
quaythuan_1();
delay(5000);
hang3();
delay(5000);
nhavat();
delay(5000);
quaynghich();
//======================
gapvat();
delay(50);
quaythuan_2();
delay(50);
hang1();
delay(50);
nhavat();
delay(5000);
quaynghich();
//---------------
gapvat();
delay(5000);
quaythuan_2();
delay(5000);
hang2();
delay(5000);
nhavat();
delay(5000);
quaynghich();
//---------------
gapvat();
delay(5000);
quaythuan_2();
delay(5000);
hang3();
delay(5000);
nhavat();
delay(5000);
quaynghich();
//======================
gapvat();
delay(5000);
quaythuan_3();
delay(5000);
hang1();
delay(5000);
nhavat();
delay(5000);
quaynghich();
//---------------
gapvat();
delay(5000);
quaythuan_3();
delay(5000);
hang2();
delay(5000);
nhavat();
delay(5000);
quaynghich();
//---------------
gapvat();
delay(5000);
quaythuan_3();
delay(5000);
hang3();
delay(5000);
nhavat();
delay(5000);
quaynghich();
}
while (P0^7==1);
}
Chương trình quét phím:
// ma tran phim 9 nut, vao p1 ra p2 hien thi tren led 7 thanh
#include
#include
sbit LED1=P3^0; // den LED 1 bao khay san con trong
sbit LED2=P3^1; // den LED 2 bao khay san pham da day
unsigned long int num,i;
unsigned char M[10] =
{0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x83,0xF8,0x80,0x98};
void hienthi()
{
if(P1==0xde)
{
P2=M[1]; // hien thi so 1
LED1=0;
LED2=1;
}
if(P1==0xdd)
{
P2=M[2]; // hien thi so 2
LED1=0;
LED2=1;
}
if(P1==0xdb)
{
P2=M[3]; // hien thi so 3
LED1=0;
LED2=1;
}
if(P1==0xee)
{
P2=M[4]; // hien thi so 4
LED1=0;
LED2=1;
}
if(P1==0xed)
{
P2=M[5]; // hien thi so 5
LED1=0;
LED2=1;
}
if(P1==0xeb)
{
P2=M[6]; // hien thi so 6
LED1=0;
LED2=1;
}
if(P1==0xf6)
{
P2=M[7]; // hien thi so 7
LED1=0;
LED2=1;
}
if(P1==0xf5)
{
P2=M[8]; // hien thi so 8
LED1=0;
LED2=1;
}
if(P1==0xf3)
{
P2=M[9]; // hien thi so 9
LED1=1;
LED2=0;
}
}
void quet(void)
{
int n[3]={0xfe,0xfd,0xfb};
for(i=0;i<=2;i++)
{
P1=n[i];
hienthi();
}}
void main()
{
P2=M[0]; // hien thi so 0
while(1)
{
quet();
}
}
4.4. Chế tạo mô hình
4.4.1. Mạch nguyên lý
Hình 4.16. Sơ đồ nguyên lý mạch điện điều khiển kho hàng thông minh
4.4.2. Mạch in
Hình 4.17. Mặt trước của mạch in
Hình 4.18. Mặt sau của mạch in
4.4.3. Mô hình thực tế
Hình 4.19. Mô hình kho hàng thông minh
KẾT LUẬN
Qua thời gian làm đồ án, với sự hướng dẫn tận tình của cô giáo Lê Thị Mai và qua quá trình tìm tòi của bản thân, đồ án tốt nghiệp của em đạt được một số kết quả sau:
Về mặt lý thuyết:
Tìm hiểu về vi điều khiển nói chung và 89C52 nói riêng.
Tìm hiểu được phần mềm như Proteus.
Tìm hiểu được nguyên lý làm việc một số phần tử khí nén.
Phương pháp thiết kế mạch điện điều khiển.
Về mặt thực hành:
Sử dụng thành thạo phần mềm Proteus để vẽ mạch sơ đồ nguyên lý.
Thiết kế được phần cứng và phần mềm cho việc điều khiển kho hàng thông minh.
Đấu nối mạch điện điều khiển và mạch cơ khí chính xác, mô hình chạy ổn định.
Với đề tài “ Thiết kế mạch điện điều khiển kho hàng thông minh” là một đề tài có tính ứng dụng cao phục vụ trong thực tế và đặc biệt cho phòng thí nghiệm Vi xử lý của các trường học nói chung, trường Đại học Sao đỏ nói riêng.
TÀI LIỆU THAM KHẢO
1. Nguyễn Tăng Cường “Cấu trúc lập trình và họ vi điều khiển 8051” Nhà xuất bản Khoa học kỹ thuật (1999).
2. Phạm Thượng Hàn, Nguyễn Trọng Quế, Nguyễn Văn Hòa, Võ Thanh Sơn, Đào Văn Tú “Các bộ cảm biến trong kĩ thuật đo lường và điều khiển”. Nhà xuất bản khoa học kỹ thuật (2005).
3. Lê Đăng Hưng, Tạ Tuấn Anh, Nguyễn Hữu Đức, Nguyễn Thanh Thủy “ Lập trình hướng đối tượng với C++”. Nhà xuất bản khoa học kỹ thuật (2006)
4. Tống Văn On “Lập trình hệ thống với vi điều khiển” Nhà xuất bản Khoa học kỹ thuật (2000).
Các file đính kèm theo tài liệu này:
- do_antot_nghiep_dhlt__0838.doc