Việc chuyển đối tín hiệu tương tự sang số và ngược lại thường gặp khi ta muốn kết nối máy tính với thế giới tương tự. Trong phần này giới thiệu sử dụng bộ vi điều khiển kết nối với bộ chuyển đổi tương tự số (A/D) và ngược lại (D/A). Thông thường các bộ chuyển đổi cho phép kết nối thông qua kênh dữ liệu 8 bít, ba trạng thái và cho phép điều khiển thôngqua các tín hiệu đọc/ghi, chọn chíp.
3.1 Chuyển đổi số tương tự (D/A)
Hình 6-3 giới thiệu kết nối giữa vi điều khiển 8051 và bộ chuyển đổi D/A khái quát. Bộ chuyển đổi D/A có đặc điểm sau:
Thời gian chuyển đổi 5s.
Trình tự điều khiển ~CS rồi ~WR.
Cổng 1 được nối với các tín hiệu dữ liệu của bộ chuyển đổi còn cổng 3 dùng để điều khiển. Trong ví dụ này, thiết bị tạo ra sóng hình sin với chu kỳ 1000Hz và có thể thay đổi theo chương trình. Vref đặt bằng -10V dạng tín hiệu đầu ra thay đổi từ 0V tới +9, 96V. Chương trình dùng bảng tra cứu để sinh ra biên độ sóng sin. Chu kỳ được thiết lập căn cứ vào khoảng thời gian truyền dữ liệu cho bộ chuyển đổi. Với S điểm lấy mẫu, chu kỳ ngắt nhất Tmin= 5×S
s tần số tối đa fmax = 200. 000/S.
Với sóng có tần số 1000Hz, cần số lượng mẫu là 200. Tuy nhiên thực tế chạy chương trình cho thấy thời gian để tạo ra một mẫu cần 6s và thời gian để chuyển sang mẫu kế tiếp mất hơn 2s. Như vậy thực tế chỉ cho phép số lượng mẫu là 166.
Ví dụ 6-2. Chương trình chuyển đổi D/A
. org 0000h
daconv: clr p3, 2 ; Chọn chíp
mov dptr, #bang : lấy địa chỉ cơ sở bảng repeat: mov r1, #0A6h ; Khởi tạo R1 = 166
next: mov a, r1 ; Lấy địa chỉ offset của bảng movc a, @a+dptr ;Lấy giá trị mẫu
mov p1, a ; Gửi mẫu ra cổng 1 clr p3, 3
setb p3, 3 djnz r1, next sjmp repeat
131 ; Bảng chuyển đổi sử dụng hàm cosin để tính giá trị biên bộ của tín hiệu tại đầu ra. 83 giá
;trị đầu thể hiện biên độ từ cực đại tới nhỏ hơn 0, 83 giá trị còn lại từ 0 tới cực đại. Với 83
; mẫu cho nửa chu kỳ giá trị góc của hàm cosin thay đổi 2, 17 độ cho các mẫu kế tiếp.
bang: . db 00H ; . db ffH ; s1:FF×cos(0) . db feH ; s2:7FH+FF×cos(2, 17) . db feH ; s3:7FH+FF×cos(2, 17×2) . db 81H ; s42:7FH+FF×cos(88, 9) . . . . db 00H ; s84:7FH+FF×cos(180) . . . . db feH ; s166:7FH+FF×cos(2, 17)
3.2 Chuyến đổi tương tự số (A/D)
Hình 6-4 sử dụng bộ chuyển đổi tương tự số 8 bít có các đặc tính sau: Tín hiệu lấy mẫu: Vin = Vref-, dữ liệu =00h ; Vin=Vref+, dữ liệu = FFh Thời gian lấy mẫu: 1 s
Trình tự điều khiển: CS, WR rồi RD (ở mức tích cực thấp). Trong hình vẽ, cổng 1 của 8051 nối với kênh dữ liệu của bộ chuyển đổi còn cổng 3 nối với các tín hiệu điều khiển.
Ví dụ 6-3. Chương trình chuyển đổi A/D
Đoạn chương trình sau số hóa các tín hiện Vref với chu kỳ 100s và lưu kết quả vào trong bộ nhớ RAM 4000H:43E7H.
. equ begin, 4000H ;Địa chỉ bắt đầu . equ delay, 74H ;trễ 87s
. equ end1, 43H ;Địa chỉ kết thúc byte cao . equ end2, e8H ;Địa chỉ kết thúc byte thấp adconv: mov dptr, #begin
clr p3, 2 ; Gửi ~CS tới bộ A/D next: clr p3, 3 ; Tạo xung ~WR tới bộ A/D
setb p3, 3 ;
clr p3, 4 ;Tạo xung ~RD mov a, p1 ;Đọc dữ liệu từ A/D setb p3, 4 ;Kết thúc đọc mov @dptr, a ;Lưu vào RAM
inc dptr ;Tăng con trỏ RAM lên 1 mov a, dph ;Kiểm tra kết thúc
cjne a, #end1, wait mov a, dpl
cjne a, #end2, wait
sjmp done ; Kết thúc khi tới vị trí cuối cùng wait: mov r1, #delay ;Trễ 87s
here: djnz r1, here sjmp next done: sjmp done
133
Chương 7. GIỚI THIỆU MỘT SỐ VI XỬ LÍ TIÊN TIẾN