Верифікація послідовного порту
Верифікація ПОСЛІДОВНОГО ПОРТА
(курсова робота)
АНОТАЦІЯ
Опис програми містить загальний опис алгоритмів головної програми та процедур запису і зчитування повідомлень на рівні блок-схем, а також більш детальний опис розробленої програми на рівні програмного коду.
ЗМІСТ
ВСТУП
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. Форма опцій СОМ-порта
for i:=1 to length(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 біт у десяткове число. Коди символів відображаються на формі.
for i:=1 to KilSymv do //Перетворення у 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 – зчитування з файлу), яке й відображається на формі.
for i:=1 to KilSymv do //Перетворення коду у символ
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.) також є меню. Але воно вже на відміну від попередньої виконуватиме дві дії:
покаже довідку відносно користування блок-схемою (рис. 3.5.);
здійснить вихід.
Ну а зараз потрібно згадати про рис. 1.3, а точніше трошки розтлумачити принцип його дії.
Основною задачею даної програми є емулювання роботи послідовного порта. За допомогою цього вікна, виклик якого можна здійснити на головній формі, можна передати чи прийняти інформаційне повідомлення. Принцип прийому та передачі викладений вище.
Меню складається з трьох пунктів:
опції СОМ-порта(викликає вікно конфігурування порта(рис. 1.2));
довідка(показує довідку по коректній експлуатації даної форми екрану(рис. 3.4.));
закрити(виконує закриття активного вікна).
Рис. 3.4. Довідка по експлуатації форми “Організація обміну даними через послідовний порт”
Рис. 3.5. Довідка по формі блок-схеми UART
Висновки
В описі програми розглянуто алгоритм процедур запису і зчитування повідомлень на рівні блок-схеми та на рівні програмного коду. Програма має простий інтерфейс, але виконує складні задачі. Однією з її головних задач є запис/зчитування даних через послідовний порт. Дивлячись на текст програми, можна сказати, що послідовний порт має доволі складний формат даних, які передаються/приймаються, але все ж таки плюси СОМ-порта дещо виділяють його з-поміж інших і тому він є досить поширеним.
Список використаної літератури
Гофман В.Э., Хомоненко А.Д.Delphi 6. СПб.: БХВ-Петербург, 2001. – 1135 с.
Агуров П.В. Последовательные интерфейсы ПК. Практика программирования. –СПб.: БХВ-Петербург, 2004.– 496 с.