Банк рефератов содержит более 364 тысяч рефератов, курсовых и дипломных работ, шпаргалок и докладов по различным дисциплинам: истории, психологии, экономике, менеджменту, философии, праву, экологии. А также изложения, сочинения по литературе, отчеты по практике, топики по английскому.
Полнотекстовый поиск
Всего работ:
364150
Теги названий
Разделы
Авиация и космонавтика (304)
Административное право (123)
Арбитражный процесс (23)
Архитектура (113)
Астрология (4)
Астрономия (4814)
Банковское дело (5227)
Безопасность жизнедеятельности (2616)
Биографии (3423)
Биология (4214)
Биология и химия (1518)
Биржевое дело (68)
Ботаника и сельское хоз-во (2836)
Бухгалтерский учет и аудит (8269)
Валютные отношения (50)
Ветеринария (50)
Военная кафедра (762)
ГДЗ (2)
География (5275)
Геодезия (30)
Геология (1222)
Геополитика (43)
Государство и право (20403)
Гражданское право и процесс (465)
Делопроизводство (19)
Деньги и кредит (108)
ЕГЭ (173)
Естествознание (96)
Журналистика (899)
ЗНО (54)
Зоология (34)
Издательское дело и полиграфия (476)
Инвестиции (106)
Иностранный язык (62792)
Информатика (3562)
Информатика, программирование (6444)
Исторические личности (2165)
История (21320)
История техники (766)
Кибернетика (64)
Коммуникации и связь (3145)
Компьютерные науки (60)
Косметология (17)
Краеведение и этнография (588)
Краткое содержание произведений (1000)
Криминалистика (106)
Криминология (48)
Криптология (3)
Кулинария (1167)
Культура и искусство (8485)
Культурология (537)
Литература : зарубежная (2044)
Литература и русский язык (11657)
Логика (532)
Логистика (21)
Маркетинг (7985)
Математика (3721)
Медицина, здоровье (10549)
Медицинские науки (88)
Международное публичное право (58)
Международное частное право (36)
Международные отношения (2257)
Менеджмент (12491)
Металлургия (91)
Москвоведение (797)
Музыка (1338)
Муниципальное право (24)
Налоги, налогообложение (214)
Наука и техника (1141)
Начертательная геометрия (3)
Оккультизм и уфология (8)
Остальные рефераты (21697)
Педагогика (7850)
Политология (3801)
Право (682)
Право, юриспруденция (2881)
Предпринимательство (475)
Прикладные науки (1)
Промышленность, производство (7100)
Психология (8694)
психология, педагогика (4121)
Радиоэлектроника (443)
Реклама (952)
Религия и мифология (2967)
Риторика (23)
Сексология (748)
Социология (4876)
Статистика (95)
Страхование (107)
Строительные науки (7)
Строительство (2004)
Схемотехника (15)
Таможенная система (663)
Теория государства и права (240)
Теория организации (39)
Теплотехника (25)
Технология (624)
Товароведение (16)
Транспорт (2652)
Трудовое право (136)
Туризм (90)
Уголовное право и процесс (406)
Управление (95)
Управленческие науки (24)
Физика (3463)
Физкультура и спорт (4482)
Философия (7216)
Финансовые науки (4592)
Финансы (5386)
Фотография (3)
Химия (2244)
Хозяйственное право (23)
Цифровые устройства (29)
Экологическое право (35)
Экология (4517)
Экономика (20645)
Экономико-математическое моделирование (666)
Экономическая география (119)
Экономическая теория (2573)
Этика (889)
Юриспруденция (288)
Языковедение (148)
Языкознание, филология (1140)

Курсовая работа: Верифікація послідовного порту

Название: Верифікація послідовного порту
Раздел: Рефераты по информатике, программированию
Тип: курсовая работа Добавлен 02:27:06 03 июня 2010 Похожие работы
Просмотров: 20 Комментариев: 2 Оценило: 0 человек Средний балл: 0 Оценка: неизвестно     Скачать

Верифікація ПОСЛІДОВНОГО ПОРТА

(курсова робота)


АНОТАЦІЯ

Опис програми містить загальний опис алгоритмів головної програми та процедур запису і зчитування повідомлень на рівні блок-схем, а також більш детальний опис розробленої програми на рівні програмного коду.


ЗМІСТ

ВСТУП

1. Опис процедур запису і зчитування повідомлень

1.1 Опис процедури запису повідомлення Write_Message

1.2 Опис процедури зчитування повідомлення Read_Message

2. Опис процедури відображення стану регістрів

3. ОПИС ЕКРАННИХ ФОРМ ПРОГРАМИ

Висновки

Список використаної літератури


ВСТУП

