Проектирование прибора измеряющего длительность импульса
ВВЕДЕНИЕ
В настоящее время микропроцессорная техника делает большие успехи в применении, в различных отраслях производства. Сейчас микропроцессоры стали применяться не только в бытовой технике и в автомобилях, но и даже в производстве управляя сложнейшими технологическими процессами.
Цель курсового проекта послужила создание измерительного прибора на базе микропроцессора AVR90S8515
Микропроцессоры американской фирмы ATMEL, в последние годы делают значительные успехи в освоении новых областей в сфере своего применения. Микропроцессорное ядро, используемое в микроконтроллерах AVR, похоже на большинство процессоров с RISC архитектурой, пожалуй, за исключением 8-разрядных регистров. Разработано двумя разработчиками из Норвегии, в городе Trondheim. Позже, в 1995 году, разработка была приобретена фирмой Atmel. До сих пор развитие ядра происходит в Норвегии, в то время как периферия и память разрабатываются в отделении Atmel в Калифорнии.
С помощью проектируемого прибора можно будет измерять длину импульсов в диапазоне от 10 мСек до 10 Сек измеренная величена будет отображаться на четырех разрядном светодиодном индикаторе
1.ТЕХНИЧЕСКОЕ ЗАДАНИЕ
Необходимо спроектировать прибор для измерения длительности импульса.
Мин. | Макс. | |
Диапазон измерения: | 10 мС | 10с |
Погрешность измерения | 1% | |
Количество гальванически развязанных каналовВходное напряжение логической единицыВходное напряжение логического нуля | 1уровень ТТЛШуровень ТТЛШ | |
Количество режимов измерения | 2Из-ие высоко уровня длительности импульсаИз-ие низкого уровня длительности импульса | |
Возможность индикации измеренной длительностиКоличество режимов отображения измеренной длительности | ЕстьСветодиодные индикаторы –4 шт2отображение в секундахотображение в мили секундах | |
Выходное напряжение источника питания | +5 В |
2. РАЗРАБОТКА СТРУКТУРНОЙ СХЕМЫ. ОБОБЩЕННЫЙ АЛГОРИТМ РАБОТЫ
Структурная схема измерительного прибора приведена на рис.1
Структурная схема измерительного прибора
мСек – кнопка выбора отображения измеренной длительности импульса в мили Секундах.
Сек - кнопка выбора отображения измеренной длительности импульса в Секундах
Инверсия – кнопка выбора первого или второго режима измерения см ТЗ.
Св.Д1. – светодиод индицирующий включение второго режима измерения
Св.Д2. – светодиод индицирующий включение режима отображения измеренной длительности импульса в секундах.
Св.Д3. – светодиод индицирующий включение режима отображения измеренной длительности импульса в мили секундах.
AVR90S8515 – однокристальная микро-ЭВМ AVR90S8515
Рисунок 1.
Дешифраторы производят дешифрацию двоично-десятичного кода, а индикаторы отображают результаты измерения.
При включении питания микро-ЭВМ производит выполнение подпрограммы инициализации (инициализация стека, настройка используемых портовВВОДА/ВЫВОДА, загружается в компаратор А таймер/счетчика число 80000, выбирается нужный режим работы таймер/счетчика 1 (бит CTC1 регистра управления таймером/счетчиком 1(TCCR1B), устанавливается в единицу, что означает сброс таймер/счетчика 1 при срабатывании компаратора А, также бит CS10,находящийся в этом же регистре, устанавливается в единицу, это означает, что в качестве источника синхронизации будет использоваться частота синхронизации кварцевого резонатора), происходит глобальное разрешение прерываний ). Далее происходит опрос состояния кнопки выбора режима измерения длительности импульса и в зависимости от ее состояния (0 – измерение низкого уровня длительности импульса, 1 - измерение высокого уровня длительности импульса ), происходи переход на соответствующую подпрограмму (IMPULS_POLOGITELNAY – подпрограмма измерения высокого уровня длительности импульса, IMPULS_OTRICHATELNAY - подпрограмма измерения низкого уровня длительности импульса ).
Алгоритм работы этих двух подпрограмм практический одинаковый, для примера рассмотрим работу подпрограммы IMPULS_POLOGITELNAY. При переходе на эту подпрограмму МП начинает опрос линии PA0 и в случае обнаружения на ней логической единицы запускает таймер/счетчик 1. При срабатывании компаратора А происходит сброс таймер/счетчика 1 (в компаратор А загружено число – 8000, при частоте синхронизации МП равной 8Мгц срабатывание компаратора произойдет ровно через 1мС±1% ), что говорит о прошествии 1мСек. Отчет мили секунд в соответствии с ТЗ начнется после прошедшей девятой мили секунды. Индикация измеряемой длительности импульса происходит каждые 50 мСек. Вмести с этим МП продолжает сканировать линию PA0 и после того как он обнаружит на ней состояние логического нуля, что говорит о конце измерения длительности импульса, произойдет остановка таймера/счетчика 1 и произведется переход на подпрограмму перевода двоичного шестнадцати разрядного числа в двоично-десятичное - bin16BCD5 (детальный алгоритм перевода двоичного шестнадцати разрядного числа в двоично-десятичное рассмотрен ниже). После выполнения подпрограммы bin16BCD5, МП опрашивает состояние кнопок мСек и Сек. Если нажата кнопка Сек (индикация результата измерения производится в секундах), то тогда МП путем выдачи с линии РА7 логической единицы индицирует точку разделяющую целую часть числа от дробной. Если не нажата ни одна из двух кнопок или нажаты все, то тогда индикация результата измерения производится не будет. После того как произведется индикация результата измерения (через линии порта D и C) МП возвращается в основную программу. На этом цикл работы программы заканчивается .
Алгоритм подпрограмма перевода двоичного шестнадцати разрядного числа в двоично-десятичное
Арифметико-логическое устройство AVR-микроконтроллеров (как и других микропроцессоров) выполняет элементарные арифметические и логические операции над числами, представленными в двоичном коде. В двоичном коде считываются результаты преобразования АЦП, в двоичном коде (в формате целых чисел или чисел с плавающей точкой) удобно выполнять обработку результатов измерения. Однако, когда окончательный результат отображается на индикаторе, он должен быть преобразован в десятичный формат, удобный для восприятия человеком.
Форматы представления десятичных чисел
В настоящее время распространены два формата представления десятичных чисел в микропроцессорах - упакованный двоично-десятичный код (BCD-Binary-Coded Decimal).
Упакованный BCD-код - это такое представление десятичного числа, когда каждая десятичная цифра представляется 4-х битным двоичным позиционным кодом 8-4-2-1. При этом байт содержит две десятичные цифры. Младшая десятичная цифра занимает правую тетраду (биты 3 : 0), старшая - левую тетраду (биты 7 : 4). Многоразрядные BCD-числа занимают несколько смежных байт. Если число является знаковым, то для представления знака в BCD-формате отводится старшая тетрада старшего байта
Алгоритм подпрограммы bin16bcd5 заключается в следующем. Предположим, что имеется целое беззнаковое 16-битное число (диапазон от 0 до 65535). Очевидно, что необходимо найти 5 десятичных цифр. Способ преобразования заключается в том, чтобы, вычитая из исходного числа число 10000, сначала определить десятичную цифру десятков тысяч. Затем находится цифра тысяч последовательным вычитанием числа 1000 и т. д. Вычитание каждый раз производится до получения отрицательной разности с подсчетом числа вычитаний. При переходе к определению каждого следующего десятичного разряда в регистрах исходного числа восстанавливается последняя положительная разность. После того, как будет найдена десятичная цифра десятков, в регистрах исходного числа останется десятичная цифра единиц.
3. РАЗРАБОТКА И РАСЧЕТ ЭЛЕМЕНТОВ ПРИНЦИПИАЛЬНОЙ ЭЛЕКТРИЧЕСКОЙ СХЕМЫ
3.1 Выбор микропроцессорного комплекта
В соответствии с ТЗ ядром измерительного прибора послужила однокристальная микро-ЭВМ AVR90S8515 фирмы Atmel.
Основные характеристики однокристальной микро-ЭВМ AVR90S8515:
• AVR RISC архитектура - архитектура высокой производительности и малогопотребления
• 120 команд, большинство которых выполняется за один машинный цикл
• 8 Кбайта Flash ПЗУ программ, с возможностью внутрисистемногоперепрограммирования и загрузки через SPI последовательный канал, 1000 цикловстирание/запись
• 512 байтов ЭСППЗУ данных, с возможностью внутрисистемной загрузки через SPIпоследовательный канал, 100000 циклов стирание/запись
• 512 байтов встроенного СОЗУ
• 32 x 8 бит регистра общего назначения
• 32 программируемых линий ввода/вывода
• 16-разрядный и 32-разрядный формат команд
• Диапазон напряжений питания от 2,7 В до 6,0 В
• Полностью статический прибор - работает при тактовой частоте от 0 Гц до 8 МГц
• Длительность командного цикла: 125 нс, при тактовой частоте 8 МГц
• 8-разрядный и 16-разрядный (с режимами сравнения и захвата) таймеры/счетчики
• Сдвоенный ШИМ с 8, 9 или 10-разрядным разрешением
• Программируемый полный дуплексный UART
• Два внешних и десять внутренних источников сигнала прерывания
• Программируемый сторожевой таймер с собственным встроенным генератором
• Встроенный аналоговый компаратор
• Режимы энергосбережения: пассивный (idle) и стоповый (power down)
• Блокировка режима программирования
• Промышленный (-40°C...85°C) и коммерческий (0°C...70°C) диапазоны температур
• 40-выводной корпус PDIP и 44-выводные корпуса TQFP и PLCC
КМОП микроконтроллер AT90S8515 реализован по AVR RISC архитектуре
(Гарвардская архитектура с раздельной памятью и раздельными шинами для памятипрограмм и данных) и совместим по исходным кодам и тактированию с 8-разряднымимикроконтроллерами семейства AVR (AT90SXXX). Выполняя команды за один тактовыйцикл, прибор обеспечивает производительность, приближающуюся к 1 MIPS/МГц. AVRядро объединяет мощную систему команд с 32 8-разрядными регистрами общегоназначения и конвейерное обращение к памяти программ. Шесть из 32 регистровмогут использоваться как три 16-разрядных регистра-указателя при косвенной адресациипространства памяти. Выполнение относительных переходов и команд вызовареализуется с прямой адресацией всех 4К адресного пространства. Адресапериферийных функций содержатся в пространстве памяти ввода/вывода. Архитектураэффективно поддерживает как языки высокого уровня, так и программы на языкахассемблера.Встроенная загружаемая Flash память обеспечивает внутрисистемноеперепрограммирование с использованием интерфейса SPI (в последовательномВстроенная загружаемая Flash память обеспечивает внутрисистемноеперепрограммирование с использованием интерфейса SPI (в последовательномнизковольтовом режиме) или с использованием стандартных программаторовэнергонезависимой памяти (в 12-вольтовом параллельном режиме).Потребление прибора в активном режиме составляет 3,5 мА и в пассивномрежиме 1 мА (при VCC =3 В и f=4 МГц). В стоповом режиме, при работающемсторожевом таймере, микроконтроллер потребляет 50 мкА.низковольтовом режиме) или с использованием стандартных программаторовэнергонезависимой памяти (в 12-вольтовом параллельном режиме).Потребление прибора в активном режиме составляет 3,5 мА и в пассивномрежиме 1 мА (при VCC =3 В и f=4 МГц). В стоповом режиме, при работающемсторожевом таймере, микроконтроллер потребляет 50 мкА.