Студопедия
Случайная страница | ТОМ-1 | ТОМ-2 | ТОМ-3
АрхитектураБиологияГеографияДругоеИностранные языки
ИнформатикаИсторияКультураЛитератураМатематика
МедицинаМеханикаОбразованиеОхрана трудаПедагогика
ПолитикаПравоПрограммированиеПсихологияРелигия
СоциологияСпортСтроительствоФизикаФилософия
ФинансыХимияЭкологияЭкономикаЭлектроника

Лабораторна робота № 4

ЛАБОРАТОРНА РОБОТА №1 | Робота з меню | Порядок виконання роботи | ЛАБОРАТОРНА РОБОТА № 2 | Порядок виконання роботи |


Читайте также:
  1. II. Контрольна робота.
  2. IV. Лабораторная диагностика псевдотуберкулеза и кишечного иерсиниоза у людей
  3. IV. Робота над навчальною темою
  4. Безпека при вантажно-розвантажувальних роботах
  5. Блок 1: Робота з «передумовами» в процесі оцінки
  6. Виробнича робота
  7. Внутрішня енергія. Робота і теплота, як міри зміни внутрішньої енергії системи. Перший закон термодинаміки.

РОЗРОБКА ПРОГРАМИ АНАЛОГОВО-ЦИФРОВОГО ПЕРЕТВОРЕННЯ І ЧИТАННЯ ДАНИХ З АЦП ДЛЯ МП К1810ВМ86

 

Мета роботи. Навчитися створювати програми для керування процесом аналогово-цифрового перетворення і забезпечити читання перетворених даних з АЦП.

 

4.1 Теоретичні відомості

Пристрої обчислювальної системи з’єднуються один з одним за допомогою уніфікованих систем зв’язку, що називаються інтерфейсом. Інтерфейс повинен бути стандартизований, щоб забезпечити зв’язок процесора і оперативної пам’яті з будь-яким периферійним пристроєм (ПП). Алгоритми функціонування інтерфейсу і керуючого реґістра, також повинні бути стандартизовані.

До спеціалізованих пристроїв інтерфейсу мікропроцесорних систем відносяться АЦП, ЦАП та перетворювачі кодів. Перетворення аналогової інформації в цифрову базується на теоремі Котельникова: будь-який аналоговий сиґнал може бути записаний в дискретній формі й інформація не буде втрачена, якщо крок квантування D t буде вибраний за умови:

, (4.1)

де Fmax – максимальна частота спектру передаваного сиґналу.

Приклад. Процедура програмно-апаратного аналого-цифрового перетворювача працює за принципом послідовного наближення за двійковою системою. Процедура може запускатися за перериванням від зовнішнього пристрою або від таймера (періодично).

Схема АЦП на базі ЕОМ (мікроконтролера) показана на рис. 4.1.

Рис. 4.1 – Приклад (фрагмент) електричної схеми підключення АЦП до ЕОМ

Вона включає 10-розрядний реверсивний ЦАП, підключений до виходів порта РВ (молодші 8 розрядів) і порта РС.3-0 (старші розряди – РС.1-0 і знак – РС.3). Порт РС.7-4 настроюється на введення, два біти його: D7 і D6 використовуються для введення знака розузгодження компаратора в прямому та інверсного кодах. Аналоговий вихід ЦАП підключений до інверсного входу компаратора, на прямий (неінвертований) вхід якого подається вимірюваний реґістр. Вихід компаратора через реґістри інвертування DV3, DV4 підключений до входу ЕОМ для визначення знака розузгодження і програмного збереження або усунення бітів послідовного наближення.

Нижче наведений приклад фрагменту програмного коду для обміну даними між АЦП та МП системою:

stck segment para stack ‘stack’;налаштування сеґмента стека

dw 100 dup(?);встановлюється об’ємом у 100 слів

stck ends;кінець сеґмента стека

data segment public para;сеґмент даних

codin dw (?)

data ends;кінець сеґмента даних

cod segment public para ‘code’;початок сеґмента кода

cap proc far;оголошення процедури

assume cs:cod,ds:data,ss:stck,es:data

pb equ 21h;адреса порта PB

pc equ 22h;адреса порта PC

pu equ 23h;адреса реґістра керування портами

push ax;збереження в стек вмісту реґістра АХ

push cx;збереження в стек вмісту реґістра ег

push dx;збереження в стек вмісту реґістра DХ

mov al,98h;записуємо в акумулятор керуюче слово

;10011000B для настройки режиму 0 порта

;А – на введення

out pu,al;C(7-4) – введення, В – виведення,

;С(3-0) – вивід

xor al,al;очищення акумулятора

out pc,al;пересилання до ЦAП нульового значення

out pb,al;пересилання до ЦAП нульового значення

nop;пауза на час роботи ЦАП

in al,pc;введення знака біта С(7-4)

and al,0Ch;операція маскування для виділення

;бітів D(7-6)

test al,08h;перевірка знака вимірюваної напруги

jz mmin;якщо знак «мінус» – перехід

;на встановлення знака (-)

mov dx,0000;інакше знак (+)

mov ch,40h;контрольований біт розузгодження – D6

jmp short start;команда безумовного переходу на початок

mmin: mov dx,0800h;знак результату «мінус»

mov ch,80h;контрольований біт – D7

mov ch,02h;начало перевірки бітів PC.1,0

start: mov al,dh;біти, що вже пеpевіpені

or al,cl;вставлення біта, що перевіряється

out pc,al;виведення старших бітів і знака на порт

;PC (3-0)

nop;пауза ЦАП

in al,pc

and al,ch;перевірка знака розузгодження

jz nnn;якщо більше – біт не потрібен

or dh,cl;інакше вводиться результат

nnn: rol cl,1;зсув біта, що перевіряється

jnc start;якщо це не останній біт – повторити

mov cl,80h;початок перевірки бітів PB 7-0

stta: mov al,dl

or al,cl;вставлення біта, що перевіряється

out pb,al;виведення молодших бітів та знака до ЦАП

nop;пауза

in al,pc

and al,ch;перевірка знака розузгодження

jz ttt;якщо більше – біт не потрібен

or dl,cl;інакше біт вставляється в результат

ttt: rol cl,1;зсув біта, що перевіряється вліво

jnc stta;якщо біт не останній – повторити

test dx,0800h;перевірка значення знака числа

jz rrr;якщо «плюс» - вихід

and dx,03FFh;встановлення прямого позитивного кода

neg dx;отримання додаткового кода

rrr: mov codin,dx;запам’ятовування результату

pop dx;відновлення зі стека вмісту реґістра DX

pop cx;відновлення зі стека вмісту реґістра CX

pop ax;відновлення зі стека вмісту акумулятора

mov al,20h;очищення біта переривання

out PU,al;пересилання на контролер переривань

iret;вихід з процедури обробки переривання

cap endp;кінець процедури

cod ends;завершення сеґмента коду

end cap;кінець програми

 


Дата добавления: 2015-11-14; просмотров: 67 | Нарушение авторских прав


<== предыдущая страница | следующая страница ==>
ЛАБОРАТОРНА РОБОТА №3| ЛАБОРАТОРНА РОБОТА № 6

mybiblioteka.su - 2015-2024 год. (0.01 сек.)