M[i+10]=(Pdop-Pls), i=i+1;
27) Выводим Poo, Pno, Pls, lgPls, переходим к шагу 22;
28) i=17;
29) Если i<=31, то Pbo=(1-P)^i, Poo=0, k=1, иначе переходим к шагу 35;
30) Выводим Pbo;
31) Если k<=3, то Poo=, иначе переходим к шагу 33;
32) k=k+1, переходим к шагу 31;
33) Pno=1-Pbo-Poo, Pls=Pno/(1-Poo), lgPls=log10(Pls),
34) Выводим Poo, Pno, Pls, lgPls, переходим к шагу 29;
35) h=0, i=0;
36) Если i<=60, то переходим к шагу 37, иначе переходим к шагу 38;
37) Если M[i]>0, то h=h+1, i=i+1, иначе i=i+1 и переходим к шагу 36;
38) Выделяем память под массив Н из h элементов.
39) Если i<=60, то переходим к шагу 40, иначе переходим к шагу 41;
40) Если M[i]>0, то H[k]=M[i], k=k+1, i=i+1, иначе i=i+1 и переходим к шагу 39;
41) i=0;
42) Ищем минимальный элемент в массиве Н;
43) Если i<=60, то переходим к шагу 44, иначе переходим к шагу 50;
44) Если M[i]=минимальному элементу, то и переходим к шагу 45, иначе i=i+1 и переходим к шагу 43;
45) Если i>=0 и i<=20, то выводим (i+11,i+10)-код, иначе переходим к шагу 46;
46) Если i>=21 и i<=25, то выводим (i-10,i-14)-код, иначе переходим к шагу 47;
47) Если i>=26 и i<=40, то выводим (i-9,i-14)-код, иначе переходим к шагу 48;
48) Если i>=41 и i<=45, то выводим (i-30,i-35)-код, иначе переходим к шагу 49;
49) Если i>=46 и i<=60, то выводим (i-29,i-35)-код, иначе i=i+1 и переходим к шагу 39;
50) Выводим минимальный элемент из массива Н, как минимум разницы Рдоп-Рлс;
51) Конец.
Программа написана на языке С++.
#include <vcl.h>
#include <math.h>
#include <stdio.h>
#include <vector>
#include <algorithm>
#pragma hdrstop
#include "Unit1.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
float P = 0.0006;
float Pdop = 0.0000002;
using namespace std;
float M[61];
vector<float>H;
char B[128];
TForm1 *Form1;
__fastcall TForm1::TForm1(TComponent* Owner)
: TForm(Owner)
{
}
float C(int n,int m)
{float c=1.0;
for(int i=n;i>=n-m+1;i--)c*=i;
for(int i=1;i<=m;i++)c/=i;
return (int)c;
void __fastcall TForm1::ComboBox1Select(TObject *Sender)
{int i=0, k;
double Pbo,Poo,Pno,Pls,lgPls;
AnsiString s;
ListBox1->Clear();
ListBox2->Clear();
ListBox3->Clear();
ListBox4->Clear();
ListBox5->Clear();
ListBox6->Clear();
ListBox7->Clear();
//d=2
if(ComboBox1->ItemIndex==0)
for(i=11;i<=31;i++)
{s="("+IntToStr(i)+","+IntToStr(i-1)+")";
ListBox1->Items->Add(s);
Pbo=pow(1-P,i);
sprintf(B,"%.8f",Pbo);
ListBox2->Items->Add(B);
Poo=0;
Poo=C(i,1)*pow(P,1)*pow(1-P,i-1);
sprintf(B,"%.8f",Poo);
ListBox3->Items->Add(B);
Pno=1-Pbo-Poo;
sprintf(B,"%.8f",Pno);
ListBox4->Items->Add(B);
Pls=Pno/(1-Poo);
sprintf(B,"%.8f",Pls);
ListBox5->Items->Add(B);
lgPls=log10(Pls);
sprintf(B,"%.2f",lgPls);
ListBox6->Items->Add(B);
Series1->AddXY(i,lgPls,s,clRed);
M[i-11]=(Pdop-Pls);
//d=3
if(ComboBox1->ItemIndex==1)
{for(i=11;i<=15;i++)
{s="("+IntToStr(i)+","+IntToStr(i-4)+")";
for(k=1;k<=2;k++)
Poo+=C(i,k)*pow(P,k)*pow(1-P,i-k);
Series2->AddXY(i,lgPls,s,clLime);
M[i+10]=(Pdop-Pls);
for(i=17;i<=31;i++)
{s="("+IntToStr(i)+","+IntToStr(i-5)+")";
M[i+9]=(Pdop-Pls);
//d=4
if(ComboBox1->ItemIndex==2)
for(k=1;k<=3;k++)
Series3->AddXY(i,lgPls,s,clYellow);
M[i+30]=(Pdop-Pls);
{s="("+IntToStr(i)+","+IntToStr(i-6)+")";
M[i+29]=(Pdop-Pls);
int h=0;
for (i=0;i<=60;i++)
if (M[i]>0) h++;
H.resize(h);
k=0;
for (i=0; i<=60;i++)
if (M[i]>0) {H[k]=M[i]; k++;}
if (M[i]==*min_element(H.begin(),H.end()))
{if (i>=0&&i<=20)
{s="("+IntToStr(i+11)+","+IntToStr(i+10)+")-код с d=2";
ListBox7->Items->Add(s);}
if (i>=21&&i<=25)
{s="("+IntToStr(i-10)+","+IntToStr(i-14)+")-код с d=3";
if (i>=26&&i<=40)
{s="("+IntToStr(i-9)+","+IntToStr(i-14)+")-код с d=3";
if (i>=41&&i<=45)
{s="("+IntToStr(i-30)+","+IntToStr(i-35)+")-код с d=4";
if (i>=46&&i<=60)
{s="("+IntToStr(i-29)+","+IntToStr(i-35)+")-код с d=4";
ListBox7->Items->Add("");
ListBox7->Items->Add("Минимальная разность");
sprintf(B,"%.12f",*min_element(H.begin(),H.end()));
ListBox7->Items->Add("Рдоп-Рлс");
ListBox7->Items->Add(B);
void __fastcall TForm1::FormCreate(TObject *Sender)
{ComboBox1->ItemIndex=1;
Series4->AddXY(0,log10(Pdop),"lg Pдоп",clBlack);
Series4->AddXY(31.3,log10(Pdop),"lg Pдоп",clBlack);
Построить функциональные схемы кодера и декодера для найденного (n,k)-кода и заданного для него порождающего многочлена g3(X). При изображении схем кодера и декодера использовать условные изображения элементов:
элемент умножения
элемент памяти
элемент сложения по модулю 2
Исходные данные:
g3(x)=x5+x3+x2+x+1;
r=5.
Описание работы схемы:
Кодер 1 с последовательным вводом информационных символов (a12, a11, …, a1, a0) состоит из регистра проверочных символов (РПС), регистра задержки (РЗ) с 5 элементами памяти и трех ключей. В исходном состоянии в элементах памяти регистров – нули, ключи Кл1 и Кл2 разомкнуты, Кл3 замкнут.
При подаче первых 5 импульсов сдвига (ИС) 5 информационных символов, начиная со старшего, вводятся в оба регистра. С окончанием 5-го ИС ключи Кл1 и Кл2 замыкаются, а Кл3 размыкается.
В течение последующих k ИС информационные символы выводятся из РЗ, а в РПС образуются 5 проверочных символов. После этого ключи Кл1 и Кл2 размыкаются, а Кл3 замыкается.
За последующие 5 импульсов сдвига проверочные символы выдаются на выход кодера, после чего схема возвращается в исходное состояние. Таким образом, первый символ комбинации УЦК появляется на выходе кодера с задержкой на 5 ИС.
1. Хохлов Г.И., Пособие к выполнению лабораторной работы №3 по дисциплине «Системы и сети связи». – М.: 2005. – 18 с.
2. Хохлов Г.И., Пособие по выполнению курсовой работы по дисциплине «Системы и сети связи». – М.: 2005. – 15 с.
Страницы: 1, 2