рефераты бесплатно
рефераты бесплатно
Главная
Исторические личности
Журналистика
Зоология
Инвестиции
Информатика
История техники
Кибернетика
Коммуникация и связь
Косметология
Криминалистика
Криминология
Кулинария
Культура и искусство
Культурология
Международное публичное право
Международное частное право
Международные отношения
Менеджмент
Металлургия
Налогообложение
Наука и техника
Сельское лесное хозяйство и землепользование
Социальная работа
Социология и обществознание
Спорт и туризм
Строительство и архитектура
Таможенная система
Транспорт

Реферат: Аппаратно-программные средства ввода/вывода аналоговой информации в системах реального времени


Реферат: Аппаратно-программные средства ввода/вывода аналоговой информации в системах реального времени

                   Московский институт

         инженеров железнодорожного транспорта

--------------------------------------------------------------

         Кафедра: Автоматизированные системы управления

     АППАРАТНО-ПРОГРАММНЫЕ СРЕДСТВА ВВОДА-ВЫВОДА

     АНАЛОГОВОЙ ИНФОРМАЦИИ В СИСТЕМАХ РЕАЛЬНОГО

                  РЕАЛЬНОГО ВРЕМЕНИ

     Методические указания "Аппаратно-программные средства

          систем сбора данных и управления"

                    М О С К В А  1 9 9 2 г.

.

                       СОДЕРЖАНИЕ

   1. ВВЕДЕНИЕ...........................................

   2. ХАРАКТЕРИСТИКА КОНТРОЛЛЕРА ВВОДА-ВЫВОДА АНАЛОГОВОЙ

      ИНФОРМАЦИИ.........................................

      2.1. Назначение и устройство контроллера...........

      2.2. Организация управления работой АЦП и ЦАП......

   3. СРЕДСТВА ПРОГРАММИРОВАНИЯ ВВОДА-ВЫВОДА АНАЛОГОВОЙ

      ИНФОРМАЦИИ.........................................

   4. СРЕДСТВА ИЗМЕРЕНИЯ ВРЕМЕНИ В ПЭВМ..................

      4.1. Назначение и функции таймера ПЭВМ.............

      4.2. Программные средства для измерения времени....

   5. Контрольные вопросы...........................

   6. СПИСОК ЛИТЕРАТУРЫ..................................

.

   1.ВВЕДЕНИЕ

   При решении задач автоматизации контроля и  управления  техни-

ческими системами как правило возникает необходимость сбора и об-

работки информации,представленной в виде аналоговых электрических

сигналов.Источником информации при этом служат первичные преобра-

зователи (датчики) ,преобразующие физические параметры системы  в

электрический сигнал.При этом часто требуется,чтобы и управляющее

воздействие было представленно в аналоговой форме.

   Решение такого  рода  задач основано на использовании аналого-

цифровых (АЦП) и цифро-аналоговых (ЦАП) преобразователей.  Требо-

вания,предъявленные   к  выбору  средств  аналогового ввода-выво-

да,обусловлены,с одной стороны,характеристиками  объекта  контро-

ля(количество  и частотный спектр измеряемых параметров),а с дру-

гой стороны - необходимостью обеспечить совместимость (информаци-

онную,электрическую,конструктивную), с управляющей ЭВМ.

   В настоящее время применяют два варианта подключения  аналого-

вых устройств к ЭВМ.

    -непосредственно к системной магистрали ЭВМ;

    -с использованием  промежуточного  контроллера с  выходом на

     стандартный интерфейс (типа КАМАК,МЭК и т.п.)

   В данной работе используются встроенный контроллер ввода-выво-

да аналоговой информации pro411B в составе  IBM-совместимой  ПЭВМ

"МАЗОВИЯ".

   2. ХАРАКТЕРИСТИКА КОНТРОЛЛЕРА ВВОДА-ВЫВОДА АНАЛОГОВОЙ

      ИНФОРМАЦИИ pro411B.

   2.1.Назначение и устройство контроллера.

   Контроллер pro411B реализован в  виде  платы  для  компьютеров

класса  IBM  PC  XT/AT и предназначен для ввода-вывода аналоговых

сигналов с использованием АЦП и ЦАП.Плата контроллера размещается

