Курсовая

Курсовая Система съема данных с оптопар

Работа добавлена на сайт bukvasha.net: 2015-10-25

Поможем написать учебную работу

Если у вас возникли сложности с курсовой, контрольной, дипломной, рефератом, отчетом по практике, научно-исследовательской и любой другой работой - мы готовы помочь.

Предоплата всего

от 25%

Подписываем

договор

Выберите тип работы:

Скидка 25% при заказе до 22.11.2024





Содержание
Введение

1.       Анализ поставленной задачи

2.       Проектирование принципиальной схемы устройства

2.1     Схема включения микроконтроллера

2.2     Формирование тактовых импульсов

2.3     Организация сброса

2.4     Схемы входных и выходных устройств

2.5     Схема источника напряжения питания

3.       Проектирование программного обеспечения микропроцессора

3.1     Проектирование модуля инициализации микроконтроллера.

3.2     Проектирование процедур обработки прерываний.

3.3     Проектирование процедур обработки информации.

3.4     Проектирование процедур вывода информации.

3.5     Проектирование процедуры Main().

4.       Листинг программы

5.       Рекомендации по разработке программных и аппаратных диагностических средств для проверки работоспособности устройства

Заключение


Введение
В настоящее время встроенные компьютерные системы получают все большее распространение из-за их высокого качества и надежности, а так же простоты обработки информации.

В ходе курсового проекта необходимо разработать КС которая будет считывать данные с десяти оптопар и выводить обработанную информацию по интерфейсу RS485.

По техническому заданию на курсовой проект КС должна быть посторена на микроконтроллере LPC2000.

Микропроцессоры LPC20 основаны на 16/32 битном ЦП ARM7TDMI-S, содержащем функцию эмуляции в реальном времени и поддержку отслеживания, а также 128 кБ высокоскоростную программную FLASH память. 128 битный интерфейс с памятью и уникальная архитектура акселератора позволяют выполнять 32 битный код на максимальной тактовой частоте. Для приложений, в которых размер кода является критическим параметром, существует 16- разрядный режим Thumb, который позволяет при небольших ухудшениях параметром снизить размер программы на 30 %.




1. Анализ поставленной задачи
Темой курсового проекта является «Система съема данных с оптопар».

Рассмотрим общую структурную схему, приведенную на рисунке 1.


Рисунок 1 – Структурная схема устройства.
В качестве микроконтроллера выберем LPC2104.

Микропроцессор LPC2104 построен на 16/32 битном ЦП ARM7TDMI-S, содержит 128 кБ высокоскоростной программной FLASH памяти и 16 кБ статической оперативной памяти. Количество портов ввода вывода составляет 32. У предложенного микроконтроллера достаточное число контактов ввода/вывода и памяти программ и данных для реализации системы считывания оптопар.

На рисунке 2 приведен LPC2104.






Рисунок 2 – LPC2104
Характеристики LPC2104:

-                                 16/32 битный ARM7TDMI-S микропроцессор.

-                                 Встроенное 16 кБ статическое ОЗУ.

-                                 Встроенная 128 кБ программная Flash память. 128 битный интерфейс/акселератор, способные работать в высокоскоростном режиме с тактовой частотой 60 МГц.

-                                 Возможность программирования внутри системы (ISP) и внутри приложения (IAP) при помощи встроенной программы-загрузчика. Время программирования одной 512 байтной линии Flash памяти 1 мс. Стирание одного сектора или всей памяти за 400 мс.

-                                 Векторный контроллер прерываний с перестраиваемыми приоритетами и адресами векторов прерывания.

-                                 Интерфейс EmbeddedICE-RT активизации точек останова и точек просмотра. Подпрограмма обработки прерывания может продолжать выполняться, в то время как основной программный модуль отлаживается встроенной программой RealMonitor.

-                                 Встроенный модуль Trace Macrocell позволяет отслеживать в реальном времени выполнение программы.

-                                 Последовательные интерфейсы:

§                    два UART (16C550)

§                    высокоскоростной I2C (400 кбит/с)

§                    SPI.

-                                 Два 32-разрядных таймера (7 каналов захвата/сравнения), модуль ШИМ (6 выходов), часы реального времени и сторожевой таймер.

-                                 До тридцати двух линий портов ввода - вывода общего применения, совместимых с 5 В логикой, в миниатюрном 7х7 мм 48 контактном LQFP корпусе.

-                                 Встроенная система ФАПЧ позволяет обеспечить максимальную частоту тактовых импульсов ЦП 60 МГц.

-                                 Встроенный кварцевый генератор, имеющий рабочий частотный диапазон от 10 МГц до 25 МГц.

-                                 Два режима пониженного потребления: холостой режим и дежурный режим.