Метою розробленої програми є ознайомлення з принципами і форматами прийому та передачі даних через послідовний порт. Оскільки аналізувати стан бітів даних при реальній передачі через послідовний порт є досить складною задачею, тому доцільно використати програмне моделювання обміну даними.

Програма створена в середовищі Delphi і дозволяє моделювати процеси запису та зчитування даних, при цьому процес обміну інформацією відбувається не з послідовним портом, а з файлами. Процедура виводу даних повинна записувати інформацію у текстовий файл, а процедура вводу – зчитувати дані з файлу.


1. Опис процедур запису і зчитування повідомлень

1.1 Опис процедури запису повідомлення Write_Message

Розглянемо блок – схему алгоритму процедури Write_Message (рис. 1.1) для кодування повідомлень. Після зчитування символів з форми визначаються їх коди (масив mCod_bit). Далі коди символів mCod_bit перетворюються у масив бітів mBit. Значення кожного біту з масиву mBit перетворюються в аналогову напругу сигналу mU, а значення напруги записуються в текстовий файл.

Рис.1.1. Блок-схема процедури Write_Message


Розглянемо процес запису повідомлення у файл на рівні програмного коду. Спочатку зчитується з форми текст повідомлення

Str:=Edit1.Text;

та опції СОМ-порта

case Form5.RadioGroup2.ItemIndex of //Визначення довжини слова

0:DovjSlova:=7;

1:DovjSlova:=8;

end;

case Form5.RadioGroup3.ItemIndex of //Визначення к-сті стопових бітів

0:KilStopBit:=1;

1:KilStopBit:=2;

end;

Далі в циклі знаходяться коди розміром 1 байт (цілі числа від 0 до 255) для всіх символів, які записуються у масив mCod

for i:=1 to length(Str) do

begin

mCod[i]:=ord(Str[i]);

Edit3.Text:=Edit3.Text+IntToStr(mCod[i])+' ';

end;

Отримані коди символів відображаються на формі в компоненті Edit3. Код кожного символа перетворюється у двійкове представлення за допомогою процедури наступного коду програми, який перетворює байт у масив з 8 біт. Отримане бітове представлення записується у масив mCod_bit.

repeat

n:=Data div 2;

mCod_bit[i,ii]:=Data mod 2;

Data:=n;

dec(ii);

until Data<2;

mCod_bit[i,ii]:=Data;

Найскладніша частина процедури – перетворити бітове представлення символів у послідовне повідомлення. Згідно з форматом послідовної передачі даних перед кожним байтом даних потрібно вставити біти паузи (1-10 бітів) і старт-біт, а після бітів даних (кодів символів з масиву mCod_bit) – біт контролю і стоп-біт. Довжина інформаційного слова, кількість стопових бітів, парність та швидкість передачі даних встановлюється у пункті меню “Опції СОМ-порта”(Рис. 1.2).

Рис. 1.2. Форма опцій СОМ-порта

fori:=1 tolength(Str) do

begin

iii:=random(9)+1; //Діапазон бітів паузи: 1-10

ii:=iii+DovjSlova;

Data:=mCod[i];

Parnist:=0;

repeat//Перетворення у 2-ву СЧ

n:=Data div 2;

mCod_bit[i,ii]:=Data mod 2;

if mCod_bit[i,ii]=1 then //Підрахунок одиниць

Parnist:=Parnist+1;

Data:=n;

dec(ii);

until Data<2;

mCod_bit[i,ii]:=Data;

if mCod_bit[i,ii]=1 then //Підрахунок одиниць

Parnist:=Parnist+1;

n:=iii+DovjSlova+KilStopBit;

if Form5.RadioGroup5.ItemIndex<>0 then //Якщо є біт парності,то n+1

inc(n);

ii:=0;

repeat

if ii<iii then

mCod_bit[i,ii]:=1; //Запис бітів паузи

if ii=iii then

mCod_bit[i,ii]:=0; //Запис біту старту

if ii=(n-KilStopBit) then //Запис біту парності

begin

case Form5.RadioGroup5.ItemIndex of

1:begin //непарна

if (Parnist mod 2)<>0 then

mCod_bit[i,ii]:=0

else mCod_bit[i,ii]:=1;

end;

2:begin //парна

if (Parnist mod 2)=0 then

mCod_bit[i,ii]:=0

else mCod_bit[i,ii]:=1;

end;

3:mCod_bit[i,ii]:=1; //постійно 1

4:mCod_bit[i,ii]:=0; //постійно 0

end;

end;

if ii=(n-KilStopBit)+1 then //Запис бітів стопу

begin

for j:=1 to KilStopBit do

begin

mCod_bit[i,ii]:=1;