внутри системного блока ПЭВМ,  занимая один из свободных разьёмов

расширения, предназначенных специально для установки дополнитель-

ного оборудования ПЭВМ. При этом обеспечиваются основные требова-

ния по конструктивной,  электрической и информационной  совмести-

мости контроллера с системной магистралью компьютера.Для подключе-

ния приёмников и  источников  аналоговых  электрических  сигналов

контроллер имеет специальный стандартизированный разъём, вынесен-

ный на заднюю панель системного блока.

   Структурная схема  контроллера  pro411B приведена на рис.1.

.

-------¬

¦      +-----T-------------------------------------------- ШУпр

¦ЦП/ОП +-----¦---------------T---------------------------- ШАдр

¦      +-----¦---------------¦-----------------T---------- ШДан

L-------     ¦               ¦                 ¦

     ---------               ¦                 ¦

     ¦                       ¦                 ¦

-----¦-----------------------¦-----------------¦--------------¬

¦----+---¬     --------------+-----------------+------------¬ ¦

¦¦       +-----+                   ДшА                      ¦ ¦

¦¦       +-----+                                            ¦ ¦

¦¦       ¦     L-----T----------T----------T----------T------ ¦

¦¦       ¦           ¦          ¦          ¦          ¦       ¦

¦¦       ¦     ------¦----------¦----------¦----------¦-----¬ ¦

¦¦       +-----+-----+----¬-----+----¬-----+----¬-----+----¬¦ ¦

¦¦       ¦     ¦¦   P0    ¦¦   P1    ¦¦   P2    ¦¦   P3    ¦¦ ¦

¦¦       +-----+L----------L----------L----------L----------¦ ¦

¦¦       ¦     L--------T-T-------------T---------------T---- ¦

¦¦       ¦              ¦ ¦             ¦               ¦     ¦

¦¦       +--------T-----¦-¦------T------¦-------¬       ¦     ¦

¦¦  БУ   +--------+-T---¦-¦------+-T----¦-------+-¬     ¦     ¦

¦¦       ¦        ¦ ¦   ¦ ¦      ¦ ¦    ¦       ¦ ¦     ¦     ¦

¦¦       ¦     ---+-+---+-+--¬---+-+----+---¬---+-+-----+--¬  ¦

¦¦       ¦     ¦             ¦¦             ¦¦             ¦  ¦

¦¦       ¦     ¦     АЦП     ¦¦    ЦАП      ¦¦   Таймер    ¦  ¦

¦¦       ¦     ¦             ¦¦             ¦¦             ¦  ¦

¦¦       ¦     L------T-------L------T-------L--------------  ¦

¦¦       ¦            ¦              ¦                        ¦

¦¦       ¦     -------+------¬       ¦                        ¦

¦¦       +-----+ Коммутатор  ¦       ¦                        ¦

¦¦       +-----+  каналов    ¦       ¦           pro411B      ¦

¦L--------     LT-T-T-------T-       ¦                        ¦

L---------------¦-¦-¦-------¦--------¦-------------------------

                ¦ ¦ ¦       ¦        ¦

                0 1 2      15       Вых

        Рис. 1. Структурная схема контроллера pro411B

.

Блок управления(БУ)  предназначен  для организации взаимодействия

контроллера с системной магисталью ПЭВМ и  обеспечивает  согласо-

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

непосредственно к центральному процессору(ЦП) и оперативной памя-

ти (ОП) компьютера и состоит из трёх групп линий параллельной пе-

редачи:управления,  адреса и данных. Связь с контроллером pro411B

осуществляется в асинхронном режиме и всегда только по инициативе

ЦП.

   Особую роль для организации обмена данными с процессором игра-

ют специальные регистры контроллера, называемые портами ввода-вы-

вода.  Каждый порт ввода-вывода имеет уникальный адрес. Процессор

располагает  специальными средствами,  позволяющими по известному

адресу(ПЭВМ обеспечивает возможность адресовать до 65535 портов),

обращаться к любому порту ввода-вывода для чтения или записи дан-

ных. Контроллер pro411B имеет 4 однобайтных порта P0-P3 с адреса-

ми  300H-303H.  Адреса  соответствующих портов pro411B могут быть