-                                 Возможность активизации микропроцессора сигналом внешнего прерывания.

-                                 Индивидуальное включение/отключение периферийных модулей для оптимизации потребления.

-                                 Работает от двух источников питания:

-                                  Диапазон рабочего напряжения центрального процессора от 1.65 В до 1.95 В (1.8 В ±8.3 %).

-                                  Диапазон источника питания портов ввода - вывода от 3.0 В до 3.6 В (3.3 В ±10 %) с возможностью работы с 5 В логикой.

На рисунке 3 приведена внутренняя структура LPC2104


Рисунок 3 – Внутренняя структура LPC2104
В качестве часов реального времени применим встроенные RTC.


2. Проектирование принципиальной схемы устройства
2.1 Схема включения микропроцессора
Микроконтроллер LPC2104 содержит 1 тридцати двух разрядный регистр портов вода вывода регистр.

На рисунке 4 приведена структурная схема включения микроконтроллера.


Рисунок 4 – Структурная схема включения микроконтроллера
2.2 Формирование тактовых импульсов
Источником тактовых импульсов в микроконтроллере LPC2104 может быть:

                   внешний резистор

                   высокочастотный кварцевый резонатор

                   внешний источник тактовых импульсов

В данном разрабатываемом устройстве наиболее предпочтительным режимом работы генератора является применение внешнего кварцевого резонатора подключаемого к контактам X1 и X1 Это стабильный генератор с точной выдержкой временных интервалов тактовой частоты которая необходима для точной обработки данных полученных с оптопар и выдержки точных интервалов в USART0.

На рисунке 5 приведена схема тактирования.



Рисунок 5 – Схема тактирования.
2.3 Схема сброса
На рисунке 6 приведена аппаратная схема сброса по включению питания. Данная схема необходима для первичной инициализации аппаратуры микроконтроллера.






Рисунок 6 – Аппаратная схема сброса по включению питания
2.4 Схемы входных и выходных устройств
Данное устройство считывает данные с 10-ти оптопар. Применим оптрон АОД130А. Оптопара диодная, состоящая из излучателя и кремниевого фотоприёмника, изготовленных по эпитаксиальной технологии, в пластмассовом корпусе, предназначены для использования в качестве элементов гальванической развязки в высоковольтной электротехнической и радиоэлектронной аппаратуре.

Характеристик датчика:

-                                 Входное напряжение (Iвх = 10 мА) 1,5В

-                                 Время нарастания выходного сигнала 100 нс

-                                 Время спада выходного сигнала 100 нс

-                                 Сопротивление изоляции 1011 Ом

Схема включения оптрона приведена на рисунке 7.




 

Рисунок 7 – Схема включения оптрона
Обмен данными осуществляется по RS 485 интерфейсу. Для данной КС применим микросхему MAX3362. ИС MAX3362 представляют собой высокоскоростные трансиверы для коммуникационных приложений RS-485, содержащие по одному драйверу и одному приемнику. Данные ИС имеют отказоустойчивую архитектуру, гарантирующую высокое логическое состояние на выходе приемника при разомкнутых, или замкнутых на корпус, входах приемника. Это означает, что выход приемника имеет высокое логическое состояние при отключении всех передатчиков (высокоимпедансное состояние) на согласованной шине. С низким напряжением питания. На рисунке 8 приведен MAX3362.






Рисунок 9 – MAX3362
2.5 Схема стабилизатора напряжения
Источник питания микроконтроллера построен на литиевой 3V батарее. Для формирования напряжения питания ядра процессора (1.8V) применим параметрический стабилизатор на стабилитроне. На рисунке 9 приведена схема питания.
 

Рисунок 9 – Схема питания микроконтроллера.


3. Проектирование программного обеспечения микропроцессора
3.1 Проектирование модуля инициализации микроконтроллера
Для инициализации данного устройства необходимо выделить память для глобальных переменных, и провести инициализацию портов, таймеров и USART, RTC.
3.2 Проектирование процедур обработки прерываний
Данное устройство не требует написания программы с обработкой прерываний. Это связанно с линейностью выполнения алгоритма опроса датчиков и обмена данными по RS485.
3.3 Проектирование процедур обработки информации
Оптопара имеет прямоугольные сигналы на выходе. И для измерения каких либо величин необходимо измерение длительности активного и неактивного состояния датчика. И в зависимости от состояния каждой из 10 оптопар формировать соответствующую посылку.
3.4 Проектирование процедур вывода информации
C помощью встроенных RTC формируем временны метки к измеренным данным.

Вывод информации осуществляется с помощью дифференциального интерфейса обмена данными RS 485. Протокол – RS232. Встроенный аппаратный модуль LPC2000.






