СОДЕРЖАНИЕ
Введение
1. Словесное описание работы системы
2. Предварительное распределение памяти
3. Алгоритм функционирования микропроцессорной системы
4. Распределение ресурсов
5. Программа работы системы
6. Контрольный пример
Заключение
Список использованной литературы
ВВЕДЕНИЕ
В данной курсовой работе описывается отбраковка резисторов на производстве. Резисторы сортируются по допускам и раскладываются в соответствующие контейнеры. Если сопротивление не входит ни в один диапазон допуска, он помещается в отдельный контейнер и включает сигнал, что попался брак. Система построена на микропроцессоре К1816ВЕ48.
Измерение сопротивления производиться посредством измерения падения напряжения на исследуемом резисторе при пропускании через него фиксированного тока.
1.
СЛОВЕСНОЕ ОПИСАНИЕ РАБОТЫ СИСТЕМЫ
Принципиальная схема системы приведена на рис. 1.1
Работает система следующим образом:
В некоторый момент времени процессор подает роботу команду установить резистор и начинает ждать. Робот, когда установит резистор в измеряющее устройство, сигнализирует об этом процессору. Процессор выходит из режима ожидания и выдает команду начать преобразование и снова начинает ждать. АЦП, завершив преобразования падения напряжения на измеряемом резисторе в цифровой код, подает сигнал процессору. Процессор считывает с АЦП цифровой код и приступает к сравнению его с записанным в память эталонным сопротивлением. В результате вычислений процессор определяет к какой группе по отклонению от номинала относится измеряемый резистор и выдает соответствующую команду роботу- поместить резистор в один из пяти контейнеров с отклонениями
Далее цикл повторяется сначала.
2.
ПРЕДВАРИТЕЛЬНОЕ РАСПРЕДЕЛЕНИЕ ПАМЯТИ
Предварительное распределение памяти в системе показано на рис. 2.1. Т. к. программа, управляющая системой, скорее всего, будет сравнительно небольшой, то она вся поместиться во внутреннем ПЗУ процессора (памяти компьютера), поэтому на рисунке изображена только эта память; внешние ПЗУ не нужны и поэтому распределение для них не показано.
Система будет обрабатывать сравнительно небольшой объем данных, поэтому показания на схеме распределения памяти данных область “ОЗУ данных” скорее всего, останется незадействованной.
3FFh
YYYh XXXh 000h |
Свободно | 3Fh 20h 1Fh 18h 17h 08h 07h 00h |
ОЗУ данных |
Банк регистров RB1 | |||
Подпрограмма | |||
8-уровневый стек | |||
Программа, управляющая работой системы | |||
Банк регистров RB0 |
Рис. 2.1.
Память команд Память данных
3.АЛГОРИТМ ФУНКЦИОНИРОВАНИЯ МИКРОПРОЦЕССОРНОЙ СИСТЕМЫ
Укрупненная структурная схема алгоритма программы, управляющей процессором, изображена на рис. 3.1.
При включении системы вначале она принудительно переходит в режим занесения эталонного сопротивления. Процессор считывает с АЦП значение сопротивления, записывает его в память и обнуляет все счетчики, в которых ведется учет резисторов с определенным допуском.
Далее следует установка и измерение сопротивления очередного резистора. Считанное с АЦП значение сопротивления подвергается обработке процессором и вычисляется процент отклонения сопротивления резистора от эталонного. В зависимости от значения этого отклонения процессором выдается команда роботу на размещение резистора в определенном контейнере и увеличение на единицу соответствующего счетчика резисторов.
Далее анализируется состояние переключателя “ЭТАЛОН”. Если он замкнут, то снова производится замена в памяти эталонного сопротивления и обнуление счетчиков. Если этот переключатель разомкнут, то система начинает обработку следующего резистора.
4. РАСПРЕДЕЛЕНИЕ РЕСУРСОВ
В регистре R0 банка 0 находится текущее эталонное сопротивление. Остальные регистры банка 0 используются по мере надобности для хранения промежуточных результатов и временного сохранения содержимого аккумулятора.
В регистре R0 банка 1 находится счетчик количества резисторов с сопротивлением вне допуска.
В регистре R2 банка 1 находится счетчик количества резисторов с отклонением не более 10% от эталона.
В регистре R2 банка 1 находится счетчик количества резисторов с отклонением не более 10% от эталона.
В регистре R2 банка 1 находится счетчик количества резисторов с отклонением не более 10% от эталона.
В регистре R2 банка 1 находится счетчик количества резисторов с отклонением не более 10% от эталона.
В регистре R2 банка 1 находится счетчик количества резисторов с отклонением не более 10% от эталона.
Через вывод Р10 процессору сообщается режим работы:
0- сортировка резисторов по допускам;
1- смена эталонного сопротивления.
Через вывод Р20 роботу выдается команда “установить резистор”. Активное состояние – 1.
Через вывод Р21 роботу выдается команда положить резистор в контейнер “ВНЕ ДОПУСКА”. Активное состояние – 1.
Через вывод Р22 осуществляется запуск АЦП. Активное состояние – 0.
Через выводы Р25, Р26, Р27, Р28 и Р29 роботу выдается команда положить резистор в контейнер с допуском соответственно. Активное состояние – 1.
На вывод Т0 от робота поступает 1, если резистор установлен.
На вывод Т1 от АЦП поступает 1, когда данные готовы к считыванию.
Программа в памяти начинается с адреса 000h.
5. ПРОГРАММА РАБОТЫ СИСТЕМЫ
Адрес | Код | Количество циклов | Метка |
Мнемоника | Комментарий | |
000 002 003 004 008 00А 00С 00D 00F 010 011 12 013 015 017 018 019 01A 01B 01D 01E 020 021 023 024 026 027 028 02A 02B 02C 02D 02E 02F 030 031 032 033 034 035 037 038 03A 03B 03C |
14 70 A8 D5 D8 00 BA 00 BB 00 C5 14 70 33 17 68 AB 53 80 C6 1B FB 07 33 AB BC 64 FB BA 00 6B E6 24 1A EC 20 A9 97 BB 08 F9 F7 A9 FA F7 AA F8 33 17 6A A7 F6 38 F8 EB 2A F9 F7 A9 |
2 1 1 2 2 2 1 2 1 1 1 1 2 2 1 1 1 1 2 1 2 1 2 1 2 1 |
Change: Call Meas MOV R0.A SEL RB1 MOV R0, 00h MOV R2, 00h MOV R3, 00h SEL RB0 Work: CALL Meas CPL A. INC A ADD A,R0 MOV R3,A ANL A,80H. JZ Mul. MOV A,R3 DEC A CPL A MOV R3,A. Mul: MOV R4,64h MOV A,R3 MOV R2, 00h M1: ADD A, R3 JNC M2 INC R2 M2: DJNZ R4, M1 MOV R1, A CLR C MOV R3,08h M3: MOV A, R1 RLC A MOV R1, A MOV A, R2 RLC A MOV R2, A MOV A, R0 CPL A. INC A ADD A, R2 CPL C JC M4 ADD A, R0 M4: DJNZ R3, М3 MOV A, R1 RLC A MOV R1, A |
;Вызов подпрограммы измерения сопротивления резистора ;Запомним в R0 эталонное сопротивление. ;Подключим банк регистров RB1. ;Обнуление счетчика ;Обнуление счетчика ;Обнуление счетчика ;Подключим банк регистров RB0. ;Измерение сопротивления резистора. ;Инвертирование содержимого аккумулятора ;А=А+1ÞА в дополнительном коде. ;Вычитаем из эталонного сопротивления измеренное: А=R0-А. ;Спасаем А регистре R3 ;Проверяем знаковый бит ;Если А>0, то переходим на метку Mul ;Восстановим содержимое А. ;А=А-1 ;Инвертирование А; А- в прямом коде. ;Сохраним содержимое А ;В R4- число повторений цикла- 10010
;В аккумуляторе- разность между измеренным и эталонным ;сопротивлениями, взятая по модулю. ;Обнуление регистра
R2
;А=А+R3. ;Если А+R3£FFh, то переходим на М2. ;Учитываем перенос (А+R3>FFh). ;Уменьшаем счетчик цикла. Если R4>0- повторяем цикл. ;Копируем аккумулятор в регистр R1 ;После умножения в регистре R1 будет младший байт ;произведения, в R2- старший, т. е. R2R1=½Nэт
;Разделим содержимое этой пары регистров на содержимой ;регистра R0 (эталон). ;Обнуляем флаг переноса. ;Счетчик цикла. ;ВА- младший байт произведения. ;Циклический сдвиг влево через флаг переноса. ;R1=А ;ВА- младший байт произведения. ;Циклический сдвиг влево через флаг переноса ;R2=А ;ВА- эталонное вопротивление (делитель). ;Инвертирование содержимого аккумулятора А=А+1Þ А в дополнительном коде ;А=R2-А ; Инвертирование флага переноса ;Если флаг С установлен, переходим на М4. ;А=А+ R0 ;Уменьшаем счетчик цикла. Если R3>0, то повторяем цикл. ;А=R1 ;циклический сдвиг влево через флаг переноса. ; В R1- результат деления, т. е. отклонение в процентах измеренного сопротивления от эталонного. ;проверка на принадлежность к группе по допуску. |
||
03D 03F 041 042 043 044 046 047 049 04A 04C 04E 04F 050 051 053 054 056 057 058 059 05B 05C 05E 05F 060 062 |
03 F6 E6 49 D5 18 C5 23 06 3A 04 5C F9 03 FB E6 56 D5 1A C5 23 44 3A 04 5C D5 1B C5 23 24 3A 23 04 3A 09 12 00 04 0D |
2 2 1 1 1 2 2 2 1 2 2 1 1 1 2 2 2 1 1 1 2 2 2 2 2 2 2 |
P 10: P 5: Mode: |
ADD JNC SEL IBC SEL MOV OUTL JMP MOV ADD JNC STL INC SEL MOV OUTL JMP SEL INC SEL MOV OUTL MOV OUTL IN JB0 JMP |
A. F6h P10 RB1 R0 RB0 A, 06h P2, A Mode A, R1 A, FBh P5 RB1 R2 RB0 A, 44h P2, A Mode RB1 R3 RB0 A, 24h P2, A A, 04h P2, A A, P1 Change Work |
;А=А-1010
;Если А<1010
;Подключаем банк регистров RB1 ;Увеличиваем счетчик резисторов “ВНЕ ДОПУСКА” ;Подключаем банк регистров RB0 ;Устанавливаем 1-й и 2-й биты в единицу ;Команда роботу–положить резистор в контейнер “вне допуска” ;Пропускаем остальные отклонения ;A=R1 ;A=A–5 ;Если А<5, то переходим на Р5 ;Подключаем банк регисторов RB1 ;Увеличиваем счетчик резисторов с отклонением до 10% ;Подключаем банк регистров RB0 ;Устанавливаем в единицу 2–й и 6–й биты ;Команда роботу – положить резистор в контейнер “10%” ; Пропускаем отклонение 5% ; Подключаем банк регистров RB1 ;Увеличиваем счетчик резисторов с отклонением до 5% ; Подключаем банк регистров RB0 ; Устанавливаем в единицу 2–й и 5–й биты ; Команда роботу – положить резистор в контейнер “10%” ; Устанавливаем в единицу только 2–й бит ;Снимаем все активные сигналы с порта Р2 ;Читаем порт Р1 ;Нулевой бит установлен в единицу–команда смены эталона. ;Проверяем следующий резистор. |
070 072 073 075 077 079 07В 07С 07Е 07D |
23 05 3A 26 73 9A 00 8A 04 56 79 09 12 7B 08 83 |
2 2 2 2 2 2 2 2 2 2 |
Meas: W1: W2: W3: |
MOV OUTL JNT0 ANL ORL JT1 IN JB0 INS RET |
A, 05h P2, A W1 P2,00h P2,04h W2 A, P1 W3 A, Bus |
; Устанавливаем в единицу 0–й и 2–й биты ; Команда роботу –установить резистор ;Ждем установки резистора ;На АЦП-сигнал “начать измерение” ;Убираем все активные сигналы с порта Р2 ;Ждем окончания измерения ;Ждем выключения режима ; “эталонное сопротивление” ;Считываем с АЦП значение сопротивления ;Возврат в основную программу. |
К полученной программе трудно применить термин “быстродействие”, на это есть несколько причин:
-В программе есть несколько задержек на неопределенное время ( эти задержки определяются роботом);
-Программа имеет сильно разветвленную структуру, а выбор ветви в некоторых случаях зависит от внешних условий;
-Программа представляет собой бесконечный цикл, т. е. программа выполняется с момента включения системы и до выключения.
Для того, чтобы все-таки оценить быстродействие, сделаем некоторые допущения: предположим, что внешние устройства совершенно не затормаживают систему, т. е. если система выдает запрос во внешние устройства, результат приходит мгновенно. Таким образом, будет посчитано быстродействие собственно программы.
Для определенности примем, что система работает в режиме сортировки, эталонное значение уже занесено в память и в измеритель установлен резистор с 10% допуском.
Так как программа зациклена, посчитаем количество машинных циклов за один проход программы:
2+2´10+1´4+2+2+1´4+2+1+2+1+(1+2+1+2)´100+1+1+2+(1´11+2+1+2)´8+1+1+1+2+2+2+1+ 2+2+1+1+1+2+2+2+1+1+1+2´7=812 циклов
К процессору подключен кварцевый резонатор на частоту 6 МГц, следовательно тактовая частота процессора равна 6/3=2 МГц; время одного такта равно 0,5 мкс. Один машинный цикл равен пяти тактам, т. е. 2,5 мкс.
Время выполнения одного цикла программы равно 812´2,5=2030 мкс » 2 мс.
6. КОНТРОЛЬНЫЙ ПРИМЕР
Напряжение, подаваемое на АЦП, равно
U=Iэт
´R; Iэт
= 0,025 А
Входные данные:
Rэт
= 51Ом; Rизм
= 53 Ом; Uэт
= Iэт
´Rэт
= 0,025 А´51Ом = 1,28 В
С АЦП в память запишется число 128 = 80h, т. е. (R0) = 80h
U= Iэт
´Rэт
= 0,025 А´53 Ом = 1,33 В
С АЦП в аккумулятор запишеться число 133 = 85h.
Находим модель разности эталонного и измеренного сопротивлений:
½Rэт
–Rизм
½=½128-133½=½-5½=5
Отклонение в процентах находиться по формуле:
и именно по этой формуле работает написанная выше программа.
Умножаем разность на 100:
½Rэт
–Rизм
½´100=500
Делим полученное число на Rэт
/800/102 = 3, т. к. деление целочисленное.
Итак, в программе получается, что Rизм
имеет отклонение 3% от
номинала. На самом деле Rизм
имеет отклонение
Число, полученное программой, и число, рассчитанное непосредственно, достаточно близки друг к другу.
Система поместит данный резистор в контейнер с допуском 5%.
ЗАКЛЮЧЕНИЕ
В процессе работы была разработана система, способная рассортировать партию резисторов по допускам 5, 10% и брак. Система также подсчитывает число резисторов каждого допуска.
В устройстве предусмотрена возможность смены эталонного сопротивления, записанного в памяти, при смене партии резисторов.
При каждом попадании резистора с отклонением более 10% система подает световой сигнал.
СПИСОК ИСПОЛЬЗОВАННОЙ ЛИТЕРАТУРЫ
1. Микропроцессоры. В 3–х кн. Кн. 1. Архитектура и проектирование микро–ЭМВ. Организация вычислительных процессов: Учебник для вузов. Под редакцией Л.Н. Преснухина. – М.: Высшая школа, 1986г.
2. Калабеков Б.А. Микропроцессоры и их применение в системах передачи и обработки сигналов: Учебное пособие для вузов. – М.: Радио и связь, 1988г.
3. В.Н. Пильщиков. Программирование на языке ассемблер IBMPC. – М.: Диалог МИФИ, 1994г.