изменены при помощи специальных  переключателей, расположенных на

плате.

   Таким образом,  чтобы передать или получить информацию от уст-

ройства,  прцессор  в соответствующих линиях магистрали формирует

управляющий сигнал(чтение или запись), устанавливает адрес требу-

емоего  порта и(в случае записи) посылает данные.  Дешифратор ад-

реса порта(ДшА) контроллера определяет,  с каким из портов затре-

бована связь,  а блок управления реализует операцию чтения данных

из магистрали в порт или выдаёт данные из порта в магистраль.

   С портами ввода-вывода связаны функциональные блоки контролле-

ра:  АЦП,ЦАП,таймер  и  коммутатор  каналов.  Коммутатор  каналов

обеспечивает  возможность подключения к АЦП нескольких источников

аналоговых сигналов. Таймер предназначен для настройки АЦП на тре-

буемую частоту опроса,  поддерживая режим автоматического запуска

через заданный прмежуток времени( от 18мкс до 65мс).

   Блок АЦП  контроллера pro411B обеспечивает преобразование нап-

ряжение-код методом последовательной аппроксимации и характеризу-

ется следующими параметрами:

    - разрядность кода:12 бит;

    - диапазон входного напряжения: -10..+10 В;

    - время преобразования: 15 мкс;

    - число коммутируемых каналов: 16.

   Блок АЦП реализует режим работы с автоматическим переключением

каналов,  а  также предоставляет возможность призводить как внеш-

ний (программный), так и внутренний (автоматический) запуск через

заданный интервал времени.

   Блок ЦАП контроллера имеет следующие характеристики:

   - разрядность кода: 12 бит;

   - диапазон выходного напряжения: -10..+10 В;

   - время стабилизации выходного напряжения: 500 нс;

   - скорость нарастания выходного напряжения: 0.5 В/мкс;

   - количество выходов: 1.

.

   2.2 Организация управления работой АЦП и ЦАП

   Как отмечалось выше,  связь ЦП ЭВМ с  контроллером  pro411B

организуется путём обмена данными с портами ввода-вывода, име-

ющими адреса  300H-303H.При этом ЦП является активной стороной

и  имеет  возможность в произвольные моменты времени выполнять

операции чтения данных из любого порта  или  записи  данных  в

порт.  Каждый  из  портов  предназначен для обмена информацией

строго определённого назначения и формата.  Более того, один и

тот  же порт может использоваться для данных различного типа в

зависимости от того, какая операция (чтение или запись) выпол-

няется.В  таблице  1 дано описание функций,  реализуемых путём

записи или чтения портов ввода-вывода контроллера pro411B.

                                                     Таблица 1

         Назначение портов ввода-вывода контроллера pro411B

------T--------T-----------------------T-------------------------¬

¦АДРЕС¦ОПЕРАЦИЯ¦        ФОРМАТ         ¦   НАЗНАЧЕНИЕ            ¦

¦ПОРТА¦        +--T--T--T--T--T--T--T--+                         ¦

¦     ¦        ¦ 7¦ 6¦ 5¦ 4¦ 3¦ 2¦ 1¦ 0¦                         ¦

+-----+--------+--+--+--+--+--+--+--+--+-------------------------+

¦     ¦ запись ¦b7¦b6¦b5¦b4¦b3¦b2¦b1¦b0¦Младшие 8 бит кода ЦАП   ¦

¦300H +--------+--+--+--+--+--+--+--+--+-------------------------+

¦     ¦ чтение ¦a7¦a6¦a5¦a4¦a3¦a2¦a1¦a0¦Младшие 8 бит кода АЦП   ¦

+-----+--------+--+--+--+--+--+--+--+--+-------------------------+

¦     ¦ запись ¦c3¦c2¦c1¦c0¦b ¦b ¦b9¦b8¦Старшие 4 бита кода ЦАП  ¦

¦     ¦        ¦  ¦  ¦  ¦  ¦  ¦  ¦  ¦  ¦и номер  канала АЦП      ¦

¦301H +--------+--+--+--+--+--+--+--+--+-------------------------+

¦     ¦ чтение ¦c3¦c2¦c1¦c0¦a ¦a ¦a9¦a8¦Старшие 4 бита кода АЦП  ¦

