3.2 Работа с драйвером, передача информации по сети.
Драйвер обеспечивает расшифровку байта данных поступающего с формирователя байта адаптера, обработку информации и выдаст сообщение на экран (принтер). Алгоритм программы может быть успешно реализован на языках высокого уровня Turbo Pascal 7.0 или С++ с применением ассемблерных вставок, при этом обеспечится удобный графический интерфейс программы управления, четкость работы, рациональность алгоритма программы, автозапуск и резидентность.
Драйвер резидентно располагается в памяти компьютера, постоянно опрашивает состояние порта, осуществляет обработку информации, поступающей от адаптера и отображение ее на экране монитора. Неотъемлемым звеном работы этой системы является интерфейс RS-232-C и, в частности, порт последовательной передачи данных СОМ2 для соединения с ком. Последовательная передача данных означает, что данные передаются по единственной линии. При этом биты байта данных передаются по очереди с использованием одного провода. Для синхронизации группе битов данных обычно предшествует специальный стартовый бит, после группы битов следуют бит проверки на четность и один или два стоповых бита. Иногда бит проверки на четность может отсутствовать.
Существует три основных способа соединения с компьютером для обмена информацией:
- непосредственная связь через асинхронный порт;
- связь с использованием модема;
- связь через локальные сети.
Далее рассматриваются первые два типа соединений непосредственное и соединение через модем.
Практически каждый компьютер оборудован хотя бы одним последовательным асинхронным адаптером. Обычно он представляет собой отдельную плату или же расположен прямо на материнской плате компьютера. Его полное название - RS-232-C. Каждый асинхронный адаптер обычно содержит несколько портов, через которые к компьютеру можно подключать внешние устройства. Каждому такому порту соответствует несколько регистров, через которые программа получает к нему доступ, и определенная линия IRQ (линия запроса прерывания) для сигнализации компьютеру об изменении состояния порта. Каждому порту присваивается логическое имя (COM1,COM2,и т.д.).
Компьютер IBM PC поддерживает интерфейс RS-232-C не в полной мере; скорее разъем, обозначенный на корпусе компьютера как порт последовательной передачи данных, содержит некоторые из сигналов, входящих в интерфейс RS-232-C и имеющих соответствующие этому стандарту уровни напряжения.
В настоящее время порт последовательной передачи данных используется очень широко. Вот далеко не полный список применений:
- подключение мыши;
- подключение графопостроителей, сканеров, принтеров, дигитайзеров;
- связь двух компьютеров через порты последовательной передачи данных с использованием специального кабеля и таких программ, как FastWire II или Norton Commander;
- подключение модемов для передачи данных по телефонным линиям;
- подключение к сети персональных компьютеров;
Последовательная передача данных означает, что данные передаются по единственной линии. При этом биты байта данных передаются по очереди с использованием одного провода. Для синхронизации группе битов данных обычно предшествует специальный стартовый бит, после группы битов следуют бит проверки на четность и один или два стоповых бита. Иногда бит проверки на четность может отсутствовать.
Компьютер может быть оснащен одним или двумя портами последовательной передачи данных. Эти порты расположены либо на материнской плате, либо на отдельной плате, вставляемой в слоты расширения материнской платы.
Бывают также платы, содержащие четыре или восемь портов последовательной передачи данных. Их часто используют для подключения нескольких компьютеров или терминалов к одному, центральному компьютеру. Эти платы имеют название "мультипорт".
В основе последовательного порта передачи данных лежит микросхема INTEL 8250 или ее современные аналоги - INTEL 16450,16550,16550A. Эта микросхема является универсальным асинхронным приемопередатчиком (UART - Universal Asynchronous Receiver Transmitter). Микросхема содержит несколько внутренних регистров, доступных через команды ввода/вывода.
Микросхема 8250 содержит регистры передатчика и приемника данных. При передаче байта он записывается в буферный регистр передатчика, откуда затем переписывается в сдвиговый регистр передатчика. Байт "выдвигается" из сдвигового регистра по битам.
Программа имеет доступ только к буферным регистрам, копирование информации в сдвиговые регистры и процесс сдвига выполняется микросхемой UART автоматически.
К внешним устройствам последовательный асинхронный порт подключается через специальный разъем. Существует два стандарта на разъемы интерфейса RS-232-C, это DB-25 и DB-9. Первый имеет 25, а второй 9 выводов. Для работы приемно-адаптерного прибора используется 25-штырьковый разъем.
ТАБЛИЦА 1.
Разводка разъема DB25
Номер Назначение контакта Вход или
контакта (со стороны компьютера) выход
1 Защитное заземление (Frame Ground,FG) -
2 Передаваемые данные (Transmitted Data,TD) Выход
3 Принимаемые данные (Received Data,RD) Вход
4 Запрос для передачи (Request to send,RTS) Выход
5 Сброс для передачи (Clear to Send,CTS) Вход
6 Готовность данных (Data Set Ready,DSR) Вход
7 Сигнальное заземление (Signal Ground,SG) -
8 Детектор принимаемого с линии сигнала
(Data Carrier Detect,DCD) Вход
9-19 Не используются
20 Готовность выходных данных
(Data Terminal Ready,DTR) Выход
21 Не используется
22 Индикатор вызова (Ring Indicator,RI) Вход
23-25 Не используются
ТАБЛИЦА 2.
Разводка разъема DB9
Номер Назначение контакта Вход или
контакта (со стороны компьютера) выход
1 Детектор принимаемого с линии сигнала
(Data Carrier Detect, DCD) Вход
2 Принимаемые данные (Received Data, RD) Вход
3 Передаваемые данные (Transmitted Data, TD) Выход
4 Готовность выходных данных
(Data Terminal Ready, DTR) Выход
5 Сигнальное заземление (Signal Ground, SG) -
6 Готовность данных (Data Set Ready, DSR) Вход
7 Запрос для передачи (Request to send, RTS) Выход
8 Сброс для передачи (Clear to Send, CTS) Вход
9 Индикатор вызова (Ring Indicator,RI) Вход
Компьютер является терминальным устройством. Модем (адаптер ПС) является устройством связи.
Стандарт RS-232-C определяет возможность управления потоком только для полудуплексного соединения, при котором в каждый момент времени данные могут передаваться только в одну сторону.
Технические параметры интерфейса RS-232-C
При передаче данных на большие расстояния без использования специальной аппаратуры из-за помех, наводимых электромагнитными полями, возможно возникновение ошибок. Вследствие этого накладываются ограничения на длину соединительного кабеля между устройствами DTR-DTR и DTR-DCE.
Официальное ограничение по длине для соединительного кабеля по стандарту RS-232-C составляет 15,24 метра. Однако на практике это расстояние может быть значительно больше. Оно непосредственно зависит от скорости передачи данных.
110бод - 1524м / 914,4м
300бод - 1524м / 914,4м 1200бод - 914,4м / 914,4м 2400бод - 304,8м / 152,4м 4800бод - 304,8м / 76,2м 9600бод - 76,2м / 76,2м
Уровни напряжения на линиях разъема составляют для логического нуля -15..-3 вольта, для логической единицы +3..+15 вольт. Промежуток от -3 до +3 вольт соответствует неопределенному значению.
Порты асинхронного адаптера
На этапе инициализации системы, модуль POST BIOS тестирует имеющиеся асинхронные порты RS-232-C и инициализирует их. В зависимости от версии BIOS инициализируются первые два или четыре порта. Их базовые адреса располагаются в области данных BIOS, начиная с адреса 0000:0400h.
Первый адаптер COM1 имеет базовый адрес 3F8h и занимает диапазон адресов от 3F8h до 3FFh. Второй адаптер COM2 имеет базовый адрес 2F8h и занимает адреса 2F8h..2FFh.
Асинхронные адаптеры могут вырабатывать прерывания:
COM1, COM3 - IRQ4
COM2, COM4 - IRQ3
Имеется 7 основных регистров для управления портами:
а) Регистр данных
Регистр данных расположен непосредственно по базовому адресу порта RS-232-C и используется для обмена данными и для задания скорости обмена.
Для передачи данных в этот регистр необходимо записать передаваемый байт данных. После приема данных от внешнего устройства принятый байт можно прочитать из этого же регистра (см. Приложение 1).
В зависимости от состояния старшего бита управляющего регистра (расположенного по адресу base_adr+3, где base_adr соответствует базовому адресу порта RS-232-C),назначение этого регистра может изменяться. Если старший бит равен нулю, регистр
используется для записи передаваемых данных. Если же старший бит равен единице, регистр используется для ввода значения младшего байта делителя частоты тактового генератора. Изменяя содержимое делителя, можно изменять скорость передачи данных. Старший байт делителя записывается в регистр управления прерываниями по адресу base_adr+1.
Максимальная скорость обмена информацией, которую можно достичь при использовании асинхронного адаптера, достигает 115200 бод, что примерно соответствует 14 Кбайт в секунду.
б) Регистр управления прерываниями
Этот регистр используется либо для управления прерываниями от асинхронного адаптера, либо (после вывода в управляющий регистр байта с установленным в 1 старшим битом) для вывода значения старшего байта делителя частоты тактового генератора.
в) Регистр идентификации прерывания
Считывая его содержимое, программа может определить причину прерывания
г) Управляющий регистр
Управляющий регистр доступен по записи и чтению. Этот регистр управляет различными характеристиками UART: скоростью передачи данных, контролем четности, передачей сигнала BREAK, длиной передаваемых слов (символов).
д) Регистр управления модемом
Регистр управления модемом управляет состоянием выходных линий DTR, RTS и линий, специфических для модемов - OUT1 и OUT2, а также запуском диагностики при соединенных вместе входе и выходе асинхронного адаптера.
е) Регистр состояния линии
Регистр состояния линии определяет причину ошибок, которые могут возникнуть при передаче данных между компьютером и микросхемой UART.
ж) Регистр состояния модема
Регистр состояния модема определяет состояние управляющих сигналов, передаваемых модемом асинхронному порту компьютера.
Инициализация асинхронного адаптера
Первое, что должна сделать программа, работающая с асинхронным адаптером - установить формат и скорость передачи данных. После загрузки операционной системы для асинхронных адаптеров устанавливается скорость 2400 бод, не выполняется проверка на четность, используются один стоповый и восьмибитовая длина передаваемого символа. Можно изменить этот режим командой MS-DOS MODE.
Выполнив ввод из управляющего регистра, программа может получить текущий режим адаптера. Для установки нового режима измените нужные вам поля и запишите новый байт режима обратно в управляющий регистр.
Если вам надо задать новое значение скорости обмена данными, перед записью байта режима установите старший бит этого байта в 1, при этом регистр данных и управляющий регистр используются для задания скорости обмена. Затем последовательно двумя командами ввода загрузите делитель частоты тактового генератора. Младший байт запишите в регистр данных, а старший - в регистр управления прерываниями.
Перед началом работы необходимо также проинициализировать регистр управления прерываниями, даже если в вашей программе не используются прерывания от асинхронного адаптера (см. Приложение 1). Для этого сначала надо перевести регистр данных и регистр управления прерываниями в обычный режим, записав ноль в старший бит управляющего регистра. Затем можно устанавливать регистр управления прерываниями. Если прерывания вам не нужны, запишите в этот порт нулевое значение.
Электронная почта
Большой интерес представляет использование приемно-адаптерного прибора в локальной сети АСУ МЧС как средства обработки и дальнейшего анализа информации. Одной из возможностей сети является организация электронной почты. Если компьютер подключен к сети, и вы имеете специальное программное обеспечение для обмена почтой, имеется возможность отправлять через сеть письма (сообщения) другим пользователям сети (рис. 3).
Само письмо представляет собой обычный файл, содержащий текст письма и специальный заголовок, в котором указано, от кого письмо направлено, кому предназначено, какая тема письма и дата отправления. Автоматизировать данный процесс несложно при наличии программного обеспечения обмена данными по сети на компьютерах.
ЗАКЛЮЧЕНИЕ
В результате разработки приемно-адаптерного прибора пожарной мною проанализирован отечественный и зарубежный опыт раннего обнаружения пожара при помощи автоматических систем пожарной сигнализации, основные технические решения в этой области, перспективы развития, пути оптимизации и повышения надежности работы систем пожарной сигнализации. В данной работе в качестве одного из вариантов решения проблемы раннего обнаружения пожара в рамках концепции создания АСУ МЧС Беларуси предложен проект приемно-адаптерного прибора пожарной сигнализации.
При его использовании достигается:
1). Повышение эффективности использования установок автоматического пожаротушения и сигнализации;
2). Сокращение времени реагирования оперативного персонала на экстремальную информацию;
3). Ведение бланка протоколов событий;
4). Улучшение социальных условий труда.
На программном уровне обеспечивается документирование информации о загораниях и техническом состоянии системы пожарной сигнализации, ведется банк протоколов текущих событий, осуществляется дистанционное управление приемно-контрольным прибором, и пуском АУП. Возможна автоматизация контроля состояния установок автоматического пожаротушения. Адаптер прост и удобен в эксплуатации, в определенной степени сможет составить конкуренцию зарубежным приборам. Необходимо глубже проработать вопрос об универсальности подключения прибора к различным типам ПКП.
Несомненно, его применение на объектах хозяйствования даст положительный эффект в улучшении информативности в системе МЧС, а следовательно и повышении пожарной безопасности. Массовое внедрение системы в жилых домах, квартирах, дачах, общежитиях, гостиницах, промышленных предприятиях и других помещениях с постоянным проживанием людей и пребыванием персонала позволит существенно сократить число погибающих (уменьшение времени обнаружения, прибытия), а в сочетании с комплексом других профилактических мер либо исключить их, либо свести к минимуму.
ЛИТЕРАТУРА
1. ГОСТ 12.1.004-91. Пожарная безопасность. Общие требования.
2. ГОСТ 12.3.046 Установки пожаротушения автоматические. Общие требования.
3. Касаткин А.И. Профессиональное программирование на языке СИ. Управление ресурсами: Справочное пособие. – Мн.: Выш. Шк., 1992.
4. Малешин В.Г. Аппаратно-программные комплексы систем автоматического контроля и управления процессами пожаротушения, пожарной сигнализации//Пожарная безопасность. Материалы первой республиканской научно-практической конференции, -Мн.; 1994г.
5. Нилов В.А. Технические средства охранно-пожарной сигнализации.; НОУ «Такир», -М., 1998г.
6. Панель охранно-пожарная «Control Equipment». Техническое описание.
7. Пожарная безопасность. Специализированный каталог. – М.: «Гротек», 2000г.
8. Пожарная сигнализация. Современные устройства пожарной сигнализации. Проектирование систем безопасности на основе компьютерных технологий.; «Гротеск», -М, 1998г.
9. Пожарно-охранный извещатель «Apollo XP95». Техническое описание.
10. Пульт приемно-контрольный ППК-2. Паспорт еу2.407.003 ПС.
11. Руководство по архитектуре IBM PC/AT. под ред. М.Л.Махрхасина.; ООО «Консул», -Мн., 1993г.
12. СНиП 2.04.09-84 Пожарная автоматика.
13. Собурь В.А. Установки автоматической пожарной сигнализации: Справочник. Вып. 1-й – М.: Спецтехника, 1999.
14. Современные средства пожарной и пожарно-охранной сигнализации.; -М, 1990г.
15. СТБ 11.16.01-98 Системы пожарной сигнализации.
16. Юлин В.А., Булатова И.Р. Приглашение к СИ. – Мн.: Выш. Шк.,
1990.
ПРИЛОЖЕНИЕ 1// ======================================================================
// = Базовая программа работы с последовательным портом COMi.
// = Обмен с использованием прерываний
// ======================================================================
#include <conio.h>
#include <iostream.h>
#include <stdio.h>
#include <dos.h>
#include <stdlib.h>
#include <math.h>
#include <string.h>
#include <process.h>
#define COM 2 // задается номер порта 1-COMi; 2-COM2
// дальнейший код справедлив для машин класса AT
#define INTRS 13-COM
#define m_speed 2 // множитель задает скорость передачи
// 1-9600
// 2-19200 и т.д.
// 6-57600
// 12-115200
#define cbuf 2000 // размер буфера данных
#ifdef __cplusplus
#define __CPPARGS ...
#else
#define __CPPARGS
#endif
#define rgmask 16/COM //маска в регистре маски прерываний
#define byte_sync 33
#define byte_pream 85
int IMR=0x21; // регистр маски прерываний
int base,IER,IIR,LCR,LSR,MSR,MCR,LSB,MSB; // регистры контроллера
// последовательного интерфейса
char fl_d=0; // флаг устанавливается если принят байт
// если=0 то буфер пуст
char overb=0; // флаг устанавливается если буфер переполнен
char area[cbuf]; // буфер данных
int head=0,teil=0; // указатели головы и хвоста
char count0=0; // help count
char exiterr=0; //номер ошибки при приеме
// exiterr=0 - ошибок нет
// exiterr=1 - ошибка приема
// exiterr=2 - ошибка по тайм-ауту
// exiterr=3 - cбой в приеме: передано неверное
//число байт
// exiterr=4 - сбой при приeмe или переполнение
//буфера
char errcode=0; // код ошибки
void interrupt obrcom(__CPPARGS); /* interrupt prototype */
void interrupt (*oldfunc)(__CPPARGS); /* interrupt function pointer */
void nevid(void); //делает курсор невидимым
void initrs(void); //инициализация COM порта
void init(void); //инициализация переменных
void exitp(void); //!!! необходимо вызывать перед выходом из программы
int trans(char); //передача байта через СОМ порт
void deside(void); //обработка данных
void signal(void); //звуковой сигнал
void outinfo(void); //вывод информации на экран
void reseterr(void); //сброс ошибок RS232
void instvect(void); //Замена вектора прерываний COMi
void restorevect(void); //Восстановление старого обработчика C
void incteil(void); //Увеличение указателя хвоста
void err(char *); //Выход по ошибке
void Transb(char); // посылка байта с сервисом
int Transb_hiden(char); // Не выдает сообщения об ошибках
void clearbof(void); // очистка буфера данных
void definit(void); // определяет работоспособность с той стороны
void clearbofkey(void); // очистка буфера клавиатуры
void pusk(void);
struct k_win // координаты окна
{ int x0,y0,x1,y1,lastx,lasty; } wmain,wmes;
//=======================
void nevid(void) //невидимый курсор
{ asm{ push cx
push ax
mov ah,01
mov ch,20H
mov cl,0
int 10H
pop ax
pop cx
}
}
// =========== инициализация переменных ====================
void init(void)
{ int i;
wmain.x0=1; wmain.y0=1; wmain.x1=80; wmain.y1=16;
wmes.x0=1; wmes.y0=wmain.y1+2; wmes.x1=80; wmes.y1=25;
wmain.lastx=wmain.lasty=wmes.lastx=wmes.lasty=1;
exiterr=0;
}
//============ инициализация последовательного порта ===========
void initrs(void)
{
asm { push es
push bx
mov bx,COM
dec bx
shl bx,1
mov ax,40H //вычислить базовый адрес
mov es,ax
mov dx,es:[bx]
mov base,dx
pop bx
pop es
}
IER=base+1; IIR=base+2; LCR=base+3; MCR=base+4; LSR=base+5;
MSR=base+6; LSB=base; MSB=base+1;
disable();
instvect(); // установить обработчик
outportb(IMR,(inportb(IMR)&(255-rgmask))); // разрешить прерывание
outportb(IER,5); //разрешить прерывания по доступности данных и по ошибке
outportb(LCR,(inportb(LCR)|0x80)); // доступ к делителю частоты
outportb(LSB,12/m_speed); // 1843200/(x*16)=y бит/c
outportb(MSB,0);
outportb(LCR,27); // установить параметры :
// длина слова обмена 8 бит + контроль четности + DLAB=0
outportb(MCR,(8)); // ;rts=0 ;dtr=0
// сбросить условия возникновения прерываний
//outportb(base,0);
inportb(base);
inportb(MSR);
inportb(LSR);
enable();
}
//=========== звуковой сигнал ==================
void signal(void)
{ sound(700); delay(200); nosound();
}
// чтение LSR - сброс ошибок
void reseterr(void)
{
inportb(LSR);
}
char foi=0;
// ================= передача байта 'dm' в канал связи ==========
int trans(char dm)
{
inlsr:
asm {
mov dx,base
add dx,5
in al,dx //прочитать LSR
test al,00011110B // ошибка ?
jnz toer
test al,1
jnz indata
test al,32 // Передатчик освобожден ?
jz inlsr
sub dx,5
mov al,dm
out dx,al
}
return 0;
toer: reseterr(); return -1;
indata: return 1;
}
void instvect(void) // замена вектора прерывания
{
oldfunc = _dos_getvect(INTRS);
_dos_setvect(INTRS,obrcom);
}
// восстановление старого вектора
void restorevect(void)
{ /* restore to original interrupt routine */
_dos_setvect(INTRS,oldfunc);
}
char d;
//=========== прием данных не используя прерываний =============
int priem(void)
{ char clt; int i=0;
do { clt=inportb(LSR);
if ((clt&30)!=0) { errcode=clt; reseterr(); return -1; }
// байт принят ?
if (clt&1) { d=inportb(base); return 0; }
i++;
}
while (i!=0);
return 1;
}
// новый обработчик прерывания от COMi
void interrupt obrcom(__CPPARGS)
{ char p;
p=((inportb(IIR)>>1)&3);
switch (p) // определить тип прерывания
{ case 0: // изменение линии состояния устройства с той стороны
inportb(MSR); break;
case 1: // прерывание от передатчика
break;
case 3: // по ошибке
errcode=inportb(LSR); inportb(base); break;
case 2: // доступность данных
{ area[head++]=inportb(base); //записать байт в буфер
if (head==cbuf) head=0;
if (head==teil) overb=1; // отметить если голова догнала
// хвост
fl_d=1; // отметить заполнение буфера
break;
};
default: // неизвестное прерывание
errcode=128;
}
enfin: // завершить прерывание
asm { mov al,20H
out 20H,al
}
}
// очищает буфер данных
void clearbof(void)
{ while (fl_d) incteil(); }
void clearbofkey(void)
{ while (kbhit()) getch(); }
// Выход по ошибке
void err(char *mes)
{
exitp(); clearbofkey();
printf("%s\n",mes); exit(0);
}
// Увеличение указателя хвоста
void incteil(void)
{ if (teil==(cbuf-1)) teil=0; else teil++;
asm cli;
if (head==teil) fl_d=0; // если буфер пуст
asm sti;
}
// посылка байта с ожиданием и с очищением буфера
// от байта который был послан
void Transb(char CC)
{ int li,opf,hp;
li=1; opf=0;
do // цикл посылки и ожидания освобождения передатчика
{ hp=trans(CC);
switch (hp)
{ case 0: opf=1; break;
case 1: li++; hp=inportb(base); break;
case -1: { printf("Ошибка при передаче\n"); reseterr(); break;}
}
if (li==0) printf("Тайм-аут при передаче\n");
}
while (!opf);
}
// посылка байта с ожиданием и с очищением буфера
// от байта который был послан
// Не выдает сообщения об ошибках
int Transb_hiden(char CC)
{ int li,opf,hp;
li=0; opf=0;
do // цикл посылки и ожидания освобождения передатчика
{ hp=trans(CC);
switch (hp)
{ case 0: opf=1; break;
case 1: { //доступность данных
li++;
inportb(base);
reseterr;
break;
};
case -1: return -1; //err("Ошибка при передаче"); break;
}
if (li==100) return 1; //err("Тайм-аут при передаче");
}
while (opf==0);
// цикл ожидания приема байта - того что был послан
li=0;
while (fl_d==0)
{
if (++li==0) return 2; //err("Тайм-аут Не принято ни 1 символа");
}
if (area[teil]!=CC) return 3; //err("Не принято то что послано");
incteil();
return 0;
}
void priembig(void)
{ int a;
a=priem();
switch (a)
{ case 0: printf("Принято %d\n",d); break;
case 1: printf("Тайм-аут\n"); break;
case -1: printf("ErorCode=%d\n",errcode); inportb(base);
}
}
#define pi 3.1416
// Возвращает главное значение ARCTAN [0..2*pi]
double mARCTAN(double z_sin,double z_cos)
{ double ang;
if (z_sin==0)
{ if (z_cos<0) return (pi/2.0);
else return (1.5*pi);
}
ang=-atan(z_cos/z_sin);
if (z_sin<0) ang+=pi;
if (ang<0) ang+=2*pi;
return ang;
}
char getsym(void)
{ char a;
a=area[teil]; incteil();
return a;
}
//---------------------------------
void exitp(void) //!!! необходимо вызывать перед выходом из программы
{
disable();
reseterr();
outportb(MCR,8); //rts=0 out2=1
restorevect(); // восстановить обработчик
outportb(IMR,(inportb(IMR)|rgmask)); // запретить прерывание
enable();
}
int get_size(void) // возвращает число байт в буфере
{ int i;
if ( (i=(head-teil))<0 ) i+=cbuf;
return i;
}
//===== отобразить информацию ==================
void outinfo(void)
{ char a; char str1[40];
while ( (get_size()>=1) & (!kbhit()) )
{
printf(" %X",(int)getsym());
if (errcode!=0) { printf("ErrCode=%d\n",errcode);
errcode=0;
}
}
}
struct dostime_t w,w1;
double at,bt;
void fix_time(void) // фиксирует системное время во внутреней переменной
{
_dos_gettime(&w);
at=(double)(w.hour*360000+w.minute*6000+w.second*100+(double)w.hsecond);
}
double get_time(void) // возвращает время прошедшее с момента последнего
// фиксирования
{
_dos_gettime(&w1);
bt=(double)(w1.hour*360000+w1.minute*6000+w1.second*100+(double)w1.hsecond);
bt-=at;
return bt;}
int wait(int x)
{ fix_time();
while (get_size()<x)
{ if (get_time()>(double)(x*4)) return 0;
}
return 1;}
#define Esc 27
#define sym_S 83
#define sym_W 87
#define sym_Z 90
#define sym_A 65
//====================================
void main(void)
{ char hpl,hph,ch; char mas[100];
int j,i,jh;
long li;
int cos,sin,sh,am;
double sr;
// printf("my_dt=%7.4f \n",(mARCTAN(14927.0,-28113.0)/pi*2000));
// return ;
init(); initrs();
clrscr();
Transb(85);
Transb(6);
Transb(0);
while (!kbhit()) // { Transb(85); delay(100); }
outinfo();
me:
errcode=0;
clearbofkey();
exitp();
}
Аннотация научной работыДевиз: "Не отступать и не сдаваться!"
1. Приемно-адаптерный прибор пожарной сигнализации.
2. УДК 614.842.4
3. КИИ МЧС Республики Беларусь.
4. 2000 год.
5. Объём работы: 44 с.
6. Количество приложений: 3
7. Количество иллюстраций: 3
8. Количество таблиц: 2
9. Источников литературы: 16.
Характеристика работы.
1. Цель: Обеспечение возможности автоматизированной компьютерной обработки информации систем пожарной сигнализации.
2. Методы: анализ технических решений, опытно-конструкторская проработка, программирование.
Основные результаты: разработан проект конструкции приемно-адаптерного прибора пожарной сигнализации и программа информационного обмена.
Наличие документа об использовании научных результатов: да.
подпись автора ______________
СВЕДЕНИЯоб авторе и научном руководителе работы,
представленной под девизом: «Не отступать и не сдаваться!»
АВТОР НАУЧНЫЙ РУКОВОДИТЕЛЬ 1.Хегстрем 2.Сергей 3.Сергеевич 4. 4 5. 220118, Республика Беларусь, г. Минск, улица Машиностроителей, 25. | 1.Мисюкевич 2.Николай 3.Стефанович 4.Командно-инженерный институт Министерства по чрезвычайным ситуациям Республики Беларусь 5. 05 6. 1 7. 2 8. 220075, г. Минск, улица А. Бачило 5, кв. 68 |
Председатель конкурсной комиссии ______________ Научный руководитель ______________
Автор работы ______________
Сведения о научной работе1. Приемно-адаптерный прибор пожарной сигнализации.
2. 45
3. УДК 614.842.
4. 2
5. нет.
6. да.
7. нет.
8. нет.
9. Пожарная автоматика. Пожарная сигнализация. Приемно-контрольное оборужование.
Автор _____________Научный руководитель _____________
... технологии широкополосного доступа - по электросетям. Было разработано оборудование PLC первого и второго поколений. Достигнутая предельная скорость передачи данных не превышала 10-14 Мб/с. Реальная же скорость передачи данных в тестовых сетях PLC с применением этого оборудования отличалась на порядок и составляла 1-2 Мб/с. Кроме этого, абонентское оборудование PLC имело сравнительно высокую ...
0 комментариев