3.5 Проектирование процедуры Main()
Процедура Main это главная процедура программы с которой начинается выполнение. В данной процедуре необходимо вызвать процедуру инициализации, а затем необходимо перейти в бесконечный цикл опроса датчиков, формирование посылки, передача данных. На рисунке 10 приведен общий алгоритм работы устройства.


Рисунок 10 – Общий алгоритм работы устройства


4 Листинг программы
#include <limits.h>

#include "LPC210x.h"
#include "global.h"

#include "uart.h"
//! enable and initialize the uart

void uart0Init(uint16_t baud, uint8_t mode, uint8_t fifomode)

{

          // set port pins for UART0

          PINSEL0 = (PINSEL0 & ~U0_PINMASK) | U0_PINSEL;
          U0IER = 0x00; // disable all interrupts

          U0IIR; // clear interrupt ID

          U0RBR; // clear receive register

          U0LSR; // clear line status register
          // set the baudrate

          U0LCR = ULCR_DLAB_ENABLE; // select divisor latches

          U0DLL = (uint8_t)baud; // set for baud low byte

          U0DLM = (uint8_t)(baud >> 8); // set for baud high byte
          // set the number of characters and other

          // user specified operating parameters

          U0LCR = (mode & ~ULCR_DLAB_ENABLE);

          U0FCR = fifomode;

}
int uart0SendByte(int data)

{

          while(!(U0LSR & ULSR_THRE))                // wait for TX buffer to empty

                   continue;                                                      // also either WDOG() or swap()
          U0THR = (uint8_t)data;

          return (uint8_t)data;

}
int uart0GetByte(void)

{

          if(U0LSR & ULSR_RDR)                                     // check if character is available

                   return U0RBR;                                             // return character

          return -1;

}
void uart1Init(uint16_t baud, uint8_t mode, uint8_t fifomode)

{

 // set port pins for UART1

 PINSEL0 = (PINSEL0 & ~U1_PINMASK) | U1_PINSEL;
 U1IER = 0x00; // disable all interrupts

 U1IIR; // clear interrupt ID

 U1RBR; // clear receive register

 U1LSR; // clear line status register
 // set the baudrate

 U1LCR = ULCR_DLAB_ENABLE; // select divisor latches

 U1DLL = (uint8_t)baud; // set for baud low byte

 U1DLM = (uint8_t)(baud >> 8); // set for baud high byte
 // set the number of characters and other

 // user specified operating parameters

 U1LCR = (mode & ~ULCR_DLAB_ENABLE);

 U1FCR = fifomode;

}
int uart1SendByte(int data)

{

          while(!(U1LSR & ULSR_THRE))                // wait for TX buffer to empty

                   continue;                                                      // also either WDOG() or swap()

          U1THR = (uint8_t)data;

          return (uint8_t)data;

}
int uart1GetByte(void)

{       

          if(U1LSR & ULSR_RDR)                                     // check if character is available

                   return U1RBR;                                             // return character

          return -1;

}




5 Рекомендации по разработке программных и аппаратных диагностических средств для проверки работоспособности устройства
Для диагностики работоспособности данного устройства можно использовать как аппаратные, так и программные средства. Данные средства должны иметь возможность производить отладку с помощью модуля Trace Macrocell.

А так же существует возможность самотестирования работоспособности оптопары, при подаче тестовых сигналов на вход оптопары.




Заключение
В данном курсовом проекте было разработано устройство считывания данных с оптопар и передачи данных по RS485. Встроены часы реального времени позволяют ставить временные метки для измеренных данных.

Использование внешнего кварцевого генератора обеспечивает высокую стабильность измерения временных интервалов поступающих от оптопары.

В ходе проектирования устройства были рассмотрены основные принципы построения устройств на микроконтроллерах LPC2000 от Philips. А так же изучены аппаратные возможности данных микроконтроллеров.

Научились по описаниям работы или временным диаграммам функционирования устройств составлять алгоритмы тех или иных блоков программ.

В целом по разработанному курсовому проекту можно заметить, что использование микроконтроллеров LPC2000 позволяет строить недорогие и производительные микроконтроллерные системы не использую внешнее периферийное оборудование (аналоговый компаратор, аппаратный тайме и др.).

1. Доклад на тему Феодализм
2. Реферат на тему Evil Problem Essay Research Paper If it
3. Реферат Александр второй-реформатор
4. Контрольная работа на тему Расчеты грузооборота и дальности пробега
5. Реферат Расчет и оптимизация режимов резания
6. Реферат Рыночный механизм потребительского рынка
7. Книга Толстой Первая русская книга для чтения
8. Реферат на тему Effects Of Superstition Essay Research Paper Everyone
9. Курсовая Анализ конструкции и методика расчета автомобиля ВАЗ-2108
10. Контрольная работа Международная экономика - основа развития