¦     ¦        ¦  ¦  ¦  ¦  ¦  ¦  ¦  ¦  ¦и  номер канала АЦП      ¦

+-----+--------+--+--+--+--+--+--+--+--+-------------------------+

¦     ¦ запись ¦ X¦ X¦ Z¦ D¦t3¦t2¦t1¦t0¦Установка режимов АЦП    ¦

¦302H +--------+--+--+--+--+--+--+--+--+-------------------------+

¦     ¦ чтение ¦ X¦ X¦ X¦ X¦ X¦ E¦ R¦ X¦Признаки  формирования   ¦

¦     ¦        ¦  ¦  ¦  ¦  ¦  ¦  ¦  ¦  ¦кода  АЦП                ¦

+-----+--------+--+--+--+--+--+--+--+--+-------------------------+

¦303H ¦ запись ¦произвольное значение  ¦Запуск АЦП на измерения  ¦

L-----+--------+--+--+--+--+--+--+--+--+--------------------------

   В таблице испоьзованы следующие обозначения:

   а11...а0 - биты кода измеренного напряжения на входе АЦП

              (0-4095);

   b11...b0 -  биты кода устанавливаемого напряжения на выходе

               ЦАП (0-4095);

   с3...с0 - номер канала АЦП (0-15);

   t3...t0 - номер эадаваемой временной задержки между  запус-

             ками АЦП в автоматическом режиме(0-15);

   D - бит установки режима автоматического запуска АЦП (D=1);

   Z - бит установки режима автоматического декрементирования

       номера канала АЦП (Z=1);

   R - бит  признака  готовности кода АЦП к считыванию (R=1 -

       преобразование закончено,  данные готовы к считыванию);

   E - бит признака ошибки набегания (E=1 -сформирован новый

        код АЦП при невостребованном старом);

   X - неиспользуемые разряды (устанавливаются в 0).

.

   3. СРЕДСТВА ПРОГРАММИРОВАНИЯ  ВВОДА-ВЫВОДА АНАЛОГОВОЙ

      ИНФОРМАЦИИ

   Программное управление  работой  контроллера  аналогового уст-

ройства осуществляется с  использованием  операций  чтения/записи

применительно к портам ввода-вывода.

   На языке ТурбоПаскаль для обращения к портам применяется  спе-

циальная  языковая конструкция Port[<адрес_порта>:word],обладающая

всеми свойствами массива значений типа byte,индексируемого по ад-

ресу порта в пределах 0..65535 (в десятичной системе) или

O..FFFF (в шестнадцатиричной). Ниже приведён пример использования