inc(ii);

end;

end;

inc(ii);

until ii>n;

end;

Відповідно до рівнів напруги для логічних 0 та 1 на основі масиву mBit потрібно отримати масив напруг mU та побудувати графік залежності напруги від номеру біту на основі масиву mU (компонент DBChart). Для моделювання шумової складової напруги використано функцію Random, наприклад: mU[n]:=8.5+(Random-0.5)*2.

n:=1;

Str2:='';

Memo1.Clear;

for i:=1 to length(Str) do

begin

iii:=21;

repeat

dec(iii);

if mCod_bit[i,iii]=1 then

break;

until 1=2;

for ii:=0 to iii do

begin

Str2:=Str2+IntToStr(mCod_bit[i,ii]); //Запис до Str2 масиву mCod_bit

if mCod_bit[i,ii]=0 then

begin

mU[n]:=8.5+(Random-0.5)*2;

inc(n);

end

else begin

mU[n]:=-8.5+(Random-0.5)*2;

inc(n);

end;

end;

end;

Отримана послідовність бітів відображається на формі

Memo1.Lines.Add(Str2); //Запис у поле mBit

Масив напруг відображається у вигляді діаграми і записується у файл.

DBChart1.Series[0].Clear; //Очисткаграфіка

for i:=1 to n-1 do //Побудоваграфіка

DBChart1.Series[0].Add(mU[i],IntToStr(i),clRed);

if SaveDialog1.Execute then //Записуфайл

begin

AssignFile(f,SaveDialog1.FileName);

Rewrite(f);

for i:=1 to n-1 do

writeln(f,mU[i]:3:1);

CloseFile(f);

end;


Рис. 1.3.Форма організації обміну даними через послідовний порт

1.2 Опис процедури зчитування повідомлення Read_Message

Розглянемо процедуру Read_Message для декодування повідомлень (зчитування з файлу). Спочатку значення аналогової напруги сигналу mU зчитується з текстового файлу і відображаються у вигляді діаграми (рис.4). Значення аналогової напруги сигналу mU перетворюються у масив бітів mBit, а на основі масиву бітів визначаються коди символів mCod_bit. За кодами символів визначаються самі символи, тобто текст повідомлення.

Розглянемо процес зчитування повідомлення з файлу на рівні програмного коду. Спочатку потрібно відкрити один з попередньо створених файлів і зчитати значення напруги в масив mU. На основі масиву mU будується графік залежності напруги від номеру біту.

Відповідно до рівнів напруги для логічних 0 та 1 на основі масиву напруг mU отримується масив логічних значень mBit.

for i:=1 to n-1 do

begin

if (mU[i]>=5)and(mU[i]<=12) then

mBit[i-1]:=0;

if (mU[i]<=-5)and(mU[i]>=-12) then

mBit[i-1]:=1;

Str2:=Str2+FloatToStr(mBit[i-1]);

end;

Значення елементів масиву mBit відображаються на формі:

Memo1.Lines.Add(Str2);

Згідно з форматом послідовної передачі даних декодуються значення масиву mBit, тобто послідовність бітів розділяється на байти, видаляються службові біти, а значення бітів даних записуються в масив mCod_bit. Для цього проводиться послідовний аналіз усіх бітів масиву mBit. Згідно з фор-матом передачі даних послідовність бітів починається з паузи, після якої слідує старт-біт. Закінчується послідовність бітів даних бітом контролю і стоп-бітом.

j:=1;

for i:=1 to KilSymv do //Відокремлення службових бітів

begin

repeat

if Str2[j]='0' then //Після 0 йдуть інформаційні символи

begin

for iii:=0 to DovjSlova-1 do

begin

inc(j);

mCod_bit[i,iii]:=StrToInt(Str2[j]);

end;

j:=j+KilStopBit; //Стрибок на біт паузи наступного повідомлення

if Form5.RadioGroup5.ItemIndex<>0 then

inc(j);

break;

end

else inc(j);

until 1=2;

end;

На основі бітів даних (масив mCod_bit) для кожного символу отримується його код (масив mCod), перетворенням набору з 8 біт у десяткове число. Коди символів відображаються на формі.

fori:=1 toKilSymvdo//Перетворення у 10-ве число

begin

mCod[i]:=0;

for ii:=0 to DovjSlova-1 do

mCod[i]:=mCod[i]+mCod_bit[i,ii]*trunc(power(2,(DovjSlova-1)-ii));

end;

Edit3.Clear;

for i:=1 to KilSymv do

Edit3.Text:=Edit3.Text+IntToStr(mCod[i])+' '; //Запис коду символів у поле mCod