конструкции Port:

        var x,y:byte;

        var   a:word;

        begin

          a:=$300;

          x:=Port[a];  {чтение из порта с адресом a}

          y:=1;

          Port[$303]:=y  {запись в порт с адресом 303H}

          Port[$302]:=32+16 {

        end;

   4. СРЕДСТВА ИЗМЕРЕНИЯ ВРЕМЕНИ В ПЭВМ

   4.1.Назначение и функции таймера ПЭВМ

   Для контроля текущего времени и измерения временных интервалов

ПЭВМ имеет специальное устройство, называемое таймером[4]. Таймер

состоит из трёх идентичных независимых блоков, называемых канала-

ми. Канал 0 используется непосредственно для организации подсчёта

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

Канал 1 управляет процессом регенерации оперативной памяти. Канал

2 используется для генерации звуковых сигналов.

   Вход каждого  канала таймера связан с генератором тактовых им-

пульсов ПЭВМ, при этом частота импульсов, подаваемых на вход тай-

мера Fвх постоянна и равна 1193180 Гц для всех типов ПЭВМ IBM. На

выходе канала таймера также  формируется  последовательность  им-

пульсов,частота которой Fвых зависит от значения D, записанного в

специальный 16-разрядный регистр "задержки" канала в соответствии

с выражением:

                    Fвых = Fвх/D

   Таким образом  таймер  осуществляет "деление" входной тактовой

частоты, реализуемое при помощи счётчика тактовых импульсов. Пер-

воначально  в регистр счётчика помещается число D,  которое затем

уменьшается на единицу каждый раз, когда импульс от тактового ге-

нератора пропускается через канал. Когда значение счётчика дости-

гает нуля,  канал таймера изменяет уровень выходного  сигнала  на

противоположный  и вновь загружает в счётчик число D,  после чего

процесс повторяется.

   Настройка каналов таймера на требуемую выходную  частоту  осу-

ществляется  программным путём при обращении к специальным портам

таймера(40H-42H).Обычно настройка производится автоматически  при

загрузке операционной системы,  для чего имеются специальные про-

цедуры базовой системы ввода-вывода (BIOS) ПЭВМ.  При этом в  ре-

гистр задвижки канала 0, используемого для подсчёта текущего вре-

мени,  записывается число D=65535(FFFFH), обеспечивающее значение

выходной частоты Fвых = 18.2 Гц.

   Следует отметить, что таймер работает независимо от ЦП, оказы-

вая,  в то же время,  постоянное воздействие на ЦП через  систему

аппаратных прерываний.  Механизм прерываний лежит в основе метода

подсчета текущего времени,  используемого в ПЭВМ. Метод иллюстри-

руется схемой, приведённой на рис.2.

.

                         -------------¬

                         ¦ Генератор  ¦

                         ¦ тактовых   ¦

                         ¦ импульсов  ¦

                         L-----T-------

                               ¦

                               ¦    Fвх=119380 Гц

                               ¦

                         ------+------¬

                         ¦  Таймер    ¦

                         ¦ (канал 0)  ¦

                         L-----T-------

                               ¦

                               ¦    Fвых=18.2 Гц

                               ¦

                         ------+------¬

                         ¦ Контроллер ¦

                         ¦ прерываний ¦

                         L-----T-------

                               ¦

                               ¦    IRQ 0

                               ¦

                         ------+------¬

                         ¦ Центральный¦

                         ¦  процессор ¦

                         L-----T-------

                               ¦

                               ¦    INT 8

                               ¦

                         ------+------¬

                         ¦ Программа  ¦

                         ¦ обработки  ¦

                         ¦ прерывания ¦

                         ¦    INT8    ¦

                         L-----T-------

                               ¦

                               ¦

                               ¦

                         ------+------¬

                         ¦СчТB=СчТB+1 ¦

                         L-------------

      Рис.2. Последовательность операций при подсчете текущего

             времени

.

   Импульсы с выхода канала 0  таймера  поступают  на  контроллер

прерываний ПЭВМ,  который вырабатывает сигналы прерывания с кодом

IRQ0,соответствующим прерыванию от таймера.  Прерывания возникают

18.2 раза в секунду, т.е. приблизительно каждые 55мс. ЦП, получив

прерывание,  приостанавливает работу и передаёт управление специ-

альной  программе  обработки  прерывания  от таймера INT8 в BIOS.

Программа обработки увеличивает на 1 значение 4-байтового счётчи-

ка   текущего  времени(СчТВ),  хранящегося  в  памяти  по  адресу

0040Н:006CН.

   Анализируя содержимое  счётчика  в  различные моменты времени,

можно измерять временные интервалы и определять текущее время су-

ток.Например,  если известны значения СчТВ n1 и n2,  полученные в

моменты t1 и t2, то величину интервала dt=t2-t1 можно вычислить

по формуле:

                dt=(n2 - n1)/18.2          (3.1)

   Обычно при загрузке операционной системы СчТВ обнуляется (ска-

занное  относится  к  ПЭВМ  типа  XT,  не имеющим часов реального

времeни с автономным источником питания), что соответствует уста-

новке текущего времени 0час 0мин 0.0сек или,  как принято обозна-

чать в DOS: 00:00:00.00. Максимальное значение, которое может со-

держать счетчик, соответствует 23:59:59.99 и равно

           ((23*60+59)*60+59)*18.2+99=1573039

   Любое значение СчТВ в интервале 0..1573039  может  интерпретироваться

как  текущее время суток после выполнения соответствующих арифмети-

ческих преобразований,  для чего имеются необходимые  программные

средства  как  в  DOS,  так и в системах программирования (см. п.

4.2).Следует отметить, что программа обработки прерывания от тай-

мера  INT8 обеспечивает автоматический сброс значения СчТВ в ноль

при достижении максимального значения.

    4.2.Программные средства для работы с таймером ПВЭМ

   Программное прерывание   DOS   INT21H  содержит  две  функции,

обеспечивающие чтение и установку текущего времени суток и выпол-

няющие  необходимые  преобразования между значениями СчТВ и часа-

ми-минутами-секундами.  Время выдаётся с точностью до 0.01 секун-

ды,  но  поскольку счётчик времени обновляется с частотой в 5 раз

меньше,  то показание сотых долей секунды весьма приблизительное.

Функция 2CH выдаёт,  а функция 2DH -устанавливает время.  В обоих

случаях используются одни и те же регистры процессора:

               AH - номер функции;

               CH - часы(от 0 до 23);

               CL - минуты(от 0 до 59);

               DH - секунды(от 0 до 59);

               DL - сотые доли секунды(от 0 до 99).

   Функция установки  текущего  времени  производит запись в СчТВ

числа, соответствующего заданным значениям параметров CH...DL.

   Язык командного  процессора MS DOS содержит встроенную команду

time,  обеспечивающую чтение и установку текущего времени суток в

диалоговом режиме с использованием формата DOS.В ПЭВМ, не имеющих

часов с автономным питанием, рекомендуется выполнять команду time

перед началом каждого сеанса работы.

   Системы программирования на  языках  высокого  уровня(Паскаль,

Бейсик, Си) содержат собственные процедуры чтения и установки те-

кущего времени и, кроме того, содержат дополнительные возможности

по измерению времени.

   В системе Турбо Паскаль 5.5 для установки  и  чтения  текущего

времени предназначены процедуры SetTime и GetTime модуля DOS:

          SetTime(var Hour,Minute,Second,Sec100:word)

          GetTime(var Hour,Minute,Second,Sec100:word),

где Hour -часы,  Minute -минуты,  Second -секунды, Sec100 -сотые

доли секунды.

   Рассмотренные выше программные средства можно  использовать

для  измерения временных интервалов.  При этом,  однако,  если

нужно оценить интервал в несколько секунд,  потребуется отсле-

живать  изменение  сразу трeх переменных (Hour,Minute,Second).

Поэтому,  в данном случае,  целесообразно было бы располагать

одной  переменной  времени,  а именно значением СчТВ.  В Турбо

Паскале имеется возможность непосредственно прочитать содержи-

мое  СчТВ из памяти с использованием конструкции MemL.  Напри-

мер:

                   var TimeCount: longint;

                       . . .

                   TimeCount:=MemL[$0040 : $006C];

   В этом  случае оценка временных интервалов сводится к простому

расчeту по формуле (3.1).

5. Контрольные вопросы

1.  Назовите основные функциональные блоки контроллера pro411B.

2.  Каковы режимы функционирования АЦП?

3.  Что такое цикл опроса, и от каких факторов зависит его деятельность?

4.  Что такое ошибка набегания?

5.  Каким образом определяется готовность АЦП к считыванию кода преобразованного напряжения?

6.  Объясните используемый принцип управления работ ЦАП.

7.  От каких факторов зависит быстродействие программы вывода данных через ЦАП?

8.  Каков механизм организации контроля текущего времени в ПЭВМ?

9.  Назовите способы определения длительности временных интервалов в ПЭВМ. Каково точность измерения?

6. Список литературы.

1.  Краус М., Кучбах Э., Вошми О. Г. Сбор данных в управляющих вычислительных системах: М.: Мир, 1987.-294 с.

2.  Блок 12-битного АЦП для компьютеров IBM PC XT/AT: -Научно-производственное предприятие proТЕСТ: Варшава, 1990.

3.  Микропроцессоры: в 3 кн. Кн. 25 средства сопряжения. Контролирующие и информационно-управляющие системы:/ В. Д. Вернер, И. В. Воробьёв, А. В. Горячев и др.; под ред Л. Н. Преснухина.-Мн. Выш. шк. ;1987 -303 с.

4.  Джордайн Р. Справочник программиста персональных компьютеров типа IBM PC XT/AT: - М. Финансы и статистика, 1991 - 544 с.

   

       

_




© 2009 РЕФЕРАТЫ
рефераты бесплатно