Значення байтів даних (код символу з mCod) перетворюються у сим-воли повідомлення (Message_In – зчитування з файлу), яке й відображається на формі.

fori:=1 toKilSymvdo//Перетворення коду у символ

begin

Str2:=chr(mCod[i]);

Str:=Str+Str2;

end;

Edit2.Text:=Str; //Запис у поле Message_In


Рис. 1.4. Блок-схема процедури Read_Message


2. Опис процедури відображення стану регістрів


Рис. 2.1. Блок-схема процедури відображення стану регістрів


Продовження рис. 2.1.

Роботу процедури показу стану регістрів можна прослідкувати використовуючи, наприклад, регістр формату даних.

За допомогою цього регістра можна сконфігурувати параметри СОМ-порта, а саме: дозвіл на встановлення швидкості, паритет, довжину інформаційного слова та кількість біт паузи.

Даний регістр буде змінювати числове значення своїх бітів тоді, коли будуть конфігуруватися опції СОМ-порта. Наприклад, нехай в регістрі буде записано число 11011010. В даному випадку нас цікавлять останні два біти. Зараз вони рівні 10. Це означає, що довжина інформаційного повідомлення рівна 7. Вибравши довжину слова рівною 8 біт, ми тим самим змінимо значення регістру на наступне: 11011011.


3. ОПИС ЕКРАННИХ ФОРМ ПРОГРАМИ

Рис. 3.1. Комп'ютерне моделювання роботи послідовного порта

На рис. 3.1. показана головна форма програми. У меню даної екранної форми є лише один пункт, обробник якого викликає та показує інформацію про розробника даної програми.

Рис. 3.2. Інформація про автора

На головній формі можна здійснити виклик двох обробників різних за суттю операцій. TForm1.Button1Click – викличе метод Form4.Show, тобто здійснить виклик форми “Організація обміну даними через послідовний порт”. Її вигляд можна побачити на рис. 1.3 TForm1.Button2Click – застосує метод Form2.Show, для здійснення показу інформативного відносно користувача зображення, яке матиме наступний вигляд:


Рис. 3.3. Форма блок-схеми UART

На представленій екранній формі (рис. 3.3.) також є меню. Але воно вже на відміну від попередньої виконуватиме дві дії:

1) покаже довідку відносно користування блок-схемою (рис. 3.5.);

2) здійснить вихід.

Ну а зараз потрібно згадати про рис. 1.3, а точніше трошки розтлумачити принцип його дії.

Основною задачею даної програми є емулювання роботи послідовного порта. За допомогою цього вікна, виклик якого можна здійснити на головній формі, можна передати чи прийняти інформаційне повідомлення. Принцип прийому та передачі викладений вище.

Меню складається з трьох пунктів:

1) опції СОМ-порта(викликає вікно конфігурування порта(рис. 1.2));

2) довідка(показує довідку по коректній експлуатації даної форми екрану(рис. 3.4.));

3) закрити(виконує закриття активного вікна).

Рис. 3.4. Довідка по експлуатації форми “Організація обміну даними через послідовний порт”

Рис. 3.5. Довідка по формі блок-схеми UART


Висновки

В описі програми розглянуто алгоритм процедур запису і зчитування повідомлень на рівні блок-схеми та на рівні програмного коду. Програма має простий інтерфейс, але виконує складні задачі. Однією з її головних задач є запис/зчитування даних через послідовний порт. Дивлячись на текст програми, можна сказати, що послідовний порт має доволі складний формат даних, які передаються/приймаються, але все ж таки плюси СОМ-порта дещо виділяють його з-поміж інших і тому він є досить поширеним.


Список використаної літератури

1. Гофман В.Э., Хомоненко А.Д.Delphi 6. СПб.: БХВ-Петербург, 2001. – 1135 с.

2. Агуров П.В. Последовательные интерфейсы ПК. Практика программирования. –СПб.: БХВ-Петербург, 2004.– 496с.

Оценить/Добавить комментарий
Имя
Оценка
Комментарии:
Где скачать еще рефератов? Здесь: letsdoit777.blogspot.com
Евгений06:42:21 19 марта 2016
Кто еще хочет зарабатывать от 9000 рублей в день "Чистых Денег"? Узнайте как: business1777.blogspot.com ! Cпециально для студентов!
16:03:26 25 ноября 2015

Работы, похожие на Курсовая работа: Верифікація послідовного порту

Назад
Меню
Главная
Рефераты
Благодарности
Опрос
Станете ли вы заказывать работу за деньги, если не найдете ее в Интернете?

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



Результаты(151115)
Комментарии (1843)
Copyright © 2005-2016 BestReferat.ru bestreferat@mail.ru       реклама на сайте

Рейтинг@Mail.ru