Как разработчика приборов для измерения параметров телевизионных сигналов меня часто спрашивают, как правильно интерпретировать результаты измерений. В настоящее время для специалистов, обслуживающих системы телеприема, доступно большое количество измерительных приборов, а значит, есть возможность количественно оценить качество телевизионных каналов, в том числе каналов с цифровой модуляцией. Однако при интерпретации измеренных величин до сих пор чувствуются неуверенность и сомнения. В этом материале я изложу свою точку зрения на значимость каждого из параметров, характеризующих качество телевизионного сигнала.
Mой взгляд на этот вопрос в основном формировался в процессе собственных разработок и производства телевизионных измерительных приборов. Но свою лепту внесли и консультации со специалистами всемирно известных компаний, производящих подобные приборы, и общение с операторами кабельных сетей.
Должен оговориться, что все нижеизложенное в первую очередь касается цифрового кабельного телевидения стандарта DVBC. Но в силу родственных связей между форматами DVB-вещания мои рассуждения с некоторыми оговорками можно отнести и к DVB-S, DVB-T, и др.
Содержание
- Пять основных параметров
- BER vs MER
- Самый важный параметр
- Время измерения BER
- Преимущества MER
- Констелляционная диаграмма
- Особенности измерения уровня цифровых сигналов
- Общие рекомендации по оценке качества цифровых каналов
- Использованная литература
Пять основных параметров
Для начала рассмотрим набор измеряемых параметров цифровых каналов, доступных владельцам современных приборов. Как правило, эти приборы позволяют измерять пять параметров.
Первый из них — уровень сигнала в канале. Без сомнения, это один из важнейших параметров, характеризующих качество приема. Несмотря на то, что это самый понятный для специалистов параметр и его с достаточной точностью можно измерить даже приборами, предназначенными для аналоговых сигналов, при анализе результатов измерений иногда встречаются неправильные толкования и недопонимания.
Следующий параметр — MER (Modulation Error Ratio), или Коэффициент ошибок модуляции. По своей сути MER близок параметру SNR (сигнал/шум). В некоторых странах вместо параметра MER применяют EVM (Величина вектора ошибки), но по существу это одно и то же, выражаемое в разных единицах.
Третий параметр — BER (Bit Error Ratio), или Коэффициент битовых ошибок. Он характеризует частоту появления ошибочно восстановленных битов в демодулированном потоке данных и для стандарта DVB-C измеряется в двух точках: до декодера РидаСоломона и после него. Поэтому фактически это два параметра, которым часто присваивают названия preBER и postBER. Параметр postBER — та величина, которую пользователю иногда предъявляют как значение счетчика ошибочных пакетов за интервал наблюдения.
Последний параметр — констелляционная диаграмма, которая представляет собой график расположения символов на амплитуднофазовой плоскости, формируемый с накоплением за определенное время. Как правило, диаграмма рассматривается как некий качественный, а не количественный параметр, позволяющий оценить характер искажений входного радиосигнала.
Теперь можно приступить к более подробному анализу каждого из параметров на предмет их важности в оценке качества принимаемого цифрового сигнала.
BER vs MER
В специализированной литературе, журналах и на интернет-форумах часто разгораются дискуссии о значимости этих параметров; нередко можно встретить мнение, что самым важным и информативным параметром является MER. Сторонники этой точки зрения мотивируют ее тем, что зависимость величины MER от уровня шумов в полосе канала носит более пологий характер по сравнению с кривой BER, поэтому можно точнее оценить запас по устойчивому приему сигнала. В этом высказывании есть, конечно, большая доля истины. В самом деле, диапазон измерения MER, как правило, находится в пределах от 26-27 дБ до 38-42 дБ и выше (для модуляции QAM-256). Это позволяет оценить запас по качеству сигнала от порога синхронизации, когда демодулятор только-только начинает восстанавливать сигнал при значении preBER 1E-2…1E-3 . К тому же значение MER, как правило, более стабильно по сравнению с BER, особенно когда BER ниже 1E-7, что объясняется временем усреднения этих величин. К этому обстоятельству я вернусь немного позже.
Mux: MER-ы бывают пиковые и среднеквадратичные. Среднеквадратичные отражают усредненное значение за период измерения, а пиковые — максимальное. Если измеряется среднеквадратичное, то вполне возможны краткие развалы картинок принормальном MER-е, но переход на измерения пикового значения покажут эти сбои.
Mux: Достижимая точность измерения MER тем выше, чем ниже размерность модуляции измеряемого сигнала. Чем больше точек констелляции должен обрисовать ЦАП, тем меньше у него времени на каждую точку. Karlson2k: MER — хороший показатель, однако не единственный. Для приёмника
скорее важен BER или даже PER (BER после декодера Рида-Соломона). Иногда с одними тем же MER могут быть совсем разные BER.
В «обычных» условиях корреляция между MER и BER достаточно чёткая. Действительно, появление BER свидетельствует о подходе к границе (которая для цифры очень тонкая — здесь ещё есть, ещё чуть-чуть и уже совсем нет). Но как раз граница и важна. Тем не менее, в реальной жизни полно условий, когда чёткость корреляции начинает сбивается. Например — частотный сдвиг, из-за допплеровского эффекта (актуально для DVB-H) или по каким-то другим причинам. Иногда сбой может быть вызван «особенностями» передатчиков. Конечно, на BER сложно ориентироваться при измерениях, особенно «быстрых», и в большинстве случаев достаточно на MER. Но при любых важных измерениях без BER не обойтись.
А на практике для бытовых приёмников важен еще и уровень сигнала. К сожа- лению, разница в минимальном уровне, при котором бытовой приёмник цепляется за сигнал, доходит до 30-35 дБ у разных моделей даже от одного производителя. Штампуется же всё «подешевле». То есть на что ориентироваться при постройке
сети — вопрос ещё тот .
Самый важный параметр
Тем не менее, берусь утверждать, что самый важный параметр из всех измеряемых для цифрового сигнала — BER, а точнее — postBER. Ведь уверенно заявлять, что восстановление потока, полученного за определенный период, было абсолютным, можно только в случае, если postBER за это время оказался равным нулю. В реальности значение для postBER, равное 1E10…1E11, говорит о частоте появления ошибки в восстановленном потоке данных не более 2…20 бит в час. Такой прием можно характеризовать как безошибочный. В соответствии с научной терминологией соответствующий поток данных можно назвать «квазисвободным от ошибок».
У BER есть, правда, один недостаток — невозможность оценить запас сигнала по качеству, за счет которого можно уверенно принимать и восстанавливать цифровой поток в течение длительного времени. В пороговой ситуации уменьшение значения MER для одного канала всего на 1-2 дБ может изменить ситуацию от полного восстановления данных к полной невозможности приема сигнала на этом канале и скачкообразному изменению значения BER.
Но, тем не менее, важность этого параметра весьма высока. Особенно он может быть полезен сторонникам контроля телевизионного изображения. Параметр postBER полностью заменяет контроль картинки за исключением того случая, когда в структуре транспортного потока MPEG присутствуют ошибки, приводящие к артефактам изображения. Но они не всегда приводят к дефектам картинки, заметным на экране монитора, или же искажениям звукового сопровождения, да и вообще появляются достаточно редко.
Зато postBER по сравнению с контролем изображения имеет несколько преимуществ. Во-первых, он показывает общее количество ошибок в транспортном потоке, а не на одной программе, как при контроле картинки.
Во-вторых, вычислению postBER никак не препятствует шифровка потоков системами условного доступа. И для открытых, и для закрытых каналов он вычисляется одинаково.
И, в-третьих, postBER более чувствителен к ошибкам: счетчик невосстановленных пакетов будет неумолимо увеличиваться с каждой следующей ошибкой, хотя «битый» пакет может принадлежать другой программе или вообще не оказывать влияния на картинку или звук и, как результат, будет пропущен при визуальном контроле.
С точки зрения оценки запаса по качеству сигнала более информативен, конечно, preBER. Общеизвестно, что пороговое значение preBER, равное 2E-4, дает возможность восстанавливать данные до требуемых 1E-10…1E-11 значения postBER. Но это как раз тот случай, когда мы находимся на границе между уверенным приемом и отсутствием возможности восстановить сигнал при ухудшении значения MER. Если при измерении параметров мы получаем значение preBER, скажем, 1E-6, это уже указывает на наличие некоего запаса, позволяющего нам быть увереннее в будущем.
Время измерения BER
Большинство приборов для измерения параметров сигналов с цифровой модуляцией имеют нижнюю границу диапазона измерения параметра BER 1E-8 или 1E-9, реже — 1E-10, 1E-11. Совершенно естественно, что пользователи приборов хотят иметь границу как можно ниже, а результат измерения получать как можно быстрее. Давайте посчитаем: если мы используем модуляцию QAM-256 и символьную скорость 6,9 Мбод, то битовая скорость на входе декодера РидаСоломона будет составлять 6,9*8=55,2 Мбит/с. Если вероятность появления ошибки 1E-8, то для измерения этой величины нам надо накопить 108 бит потока данных, из которых один бит будет ошибочным. А накапливать мы их будем в течение 108/55,2×106 = 1,8 с. То есть один неправильно декодированный бит будет появляться, в среднем, раз в две секунды.
Результат, измеренный за этот промежуток времени, будет, конечно, весьма неточным. Для уменьшения случайной погрешности необходимо его усреднить хотя бы за 10 периодов измерения, то есть за 18 секунд. Если мы захотим измерить BER с нижней границей 1E-9, то для этого нам потребуется в 10 раз больше времени: 180 секунд или 3 минуты, а для получения достоверного результата 1E-11 мы должны ждать пять часов! Если использовать модуляцию более низкого порядка или более низкую символьную скорость, время измерения увеличится еще больше
Преимущества MER
MER (Modulation Error Ratio) — это ошибка модуляции, характеризующая отклонение реального символа от местоположения символа идеального на констелляционной диаграмме1.
По сравнению с BER параметр MER предоставляет более оперативную информацию о сигнале. Как я уже упоминал, MER является подобием параметра отношения сигнал/шум, хотя и учитывает большее число факторов, искажающих исходный радиосигнал. Значение параметра так же усредняется по времени, как и все величины, связанные с измерением мощности, но его измерение производится для каждого символа и, учитывая большие символьные скорости, накопление за одну секунду дает достаточно достоверный результат.
Вторым достоинством параметра MER является возможность его измерения с нормированной точностью. Большинство современных микросхем декодеров, на основе которых производятся приборы, позволяют вычислять MER аппаратно или на основе величин амплитуд векторов I и Q.
Под аппаратным вычислением я имею в виду возможность получения среднеквадратичного значения вектора ошибки из одного из внутренних регистров демодулятора. Во всяком случае производители микросхем утверждают, что это именно оно, и измерения, в принципе, это подтверждают. А зная среднеквадратичное значение вектора ошибки, вычислить MER уже несложно.
Использование значений амплитуд векторов квадратур для этих целей часто менее пригодно, потому что от микросхемы можно получить лишь 7 или 8 двоичных разрядов амплитуды QIвекторов. В результате динамический диапазон расчетного значения MER получается весьма низок. А разрядность регистра ошибки, напротив, часто бывает 10-, а то и 16-битная.
Погрешность измерения, связанную с неидеальными параметрами тюнера и демодулятора, можно скорректировать, имея источник сигнала с калиброванным параметром сигнал/шум. Калибровка производится для входного сигнала с добавлением только белого шума, но такой метод, тем не менее, дает весьма хороший результат.
Поэтому погрешность параметра MER для многих приборов является нормированной величиной в отличие от BER. Точность измерения BER зависит от качества приемника и демодулятора прибора, и корректировать ее невозможно. В результате измерение BER разными приборами дает близкие значения при плохом и заметно различающиеся при хорошем (при больших значениях MER).
То есть более качественный прибор показывает более низкие (более близкие к реальным) значения BER. Способность измерять низкие значения BER является хорошим индикатором качества измерительного прибора.
Если это так, возникает вопрос: «А не достаточно ли измерять один только MER для оценки качества принимаемого сигнала, ведь время измерения небольшое. Параметр предоставляет комплексную и точную информацию. С этим можно согласиться, но только в одном случае, когда к исходному сигналу примешивается только белый гауссовский шум. Как показывают практика и тестовое моделирование, при выполнении этого условия MER совпадает с SNR, и поэтому в данном случае для определения значений preBER и postBER можно воспользоваться кривыми зависимости BER от отношения SNR входного сигнала.
Констелляционная диаграмма
К сожалению, в реальной жизни все далеко не так идеально. На пути доставки телевизионного сигнала от источника до конечного пользователя существует великое множество факторов, приводящих к искажению сигнала. В результате для определения качества сигнала все-таки приходится использовать все возможные параметры, в том числе констелляционную диаграмму.
ассмотрим подробнее процесс демодуляции сигнала с цифровой модуляцией. После синхронизации с входным сигналом на выходе блока демодулятора для каждого символа появляются два значения векторов I и Q.2 Пара векторов определяет точку на амплитуднофазовой плоскости, каждая из которых принадлежит одной клетке, определяющей конкретное значение символа. В идеальном случае точки ложатся точно в середины клеток.
В условиях воздействия шума точки получают некоторое смещение от ожидаемого положения, которое носит название вектора выходной ошибки. Если точка остается в пределах своей клетки, демодулятор принимает правильное решение, в противном случае символу присваивается значение соседней клетки, что к появлению ошибки во входном потоке данных. Добавление белого шума к входному сигналу приводит к «размазыванию» точки в пятно круглой формы (рис. 1). Наибольшая частота попадания точки — в центре, а к краю окружности она уменьшается. В этом случае все пятна имеют примерно одинаковый диаметр.
Теперь рассмотрим случай одновременного воздействия белого и фазового шумов на демодуляцию сигнала. На рис. 2 приведена констелляционная диаграмма для сигнала с добавлением паразитной фазовой модуляции (джиттер фазы), из которой видно, что фазовая модуляция приводит к большему отклонению точек от центра клетки с увеличением длины вектора. В результате вероятность возникновения ошибки при декодировании точек в углах констелляционной диаграммы резко увеличивается. При этом значение MER уменьшается не так сильно, потому как смещение для точек ближе к центру диаграммы незначительное.
Ситуация ухудшается еще сильнее в случае, если кроме фазовой модуляции присутствует компрессия сигнала, появившаяся при прохождении им активных устройств в зоне нелинейности их передаточной характеристики. Вершины длинных векторов смещаются к центру констелляционной диаграммы, в результате чего вероятность ошибок для этих векторов увеличивается еще значительнее. На значение MER такие искажения также не оказывают большого влияния.
Ниже приведены результаты моделирования трех перечисленных ситуаций: измерение сигнала QAM-256 в случае воздействия только белого шума, белого шума и фазовой модуляции и белого шума одновременно с компрессией амплитуды сигнала. Три соответствующие констелляционных диаграммы представлены на рис. 3.
На следующей диаграмме (рис. 4) представлены три кривые зависимости параметра BER при изменении отношения сигнал/шум во входном сигнале. Синяя линия соответствует первому случаю, когда во входном сигнале присутствует только белый шум, фиолетовая — белый шум и фазовая модуляция и, наконец, зеленая — белый шум и компрессия.
Рис. 4. Кривые зависимости параметра BER при изменении отношения сигнал/шум во входном сигнале
Видно, что при низких значениях сигнал/шум линии практически совпадают, но с увеличением параметра они начинают расходиться. Наконец, на последнем графике (рис. 5) приведена зависимость параметра MER при тех же условиях. Из графика видно: при соотношении сигнал/шум 36 дБ при добавления фазовой модуляции к входному сигналу MER уменьшается на 0,5 дБ, при этом значение BER ухудшается сразу на несколько порядков. Еще сильнее влияние компрессии, хотя она и едва различима на констелляционной диаграмме.
Это не единственные случаи искажения в исходном входном сигнале, которые приводят к сильному ухудшению BER при незначительном изменении значения MER. К аналогичным последствиям приводят фазовые искажения квадратур, амплитудный разбаланс векторов квадратур и т.д.
Правда, последние виды искажений возникают реже. Гораздо хуже ситуация с помехой импульсного характера. Такого рода искажения сигнала не редкость, поскольку существует большое количество устройств, излучающих радиосигнал, который может
выступать в роли импульсной помехи для cигнала телевизионного.
При достаточно низкой частоте повторения и короткой длительности такая помеха практически не влияет на значение MER, но при этом может приводить к полной деградации BER. Ситуация осложняется тем, что подобную помеху сложно обнаружить. Часто не помогает и анализатор спектра. К примеру, если мешающий сигнал находится в полосе канала и при этом меньше по мощности на 20-30 дБ, то он маскируется полезным сигналом.
Особенности измерения уровня цифровых сигналов
Пожалуй, самым понятным для цифровых ТВсигналов, как и для аналогового телевидения, является параметр, характеризующий мощность сигнала. Но, тем не менее, довольно часто возникают вопросы, связанные с определением уровня цифровых каналов, поэтому немного внимания уделим и этому параметру.
Для аналогового телевидения измеряется уровень напряжения радиосигнала несущей частоты изображения. Для цифрового ТВ — «мощность радиосигнала в полосе канала» (такое название часто применяется в зарубежной литературе) или «фактический уровень напряжения радиосигналов с цифровой модуляцией в полосе частот распределения радиосигналов», как он называется в российском ГОСТ Р 52023 — «Сети распределительных систем кабельного телевидения». В России параметр принято обычно измерять в дБ относительно 1 микровольта (дБмкВ) как для аналоговых, так и для цифровых каналов.
Мощность3 радиосигнала для цифровых каналов измеряется как уровень напряжения немодулированного сигнала, который на нагрузке 75 Ом рассеивает мощность, эквивалентную мощности сигнала измеряемого канала.
При измерении уровней сигналов с помощью специализированных телевизионных измерителей или универсальных анализаторов спектра следует учитывать, что в аналоговых каналах характер сигнала — узкополосный, то есть основная часть мощности канала сосредоточена в довольно узком частотном диапазоне, а цифровые каналы характеризуются равномерным распределением мощности в полосе канала. В основе работы измерителей уровня лежит принцип селективного вольтметра. То есть в спектре радиосигнала выделяется (отфильтровывается) определенная частотная полоса, а затем измеряется напряжение сигнала, попавшего в эту полосу.
Если при измерении уровня узкополосного сигнала ширина его спектра заведомо меньше полосы измерения4, уровень измеряемого сигнала будет постоянным при изменении полосы измерения в пределах канала. Ситуация меняется при измерении широкополосных сигналов, каковыми являются радиосигналы цифрового телевидения. В этом случае чем шире полоса измерения прибора, тем выше уровень измеряемого напряжения. На рис. 6 представлена спектрограмма частотного диапазона с несколькими телевизионными каналами с аналоговой и цифровой модуляциями.
Спектрограмма была снята с помощью прибора с полосой измерения 230 кГц. На первый взгляд, уровни цифровых каналов ниже аналоговых более чем на 10 дБ. Однако для аналогового канала S20 уровень (Uan) можно определить по спектру как 66 дБмкВ. А для определения мощности сигнала цифрового канала S23 необходимо применить следующую формулу:
Uцк = Uизм + 10lg(Вц/Виз) + К,5
где Uцк — искомая мощность цифрового канала;
Uизм — уровень напряжения измеренный в центре полосы канала; Вц — полоса частот, занимаемая цифровым каналом; Виз — полоса измерения прибора;
К — поправочный коэффициент, компенсирующий погрешности измерения6.
Подставив исходные данные в формулу, получим:
US23 = 53 + 10lg(7,5/0,23) + 1 = 69 дБмкВ.
Таким образом, на самом деле уровень мощности канала S23 на 3 дБ больше, чем S20.
В режиме измерения уровня специализированные телевизионные приборы автоматически производят такой пересчет цифровых каналов с учетом их полосы и отображают их мощность корректно. Но при работе в режиме анализатора спектра и при измерении приборами, не рассчитанными на работу с цифровыми каналами, надо помнить об этой особенности. Такой метод измерения мощности канала в одной частотной точке дает достаточно точный результат только в случае достаточной равномерности АЧХ в полосе канала.
Общие рекомендации по оценке качества цифровых каналов
Кабельные операторы, давно работающие с цифровым телевидением и имеющие большой опыт, советуют классифицировать состояние кабельной сети по трехбалльной шкале. Оценка три балла означает, что параметры каналов в сети соответствуют требованиям качественного приема и обладают достаточным запасом для стабильной, долговременной работы. От оператора при этом требуется только продолжение текущего контроля. Оценка два балла: параметры каналов также соответствуют требованиям качественного приема, но их значения не имеют достаточного запаса для обеспечения долговременной стабильной работы.
Такое состояние сети требует от оператора планового проведения работ для выявления источника проблем и принятия решения о методах восстановления состояния сети до трех баллов. И, наконец, третье состояние сети с оценкой один балл: параметры одного или нескольких каналов не отвечают требованиям качественного приема, что требует от оператора немедленных действий по ремонту или настраиванию сети для поднятия до второго или третьего уровня. Для оценки каждого канала необходимо измерить все параметры на абонентском отводе. Оценка присваивается в соответствии со следующими условиями.
Оценка 3 балла (выполняются все четыре условия): Уровень канала: соответствует расчетному уровню для данной точки сети с учетом неравномерности и принятой разницы между уровнями аналоговых и цифровых каналов.
MER: не меньше 36 дБ для модуляции QAM-256 и 28 дБ для модуляции QAM-64.
PreBER не превышает 1E7. PostBER: не превышает 1E9.
Оценка 2 балла (выполняются все четыре условия): Уровень канала: соответствует расчетному уровню для данной точки сети с учетом неравномерности и принятой разницы между уровнями аналоговых и цифровых каналов.
MER: находится в пределах от 34 до 36 дБ для модуляции QAM256 и от 26 до 28 дБ для модуляции QAM64.
PreBER: не превышает 1E6. PostBER: не превышает 1E9.
Оценка 1 балл (выполняется хотя бы одно условие):
Уровень канала: не соответствует расчетному уровню для данной точки сети с учетом неравномерности и принятой разницы между уровнями аналоговых и цифровых каналов.
MER: значение меньше 34 дБ для модуляции QAM-256 и меньше 26 дБ для модуляции QAM-64.
PreBER: значение выше 1E6. PostBER: значение выше 1E-9.
Если есть возможность контроля констелляционной диаграммы, необходимо добавить еще одно условие. Для оценки «3» форма констелляционной диаграммы не должна содержать ярко выраженных фазовых искажений, дисбаланса квадратур и искажений типа компрессии сигнала. При наличии подобных искажений измеряемому каналу должна быть присвоена оценка не выше двух баллов.
При указании значений параметров я исходил из предположения, что они измерены корректно, в пределах погрешности измерения прибора. Но при определенных условиях измеренные значения могут выпадать за пределы погрешности. В этом случае каналу может быть присвоена оценка, не соответствующая действительности.
Данная методика оценки качества не является, конечно, абсолютной и единственно верной. Каждый оператор может для себя выбрать границы значений параметров для оценки качества сигнала в соответствии с особенностями конкретной сети и отдельных каналов; при этом следует придерживаться общего подхода к методу проверки состояния сети.
——
1 Физический смысл этого параметра и формула для вычисления его среднеквадратичного значения рассмотрены в статьях серии «Цифровое кабельное ТВ. Часть 2. Состав головной станции, расчет ретранслируемого потока», «ТелеСпутник», ноябрь 2007 и «Цифровое кабельное ТВ. Часть 4. Сигнал DVB в распределительной сети. Использование альтернативных стандартов», январь 2008 (прим. ред.).
2 I= A cosφ, а Q = A sinφ где А – амплитуда QAM символа, а φ – фаза символа.
3 Имеется в виду мощностная характеристика, в качестве которой в телевидении принято использовать эквивалентное напряжение немодулированного сигнала, который по мощности равен сигналу телевизионному. Хотя в статье применяется термин «мощность цифрового канала», на самом деле подразумевается как раз напряжение этого эквивалентного сигнала (прим. автора).
4 Полоса измерения определяется полосой пропускания измерительного фильтра (прим. ред.).
5 Так эта формула выглядит в ГОСТ Р 52023 (прим. автора).
6 Коэффициент зависит в основном от параметров детектора (тип детектора и его постоянные времени) и прямоугольности измерительного фильтра. Определяется опытным путем и, как правило, составляет 13 дБ (прим. автора).
Андрей Конорев,
ведущий инженер ООО «Планар»
Использованная литература
- Б.А. Локшин. Цифровое вещание: — от студии к телезрителю.
- ГОСТ Р 52023-2003 «Сети распределительные систем кабельного телевидения».
- ETSI TR 101 290 Measurement guidelines for DVB system.
Качество сетей передачи данных. Транспорт
Время прочтения
8 мин
Просмотры 28K
В предыдущей статье были затронуты базовые метрики качества сетей и систем передачи данных. Также было обещано написать про то, как все работает изнутри. И намеренно не было упомянуто про качество среды передачи данных и ее характеристиках. Надеюсь, что новая статья даст ответы на эти вопросы.
Среда передачи
Начну, пожалуй, с последнего пункта — качества среды передачи. Как уже написано выше, про нее ничего не говорилось в предыдущем повествовании, поскольку само по себе количество сред и их характеристики очень сильно различаются и зависят от просто колоссального множества факторов. Разбираться во всем этом многообразии задача соответствующих специалистов. Всем очевидно использование радио-эфира в качестве среды передачи данных. Я же помню в конце 90-х начале 00-х особой популярностью у операторов связи стали пользоваться такие экзотические способы передачи, как лазерные атмосферные передатчики. Выглядели они, в зависимости от производителя и конфигурации примерно как на картинке слева (да, почти такой себе светотелефон из радиолюбительского детства). Преимущество их было в том, что не надо было получать разрешение ГРКЧ, да и скорости, по сравнению с радиомостом были несколько больше, кроме того существовали модификации для организации каналов с временным разделением (E1 и т.п.), а подобное оборудование радио-доступа стоило непомерно дорого. Почему не оптический кабель? Потому что в те счастливые времена дикого провайдинга оптика еще была довольно дорогой, а за конвертер интерфейса или активное оборудование, способное принять оптический линк напрямую давали небольшой (а кто-то и большой) брусок золота. Были еще спутниковые каналы, но это вообще из области фантастики и позволить их себе могли разве что компании нефтяного сектора и прочего национального благосостояния. Но работа канала через спутник сводится к использованию радио-эфира, со всеми вытекающими и внесением огромной задержки.
Соответственно погружаясь в вопрос в результате будем иметь множество сред и ни одной обобщенной характеристики. Тем не менее для нас среда это всего лишь транспорт, передающий информацию из точки А в точку Б. А для транспорта (даже общественного) характеристикой отражающей его качество будет доставка всех битов (ну или пассажиров) без искажений и потерь (не хотелось бы лишиться части тела при перевозке, согласитесь). Т.е. мы приходим к такой обобщенной метрике качества транспорта как количество битовых ошибок, или BER (Bit error rate). В чисто пакетных сетях она практически не используется, поскольку ошибки передачи выявляются на уровне пакета, например подсчетом контрольных сумм: FCS (Frame check sequence) для L2 или сhecksum IP для L3. Если контрольная сумма не совпадает, то пакет целиком отбрасывается как невалидный. Если же рассмотреть гетерогенные сети, те в которых транспортом может служить непакетная сеть, а, например, один из вариантов описанных выше, либо вообще используется транзит через ATM, PDH, SDH и подобное без непосредственной (но с восстановлением) передачи пакета, то битовые ошибки транспорта могут значительно влиять, конечно в зависимости от технологии. Рассмотрим инкапсуляцию и передачу Ethernet-фрейма в HDLC. Другие технологии используют практически такую же технику.
Схема читается слева-направо (взята здесь).
- Какой-то узел сети А отправляет пакет в сторону какого-то узла сети Б
- Транспорт между сетями построен на сети PDH
- Узел на границе выхода сети А вырезает из Ethernet-фрейма область полезной нагрузки (поля от DestinationAddress до FCS включительно), оборачивает в HDLC заголовки, и отправляет на граничный узел входа сети Б
- Граничный узел входа сети Б выделяет область полезной нагрузки и восстанавливает Ethernet-фрейм
- Фрейм с граничного узла отправляется получателю
Как можно видеть, в данном случае контрольная передается корректно и в случае повреждения битового потока в процессе передачи восстановленный пакет с неверной FCS будет отброшен получателем. В данном случае механизм обнаружения ошибки налицо.
Но не всегда используется надстройка инкапсуляции, либо передается вообще не полноценный фрейм, а лишь поле payload. Т.е. вырезается область, оборачивается во внутренний протокол, а на другой стороне восстанавливаются недостающие данные, включая отсутствующие заголовки L2. Соответственно пропадает и FCS — она просто рассчитывается заново. Таким образом получается, если данные были повреждены, а FCS рассчитан на основании “испорченных” данных, то получатель принимает совсем не тот пакет, который ему отправляли. Это довольно часто встречается в спутниковой связи, чтобы повысить полезную утилизацию канала, избегая передачи условно “лишней” информации. Резюмируя, получается что метрика BER может быть интересна в случаях когда:
- необходимо проверить стабильность физического канала, например для оптики это 10E-12 (упоминается в IEEE802.3)
- Ethernet-фреймы упаковывают в SDH(GFP), PDH, ATM и другие транспортные сети.
- используются технологии xHSL, PPP протоколы в которые упаковывают IP пакеты
BER тест
Метрика известна — это отношение количество битовых ошибок к общему числу переданных битов. Методика измерения для сетей TDM известна как спецификация ITU-T G.821. Классически для проверки каналов используется BERT (BER Test) первого уровня, но с учетом специфики работы протоколов инкапсуляции пакетных сетей и самого принципа работы пакетных сетей необходимо иметь возможность проводить тесты на L1-L4. Немного далее будет рассмотрено подробнее. Ну а сейчас следует определиться что проверять и как проверять. На вопрос:” Что проверять?” Отвечает ITU-T 0.150. В его пункте 5 рассмотрены типы ПСП (псевдослучайных последовательностей), из которых просто берутся данные для формирования пакета. Т.е. нужно просто взять и заполнить соответствующий уровень пакета данными выбранной ПСП. У нас в приборах используются следующие ПСП:
- ПСП 2е9 (ITU-T 0.150 пункт 5.1)
- ПСП 2е11 (ITU-T 0.150 пункт 5.2)
- ПСП 2е15 (ITU-T 0.150 пункт 5.3)
- ПСП 2е23 (ITU-T 0.150 пункт 5.6)
- ПСП 2е31 (ITU-T 0.150 пункт 5.8)
- пользовательская последовательность (32 бита)
- все нули
- все единицы
- альтернативная последовательность (01010101)
Пользовательская последовательность введена для совместимости с приборами, которые существуют на рынке, т.е можно задать любую последовательность и проводить совместный тест.
Вопрос как проверять пока что открыт, попробуем разобраться. Допустим мы умеем генерировать определенные пакеты. Если отправить такой пакет на другой конец транспорта, то как понять, что он не изменился (следует абстрагироваться от пакетного принципа, поскольку у нас может не быть FCS и других типов контроля, как описано ранее)? Самый простой вариант — завернуть пакет обратно (в TDM называется “сделать петлю”, в Ethernet — установить шлейф). Заворот, во многих случаях, можно сделать на выходе канала без изменения среды передачи, т.е. реально поставить петлю на выходе E1 и все будет работать. Но т.к. данные проделывают двойной путь, то вероятность возникновения ошибки также возрастает в 2 раза. Да и каналы могут быть асимметричными или однонаправленными. Соответственно идеальным было бы иметь возможность обладать информацией о корректном следовании и сравнивать приходящие пакеты с уже известной информацией. Первый, и наиболее простой вариант, применимый когда оба выхода канала располагаются рядом (например такое возможно при TDM коммутации, или тестировании оптического “кольца”) заключается в том, что один порт прибора генерирует тестовый трафик, а другой порт этого же прибора его получает и сравнивает, а т.к. сравнение происходит в том же узле, что и генерация, то проблем со сравнением данных последовательности не возникает. Второй вариант предполагает восстановление первоначальной последовательности и сравнение ее с приходящими данными. В случае с полностью случайной последовательностью реализовать такое не представляется возможным, а вот если последовательность псевдослучайная, то вполне. Какое-то время затрачивается на синхронизацию в самом начале теста, но затем сравнение не представляет сложности. Поскольку ПСП первого прибора и ПСП второго известны и одинаковы, синхронизация сводится к поиску места начала сравнения в ПСП второго прибора. Таким образом существуют следующие топологии:
- «сам на себя» 1 — один прибор на одном порту, на другом конце транспорта стоит шлейф
- «сам на себя» 2 — один прибор с одного порта своего порта на другой свой порт
- с одного прибора на другой прибор, с синхронизацией
Еще раз стоит отметить, что тест BER не рекомендуется использовать на сетях лишь с пакетной коммутацией. Приведу пример. Допустим, уже идет тестовый поток и приборы синхронизированы (топология 3). В какой-то момент времени происходит следующее:
- формируется Ethernet-фрейм, содержащий данные ПСП
- для такого фрейма рассчитывается FCS и он укладывается в выходной буфер
- фрейм отправляется по сети на другой прибор
- по каким-то причинам происходит изменение всего одного бита внутри пакета
- получатель принимает пакет
- FCS принятого пакета не соответствует содержимому
- пакет отбрасывается (если между отправителем и получателем есть, например, коммутатор, то “кривой” пакет вообще не дойдет до получателя, т.к. будет уничтожен до него)
- отправитель формирует следующий пакет (все начинается с п.1)
В приведенном примере на шаге 8 произойдет срыв синхронизации на стороне получателя. Произойдет это потому, что отправитель возьмет следующий блок ПСП, а получатель будет сравнивать с тем блоком, который потерялся в предыдущем цикле (он ведь ничего не знает о потере). Срыв синхронизации приведет к необоснованно большому росту битовых ошибок, т.к. все вновь идущие блоки абсолютно не совпадают, что приведет к тому, что за один пакет число битовых ошибок будет увеличиваться на размер фрейма. Через какое-то время будет предпринята попытка восстановления синхронизации, но количество накопленных битовых ошибок будет сильно не соответствовать действительности.
А как в железе?
Как у других не знаю, но у наших приборов Беркут (ET, ETX, ETL, B100, а также модуль B5-GBE для MMT) дела обстоят следующим образом. Помня принцип о генерации и анализе трафика как можно ближе к физическому сегменту из первой статьи, все подобные задачи были возложены на FPGA. Упрощенная структурная схема выглядит так:
MAC ядро представлено двумя блоками: один на прием, другой на передачу. Это позволяет независимо принимать и отправлять пакеты, т.е. нет взаимовлияния очереди отправки на очередь приема и наоборот. Также с двух независимых блоков возможно вести общую статистику по полученному и отправленному трафику независимо от типа теста. Данные с блока передачи поступают на трансмиттер и отправляются в сеть, а входящие данные с трансивера поступают в блок приема.
Поскольку для некоторых топологий тестов необходим функционал шлейфа (loopback, петля), то он реализован отдельным блоком. Возможно установить шлейф уровня L1-L4:
- L1 — просто заворачивает трафик обратно (происходит это еще в трансивере)
- L2 — меняет DstMAC<->SrcMAC местами, пересчитывает FCS
- L3 — меняет DstMAC<->SrcMAC и DstIP<->SrcIP местами, пересчитывает FCS
- L4 — меняет DstMAC<->SrcMAC, DstIP<->SrcIP и DstPort<->SrcPort, пересчитывает FCS
Статистика по пакетам ведется и для режима шлейфа тоже, что позволяет грубо оценить соотношение отправленных и принятых пакетов.
Модуль генератора для каждого типа теста свой, для BERT он содержит генератор ПСП всех заявленных типов.
Работает это следующим образом. От генератора ПСП поступают данные на мультиплексор (проще говоря коммутатор), который, если не включен какой-то другой канал в данный момент, направляет поток в MAC tx модуль. MAC tx модуль, в соответствии с настройками теста (уровень BERT, размер пакета, данные полей) формирует из ПСП валидный Ethernet-фрейм и отправляет его в трансивер, который в свою очередь отправляет его в сеть. В зависимости от топологии теста фрейм либо заворачивается удаленной стороной, либо анализируется. В любом случае первичная обработка пакета не отличается. Фрейм попадает на MAC rx ядро, которое отправляет его на мультиплексор. Мультиплексор в зависимости от режима работы прибора направляет пакет либо в Loopback модуль, откуда после обработки он сразу же направляется в MAC tx для отправки, либо в модуль обработки и статистики теста, где, если потребуется, будет проведена попытка синхронизации ПСП и выполнено сравнение исходной последовательности с полученной. Результаты обработки отдаются в модуль вывода статистики.
Использование FPGA или ASIC позволяет все операции проводить параллельно, что не вносит какие либо задержки на обработку и исключает взаимовлияние модулей обработки.
Заключение
Несмотря на всю кажущуюся простоту алгоритмов и методик, за ними стоит много лет серьезных исследований. Огромное число факторов до сих пор влияет как на точность измерений, так и на стоимость приборов (прецизионные элементы, высокоскоростные ПЛИС). Например, приведенный выше BER тест не отличается значительной сложностью в общем алгоритмическом плане, но требует знаний в области математики, информатики и теории информации для разработки жизнеспособной модели. Модификация BER теста для пакетных сетей (поддержка уровней L2-L4) требует глубокого понимания принципов коммутации и маршрутизации. Надеюсь, что подобного рода статьи интересны и приносят пользу. В следующих публикациях планирую написать про сертифицированные тесты, генераторы трафика, фильтры и аналитические комплексы. Ведь как сказал Джон Фицджеральд Кеннеди на выступлении перед гражданами США перед стартом Лунной программы:
“И мы сделаем это. Не потому, что это легко, а потому что трудно.”
PS. Задавайте вопросы и предлагайте темы, в рамках нашей компетенции готовы на все
Выполнил: Студент гр. СОД 3-15-1 Папсуев О.С.
Что такое BER?
Ber (Bit Error Rate) — отношение числа ошибочно принятых битов к общему числу принятых битов. Его величина статистически колеблется около значения среднего коэффициента ошибок за длительный промежуток времени. Разница между непосредственно измеренным коэффициентом ошибок и долговременным средним значением зависит от числа контролируемых бит и тем самым от длительности измерения.
Kош= Nош/N
где N – общее число символов, переданных за интервал измерения; Nош – число ошибочно принятых символов за интервал измерения
Например, если число ошибочно принятых бит оказалось равным 20, а заданное общее число принимаемых бит – 106, то коэффициент ошибок составит
20/106 = 20 x 10-6 = 2 x 10-5
Зачем измеряется BER
Измерения параметра ошибок – это самая важная часть практики эксплуатации цифровой системы связи. Так как информация передается в системе связи в цифровом виде, то единственной мерой качества работы системы связи является параметр ошибки. Эта мера является универсальной в том смысле, что она едина для любых цифровых систем передачи и коммутации. Действительно, вне зависимости от того, какие типы линейного кода используются в системе передачи, на каких принципах построена система коммутации и какие протоколы используются, единой мерой качества цифровой сети является уровень ошибок, который она привносит в передаваемый цифровой поток.
Все технические решения в области эксплуатации направлены на уменьшение параметра ошибок, все измерения соотносятся с параметром ошибок (например, исследуются вопросы о влиянии джиттера на параметр ошибок, кодовых ошибок на параметр ошибок и пр.). Таким образом, измерение параметра ошибок представляет собой ключ к эксплуатационным измерениям, и уже одного этого достаточно, чтобы посвятить раздел методам измерения ошибок.
Модель возникновения ошибок в системе передачи
В самом общем виде модель возникновения ошибок выглядит следующим образом. Устройство А передает по рабочему каналу устройству В цифровой поток в виде единиц и нулей. Внешние воздействия на канал (шумы, интерференция, сбои в системе связи и т.д.) приводят к нарушению в интерпретации принимаемых символов на стороне В. В результате в некоторых случаях вместо 1 устройство В принимает 0 и наоборот.
Измерение параметра ошибок с использованием тестовой последовательности
В методе использования тестовой последовательности очень важным является вопрос о том, каким образом передать на сторону В знание о структуре последовательности. Здесь существует два способа. Первый заключает в том, чтобы передавать одну и ту же последовательность циклично, например, одна единица, затем три нуля, тогда в канале будет передаваться информация
1000100010001000100010001000 … тестовая последовательность
Если на стороне В приемник понимает правило формирования этой тестовой последовательности, то он легко найдет все отклонения, например:
1000100010001010100000001000 … 2 битовые ошибки
Метод измерения параметра ошибки без отключения канала
Суть метода состоит в том, что передаваемые данные реального трафика разделяются на блоки данных. Затем перед началом передачи данных в системе передачи над блоком совершается специальные вычисления, результат которых добавляется к блоку и передается на сторону В. На стороне приемника В над блоком производятся аналогичные вычисления, результат которых сравнивается с пересланным служебным полем от стороны А. Если результаты вычислений не совпадают, делается вывод о присутствии ошибки в блоке данных. Таким образом, можно проводить измерения на реальном трафике, без отключения канала. Единство методики определяется тем, что контроллеры, производящие вычисления, действуют по единым правилам расчета.
Принципы нормирования и измерения параметров ошибок
Выше уже было показано, что существует два метода измерений параметров соответственно BER и BLER. Рассмотрим теперь, каким образом эти методы накладываются на реальные методики измерений цифровых систем передачи.
Прежде всего, следует четко понять, что сами по себе параметры BER и BLER не могут быть использованы для нормирования качества в цифровых системах передачи. Возникает это потому, что оба параметра являются интегральными.
По определению, параметр BER представляет собой частное от деления количества ошибок на общее количество переданных битов:
BER=ErrB/BITS
Такое определение не учитывает природу возникновения ошибок и структуру их распределения. В то же время от структуры распределения битовых ошибок зависит окончательный вывод о том, качественный или некачественный канал системы передачи мы измеряем.
Для иллюстрации рассмотрим два случая возникновения ошибок в канале цифровой системы передачи
Слева представлен «пакет» ошибок, возникающий обычно вследствие наводок на кабель системы передачи.
Справа показан случай появления случайных ошибок, которые обусловлены самим качеством системы передачи и в большинстве случаев не связаны с какой-либо конкретной причиной.
В обоих случаях параметр BER оказывается очень высоким, например BER=10-5. Но сказать о практическом качестве цифровой системы передачи этот параметр не может. В рассмотренных примерах при одинаковом BER канал слева – это очень качественный канал. Все возникшие в нем ошибки помещаются в течение 6 сек, а других ошибок в канале нет. Если мы мысленно «вырежем» эти 6 секунд, то мы получим идеальный канал. В противоположность этому при BER=10-5 для канала справа мы имеем совершенно неприемлемое качество, т.к. появление единичных ошибок в таком канале – это слишком частое явление.
Эта иллюстрация показывает, что интегральная природа параметра BER (следовательно, и BLER) не позволяет использовать его в качестве корректного параметра нормирования и характеристики качества. Для полноты картины необходимо знать еще и характеристику распределения ошибок.
Для того, чтобы оценить распределение ошибок было предложено считать отдельно секунды с ошибками (ES) и секунды, пораженные ошибками (SES).
Секунды с ошибками ES – это все секунды в течении которых были ошибки, тогда как SES — это секунды, в течении которых BER был хуже, чем 10-3. Переход от анализа интегрированного параметра BER к дифференцированным значениям этого параметра в течении односекундных интервалов позволяет учесть распределение параметра ошибок. Например, на рисунке представлены значения не только параметра BER, но и соответствующие ситуации значения параметров ES и SES. По соотношению параметров ES и SES можно оценить кучность возникновения ошибок в измеряемом канале. Речь идет именно об оценке, а не о точном измерении параметров распределения ошибок, но для целей эксплуатации этого оказывается достаточно.
Следует отметить, что относительно измерений BER параметры ES, SES, а также другие параметры методики (AS, UAS и пр.) являются вторичными, т.к. непосредственно измеряется параметр BER в односекундных интервалах. Но именно эти параметры представляют интерес для отчетности по качеству в цифровом канале.
Измеритель коэффициента битовых ошибок Tektronix BERTScope BSA
Измерители коэффициента битовых ошибок Tektronix BERTScope серии BSA предлагают новый подход к измерению целостности сигнала в системах последовательных данных. Быстрое и точное определение коэффициента битовых ошибок (BER) за счет анализа диаграмм и генерации цифровых последовательностей с битовыми ошибками. Tektronix BERTScope серии BSA легко позволяет выделить проблемные биты или последовательности бит для дальнейшего анализа с помощью семи алгоритмов, обеспечивая непревзойденную глубину статистических измерений.
Что такое BER — Bit Error Rate?
Date:2016/4/5 15:56:57 Hits:
«Коэффициент ошибок по битам, BER используется для количественной оценки канала, несущего данные, путем подсчета частоты ошибок в строке данных. Он используется в телекоммуникациях, сетях и радиосистемах.Коэффициент битовых ошибок, BER — ключевой параметр, который используется при оценке систем, передающих цифровые данные из одного места в другое «. — Fmuser
Системы, для которых коэффициент битовых ошибок, BER применима включают ссылки радио данных, а также информационных систем волоконно-оптические, Ethernet, или любую систему, которая передает данные по сети той или иной форме, где шум, помехи, и дрожание фазы может вызвать ухудшение цифрового сигнал.Хотя есть некоторые различия в том, как эти системы работают и каким образом влияет скорость передачи в битах ошибки, основы скорости битовых ошибок сама по-прежнему то же самое.
Когда данные передаются по каналу передачи данных, существует вероятность ошибок, вводимых в систему. Если ошибки вводятся в данных, то целостность системы может быть поставлена под угрозу. В результате, необходимо оценить производительность системы, и коэффициент ошибок в битах, BER, обеспечивает идеальный способ, в котором это может быть достигнуто.
В отличие от многих других форм оценки, частота ошибок по битам, КОБ оценивает полный впритык производительность системы, включающей передатчик, приемник и среды между ними. Таким образом, частота появления ошибочных битов, КОБ позволяет реальная производительность системы в эксплуатацию, подлежащих испытанию, а не проверки составных частей и в надежде, что они будут работать удовлетворительно, когда на месте.
Бит ошибки скорости определения BER и основы
Как следует из названия, частота ошибочных битов определяется как скорость, при которой возникают ошибки в системе передачи. Это может быть непосредственно переведены в число ошибок, возникающих в строке заявленным количеством битов. Определение частоты появления ошибочных битов может быть переведена в простую формулу:
Если среда между передатчиком и приемником хорошо и соотношение сигнал-шум является высоким, то скорость битовых ошибок будет очень мала — возможно, незначительны и не имеющие какого-либо заметного влияния на общую систему Однако, если шум может быть обнаружен, то есть вероятность того, что частота появления ошибочных битов нужно будет рассмотреть.
Основными причинами деградации канала передачи данных и соответствующей частоты ошибок передачи в битах, BER шум и изменения в пути распространения (где используются сигнальные пути радио). Оба эффекта имеют случайный элемент к ним, шум следующий гауссовой функции вероятности в то время как модель распространения следует модели Рэлея. Это означает, что анализ характеристик канала, как правило, проводится с использованием методов статистического анализа.
Для волоконно-оптических систем, битовых ошибок в основном являются результатом несовершенства используемых компонентов, чтобы сделать ссылку. Они включают в себя оптический драйвер, приемник, разъемы и самого волокна. Ошибки в битах также могут быть введены в результате оптической дисперсии и затухания, которые могут присутствовать. Также шум может быть введен в самом оптическом приемнике. Как правило, они могут быть фотодиоды и усилители, которые должны реагировать на очень маленьких изменений, и в результате может быть высокий уровень шума, который присутствует.
Другим фактором, способствующим для битовых ошибок является любой Дрожание фазы, которые могут присутствовать в системе, так как это может изменить выборку данных Теа.
BER и Eb / No
Отношение сигнал-шум и Eb / No цифры не являются параметрами, которые в большей степени связаны с радиолиний и систем радиосвязи. С точки зрения этого, частота появления ошибочных битов, BER, также может быть определена в терминах вероятности ошибки или POE. Определения этого используются три других переменных. Они являются функция ошибки, ERF, энергия в один бит, ЭБ, и спектральная плотность мощности шума (что мощность шума в полосе частот Гц 1), №
Следует отметить, что каждый тип модуляции имеет свое собственное значение функции ошибки. Это происходит потому, что каждый тип модуляции выполняет по-разному в присутствии шума. В частности, схемы более высокого порядка модуляции (к примеру 64QAM и т.д.), которые способны переносить более высокие скорости передачи данных, не столь надежными в присутствии шума. Меньшие форматы модуляции порядка (например, BPSK, QPSK и т.д.) предлагают более низкие скорости передачи данных, но являются более надежными.
Энергии на бит, ЭБ, может быть определена путем деления мощности несущей на скорости передачи данных и является мерой энергии с размерами джоулей. Нет это мощность на герц, и поэтому это имеет размерность мощности (джоулей в секунду), разделенное на секунды). Не Глядя на размеры отношение Eb / No все размеры компенсируют дать безразмерное отношение. Важно отметить, что РОЕ пропорционально Eb / No и является формой сигнала к шуму.
Факторы, влияющие на частоту появления ошибочных битов BER,
Это можно видеть из использования Eb / No, что частоты появления ошибочных битов, КОБ может зависеть от ряда факторов. Изменяя переменные, которыми можно управлять, можно оптимизировать систему, чтобы обеспечить уровень производительности, которые необходимы. Это, как правило, проводится в стадии проектирования системы передачи данных таким образом, что рабочие параметры могут быть скорректированы на начальных этапах проектирования концепции.
• Помехи: Уровни помех, присутствующих в системе, как правило, установлены под воздействием внешних факторов и не может быть изменен с помощью конструкции системы. Тем не менее, можно установить ширину полосы пропускания системы. За счет снижения пропускной способности уровень помех может быть уменьшено. Однако уменьшение полосы пропускания ограничивает пропускную способность данных, что может быть достигнуто.
• Увеличьте мощность передатчика: Кроме того, можно повысить уровень мощности системы таким образом, чтобы мощность на бит увеличивается. Это должно быть сбалансировано против факторов, включая уровни помех другим пользователям и влияние увеличения выходной мощности от размера усилителя мощности и общее энергопотребление и время автономной работы и т.д.
• Модуляция низшего порядка: схемы модуляции Низшие порядка могут быть использованы, но это за счет скорости передачи данных.
• Уменьшите пропускную способность: Другой подход, который может быть принят, чтобы уменьшить частоту появления ошибочных битов, чтобы уменьшить ширину полосы частот. Более низкие уровни шума будут получены, и, следовательно, соотношение сигнал-шум улучшится. Опять же это приводит к уменьшению пропускной способности данных достижимым.
Необходимо сбалансировать все имеющиеся факторы для достижения удовлетворительной скорости появления ошибочных битов. Обычно это не представляется возможным достичь всех требований и некоторые компромиссы необходимы. Тем не менее, даже с битовой частотой ошибок ниже того, что в идеале требуется, дополнительные компромиссы могут быть сделаны с точки зрения уровней коррекции ошибок, которые вводятся в передаваемые данные. Хотя более избыточные данные должны быть отправлены с более высокими уровнями коррекции ошибок, это может помочь замаскировать последствия любых битовых ошибок, которые возникают, тем самым улучшая общую частоту появления ошибок в битах.
Частота появления ошибочных битов BER является параметром, который дает прекрасную индикацию производительности линии передачи данных, таких как радио или волоконно-оптической системы. В качестве одного из основных параметров, представляющих интерес в любой линии передачи данных является количество ошибок, которые возникают, то коэффициент ошибок в битах является ключевым параметром. Знание BER также позволяет использовать другие особенности ссылки, такие как мощность и пропускную способность, и т.д., чтобы быть адаптированы для того, чтобы требуемые эксплуатационные характеристики, которые будут получены.
Оставить сообщение
Список сообщений
6.1. Определения коэффициента ошибок
6.2. Математическое выражение коэффициента битовых ошибок
6.3. Нормы на параметры ошибок систем передачи
6.4. Принципы построения измерителей ошибок
6.5. Техника измерения коэффициента ошибок
6.1. Определения коэффициента ошибок
Коэффициент ошибок – важнейшая характеристика линейного тракта. Он измеряется как для отдельных участков регенерации, так и для тракта в целом. Определяется коэффициент ошибок kОШ, по формуле:
kОШ = NОШ /N, (6.1)
где N – общее число символов, переданных за интервал измерения; NОШ – число ошибочно принятых символов за интервал измерения.
Измерение коэффициента ошибок носит статистический характер, так как получаемый за конечное время результат является случайной величиной. Относительную погрешность измерения в случае нормального закона распределения числа ошибок, что допустимо при N≥10, можно определить по формуле:
. (6.2)
Здесь — коэффициент, зависящий от доверительной вероятности результата измерений:
, (6.3)
где — обратная функция интеграла вероятности :
. (6.4)
Значение kОШ позволяет оценивать вероятность ошибки pОШ – количественную оценку помехоустойчивости. Область возможных значений оценки, в которой с заданной доверительной вероятностью будет находиться значение pОШ, определяется верхней (pВ) и нижней (pН) доверительными границами. При нормальном законе распределения числа ошибок значения pВ и pН определяются по формулам:
, (6.5)
, (6.6)
Очевидно, что точность оценок вероятности ошибки и коэффициента ошибки растет с увеличением N. Общее число символов цифрового сигнала, переданных за интервал измерения T, зависит от скорости передачи B: N = TB. Отсюда следует, что чем больше скорость передачи, тем быстрее и точнее можно оценить коэффициент ошибок.
6.2. Математическое выражение коэффициента битовых ошибок
Определим коэффициент битовых ошибок для реальных приёмников, которым свойственно наличие различных источников шумов. При этом будем считать, что приёмник принимает решение, какой бит (0 или 1) был передан в каждом битовом интервале путем стробирования фототока. Очевидно, что из-за наличия шумов данное решение может быть неверным, что приводит к появлению ошибочных битов. Поэтому, чтобы определить коэффициент битовых ошибок, необходимо понять, каким образом приемник принимает решение относительно переданного бита.
Обозначим через I1 и I0 фототоки, стробированные приемником в течение 1 и 0 битов, соответственно, а через s12 и s02 соответствующие шумы. Принимая, что последние имеют гауссовское распределение, проблема установления истинного значения принятого бита имеет следующую математическую формулировку. Фототок для битов 1 и 0 является выборкой гауссовской переменной со средним значением I1 и вариацией s1, а приёмник должен отслеживать этот сигнал и решать, является ли переданный бит 0 или 1. При этом существует много возможных правил принятия решения, которые могут быть реализованы в приёмнике с целью минимизации коэффициента битовых ошибок. Для значения фототока I этим оптимальным решением является наиболее вероятное значение переданного бита, которое определяется путём сравнения текущего значения фототока с пороговым значением Iп, используемым для принятия решения.
Рисунок 6.1. Функция плотности вероятности фототока принятых сигналов
Пусть при I ³ Iп принимается решение о том, что был передан бит 1, в противном случае – бит 0. Когда биты 1 и 0 равновероятны, что и рассматривается в дальнейшем, пороговый ток приблизительно равен:
(6.7)
Геометрически Iп представляет собой значение тока I, для которого две кривые плотности вероятностей (рис. 6.1) пересекаются.
Вероятность того, что I < Iп, т. е. вероятность ошибки при передаче бита 1, обозначим через Р0,1, а вероятность решения для переданного бита 1, когда I ³ Iп при переданном 0, обозначим Р1,0.
Пусть Q(х) обозначает вероятность того, что нулевая средняя вариация гауссовской переменной превышает значение х, тогда:
(6.8)
а
(6.9)
а
(6.10)
Можно показать [14], что BER определяется,
(6.11)
Очень важно отметить, что в ряде случаев эффективным является использование изменяемого в зависимости от уровня сигнала порога принятия решения, как, например, шума оптического усилителя. Многие высокоскоростные приёмники обладают такой особенностью. Однако более простые приемники имеют порог, соответствующий среднему уровню принимаемого тока, а именно (I1 + I0)/2. Такая настройка порогового значения дает большой коэффициент битовых ошибок, определяемый выражением [14].
(6.12)
Выражение (6.11) можно использовать для оценки BER, когда известны как мощность полученного сигнала, соответствующего битам 0 и 1, так и статистика шумов.
6.3. Нормы на параметры ошибок систем передачи
Битовые ошибки являются основным источником ухудшения качества связи, проявляющегося в искажении речи в телефонных каналах, недостоверности передачи информации или снижении пропускной способности передачи данных, и характеризуются статистическими параметрами и нормами на них, которые определены соответствующей вероятностью выполнения этих норм. Последние делятся на долговременные и оперативные нормы, первые из которых определяются рекомендациями ITU-T G.821 и G.826, а вторые – М.2100, М.2110 и М.2120, при этом, согласно М.2100, качество цифрового тракта по критерию ошибок делят на три категории:
- нормальное – BER < 10-6;
- пониженное – 10-6 ≤ BER < 10-3 (предаварийное состояние);
- неприемлемое – BER ≥ 10-3 (аварийное состояние).
Так как появление ошибок является следствием совокупности всех текущих условий передачи цифровых сигналов, имеющих случайный характер, то при отсутствии данных о законе распределения ошибок его отдельные элементы могут быть определены с определенной степенью достоверности только по результатам продолжительных измерений. В то же время на практике необходимо, чтобы значения параметров ошибок для ввода в эксплуатацию и технического обслуживания систем передачи основывались на достаточно коротких интервалах времени измерения. Исходя из этого, были определены следующие параметры ошибок [14]:
- секунда с ошибками (error second, ES) – односекундный интервал, содержащий хотя бы один ошибочный бит;
- секунда, пораженная ошибками (severely error second, SES) – односекундный интервал с BER ≥ 10-3.
Данные параметры ошибок должны оцениваться в течение времени готовности (available time), отсчет которого начинается с первой секунды из десяти следующих друг за другом секунд, в каждой из которых BER<10-3. ITU-T M.2100 регламентирует нормы качества (performance objectives, PO) на выраженные максимальным процентом времени параметры ошибок, которые зависят только от скорости передачи и приводятся для условного эталонного соединения (hypothetical reference connection, HRC/HRX/) длиной 27500 км. При этом нормы качества распределяются по участкам соединения соответствующей категории качества. В качестве эталонной модели такого распределения принимается участок высокой категории качества протяженностью 25000 км, которому присваивается 40% от общей нормы качества на параметры ошибок передачи точка-точка, что в пересчете на 1 км, дает 0.0016 %/км.. Остальные 4 участка (2 среднего качества и 2 с приемлемым качеством) длиной 2 х 1250 км расположены по обе стороны от центрального. Поэтому распределение, пропорциональное протяженности L км тракта высокой категории качества, будет определяться, как
AL = 0.0016 · L %/км. (6.13)
Нормы качества на цифровые тракты и каналы подразделяются на настроечные и эксплуатационные, причем вводимые в эксплуатацию впервые или после проведения корректирующих действий они должны сдаваться по настроечным нормам качества, а в процессе эксплуатации должны соответствовать эксплуатационным нормам. Обычно [105] эксплуатационная норма представляется в виде эталонной нормы качества (reference performance objective, RPO)
RPO = A · T · PO, (6.14)
а настроечная, включающая запас на старение, используемая при вводе в эксплуатацию (bringing into service objective, BISO), определяется, как половина RPO, т.е.
BISO = RPO/2. (6.15)
Здесь PO – норма качества оцениваемого параметра, а T = 86400 с (одни сутки) – продолжительность измерений (количество односекундных интервалов).
Для анализа результатов, полученных в процессе измерений, используются также предельные значения S1и S2 норм (рисунок 6.2), которые соответствуют числу событий (ES,SES) и определяются, как:
S1 = RPO/2 – D и S2 = RPO/2 + D, (6.16)
где D = 2 — дисперсия оцениваемого параметра.
Рисунок 6.2. Предельные значения и условия ввода в эксплуатацию системы передачи
При соответствии результатов измерений норме S1 цифровой тракт может быть введен в эксплуатацию без всякого сомнения, а при превышении нормы S2 в обязательном порядке требуется повышение качества испытываемого цифрового тракта, т.е. должны быть проведены корректирующие действия с повторными измерениями. Если значение ES или SES лежит в интервале от S1 до S2, цифровой тракт может быть введен в эксплуатацию условно или временно с продолжением измерений в течение 7 суток. Данный подход к оценке качества цифровых систем передачи по параметрам ошибок позволяет сократить время измерений и получить норму цифрового тракта суммированием норм цифровых участков. При этом значения RPO, D, S1 и S2 выражаются в виде числа событий за установленный интервал времени, а не в виде процентов времени.
Для измерения коэффициента ошибок разработан ряд специальных BER анализаторов – измерителей коэффициента ошибок, включающих генераторы псевдослучайных и детерминированных последовательностей передаваемых кодированных символов, а также приемное оборудование, осуществляющее собственно измерение коэффициента ошибок. В случае посимвольного сравнения кодов измерение может быть выполнено с использованием шлейфа, т.е. путем измерения ошибок с одной оконечной станции при установке на противоположном конце шлейфа. Другой метод основан на выделении ошибок благодаря избыточности используемых кодов и используется для измерений от передающей до приемной сторон тракта или участка линии, т.е. когда выделение и фиксация ошибок производятся на ее приемном конце. Очевидно, что в первом случае требуется использование одного комплекта, а во втором – двух комплектов приборов. При этом измеренное значение коэффициента ошибок отражает качество передачи при прохождении сигнала в обоих направлениях и в каждом направлении соответственно.
6.4. Принципы построения измерителей ошибок
В зависимости от скорости передачи контролируемой системы передачи в анализаторе используются различные схемотехнические решения.
Рисунок 6.3. Генератор низкоскоростного BER анализатора
Низкоскоростной генератор тестовых кодов и детектор ошибок. Используемый в телекоммуникациях анализатор BER, состоящий [106] из генератора тестовых кодов и собственно анализатора ошибок, представлен на рисунках 6.3 и 6.4. Он предназначен для невысоких (до 200 Мбит/с) битовых скоростей, учитывая, что максимальные типовые скорости составляют 44.736 Мбит/с (DS3) в Северной Америке и 139.364 Мбит/с – за пределами Северной Америки.
PRBS с генератором кодовых групп, представленный на рис. 6.16, синхронизируется либо от источника тактового сигнала с фиксированной частотой (согласно G.703), либо от синтезатора, осуществляя тем самым изменение частоты синхронизации. В связи с этим использование данных средств требует задания некоторых определенных частот синхронизации и наличия возможности обеспечения их небольших смещений от ±15 до ±50 ppm. Для повторения тестовых кодов схема PRBS и генератор кодовых групп обычно имеют триггерную схему, управляющую либо выходным усилителем бинарных данных, который обеспечивает данные и данные с сопровождающим синхросигналом, либо выходную схему кодированных данных. Это позволяет создавать цикловую синхронизацию сигнала в соответствии с требованием, например, системы SONET/SDH. Кроме этого, данная схема способствует созданию соответствующего интерфейсного кода для эффективного восстановления тактовой синхронизации. Выходной усилитель обеспечивает необходимый уровень сигнала в соответствии со спецификацией электрического интерфейса, в том числе сигнала с чередованием полярности импульсов.
Рисунок 6.4. Низкоскоростной детектор ошибок
Детектор ошибок, показанный на рисунке 6.4, получает стандартный кодированный сигнал, восстанавливает генератор синхросигнала и устраняет кодирование для обеспечения бинарной даты и синхросигналов. Он обнаруживает любые нарушения алгоритма интерфейсного кода и посылает сигналы на счетчик ошибок, что составляет первый уровень процесса обнаружения ошибок. При работе с цикловыми сигналами приемник захватывает любой присутствующий элемент цикловой синхронизации, проверяет наличие цикловых ошибок и декодирует любые встроенные сигналы тревоги, или CRC биты, тем самым обеспечивая возможность измерения.
Наконец, бинарные данные и синхросигнал направляются на детектор ошибок и генератор эталонных тестовых кодов, которые проверяют полученный тестовый код бит за битом на предмет обнаружения логических ошибок. Временная база контролирует пропускание измерения для непрерывного, периодического и ручного режима. Накопленное количество ошибок обрабатывается для получения значения BER и анализа функционирования при наличии ошибок.
Высокоскоростной генератор тестовых кодов и детектор ошибок. На рисунках 6.5 и 6.6 показаны схемы [14] для 3 Гбит/с генератора тестовых кодов и детектора ошибок. Вследствие высокой битовой скорости генерация последовательных PRBS и кодовых групп на этой скорости не представляется целесообразной. Поэтому тестовые коды генерируются (рисунок 6.5) как параллельные 16-битные кодовые группы при максимальной скорости 200 Мбит/с, используя затем выполненные по биполярной технологии регистраторы смещения и высокоемкостную память. Высокоскоростные схемы обычно выполняются на основе арсенид-галлиевых логических схем, преобразующих параллельные данные в последовательный поток на скорости до 3 Гбит/с.
Согласно данной схеме, вход синхросигнала генерируется синтезатором частоты, согласующее устройство управляется через линию фиксированной задержки, а генератор тестовых кодов и выходной усилитель синхронизируются через схему дискретной и плавно изменяемой задержки, так что фаза синхросигнала/данных может изменяться как в положительном направлении, так и в отрицательном. Дискретные значения задержки составляют 250, 500 и 1000 пс, тогда как диапазон плавной задержки лежит в пределах от 0 до 250 пс с 1 пс инкрементом.
Корректор временной диаграммы, связанный с выходным усилителем, пересинхронизирует данные через триггер D типа для поддержания минимального фазового дрожания. Так как подобный тип тестового устройства обычно используется при проведении лабораторных измерений, выходные уровни синхросигнала и данных и постоянные смещения могут варьироваться для того или иного конкретного случая использования.
Детектор ошибок, показанный на рис. 6.6, имеет простое параллельное соединение, в связи с чем входы синхросигнала и данных проходят через схемы дискретной и плавной задержки, обеспечивая оптимальную настройку при обнаружении ошибок для любой фазы синхросигнала/данных. Действительно, путем настройки под контролем внутреннего процессора решающего порога и фазы синхросигнала условия функционирования детектора ошибок могут быть оптимизированы автоматически. Высокоскоростной демультиплексор преобразует последовательный поток данных в 16-битные параллельные кодовые группы наряду с поделенным на 16 синхросигналом. Параллельно соединенный генератор эталонных тестовых кодов синхронизируется с входными данными и осуществляет сравнение битов, поэтому любая ошибка фиксируется одним из двух счетчиков, первый из которых подсчитывает число ошибок, а второй – общее число битов. Процессор измерения обеспечивает анализ функционирования при наличии ошибок с разрешением до 1 мс.
6.5. Техника измерения коэффициента ошибок
Рассмотрим измерение коэффициента ошибок путем посимвольного сравнения и подсчета ошибочно принятых элементарных импульсов. Для этого вначале (перед измерением) на передающей станции с помощью оптического аттенюатора устанавливают заданный в технических условиях на аппаратуру линейного тракта уровень оптического излучения. Затем на передающем конце подключают генератор испытательных сигналов, а на приемном – измеритель коэффициента ошибок и, изменяя значения уровней средней мощности, измеряют коэффициент ошибок. Время измерения определяют в зависимости от скорости передачи, объема информации и значений коэффициента ошибок Кошi (BERi).
Коэффициент ошибок при заданном уровне оптического излучения вычисляют по формуле [14]
(6.17)
где
, , (6.18)
где и — погрешность и среднее значение коэффициента ошибок при пяти и более измерениях с интервалом 3 мин, соответственно, a — коэффициент, учитывающий наличие погрешности измерения при проведении n измерений.
В предыдущей статье были рассмотрены общие аспекты оценки качества и измерений в цифровых системах связи. Дальнейшее рассмотрение начнем с анализа методов оценки качества сигнала.
ГЛАЗ-ДИАГРАММА
Удобным (и гениально простым!) графическим методом оценки качества цифрового сигнала на выходе регенератора является глаз-диаграмма. Она представляет собой результат наложения всех возможных импульсных последовательностей в течение промежутка времени, равного двум тактовым интервалам линейного сигнала.
Наиболее простой пример — диаграмма для троичного (возможные уровни -1, 0, +1) линейного сигнала при косинус-квадратной форме входного сигнала регенератора. Хорошо видна область («раскрыв») глаз-диаграммы, в пределах которой должна производиться операция опознания сигнала для каждого из двух уровней решения. Горизонтальные линии, обозначенные как -1, 0 и +1, соответствуют амплитудам импульсов при отсутствии помех, а вертикальные линии через каждый тактовый интервал Т — идеальным моментам решения.
Процесс принятия решения показан в виде двух крестиков в каждом «раскрыве» глаз-диаграммы. Вертикальная черта каждого крестика определяет момент решения, а горизонтальная — его уровень. Гарантией безошибочной регенерации цифрового сигнала является наличие вблизи каждого крестика определенной области, в пределах которой и должно происходить опознание сигнала.
Наличие помех приводит к сокращению этой области по сравнению с идеальным случаем. Минимальное расстояние между центром крестиков и краями «глаза» служит мерой запаса помехозащищенности. Запас уменьшается как из-за искажений формы импульса, так и вследствие несовершенства самого процесса принятия решения. Первая причина приводит к уменьшению «раскрыва» глаз-диаграммы, а вторая — к перемещению точки принятия решения вдоль границ глаза. Возникающие вследствие двух указанных причин искажения принято подразделять на амплитудные и временные, соответствующие смещению точки принятия решения по вертикали и горизонтали. Для удобства дальнейших рассуждений будем считать, что точка принятия решения остается неподвижной, а уменьшается «раскрыв».
Степень уменьшения «раскрыва» глаз-диаграммы по вертикали определяется результирующими искажениями, вызванными межсимвольными помехами, эхосигналами, изменениями амплитуды импульсов на выходе регенератора, погрешностями порогов решающих устройств. В результате воздействий появляется вертикальная составляющая искажений глаз-диаграммы ΔA. Именно на эту величину должны быть сдвинуты края идеальной глаз-диаграммы.
Временные искажения глаз-диаграммы ΔТ, включающие несоответствие моментов решения их статическим значениям и джиттер, учитываются обычно в смещении границ «глаза» по горизонтали.
Очевидно, что для компенсации ухудшения реальной глаз-диаграммы по сравнению с идеальной необходимо увеличить величину отношения сигнал/шум на величину ΔS/N = 20 lg (H/h), дБ, где H и h представляют собой вертикальный «раскрыв» идеальной и реальной глаз-диаграмм, соответственно.
КОЭФФИЦИЕНТ БИТОВЫХ ОШИБОК
Ключевым параметром качества ЦСП являются ошибки. Показателей ошибок множество, все они будут по-очередно рассмотрены ниже. Самый простой из них — коэффициент битовых ошибок (Bit Error Ratio, BER). Напомним, что под BER следует понимать отношение количества ошибочных битов к их общему переданному числу.
Необходимо отметить, что при прочих равных условиях BER зависит от количества переданных битов. Например, длинная последовательность одинаковых символов может вызвать низкочастотную амплитудную модуляцию и детерминированный джиттер, следствием которых будет рост числа ошибок. Для обеспечения корректности сравнения разных ЦСП используются типовые испытательные последовательности, причем каждой стандартной скорости передачи соответствует своя испытательная последовательность. По своим свойствам они близки к гауссову шуму, но имеют определенный период повторения. Поэтому они называются не просто случайными, а псевдослучайными последовательностями (ПСП) (Pseudo-Random Bit Sequence, PRBS).
Следует особо подчеркнуть, что оценка BER будет абсолютно точной только при бесконечно большом числе переданных битов. Строго говоря, когда их число ограничено, мы получаем не вероятность события BER, а его оценку BERT. Очевидно, что уровень достоверности этой оценки (Confidential Level, CL), называемый также доверительной вероятностью, зависит от количества зарегистрированных ошибок и от общего числа переданных битов N.
Это подтверждают данные таблицы (см. Таблицу 1), где приведены требуемые значения нормированной длительности NxBER в зависимости от числа зарегистрированных ошибок Е и уровня достоверности оценки CL — чем больше число зарегистрированных ошибок и уровень достоверности оценки CL, тем большее число битов необходимо передать.
Типовая схема измерения BER предполагает наличие генератора испытательных битовых (символьных) последовательностей тестера BER, испытуемого объекта (регенератора, участка ЦСП и т. д.) и детектора ошибок тестера BER.
Генератор тестера BER формирует испытательные сигналы, которые подаются на вход тестируемого объекта. Генератор тестируемого сигнала является также источником сигнала для детектора ошибок тестера BER.
Тестируемый объект может быть территориально совмещен с тестером BER или находиться в удаленном пункте. В любом случае испытуемый объект должен быть выведен из эксплуатации и сигнал с его выхода подан на вход приемника тестера BER. Как говорят связисты, должен быть организован измерительный шлейф.
Детектор ошибок получает испытательный сигнал с выхода тестируемого объекта или формирует точную копию этого сигнала автономно. Испытательный сигнал генератора сравнивается побитно с сигналом, поступающим с выхода испытуемого объекта. Каждое различие сигналов детектор фиксирует как битовую ошибку.
Необходимую синфазность двух указанных сигналов обеспечивает детектор ошибок, в котором предусмотрена требуемая задержка сигнала с выхода генератора. Задача фазирования сигналов обычно выполняется на этапе калибровки тестера BER.
Испытательные сигналы тестеров BER стандартизованы. Как уже отмечалось выше, информационный сигнал в тестерах BER имитируется в виде так называемых псевдослучайных последовательностей ПСП (PRBS), они формируются в соответствии со стандартными алгоритмами и различаются числом генерируемых символов M = 2k-1 , где k — целое число.
В генераторах тестеров BER предусмотрена возможность создания произвольных испытательных последовательностей, называемых обычно кодовыми словами.
Очевидным недостатком BER является необходимость вывода тестируемого объекта из эксплуатации (Out of Service, OoS), что вполне приемлемо в процессе разработки или ремонта объекта и неудобно, если ЦСП уже эксплуатируется. Кроме того, параметр BER хорош для оценки влияния одиночных помех, обусловленных гауссовыми процессами, например собственными и переходными помехами. В то же время в любой реальной системе связи присутствуют и целые пакеты таких ошибок (их еще называют серийными ошибками). Поэтому без знания временной структуры ошибок системы связи невозможна эффективная локализация повреждений и накопление адекватной информации о качестве разработки и инсталляции оборудования. По сути, одного параметра BER недостаточно для корректной оценки работы ЦСП. Необходимы более адекватные, учитывающие структуру помех, показатели качества ЦСП с возможностью их мониторинга в процессе нормальной эксплуатации системы связи (In Service Monitoring, ISM). Но об этом уже в следующей статье.
Игорь Иванцов — менеджер отдела «Инструменты и приборы для монтажа и обслуживания телекоммуникационных систем» компании «СвязьКомплект». С ним можно связаться по тел. (095) 362-7787, по адресам: info@skomplekt.com, http://www.skomplekt.com.
Таблица 1. Требуемые значения нормированной длительности.
E | CL = 90% | CL = 95% | CL = 99% |
NxBER | |||
0 | 2,3 | 3 | 4,61 |
1 | 3,89 | 4,74 | 6,64 |
2 | 5,32 | 6,3 | 8,4 |
Теоретические результаты
Общее обозначение
Следующее обозначение используется в этом Приложении:
Количество или операция | Обозначение |
---|---|
Размер созвездия модуляции |
M |
Количество битов на символ |
k=log2M |
Энергия на отношение спектральной плотности степени бита к шуму |
EbN0 |
Энергия на отношение спектральной плотности степени символа к шуму |
EsN0=kEbN0 |
Частота ошибок по битам (BER) |
Pb |
Коэффициент ошибок символа (SER) |
Ps |
Действительная часть |
Re[⋅] |
Самое большое целое число, меньшее, чем |
⌊⋅⌋ |
Следующие математические функции используются:
Функция | Математическое выражение |
---|---|
Q функция |
Q(x)=12π∫x∞exp(−t2/2)dt |
Marcum Q функция |
Q(a,b)=∫b∞texp(−t2+a22)I0(at)dt |
Модифицированная функция Бесселя первого рода порядка ν |
Iν(z)=∑k=0∞(z/2)υ+2kk!Γ(ν+k+1) где Γ(x)=∫0∞e−ttx−1dt гамма функция. |
Вырожденная гипергеометрическая функция |
F11(a,c;x)=∑k=0∞(a)k(c)kxkk! где символ Pochhammer, (λ)k, задан как (λ)0=1, (λ)k=λ(λ+1)(λ+2)⋯(λ+k−1). |
Следующие акронимы используются:
Акроним | Определение |
---|---|
M-PSK | M-арное манипулирование сдвига фазы |
DE-M-PSK | Дифференцированно закодированное M-арное манипулирование сдвига фазы |
BPSK | Бинарное манипулирование сдвига фазы |
DE-BPSK | Дифференцированно закодированное бинарное манипулирование сдвига фазы |
QPSK | Четвертичное манипулирование сдвига фазы |
DE-QPSK | Дифференцированно закодированное квадратурное манипулирование сдвига фазы |
OQPSK | Возместите квадратурное манипулирование сдвига фазы |
DE-OQPSK | Дифференцированно закодированное квадратурное манипулирование сдвига фазы смещения |
M-DPSK | M-арное дифференциальное манипулирование сдвига фазы |
M-PAM | M-арная импульсная амплитудная модуляция |
M-QAM | M-арная квадратурная амплитудная модуляция |
M-FSK | M-арное манипулирование сдвига частоты |
MSK | Минимальное манипулирование сдвига |
M-CPFSK | M-арное манипулирование сдвига частоты непрерывной фазы |
Аналитические Выражения, Используемые в berawgn
-
M-PSK
-
DE-M-PSK
-
OQPSK
-
DE-OQPSK
-
M-DPSK
-
M-PAM
-
M-QAM
-
Ортогональный M-FSK с когерентным обнаружением
-
Неортогональный 2-FSK с когерентным обнаружением
-
Ортогональный M-FSK с некогерентным обнаружением
-
Неортогональный 2-FSK с некогерентным обнаружением
-
Предварительно закодированный MSK с когерентным обнаружением
-
Дифференцированно закодированный MSK с когерентным обнаружением
-
MSK с некогерентным обнаружением (оптимальный блок блоком)
-
CPFSK когерентное обнаружение (оптимальный блок блоком)
M-PSK. От уравнения 8.22 в [2]
Следующее выражение очень близко, но не строго равно к точному BER (от [4] и уравнение 8.29 от [2]):
где wi’=wi+wM−i, wM/2’=wM/2, wiвес Хэмминга битов, присвоенных символу i, и
Особый случай M=2, e.g., BPSK (уравнение 5.2-57 от [1]):
Особый случай M=4, e.g., QPSK (уравнения 5.2-59 и 5.2-62 от [1]):
DE-M-PSK. M=2, e.g., DE-BPSK (уравнение 8.36 от [2]):
M=4, e.g., DE-QPSK (уравнение 8.38 от [2]):
От уравнения 5 в [3]:
OQPSK. Тот же BER/SER как QPSK [2].
DE-OQPSK. Тот же BER/SER как DE-QPSK [3].
M-DPSK. От уравнения 8.84 в [2]:
Следующее выражение очень близко, но не строго равно к точному BER [4]:
где wi’=wi+wM−i, wM/2’=wM/2, wi вес Хэмминга битов, присвоенных символу i, и
Особый случай M=2 (уравнение 8.85 от [2]):
M-PAM. От уравнений 8.3 и 8.7 в [2] и уравнения 5.2-46 в [1]:
От [5]:
M-QAM. Для квадратного M-QAM, k=log2M является четным (уравнение 8.10 от [2] и уравнения 5.2-78 и 5.2-79 от [1]):
От [5]:
Для прямоугольного (неквадратного) M-QAM, k=log2M является нечетным, M=I×J, I=2k−12, и J=2k+12:
От [5]:
где
и
Ортогональный M-FSK с Когерентным Обнаружением. От уравнения 8.40 в [2] и уравнения 5.2-21 в [1]:
Неортогональный 2-FSK с когерентным обнаружением. Для M=2 (от уравнения 5.2-21 в [1] и уравнения 8.44 в [2]):
ρкомплексный коэффициент корреляции:
где s˜1(t) и s˜2(t) комплексные сигналы lowpass, и
Например:
где Δf=f1−f2.
(от уравнения 8.44 в [2], где h=ΔfTb)
Ортогональный M-FSK с Некогерентным Обнаружением. От уравнения 5.4-46 в [1] и уравнения 8.66 в [2]:
Неортогональный 2-FSK с некогерентным обнаружением. Для M=2 (от уравнения 5.4-53 в [1] и уравнения 8.69 в [2]):
где
Предварительно закодированный MSK с когерентным обнаружением. Тот же BER/SER как BPSK.
Дифференцированно закодированный MSK с когерентным обнаружением. Тот же BER/SER как DE-BPSK.
MSK с Некогерентным Обнаружением (Оптимальный Блок Блоком). Верхняя граница (от уравнений 10.166 и 10.164 в [6]):
где
CPFSK Когерентное Обнаружение (Оптимальный Блок Блоком). Нижняя граница (от уравнения 5.3-17 в [1]):
Верхняя граница:
где h является индексом модуляции, и Kδmin количество путей, имеющих минимальное расстояние.
Аналитические Выражения, Используемые в berfading
-
Обозначение
-
M-PSK с MRC
-
DE-M-PSK с MRC
-
M-PAM с MRC
-
M-QAM с MRC
-
M-DPSK с постобнаружением EGC
-
Ортогональный 2-FSK, когерентное обнаружение с MRC
-
Неортогональный 2-FSK, когерентное обнаружение с MRC
-
Ортогональный M-FSK, некогерентное обнаружение с EGC
-
Неортогональный 2-FSK, некогерентное обнаружение без разнообразия
Обозначение. Следующее обозначение используется для выражений, найденных в berfading
.
Значение | Обозначение |
---|---|
Степень исчезающего амплитудного r | Ω=E[r2], где E[⋅] обозначает статистическое ожидание |
Количество ветвей разнообразия |
L |
ОСШ на символ на ветвь |
γ¯l=(ΩlEsN0)/L=(ΩlkEbN0)/L Для тождественно распределенных ветвей разнообразия: γ¯=(ΩkEbN0)/L |
Производящие функции момента для каждой ветви разнообразия |
Релеевское замирание: Mγl(s)=11−sγ¯l Исчезновение Rician: Mγl(s)=1+K1+K−sγ¯le[Ksγ¯l(1+K)−sγ¯l] где K является отношением энергии в зеркальном компоненте к энергии в рассеянном компоненте (линейная шкала). Для тождественно распределенных ветвей разнообразия:Mγl(s)=Mγ(s) для всего l. |
Следующие акронимы используются:
Акроним | Определение |
---|---|
MRC | объединение максимального отношения |
EGC | объединение равного усиления |
M-PSK с MRC. От уравнения 9.15 в [2]:
От [4] и [2]:
где wi’=wi+wM−i, wM/2’=wM/2, wi вес Хэмминга битов, присвоенных символу i, и
Для особого случая Релеевского замирания с M=2 (от уравнений C-18, C-21 и Таблицы c-1 в [6]):
где
Если L=1:
DE-M-PSK с MRC. Для M=2 (от уравнений 8.37 и 9.8-9.11 в [2]):
M-PAM с MRC. От уравнения 9.19 в [2]:
От [5] и [2]:
M-QAM с MRC. Для квадратного M-QAM, k=log2M является четным (уравнение 9.21 в [2]):
От [5] и [2]:
Для прямоугольного (неквадратного) M-QAM, k=log2M является нечетным, M=I×J, I=2k−12, J=2k+12, γ¯l=Ωllog2(IJ)EbN0, и
От [5] и [2]:
M-DPSK с Постобнаружением EGC. От уравнения 8.165 в [2]:
От [4] и [2]:
где wi’=wi+wM−i, wM/2’=wM/2, wi вес Хэмминга битов, присвоенных символу i, и
Для особого случая Релеевского замирания с M=2, и L=1 (уравнение 8.173 от [2]):
Ортогональный 2-FSK, Когерентное Обнаружение с MRC. От уравнения 9.11 в [2]:
Для особого случая Релеевского замирания (уравнения 14.4-15 и 14.4-21 в [1]):
Неортогональный 2-FSK, когерентное обнаружение с MRC. Уравнения 9.11 и 8.44 в [2]:
Для особого случая Релеевского замирания с L=1 (уравнение 20 в [8] и уравнение 8.130 в [2]):
Ортогональный M-FSK, Некогерентное Обнаружение с EGC. Релеевское замирание (уравнение 14.4-47 в [1]):
Исчезновение Rician (уравнение 41 в [8]):
где
и I[a,b](i)=1 если a≤i≤b и 0 в противном случае.
Неортогональный 2-FSK, Некогерентное Обнаружение без Разнообразия. От уравнения 8.163 в [2]:
где
Аналитические Выражения, Используемые в bercoding и BERTool
-
Общее обозначение для этого раздела
-
Блочное кодирование
-
Сверточное кодирование
Общее обозначение для этого раздела
Описание | Обозначение |
---|---|
Отношение спектральной плотности степени бита к шуму энергии на информацию |
γb=EbN0 |
Передайте длину |
K |
Разрядность кода |
N |
Уровень кода |
Rc=KN |
Блочное кодирование. Определенное обозначение для выражений блочного кодирования: dmin минимальное расстояние кода.
Мягкое решение
BPSK, QPSK, OQPSK, PAM-2, QAM-4 и предварительно закодированный MSK (уравнение 8.1-52 в [1]):
DE-BPSK, DE-QPSK, DE-OQPSK и DE-MSK:
BFSK, когерентное обнаружение (уравнения 8.1-50 и 8.1-58 в [1]):
BFSK, некогерентное квадратичное обнаружение (уравнения 8.1-65 и 8.1-64 в [1]):
DPSK:
Трудное решение
Общий линейный блочный код (уравнения 4.3, 4.4 в [9], и 12.136 в [6]):
Код Хемминга (уравнения 4.11, 4.12 в [9], и 6.72, 6.73 в [7]):
(24, 12), расширил код Golay (уравнение 4.17 в [9], и 12.139 в [6]):
где βm среднее количество ошибок символа канала, которые остаются в откорректированном N — кортеж, когда канал вызвал ошибки символа m (таблица 4.2 в [9]).
Код тростника-Solomon с N=Q−1=2q−1:
для FSK (уравнения 4.25, 4.27 в [9], 8.1-115, 8.1-116 в [1], 8.7, 8.8 в [7], и 12.142, 12.143 в [6]), и
в противном случае.
Если log2Q/log2M=q/k=h где h является целым числом (уравнение 1 в [10]):
где s является коэффициентом ошибок символа (SER) в незакодированном канале AWGN.
Например, для BPSK, M=2 и Ps=1−(1−s)q
В противном случае, Ps дан таблицей 1 и уравнением 2 в [10].
Сверточное Кодирование. Определенное обозначение для сверточных выражений кодирования: dfree свободное расстояние кода, и ad количество путей расстояния d от все-нулевого пути, которые объединяют со все-нулевым путем впервые.
Мягкое решение
От уравнений 8.2-26, 8.2-24, и 8.2-25 в [1], и уравнений 13.28 и 13.27 в [6]:
с передаточной функцией
где f(d) экспонента N как функция d.
Результаты для BPSK, QPSK, OQPSK, PAM-2, QAM-4, предварительно закодировали MSK, DE-BPSK, DE-QPSK, DE-OQPSK, DE-MSK, DPSK, и BFSK получен как:
где Pb BER в соответствующем незакодированном канале AWGN. Например, для BPSK (уравнение 8.2-20 в [1]):
Трудное решение
От уравнений 8.2-33, 8.2-28, и 8.2-29 в [1], и уравнений 13.28, 13.24, и 13.25 в [6]:
где
когда d является нечетным, и
когда d является четным (p является частотой ошибок по битам (BER) в незакодированном канале AWGN).
Результаты эффективности через Симуляцию
-
Разделите обзор
-
Используя симулированные данные, чтобы вычислить коэффициенты ошибок бита и символа
-
Пример: вычисление коэффициентов ошибок
-
Сравнение коэффициента ошибок символа и частоты ошибок по битам
Разделите обзор
Один способ вычислить частоту ошибок по битам или коэффициент ошибок символа для системы связи состоит в том, чтобы симулировать передачу сообщений данных и сравнить все сообщения до и после передачи. Симуляция компонентов системы связи с помощью Communications Toolbox™ покрыта другими частями этого руководства. В этом разделе описывается сравнить сообщения данных, которые вводят и оставляют симуляцию.
Другой пример вычислительных результатов эффективности через симуляцию находится в Curve Fitting для Графиков Коэффициента ошибок в обсуждении аппроксимирования кривыми.
Используя симулированные данные, чтобы вычислить коэффициенты ошибок бита и символа
biterr
функция сравнивает два набора данных и вычисляет количество битовых ошибок и частоты ошибок по битам. symerr
функция сравнивает два набора данных и вычисляет количество ошибок символа и коэффициента ошибок символа. Ошибка является несоответствием между соответствующими точками в двух наборах данных.
Из двух наборов данных обычно каждый представляет сообщения, вводящие передатчик, и другой представляет восстановленные сообщения, оставляя приемник. Вы можете также сравнить ввод данных и отъезд других частей вашей системы связи, например, данные, вводящие энкодер и данные, оставив декодер.
Если ваша система связи использует несколько битов, чтобы представлять один символ, подсчет битовых ошибок отличается от подсчета ошибок символа. Или в бите — или в считающем символ случае, коэффициент ошибок является количеством ошибок, разделенных на общее количество (битов или символов) переданный.
Примечание
Чтобы гарантировать точный коэффициент ошибок, необходимо обычно симулировать достаточно данных, чтобы произвести по крайней мере 100 ошибок.
Если коэффициент ошибок очень мал (например, 10-6 или меньший), полуаналитический метод может вычислить результат более быстро, чем подход только для симуляции. Смотрите Результаты Эффективности через Полуаналитический Метод для получения дополнительной информации о том, как использовать этот метод.
Пример: вычисление коэффициентов ошибок
Скрипт ниже использует symerr
функция, чтобы вычислить коэффициенты ошибок символа для шумного линейного блочного кода. После искусственного добавления шума к закодированному сообщению это сравнивает получившийся шумный код с оригинальным кодом. Затем это декодирует и сравнивает декодируемое сообщение с исходным.
m = 3; n = 2^m-1; k = n-m; % Prepare to use Hamming code. msg = randi([0 1],k*200,1); % 200 messages of k bits each code = encode(msg,n,k,'hamming'); codenoisy = rem(code+(rand(n*200,1)>.95),2); % Add noise. % Decode and correct some errors. newmsg = decode(codenoisy,n,k,'hamming'); % Compute and display symbol error rates. noisyVec = step(comm.ErrorRate,code,codenoisy); decodedVec = step(comm.ErrorRate,msg,newmsg); disp(['Error rate in the received code: ',num2str(noisyVec(1))]) disp(['Error rate after decoding: ',num2str(decodedVec(1))])
Выход ниже. Уменьшения коэффициента ошибок после декодирования, потому что декодер Хэмминга корректирует некоторые ошибки. Ваши результаты могут варьироваться, потому что этот пример использует случайные числа.
Error rate in the received code: 0.054286 Error rate after decoding: 0.03
Сравнение коэффициента ошибок символа и частоты ошибок по битам
В примере выше, ошибки символа и битовые ошибки являются тем же самым, потому что каждый символ немного. Команды ниже иллюстрируют различие между ошибками символа и битовыми ошибками в других ситуациях.
a = [1 2 3]'; b = [1 4 4]'; format rat % Display fractions instead of decimals. [snum,srate] = symerr(a,b) [bnum,brate] = biterr(a,b)
Выход ниже.
snum = 2 srate = 2/3 bnum = 5 brate = 5/9
bnum
5, потому что вторые записи отличаются по двум битам, и третьи записи отличаются по трем битам. brate
5/9, потому что общее количество битов равняется 9. Общее количество битов является, по определению, количеством записей в a
или b
времена максимальное количество битов среди всех записей a
и b
.
Результаты эффективности через Полуаналитический Метод
Метод, описанный в Результатах Эффективности через Моделирование хорошо для большого множества систем связи, но, может быть предельно длительным, если коэффициент ошибок системы очень мал (например, 10-6 или меньше). В этом разделе описывается использовать полуаналитический метод в качестве альтернативного способа вычислить коэффициенты ошибок. Для определенных типов систем полуаналитический метод может привести к результатам намного более быстро, чем неаналитический метод, который использует только симулированные данные.
Полуаналитический метод использует комбинацию симуляции и анализа, чтобы определить коэффициент ошибок системы связи. semianalytic
функция в Communications Toolbox помогает вам реализовать полуаналитический метод путем выполнения части анализа.
Когда использовать полуаналитический метод
Полуаналитический метод работает хорошо на определенные типы систем связи, но не на других. Полуаналитический метод применим, если система имеет все эти характеристики:
-
Любые эффекты многопутевого исчезновения, квантования и нелинейности усилителя должны предшествовать эффектам шума в фактическом смоделированном канале.
-
Приемник отлично синхронизируется с поставщиком услуг, и синхронизирующий дрожание незначительно. Поскольку шум фазы и синхронизирующий дрожание является медленными процессами, они уменьшают применимость полуаналитического метода к системе связи.
-
Бесшумная симуляция не имеет никаких ошибок в полученном сигнальном созвездии. Искажения из источников кроме шума должны быть достаточно умеренными, чтобы сохранить каждую точку сигнала в ее правильной области решения. Если дело обстоит не так, расчетный BER является слишком низким. Например, если смоделированная система имеет вращение фазы, которое помещает полученные очки сигнала за пределами их соответствующих областей решения, полуаналитический метод не подходит, чтобы предсказать производительность системы.
Кроме того, semianalytic
функция принимает, что шум в фактическом смоделированном канале является Гауссовым. Для получения дополнительной информации о том, как адаптировать полуаналитический метод к негауссову шуму, смотрите обсуждение обобщенных экспоненциальных распределений в [11].
Процедура для полуаналитического метода
Процедура ниже описывает, как вы обычно реализовывали бы полуаналитический метод с помощью semianalytic
функция:
-
Сгенерируйте сигнал сообщения, содержащий, по крайней мере, символы ML, где M является размером алфавита модуляции, и L является длиной импульсной характеристики канала в символах. Общий подход должен начать с увеличенного бинарного псевдошума (PN) последовательность общей длины
(log2M)ML
. Увеличенная псевдошумовая последовательность является псевдошумовой последовательностью с дополнительным добавленным нулем, который делает распределение единиц и нулей равным. -
Модулируйте поставщика услуг с сигналом сообщения использование полосовой модуляции. Поддерживаемые типы модуляции перечислены на странице с описанием для
semianalytic
. Сформируйте результирующий сигнал с формированием меандра, с помощью фактора сверхдискретизации, что вы будете дальнейшее использование, чтобы отфильтровать модулируемый сигнал. Сохраните результат этого шага какtxsig
для дальнейшего использования. -
Отфильтруйте модулируемый сигнал с фильтром передачи. Этот фильтр часто является повышенным фильтром косинуса квадратного корня, но можно также использовать Баттерворта, функцию Бесселя, Чебышевский тип 1 или 2, эллиптического, или более общего КИХ или БИХ-фильтр. Если вы используете повышенный фильтр косинуса квадратного корня, используйте его на несверхдискретизированном модулируемом сигнале и укажите, что сверхдискретизация включает функцию фильтрации. Если вы используете другой тип фильтра, можно применить его к rectangularly сигналу импульсной формы.
-
Запустите пропущенный сигнал через бесшумный канал. Этот канал может включать многопутевые исчезающие эффекты, сдвиги фазы, нелинейность усилителя, квантование и дополнительную фильтрацию, но это не должно включать шум. Сохраните результат этого шага как
rxsig
для дальнейшего использования. -
Вызовите
semianalytic
функция с помощьюtxsig
иrxsig
данные из более ранних шагов. Задайте получить фильтр как пару входных параметров, если вы не хотите использовать фильтр функции по умолчанию. Функция фильтруетrxsig
и затем определяет вероятность появления ошибки каждого полученного очка сигнала путем аналитичного применения Гауссова шумового распределения к каждой точке. Функциональные средние значения вероятности появления ошибки по целому полученному сигналу определить полную вероятность появления ошибки. Если вероятность появления ошибки, вычисленная таким образом, является вероятностью появления ошибки символа, функция преобразует ее в небольшой коэффициент ошибок, обычно путем принятия Грэя, кодирующего. Функция возвращает частоту ошибок по битам (или, в случае модуляции DQPSK, верхней границы на частоте ошибок по битам).
Используя полуаналитический метод
Пример ниже иллюстрирует процедуру для полуаналитического метода, с помощью 16-QAM модуляции. Это также сравнивает коэффициенты ошибок, полученные из полуаналитического метода с теоретическими коэффициентами ошибок, полученными из опубликованных формул и вычисленного использования berawgn
функция. Получившийся график показывает, что полученное использование коэффициентов ошибок этих двух методов почти идентично. Несоответствия между теоретическими и вычисленными коэффициентами ошибок происходят в основном из-за смещения фазы, вставленного через бесшумную модель канала.
Сгенерируйте сигнал сообщения длины> = M^L.
M = 16; % Alphabet size of modulation L = 1; % Length of impulse response of channel msg = [0:M-1 0]; % M-ary message sequence of length > M^L
Модулируйте сигнал сообщения использование полосовой модуляции.
modsig = qammod(msg',M); % Modulate data Nsamp = 16; modsig = rectpulse(modsig,Nsamp); % Use rectangular pulse shaping.
Примените фильтр передачи.
txsig = modsig; % No filter in this example
Запустите txsig
через бесшумный канал.
rxsig = txsig*exp(1i*pi/180); % Static phase offset of 1 degree
Используйте semianalytic
функция.
Задайте получить фильтр как пару входных параметров. В этом случае цифра и логово описывают идеальный интегратор.
num = ones(Nsamp,1)/Nsamp; den = 1; EbNo = 0:20; % Range of Eb/No values under study ber = semianalytic(txsig,rxsig,'qam',M,Nsamp,num,den,EbNo); % For comparison, calculate theoretical BER. bertheory = berawgn(EbNo,'qam',M); % Plot computed BER and theoretical BER. figure; semilogy(EbNo,ber,'k*'); hold on; semilogy(EbNo,bertheory,'ro'); title('Semianalytic BER Compared with Theoretical BER'); legend('Semianalytic BER with Phase Offset',... 'Theoretical BER Without Phase Offset','Location','SouthWest'); hold off;
Теоретические результаты эффективности
-
Вычисление теоретической ошибочной статистики
-
Графический вывод теоретических коэффициентов ошибок
-
Сравнение теоретических и эмпирических коэффициентов ошибок
Вычисление теоретической ошибочной статистики
В то время как biterr
функция, обсужденная выше, может помочь вам собрать эмпирическую ошибочную статистику, вы можете также сравнить те результаты с теоретической ошибочной статистикой. Определенные типы систем связи сопоставлены с выражениями закрытой формы для частоты ошибок по битам или привязанного это. Функции, перечисленные в таблице ниже, вычисляют выражения закрытой формы для некоторых типов систем связи, где такие выражения существуют.
Тип системы связи | Функция |
---|---|
Незакодированный канал AWGN | berawgn
|
Закодированный канал AWGN | bercoding |
Незакодированный Rayleigh и Rician, исчезающий канал | berfading
|
Незакодированные AWGN образовывают канал с несовершенной синхронизацией | bersync
|
Страница с описанием каждой функции перечисляет одну или несколько книг, содержащих выражения закрытой формы, которые реализует функция.
Графический вывод теоретических коэффициентов ошибок
Этот пример использует bercoding
функция, чтобы вычислить верхние границы на частотах ошибок по битам для сверточного кодирования с декодером мягкого решения.
coderate = 1/4; % Code rate
Создайте структуру dspec
с информацией о спектре расстояния. Задайте развертку EbNo, располагаются и генерируют теоретические связанные результаты.
dspec.dfree = 10; % Minimum free distance of code dspec.weight = [1 0 4 0 12 0 32 0 80 0 192 0 448 0 1024 ... 0 2304 0 5120 0]; % Distance spectrum of code EbNo = 3:0.5:8; berbound = bercoding(EbNo,'conv','soft',coderate,dspec);
Постройте теоретические связанные результаты.
semilogy(EbNo,berbound) xlabel('E_b/N_0 (dB)'); ylabel('Upper Bound on BER'); title('Theoretical Bound on BER for Convolutional Coding'); grid on;
Ссылки
[1] Proakis, J. G. цифровая связь, 4-й Эд., McGraw-Hill, 2001.
[2] Frenger, Приятель, Приятель Ортен, и Тони Оттоссон, «Сверточные коды с Оптимальным Спектром Расстояния», Коммуникационные Буквы IEEE, Издание 3, № 11, ноябрь 1999, стр 317-319
Сравнение теоретических и эмпирических коэффициентов ошибок
Этот пример использует berawgn
функция, чтобы вычислить коэффициенты ошибок символа для импульсной амплитудной модуляции (PAM) с серией значений Eb/N0. Для сравнения код симулирует 8-PAM с каналом AWGN и вычисляет эмпирические коэффициенты ошибок символа. Код также строит теоретические и эмпирические коэффициенты ошибок символа того же набора осей.
Вычислите и постройте теоретический коэффициент ошибок с помощью berawgn
.
rng('default') % Set random number seed for repeatability M = 8; EbNo = 0:13; [ber, ser] = berawgn(EbNo,'pam',M); semilogy(EbNo,ser,'r'); xlabel('E_b/N_0 (dB)'); ylabel('Symbol Error Rate'); grid on;
Вычислите эмпирический коэффициент ошибок путем симуляции. Задайте параметры симуляции и предварительно выделите переменные, чтобы сэкономить время. Преобразуйте от EbNo до ОСШ. С тех пор No = 2*noiseVariance^2, мы должны добавить 3 дБ, чтобы получить ОСШ. Для получения дополнительной информации см. книгу Проукиса, перечисленную в «Выбранной Библиографии для Оценки результатов деятельности».
n = 10000; % Number of symbols to process k = log2(M); % Number of bits per symbol snr = EbNo+3+10*log10(k); ynoisy = zeros(n,length(snr)); z = zeros(n,length(snr)); berVec = zeros(3,length(EbNo));
Создайте объекты для калькулятора коэффициента ошибок канала AWGN. Калькулятор коэффициента ошибок используется, чтобы сравнить декодируемые символы с исходными переданными символами.
awgnchan = comm.AWGNChannel('NoiseMethod', 'Signal to noise ratio (SNR)'); errcalc = comm.ErrorRate;
Сгенерируйте случайное сообщение данных и примените модуляцию PAM. Нормируйте канал, чтобы сигнализировать о степени. Симуляция цикла, чтобы сгенерировать BERs в области значений значений ОСШ.
x = randi([0 M-1],n,1); % Create message signal. y = pammod(x,M); % Modulate. awgnchan.SignalPower = (real(y)' * real(y))/ length(real(y)); for jj = 1:length(snr) reset(errcalc) awgnchan.SNR = snr(jj); % Assign Channel SNR ynoisy(:,jj) = awgnchan(real(y)); % Add AWGN z(:,jj) = pamdemod(complex(ynoisy(:,jj)),M); % Demodulate. % Compute symbol error rate from simulation. berVec(:,jj) = errcalc(x,z(:,jj)); end
Сравните теоретические и эмпирические результаты.
hold on; semilogy(EbNo,berVec(1,:),'b.'); legend('Theoretical SER','Empirical SER'); title('Comparing Theoretical and Empirical Error Rates'); hold off;
Графики коэффициента ошибок
-
Разделите обзор
-
Создание коэффициента ошибок строит Используя
semilogy
-
Curve Fitting для графиков коэффициента ошибок
-
Curve Fitting график коэффициента ошибок
Разделите обзор
Графики коэффициента ошибок обеспечивают визуальный способ исследовать эффективность системы связи, и они часто включаются в публикации. Этот раздел упоминает некоторые инструменты, которые можно использовать, чтобы создать графики коэффициента ошибок, изменить их, чтобы удовлетворить потребностям и сделать аппроксимирование кривыми на данных о коэффициенте ошибок. Это также обеспечивает пример аппроксимирования кривыми. Для более детальных обсуждений о более общих возможностях графического вывода в MATLAB® смотрите набор документации MATLAB.
Создание коэффициента ошибок строит Используя semilogy
Во многих графиках коэффициента ошибок горизонтальная ось указывает на значения Eb/N0 в дБ, и вертикальная ось указывает на коэффициент ошибок с помощью логарифмического (базируйтесь 10), шкала. Чтобы видеть пример такого графика, а также кода, который создает его, смотрите Сравнение Теоретических и Эмпирических Коэффициентов ошибок. Часть того примера, который создает использование графика semilogy
функционируйте, чтобы произвести логарифмический масштаб на вертикальной оси и линейную шкалу на горизонтальной оси.
Другие примеры, которые иллюстрируют использование semilogy
находятся в этих разделах:
-
Используя Полуаналитический Метод, который также иллюстрирует
-
Графический вывод двух наборов данных по одной паре осей
-
Добавление заголовка
-
Добавление легенды
-
-
Графический вывод Теоретических Коэффициентов ошибок, который также иллюстрирует
-
Добавление подписей по осям
-
Добавление линий сетки
-
Curve Fitting для графиков коэффициента ошибок
Аппроксимирование кривыми полезно, когда вы имеете небольшой или несовершенный набор данных, но хотите построить плавную кривую в целях представления. berfit
функция в Communications Toolbox предлагает возможности подбора кривых, которые хорошо подходят для ситуации, когда эмпирические данные описывают коэффициенты ошибок в различных значениях Eb/N0. Эта функция позволяет
-
Настройте различные соответствующие аспекты процесса подбора кривых, такие как тип функции закрытой формы (из списка предварительно установленного выбора) раньше генерировал подгонку.
-
Отобразите эмпирические данные на графике наряду с кривой это
berfit
подгонки к данным. -
Интерполируйте точки на кривой по экспериментальным точкам между значениями Eb/N0 в вашем наборе эмпирических данных, чтобы сделать график более сглаженным взглядом.
-
Соберите релевантную информацию о подгонке, такой как численные значения точек вдоль кривой по экспериментальным точкам и коэффициентов подходящего выражения.
Примечание
berfit
функция предназначается для аппроксимирования кривыми или интерполяции, не экстраполяции. Экстраполирование данных о BER вне порядка величины ниже наименьшего эмпирического значения BER по сути ненадежно.
Для полного списка вводов и выводов для berfit
, смотрите его страницу с описанием.
Curve Fitting график коэффициента ошибок
Этот пример симулирует простую систему связи дифференциального бинарного манипулирования сдвига фазы (DBPSK) и отображает данные о коэффициенте ошибок на графике для серии значений Eb/N0. Это использует berfit
функционируйте, чтобы соответствовать кривой к несколько грубому набору эмпирических коэффициентов ошибок.
Инициализируйте параметры симуляции
Задайте длину сообщения входного сигнала, порядок модуляции, область значений значений Eb/N0, чтобы рассмотреть, и минимальное количество ошибок, которые должны произойти, прежде чем симуляция вычислит коэффициент ошибок для этого значение Eb/N0. Предварительно выделите переменные для результатов и промежуточных результатов.
Для статистически точных результатов коэффициента ошибок минимальное количество ошибок должно быть на порядке 100, но эта симуляция использует небольшое количество ошибок сократить время выполнения и проиллюстрировать, как аппроксимирование кривыми может сгладить грубый набор данных.
siglen = 100000; % Number of bits in each trial M = 2; % DBPSK is binary. EbN0vec = 0:5; % Vector of EbN0 values minnumerr = 5; % Compute BER only after 5 errors occur. numEbN0 = length(EbN0vec); % Number of EbN0 values ber = zeros(1,numEbN0); % final BER values berVec = zeros(3,numEbN0); % Updated BER values intv = cell(1,numEbN0); % Cell array of confidence intervals
Создайте Систему калькулятора коэффициента ошибок object™.
errorCalc = comm.ErrorRate;
Цикл симуляции
Симулируйте модулируемую систему связи DBPSK и вычислите BER с помощью for
цикл, чтобы варьироваться значение Eb/N0. Внутренний while
цикл гарантирует, что минимальное количество битовых ошибок происходит для каждого значения Eb/N0. Статистические данные коэффициента ошибок сохранены для каждого значения Eb/N0, чтобы использовать когда аппроксимирование кривыми и графический вывод.
% Loop over the vector of EbN0 values. for jj = 1:numEbN0 EbN0 = EbN0vec(jj); snr = EbN0; % Because of binary modulation reset(errorCalc) awgnChan.SNR = snr; % Assign Channel SNR while (berVec(2,jj) < minnumerr) msg = randi([0,M-1],siglen,1); % Generate message sequence % txsig = step(hMod,msg); % Modulate txsig = dpskmod(msg,M); % Modulate awgnChan.SignalPower = (txsig'*txsig)/length(txsig); % Calculate and assign signal power % rxsig = awgnChan(txsig); % Add noise. rxsig = awgn(txsig,snr,'measured'); % Add noise. % decodmsg = step(hDemod, rxsig); % Demodulate. decodmsg = dpskdemod(rxsig,M); % Demodulate. berVec(:,jj) = errorCalc(msg,decodmsg); % Calculate BER end
Используйте berconfint
вычислить коэффициент ошибок в 98%-м доверительном интервале для значения Eb/N0.
[ber(jj), intv1] = berconfint(berVec(2,jj),berVec(3,jj),0.98); intv{jj} = intv1; disp(['EbN0 = ' num2str(EbN0) ' dB, ' num2str(berVec(2,jj)) ... ' errors, BER = ' num2str(ber(jj))]) end
EbN0 = 0 dB, 18392 errors, BER = 0.18392 EbN0 = 1 dB, 14307 errors, BER = 0.14307 EbN0 = 2 dB, 10190 errors, BER = 0.1019 EbN0 = 3 dB, 6940 errors, BER = 0.0694 EbN0 = 4 dB, 4151 errors, BER = 0.04151 EbN0 = 5 dB, 2098 errors, BER = 0.02098
Используйте berfit
построить лучшую кривую по экспериментальным точкам, интерполируя, чтобы получить сглаженный график. Добавьте доверительные интервалы в график.
fitEbN0 = EbN0vec(1):0.25:EbN0vec(end); % Interpolation values berfit(EbN0vec,ber,fitEbN0); hold on; for jj=1:numEbN0 semilogy([EbN0vec(jj) EbN0vec(jj)],intv{jj},'g-+'); end hold off;
BERTool
Команда bertool
запускает Аналитический Инструмент Частоты ошибок по битам (BERTool) приложение.
Приложение позволяет вам анализировать эффективность частоты ошибок по битам (BER) систем связи. BERTool вычисляет BER как функцию отношения сигнал-шум. Это анализирует эффективность или с симуляциями Монте-Карло функций MATLAB и моделей Simulink® или с теоретическими выражениями закрытой формы для выбранных типов систем связи.
Используя BERTool вы можете:
-
Сгенерируйте данные о BER для использования системы связи
-
Выражения закрытой формы для теоретической эффективности BER выбранных типов систем связи.
-
Полуаналитический метод.
-
Симуляции содержатся в функциях симуляции MATLAB или моделях Simulink. После того, как вы создаете функцию или модель, которая симулирует систему, BERTool выполняет итерации по вашему выбору значений Eb/N0 и собирает результаты.
-
-
Постройте один или несколько наборов данных BER на одном наборе осей. Например, можно графически сравнить данные моделирования с теоретическими результатами или данные моделирования от ряда подобных моделей системы связи.
-
Соответствуйте кривой к набору данных моделирования.
-
Отправьте данные о BER в рабочее пространство MATLAB, или в файл для дальнейшей обработки вас может хотеть выполнить.
Примечание
BERTool спроектирован для анализа частот ошибок по битам только, не коэффициентов ошибок символа, коэффициентов ошибок слова или других типов коэффициентов ошибок. Если, например, ваша симуляция вычисляет коэффициент ошибок символа (SER), преобразуйте SER в BER перед использованием симуляции с BERTool.
Следующие разделы описывают Аналитический Инструмент Частоты ошибок по битам (BERTool) и обеспечивают примеры, показывающие, как использовать его графический интерфейс пользователя.
-
Запустите BERTool
-
Среда BERTool
-
Вычисление теоретического BERs
-
Используя полуаналитический метод, чтобы вычислить BERs
-
Запустите симуляции MATLAB
-
Используйте функции симуляции с BERTool
-
Запустите симуляции Simulink
-
Используйте модели Simulink с BERTool
-
Управляйте данными о BER
Запустите BERTool
Чтобы открыть BERTool, ввести
Среда BERTool
-
Компоненты BERTool
-
Взаимодействие среди компонентов BERTool
Компоненты BERTool
-
Средство просмотра данных наверху. Это первоначально пусто.
После того, как вы дадите BERTool команду генерировать один или несколько наборов данных BER, они появляются в средстве просмотра данных. Пример, который показывает, как взгляд наборов данных в средстве просмотра данных находится в Примере: Используя Симуляцию MATLAB с BERTool.
-
Набор вкладок на нижней части. Пометил Theoretical, Semianalytic и Monte Carlo, вкладки соответствуют различным методам, которыми BERTool может сгенерировать данные о BER.
Примечание
При использовании BERTool, чтобы сравнить теоретические результаты и результаты Монте-Карло, предоставленная модель Simulink должна смоделировать точно систему, заданную параметрами на вкладке Theoretical.
Чтобы узнать больше о каждом из методов, смотрите
-
Вычисление теоретического BERs
-
Используя полуаналитический метод, чтобы вычислить BERs
-
Запустите симуляции MATLAB или запущенные симуляции Simulink
-
-
Отдельное Окно рисунка BER, которое отображает некоторых или все наборы данных BER, которые перечислены в средстве просмотра данных. BERTool создает Окно фигуры BER после того, как это имеет по крайней мере один набор данных, чтобы отобразиться, таким образом, вы не видите Окно рисунка BER, когда вы открываете сначала BERTool. Для примера того, как Окно рисунка BER выглядит, смотрите Пример: Используя Теоретическую Вкладку в BERTool.
Взаимодействие Среди Компонентов BERTool. Компоненты BERTool действуют как один интегрированный инструмент. Эти поведения отражают свое интегрирование:
-
Если вы выбираете набор данных в средстве просмотра данных, BERTool реконфигурировал вкладки, чтобы отразить параметры, сопоставленные с тем набором данных, и также подсвечивает соответствующие данные в Окне рисунка BER. Это полезно, если средство просмотра данных отображает несколько наборов данных, и вы хотите вспомнить значение и источник каждого набора данных.
-
Если вы кликаете по данным, отображенным на графике в Окне рисунка BER, BERTool реконфигурировал вкладки, чтобы отразить параметры, сопоставленные с теми данными, и также подсвечивает соответствующий набор данных в средстве просмотра данных.
Примечание
Вы не можете нажать на точку данных, в то время как BERTool генерирует результаты симуляции Монте-Карло. Необходимо ожидать, пока инструмент не генерирует все точки данных прежде, чем щелкнуть для получения дополнительной информации.
-
Если вы конфигурируете вкладку Semianalytic или Theoretical способом, которая уже отражается в существующем наборе данных, BERTool подсвечивает что набор данных в средстве просмотра данных. Это препятствует тому, чтобы BERTool копировал свои расчеты и свои записи в средстве просмотра данных, все еще показывая вам результаты, которые вы запросили.
-
Если вы закрываете Окно рисунка BER, то можно вновь открыть его путем выбора из меню в BERTool.
-
Если вы выбираете опции в средстве просмотра данных, которые влияют на график BER, Окно рисунка BER сразу отражает ваши выборы. Такие опции относятся к именам набора данных, доверительным интервалам, аппроксимированию кривыми, и присутствию или отсутствию определенных наборов данных в графике BER.
Примечание
Если вы сохраняете Окно рисунка BER с помощью меню окна, получившийся файл содержит содержимое окна, но не данных BERTool, которые привели к графику. Чтобы сохранить целый сеанс BERTool, смотрите Сохранение Сеанса BERTool.
Вычисление теоретического BERs
-
Разделите обзор
-
Пример: Используя теоретическую вкладку в BERTool
-
Доступные наборы теоретических данных о BER
Разделите Обзор. Можно использовать BERTool, чтобы сгенерировать и анализировать теоретические данные о BER. Теоретические данные полезны для сравнения с вашими результатами симуляции. Однако выражения BER закрытой формы существуют только для определенных видов систем связи.
Чтобы получить доступ к возможностям BERTool, связанного с теоретическими данными о BER, используйте следующую процедуру:
-
Откройте BERTool и перейдите к вкладке Theoretical.
-
Установите параметры, чтобы отразить систему, эффективность которой вы хотите анализировать. Некоторые параметры отображаются и активны только, когда другие параметры имеют определенные значения. Смотрите Доступные Наборы Теоретических Данных о BER для деталей.
-
Нажмите Plot.
Для примера, который показывает, как сгенерировать и анализировать теоретические данные о BER через BERTool, смотрите Пример: Используя Теоретическую Вкладку в BERTool.
Кроме того, Доступные Наборы Теоретических Данных о BER указывает, какие комбинации параметров доступны на вкладке Theoretical и какие базовые функции выполняют расчеты.
Пример: Используя Теоретическую Вкладку в BERTool. Этот пример иллюстрирует, как использовать BERTool, чтобы сгенерировать и отобразить теоретические данные о BER на графике. В частности, пример сравнивает эффективность системы связи, которая использует канал AWGN и модуляцию QAM различных порядков.
Выполнение теоретического примера
-
Откройте BERTool и перейдите к вкладке Theoretical.
-
Установите параметры как показано в следующем рисунке.
-
Нажмите Plot.
BERTool создает запись в средстве просмотра данных и отображает данные на графике в Окне рисунка BER. Даже при том, что параметры запрашивают, чтобы Eb/N0 подошли 18, BERTool строит только те значения BER, которые являются по крайней мере 10-8. Следующие фигуры иллюстрируют этот шаг.
-
Измените параметр Modulation order в
16
, и нажмите Plot.BERTool создает другую запись в средстве просмотра данных и отображает новые данные на графике в том же Окне рисунка BER (не изображенный).
-
Измените параметр Modulation order в
64
, и нажмите Plot.BERTool создает другую запись в средстве просмотра данных и отображает новые данные на графике в том же Окне рисунка BER, как показано на следующих рисунках.
-
Чтобы вспомнить, какое значение Modulation order соответствует данной кривой, кликните по кривой. BERTool отвечает путем корректировки параметров во вкладке Theoretical, чтобы отразить значения, которые соответствуют той кривой.
-
Чтобы удалить последнюю кривую из графика (но не из средства просмотра данных), снимите флажок в последней записи средства просмотра данных в столбце Plot. Чтобы восстановить кривую к графику, установите флажок снова.
Доступные Наборы Теоретических Данных о BER. BERTool может сгенерировать большой набор теоретических частот ошибок по битам, но не все комбинации параметров в настоящее время поддерживаются. Вкладка Theoretical настраивает себя к вашему выбору, так, чтобы комбинация параметров была всегда допустима. Можно установить параметр Modulation order путем выбора выбора из меню или путем ввода значения в поле. Normalized timing error должен быть между 0 и 0.5.
BERTool принимает, что Грэй, кодирующий, используется для всех модуляций.
Для QAM, когда log2M является нечетным (M, являющийся порядком модуляции), прямоугольное созвездие принято.
Комбинации параметров для систем канала AWGN
В следующей таблице перечислены доступные наборы теоретических данных о BER для систем, которые используют канал AWGN.
Модуляция | Порядок модуляции | Другой выбор |
---|---|---|
PSK | 2, 4 | Дифференциальное или недифференциальное кодирование. |
8, 16, 32, 64, или более высокая степень 2 | ||
OQPSK | 4 | Дифференциальное или недифференциальное кодирование. |
DPSK | 2, 4, 8, 16, 32, 64, или более высокая степень 2 | |
PAM | 2, 4, 8, 16, 32, 64, или более высокая степень 2 | |
QAM | 4, 8, 16, 32, 64, 128, 256, 512, 1024, или более высокая степень 2 | |
FSK | 2 | Ортогональный или неортогональный; Coherent или Noncoherent демодуляция. |
4, 8, 16, 32, или более высокая степень 2 | Ортогональный; Coherent демодуляция. |
|
4, 8, 16, 32, или 64 | Ортогональный; Noncoherent демодуляция. |
|
MSK | 2 | Coherent обычный или предварительно закодированный MSK; Noncoherent предварительно закодированный MSK. |
CPFSK | 2, 4, 8, 16, или более высокая степень 2 | Modulation index > 0. |
Результаты BER также доступны для следующего:
-
блокируйтесь и сверточное кодирование с декодированием трудного решения для всех модуляций кроме CPFSK
-
блочное кодирование с декодированием мягкого решения для всех двоичных модуляций (включая 4-PSK и 4-QAM) кроме CPFSK, некогерентного неортогонального FSK и некогерентного MSK
-
сверточное кодирование с декодированием мягкого решения для всех двоичных модуляций (включая 4-PSK и 4-QAM) кроме CPFSK
-
незакодированный недифференцированно закодированный 2-PSK с ошибками синхронизации
Для получения дополнительной информации об определенных комбинациях параметров, включая библиографические ссылки, которые содержат выражения закрытой формы, смотрите страницы с описанием для следующих функций:
-
berawgn
— Для систем без кодирования и совершенной синхронизации -
bercoding
— Для систем с кодированием канала -
bersync
— Для систем с модуляцией BPSK, никаким кодированием и несовершенной синхронизацией
Комбинации параметров для рэлеевского и систем канала Rician
В следующей таблице перечислены доступные наборы теоретических данных о BER для систем, которые используют канал Rayleigh или Rician.
Когда разнообразие используется, ОСШ на каждой ветви разнообразия выведен из ОСШ во входе канала (EbNo
) разделенный на порядок разнообразия.
Модуляция | Порядок модуляции | Другой выбор |
---|---|---|
PSK | 2 |
Дифференциальное или недифференциальное кодирование
В случае недифференциального кодирования, порядок разнообразия, являющийся 1, и исчезновение Rician, может быть задано значение для шума фазы RMS (в радианах). |
4, 8, 16, 32, 64, или более высокая степень 2 | Diversity order ≧1 |
|
OQPSK | 4 | Diversity order ≧1 |
DPSK | 2, 4, 8, 16, 32, 64, или более высокая степень 2 | Diversity order ≧1 |
PAM | 2, 4, 8, 16, 32, 64, или более высокая степень 2 | Diversity order ≧1 |
QAM | 4, 8, 16, 32, 64, 128, 256, 512, 1024, или более высокая степень 2 | Diversity order ≧1 |
FSK | 2 |
Коэффициент корреляции ∈[−1,1].
В случае ненулевого коэффициента корреляции и некогерентной демодуляции, порядок разнообразия равняется 1 только. |
4, 8, 16, 32, или более высокая степень 2 | Noncoherent демодуляция только. Diversity order ≧1 |
Для получения дополнительной информации об определенных комбинациях параметров, включая библиографические ссылки, которые содержат выражения закрытой формы, смотрите страницу с описанием для berfading
функция.
Используя полуаналитический метод, чтобы вычислить BERs
-
Разделите обзор
-
Пример: Используя полуаналитическую вкладку в BERTool
-
Процедура для Использования полуаналитической вкладки в BERTool
Разделите Обзор. Можно использовать BERTool, чтобы сгенерировать и анализировать данные о BER через полуаналитический метод. Полуаналитический метод обсужден в Результатах Эффективности через Полуаналитический Метод, и Когда Использовать Полуаналитический Метод, особенно релевантно как справочный материал.
Чтобы получить доступ к полуаналитическим возможностям BERTool, откройте вкладку Semianalytic.
Для получения дальнейшей информации о том, как BERTool применяет полуаналитический метод, смотрите страницу с описанием для semianalytic
функция, который использование BERTool выполнить расчеты.
Пример: Используя Полуаналитическую Вкладку в BERTool. Этот пример иллюстрирует, как BERTool применяет полуаналитический метод, с помощью 16-QAM модуляции. Этим примером является изменение на примере в Использовании Полуаналитического Метода, но это адаптируется, чтобы использовать BERTool вместо того, чтобы использовать semianalytic
функционируйте непосредственно.
Выполнение полуаналитического примера
-
Настройте переданные и полученные сигналы. Сгенерируйте сигнал сообщения длины> = M L. Модулируйте сигнал сообщения использование полосовой модуляции. Примените формирование импульса без дальнейшей фильтрации передачи. Передайте сигнал передачи через бесшумный канал.
M = 16; % Alphabet size of modulation L = 1; % Length of impulse response of channel msg = [0:M-1 0]; % M-ary message sequence of length > M^L modsig = qammod(msg,M); % Use 16-QAM. Nsamp = 16; modsig = rectpulse(modsig,Nsamp); % Use rectangular pulse shaping. txsig = modsig; % No filter in this example rxsig = txsig*exp(j*pi/180); % Static phase offset of 1 degree
-
Откройте BERTool и перейдите к вкладке Semianalytic.
-
Установите параметры как показано в следующем рисунке.
-
Нажмите Plot.
Видимые результаты полуаналитического примера
После того, как вы нажмете Plot, BERTool создает листинг для получившихся данных в средстве просмотра данных.
BERTool отображает данные на графике в Окне рисунка BER.
Процедура для Использования Полуаналитической Вкладки в BERTool. Процедура ниже описывает, как вы обычно реализуете полуаналитический метод с помощью BERTool:
-
Сгенерируйте сигнал сообщения, содержащий, по крайней мере, символы ML, где M является размером алфавита модуляции, и L является длиной импульсной характеристики канала в символах. Общий подход должен начать с увеличенного бинарного псевдошума (PN) последовательность общей длины
(log2M)ML
. Увеличенная псевдошумовая последовательность является псевдошумовой последовательностью с дополнительным добавленным нулем, который делает распределение единиц и нулей равным. -
Модулируйте поставщика услуг с сигналом сообщения использование полосовой модуляции. Поддерживаемые типы модуляции перечислены на странице с описанием для
semianalytic
. Сформируйте результирующий сигнал с формированием меандра, с помощью фактора сверхдискретизации, что вы будете дальнейшее использование, чтобы отфильтровать модулируемый сигнал. Сохраните результат этого шага какtxsig
для дальнейшего использования. -
Отфильтруйте модулируемый сигнал с фильтром передачи. Этот фильтр часто является повышенным фильтром косинуса квадратного корня, но можно также использовать Баттерворта, функцию Бесселя, Чебышевский тип 1 или 2, эллиптического, или более общего КИХ или БИХ-фильтр. Если вы используете повышенный фильтр косинуса квадратного корня, используйте его на несверхдискретизированном модулируемом сигнале и укажите, что сверхдискретизация включает функцию фильтрации. Если вы используете другой тип фильтра, можно применить его к rectangularly сигналу импульсной формы.
-
Запустите пропущенный сигнал через бесшумный канал. Этот канал может включать многопутевые исчезающие эффекты, сдвиги фазы, нелинейность усилителя, квантование и дополнительную фильтрацию, но это не должно включать шум. Сохраните результат этого шага как
rxsig
для дальнейшего использования. -
На вкладке Semianalytic BERTool введите параметры как в приведенную ниже таблицу.
‘ParameterName’ Значение Eb/No range Вектор, который перечисляет значения Eb/N0, для которого вы хотите собрать данные о BER. Значение в этом поле может быть выражением MATLAB или именем переменной в рабочем пространстве MATLAB. Modulation type Эти параметры описывают схему модуляции, которую вы использовали ранее в этой процедуре. Modulation order Differential encoding Этот флажок, который отображается и активен для MSK и модуляции PSK, позволяет вам выбрать между дифференциальным и недифференциальным кодированием. Samples per symbol Количество выборок на символ в переданном сигнале. Это значение является также частотой дискретизации переданных и полученных сигналов в Гц. Transmitted signal txsig
сигнализируйте, что вы сгенерировали ранее в этой процедуреReceived signal rxsig
сигнализируйте, что вы сгенерировали ранее в этой процедуреNumerator Коэффициенты фильтра приемника, что BERTool применяется к полученному сигналу Denominator Примечание
Непротиворечивость среди значений в графический интерфейсе пользователя важна. Например, если сигнал, на который ссылаются в поле Transmitted signal, был сгенерирован с помощью DPSK, и вы устанавливаете Modulation type на
MSK
, результаты не могут быть значимыми. -
Нажмите Plot.
Полуаналитические расчеты и результаты
После того, как вы нажмете Plot, BERTool выполняет эти задачи:
-
Фильтры
rxsig
и затем определяет вероятность появления ошибки каждого полученного очка сигнала путем аналитичного применения Гауссова шумового распределения к каждой точке. BERTool составляет в среднем вероятности появления ошибки по целому полученному сигналу определить полную вероятность появления ошибки. Если вероятность появления ошибки, вычисленная таким образом, является вероятностью появления ошибки символа, BERTool преобразует ее в небольшой коэффициент ошибок, обычно путем принятия Грэя, кодирующего. (Если тип модуляции является DQPSK или перекрестным QAM, результатом является верхняя граница на частоте ошибок по битам, а не самой частоте ошибок по битам.) -
Вводит получившиеся данные о BER в средство просмотра данных окна BERTool.
-
Отображает получившиеся данные о BER на графике в Окне рисунка BER.
Запустите симуляции MATLAB
-
Разделите обзор
-
Пример: Используя симуляцию MATLAB с BERTool
-
Варьируясь критерий остановки
-
Графический вывод доверительных интервалов
-
Подходящий BER указывает на кривую
Разделите Обзор. Можно использовать BERTool в сочетании с собственными функциями симуляции MATLAB, чтобы сгенерировать и анализировать данные о BER. Функция MATLAB симулирует систему связи, эффективность которой вы хотите изучить. BERTool вызывает симуляцию для значений Eb/N0, которые вы задаете, собирает данные о BER от симуляции и создает график. BERTool также позволяет вам легко изменить область значений Eb/N0 и критерий остановки для симуляции.
Чтобы изучить, как сделать ваши собственные функции симуляции совместимыми с BERTool, смотрите Функции Симуляции Использования с BERTool.
Пример: Используя Симуляцию MATLAB с BERTool. Этот пример иллюстрирует, как BERTool может запустить функцию симуляции MATLAB. Функцией является viterbisim
, один из демонстрационных файлов включен с программным обеспечением Communications Toolbox.
Чтобы запустить этот пример, выполните эти шаги:
-
Откройте BERTool и перейдите к вкладке Monte Carlo. (Параметры по умолчанию зависят от того, установили ли вам программное обеспечение Communications Toolbox. Также обратите внимание, что поле BER variable name применяется только к моделям Simulink.)
-
Установите параметры как показано в следующем рисунке.
-
Нажмите Run.
BERTool запускает функцию симуляции однажды для каждого заданного значения Eb/N0 и собирает данные о BER. (В то время как BERTool занят этой задачей, он не может обработать определенные другие задачи, включая отображение на графике данных из других вкладок графический интерфейса пользователя.)
Затем BERTool создает листинг в средстве просмотра данных.
BERTool отображает данные на графике в Окне рисунка BER.
-
Чтобы изменить область значений Eb/N0 при сокращении количества битов, обработанных в каждом случае, введите
[5 5.2 5.3]
в поле Eb/No range введите1e5
в поле Number of bits, и нажимают Run.BERTool запускает функцию симуляции снова для каждого нового значения Eb/N0 и собирает новые данные о BER. Затем BERTool создает другой листинг в средстве просмотра данных.
BERTool отображает данные на графике в Окне рисунка BER, настраивая горизонтальную ось, чтобы хранить новые данные.
Две точки, соответствующие 5 дБ от этих двух наборов данных, отличаются, потому что меньшее значение Number of bits во второй симуляции заставило симуляцию заканчиваться прежде, чем наблюдать много ошибок. Чтобы узнать больше о критериях что использование BERTool для конечных симуляций, смотрите Варьирование Критерия остановки.
Для другого примера, который использует BERTool, чтобы запустить функцию симуляции MATLAB, смотрите Пример: Подготовьте Функцию Симуляции к Использованию с BERTool.
Варьируясь Критерий остановки. Когда вы создаете функцию симуляции MATLAB для использования с BERTool, необходимо управлять потоком так, чтобы симуляция закончилась, когда это или обнаруживает целевое количество ошибок или обрабатывает максимальное количество битов, какой бы ни происходит сначала. Чтобы узнать больше об этом требовании, смотрите Требования для Функций; для примера смотрите Пример: Подготовьте Функцию Симуляции к Использованию с BERTool.
После создания вашей функции, определенной целевой номер ошибок и максимальное количество битов во вкладке Monte Carlo BERTool.
Как правило, значение Number of errors, по крайней мере, 100
производит точный коэффициент ошибок. Значение Number of bits препятствует тому, чтобы симуляция запускалась слишком долго, особенно в больших значениях Eb/N0. Однако, если значение Number of bits так мало, что симуляция собирает очень немного ошибок, коэффициент ошибок не может быть точным. Можно использовать доверительные интервалы, чтобы измерить точность коэффициентов ошибок, которые производит симуляция; чем больше доверительный интервал, тем менее точный вычисленный коэффициент ошибок.
Как пример, выполните процедуру, описанную в Примере: Используя Симуляцию MATLAB с BERTool и набором Confidence Level к 95
для каждого из этих двух наборов данных. Доверительные интервалы для второго набора данных больше, чем те для набора First Data. Это вызвано тем, что второй набор данных использует маленькое значение для Number of bits относительно свойств системы связи и значения в Eb/No range, приводящем к значениям BER только на основе небольшого количества наблюдаемых ошибок.
Примечание
Можно также использовать кнопку Stop в BERTool, чтобы остановить ряд симуляций преждевременно, пока функция настраивается, чтобы обнаружить и реагировать на нажатие кнопки.
Графический вывод Доверительных интервалов. После того, как вы запустите симуляцию с BERTool, получившийся набор данных в средстве просмотра данных имеет активное меню в столбце Confidence Level. Значением по умолчанию является off
, так, чтобы данные моделирования в Окне рисунка BER не показывали доверительные интервалы.
Чтобы показать доверительные интервалы в Окне рисунка BER, установите Confidence Level на численное значение: 90%
, 95%, или
99%
.
График в Окне рисунка BER сразу отвечает на ваш выбор. Демонстрационный график ниже.
Для примера, который строит доверительные интервалы для симуляции Simulink, смотрите Пример: Используя Модель Simulink с BERTool.
Чтобы найти доверительные интервалы для уровней не перечисленными в меню Confidence Level, используйте berconfint
функция.
Подходящие Точки BER к Кривой. После того, как вы запустите симуляцию с BERTool, Окно рисунка BER строит отдельные точки данных BER. Чтобы соответствовать кривой к набору данных, который содержит по крайней мере четыре точки, выберите поле в столбце Fit средства просмотра данных.
График в Окне рисунка BER сразу отвечает на ваш выбор. Демонстрационный график ниже.
Для примера, который выполняет аппроксимирование кривыми для данных из симуляции Simulink и генерирует график, показанный выше, смотрите Пример: Используя Модель Simulink с BERTool. Для примера, который выполняет аппроксимирование кривыми для данных из функции симуляции MATLAB, смотрите Пример: Подготовьте Функцию Симуляции к Использованию с BERTool.
Для большей гибкости в процессе подбора кривой кривой к данным о BER используйте berfit
функция.
Используйте функции симуляции с BERTool
-
Требования для функций
-
Обработайте по шаблону для функции симуляции
-
Пример: подготовьте функцию симуляции к использованию с BERTool
Требования для Функций. Когда вы создаете функцию MATLAB для использования с BERTool, гарантируете, что функция взаимодействует правильно с графический интерфейсом пользователя. В этом разделе описываются входные параметры, выходные параметры и основную операцию BERTool-совместимой функции.
Входные параметры
BERTool оценивает ваши записи в областях графический интерфейса пользователя и передает данные функции как эти входные параметры в последовательности:
-
Одно значение от вектора Eb/No range каждый раз BERTool вызывает функцию симуляции
-
Значение Number of errors
-
Значение Number of bits
Выходные аргументы
Ваша функция симуляции должна вычислить и возвратить эти выходные аргументы в последовательности:
-
Частота ошибок по битам симуляции
-
Количество битов, обработанных при вычислении BER
BERTool использует эти выходные аргументы при создании отчетов и графическом выводе результатов.
Операция симуляции
Ваша функция симуляции должна выполнить эти задачи:
-
Симулируйте систему связи для значения Eb/N0, заданного в первом входном параметре.
-
Прекратите симулировать, когда количество ошибок или количество обработанных битов будут равняться или будут превышать соответствующий порог, заданный во втором или третьем входном параметре, соответственно.
-
Обнаружьте, нажимаете ли вы Stop in BERTool и прерываете симуляцию в этом случае.
Обработайте по шаблону для Функции Симуляции. Используйте следующий шаблон при адаптации кода, чтобы работать с BERTool. Можно открыть его в редакторе путем ввода edit bertooltemplate
в командном окне MATLAB. Понимание Шаблона объясняет ключевые разделы шаблона, в то время как Используя Шаблон указывает, как использовать шаблон с вашим собственным кодом симуляции. В качестве альтернативы можно разработать функцию симуляции, не используя шаблон, но быть уверены, что это удовлетворяет требованиям, описанным в Требованиях для Функций.
function [ber, numBits] = bertooltemplate(EbNo, maxNumErrs, maxNumBits) % Import Java class for BERTool. import com.mathworks.toolbox.comm.BERTool; % Initialize variables related to exit criteria. berVec = zeros(3,1); % Updated BER values % --- Set up parameters. --- % --- INSERT YOUR CODE HERE. % Simulate until number of errors exceeds maxNumErrs % or number of bits processed exceeds maxNumBits. while((berVec(2) < maxNumErrs) && (berVec(3) < maxNumBits)) % Check if the user clicked the Stop button of BERTool. if (BERTool.getSimulationStop) break; end % --- Proceed with simulation. % --- Be sure to update totErr and numBits. % --- INSERT YOUR CODE HERE. end % End of loop % Assign values to the output variables. ber = berVec(1); numBits = berVec(3);
От изучения кода в шаблоне функции наблюдайте, как функция или удовлетворяет требованиям, перечисленным в Требованиях для Функций, или указывает, где ваши собственные вставки кода должны сделать так. В частности,
-
Функция имеет соответствующие аргументы ввода и вывода.
-
Функция включает заполнителя для кода, который симулирует систему для данного значения E b/N0.
-
Функция использует циклическую структуру, чтобы прекратить симулировать, когда количество ошибок превышает
maxNumErrs
или количество битов превышаетmaxNumBits
, какой бы ни происходит сначала.Примечание
Несмотря на то, что
while
оператор цикла описывает выходные критерии, ваш собственный код, введенный в раздел, отметилProceed with simulation
должен вычислить количество ошибок и количество битов. Если вы не выполняете эти расчеты в своем собственном коде, нажатие по Stop является единственным способом отключить цикл. -
В каждой итерации цикла функция обнаруживает, когда пользователь нажимает Stop in BERTool.
Вот процедура для использования шаблона с вашим собственным кодом симуляции:
-
Определите задачи настройки, которые необходимо выполнить. Например, вы можете хотеть инициализировать переменные, содержащие размер алфавита модуляции, коэффициенты фильтра, сверточную решетку кодирования или состояния сверточного interleaver. Поместите код для этих задач настройки в разделе шаблона отметил
Set up parameters
. -
Определите базовые задачи симуляции, приняв, что вся настройка работает, был уже выполнен. Например, эти задачи могут включать кодирование контроля ошибок, модуляцию/демодуляцию и моделирование канала. Поместите код для этих базовых задач симуляции в разделе шаблона отметил
Proceed with simulation
. -
Также в шаблоне раздел отметил
Proceed with simulation
, включайте код, который обновляет значенияtotErr
иnumBits
. КоличествоtotErr
представляет количество ошибок, наблюдаемых до сих пор. КоличествоnumBits
представляет количество битов, обработанных до сих пор. Расчеты, чтобы обновить эти переменные зависят от того, как работают ваши базовые задачи симуляции.Примечание
Обновление количеств ошибок и битов важно для обеспечения, что цикл завершает работу. Однако, если вы случайно создаете бесконечный цикл рано в вашей технической разработке с помощью шаблона функции, нажмите Stop in BERTool, чтобы прервать симуляцию.
-
Не используйте любой код настройки, который инициализирует
EbNo
,maxNumErrs
, илиmaxNumBits
, потому что BERTool передает эти количества функции как входные параметры после оценки данных, вводимых в графический интерфейс пользователя. -
Настройте свой код или код шаблона по мере необходимости, чтобы использовать сопоставимые имена переменных и значения. Например, если ваш оригинальный код использует переменную под названием
ebn0
и объявление функции шаблона (первая линия) использует имя переменнойEbNo
, необходимо поменять одно из имен, таким образом, они соответствуют. Как другой пример, если ваш оригинальный код использует ОСШ вместо E b/N0, необходимо преобразовать количества соответственно.
Пример: Подготовьте Функцию Симуляции к Использованию с BERTool. Этот раздел адаптирует шаблон функции, данный в Шаблоне для Функции Симуляции.
Подготовка функции
Чтобы подготовить функцию к использованию с BERTool, выполните эти шаги:
-
Скопируйте шаблон с Шаблона для Функции Симуляции в новый файл MATLAB в редакторе MATLAB. Сохраните его в папке на своем пути MATLAB с помощью имени файла
bertool_simfcn
. -
Из исходного примера следующие линии являются задачами настройки. Они изменяются из исходного примера, чтобы использовать входные параметры, которые BERTool предоставляет функции, вместо того, чтобы задать переменные, такие как
EbNovec
иnumerrmin
непосредственно.% Set up initial parameters. siglen = 1000; % Number of bits in each trial M = 2; % DBPSK is binary. snr = EbNo; % Because of binary modulation % ErrorRate calculator System object to compare decoded symbols to the % original transmitted symbols. errorCalc = comm.ErrorRate;
Поместите эти строки кода в разделе шаблона отметили
Set up parameters
. -
Из исходного примера следующие линии являются базовыми задачами симуляции, после того, как вся настройка работает, был выполнен.
msg = randi([0,M-1], siglen, 1); % Generate message sequence. txsig = dpskmod(msg,M); % Modulate. hChan.SignalPower = (txsig'*txsig)/length(txsig); % Calculate and % assign signal power rxsig = awgn(txsig,snr,'measured'); % Add noise. decodmsg = dpskdemod(rxsig,M); % Demodulate. berVec = errorCalc(msg,decodmsg); % Calculate BER
Поместите код для этих базовых задач симуляции в разделе шаблона отметил
Proceed with simulation
.
bertool_simfcn
функция теперь совместима с BERTool. Обратите внимание на то, что различающийся исходный пример, функция здесь не инициализирует EbNovec
, задайте EbNo
как скаляр или использование numerrmin
как целевое количество ошибок; это вызвано тем, что BERTool обеспечивает входные параметры для подобных количеств. bertool_simfcn
функция также исключает код, связанный с графическим выводом, аппроксимированием кривыми и доверительными интервалами в исходном примере, потому что BERTool позволяет вам сделать подобные задачи в интерактивном режиме без написания кода.
Используя подготовленную функцию
Использовать bertool_simfcn
в сочетании с BERTool продолжите пример путем выполнения этих шагов:
-
Откройте BERTool и перейдите к вкладке Monte Carlo.
-
Установите параметры на вкладке Monte Carlo как показано в следующем рисунке.
-
Нажмите Run.
BERTool тратит результаты вычисления некоторого времени и затем строит их. Они, кажется, не падают вдоль плавной кривой, потому что симуляция потребовала только пяти ошибок для каждого значения в
EbNo
. -
Чтобы соответствовать кривой к серии точек в Окне рисунка BER, выберите поле рядом с Fit в средстве просмотра данных.
BERTool строит кривую как показано в следующем рисунке.
Запустите симуляции Simulink
-
Разделите обзор
-
Пример: Используя модель Simulink с BERTool
-
Варьируясь критерий остановки
Разделите Обзор. Можно использовать BERTool в сочетании с моделями Simulink, чтобы сгенерировать и анализировать данные о BER. Модель Simulink симулирует систему связи, эффективность которой вы хотите изучить, в то время как BERTool управляет рядом симуляций с помощью модели и собирает данные о BER.
Примечание
Чтобы использовать модели Simulink в BERTool, у вас должна быть лицензия Simulink. Программное обеспечение Communications Toolbox настоятельно рекомендовано. Остальная часть этого раздела принимает, что у вас есть лицензия и на Simulink и на приложения Communications Toolbox.
Чтобы получить доступ к возможностям BERTool, связанного с моделями Simulink, откройте вкладку Monte Carlo.
Для получения дальнейшей информации о доверительных интервалах и аппроксимировании кривыми для данных моделирования, смотрите Доверительные интервалы Графического вывода и Подходящие Точки BER к Кривой, соответственно.
Пример: Используя Модель Simulink с BERTool. Этот пример иллюстрирует, как BERTool может управлять рядом симуляций модели Simulink, и как можно варьироваться график. Моделью является commgraycode
, одна из демонстрационных моделей включена с программным обеспечением Communications Toolbox. Пример принимает, что вам установили программное обеспечение Communications Toolbox.
Чтобы запустить этот пример, выполните эти шаги:
-
Откройте BERTool и перейдите к вкладке Monte Carlo. Имя файла модели,
commgraycode.mdl
, появляется как параметр Simulation MATLAB file or Simulink model. (Еслиviterbisim.m
появляется там, выберите, чтобы указать, что программное обеспечение Communications Toolbox установлено.) -
Нажмите Run.
BERTool загружает модель в память (который в свою очередь инициализирует несколько переменных в рабочем пространстве MATLAB), запускает симуляцию однажды для каждого значения Eb/N0 и собирает данные о BER. BERTool создает листинг в средстве просмотра данных.
BERTool отображает данные на графике в Окне рисунка BER.
-
Чтобы соответствовать кривой к серии точек в Окне рисунка BER, выберите поле рядом с Fit в средстве просмотра данных.
BERTool строит кривую, как ниже.
-
Чтобы указать на 99%-й доверительный интервал вокруг каждой точки в данных моделирования, установите Confidence Level на
99%
в средстве просмотра данных.BERTool отображает значение погрешности, чтобы представлять доверительные интервалы, как ниже.
Другой пример, который использует BERTool, чтобы управлять рядом симуляций Simulink, находится в Примере: Подготовьте Модель к Использованию с BERTool.
Варьируясь Критерий остановки. Когда вы создаете модель Simulink для использования с BERTool, необходимо настроить его так, чтобы симуляция закончилась, когда это или обнаруживает целевое количество ошибок или обрабатывает максимальное количество битов, какой бы ни происходит сначала. Чтобы узнать больше об этом требовании, смотрите Требования для Моделей; для примера смотрите Пример: Подготовьте Модель к Использованию с BERTool.
После создания вашей модели Simulink, определенной целевой номер ошибок и максимальное количество битов во вкладке Monte Carlo BERTool.
Как правило, значение Number of errors, по крайней мере, 100
производит точный коэффициент ошибок. Значение Number of bits препятствует тому, чтобы симуляция запускалась слишком долго, особенно в больших значениях Eb/N0. Однако, если значение Number of bits так мало, что симуляция собирает очень немного ошибок, коэффициент ошибок не может быть точным. Можно использовать доверительные интервалы, чтобы измерить точность коэффициентов ошибок, которые производит симуляция; чем больше доверительный интервал, тем менее точный вычисленный коэффициент ошибок.
Можно также нажать Stop in BERTool, чтобы остановить ряд симуляций преждевременно.
Используйте модели Simulink с BERTool
-
Требования для моделей
-
Советы для подготовки моделей
-
Пример: подготовьте модель к использованию с BERTool
Требования для Моделей. Модель Simulink должна удовлетворить этим требованиям, прежде чем можно будет использовать ее с BERTool, где чувствительные к регистру имена переменных нужно точно так же, как показать ниже:
-
Блок канала должен использовать переменную
EbNo
вместо трудно закодированного значения для Eb/N0. -
Симуляция должна остановиться, когда ошибочное количество достигает значения переменной
maxNumErrs
или когда количество обработанных битов достигает значения переменнойmaxNumBits
, какой бы ни происходит сначала.Можно сконфигурировать блок Error Rate Calculation в программном обеспечении Communications Toolbox, чтобы остановить симуляцию на основе таких критериев.
-
Симуляция должна отправить данные об уровне конечной погрешности в рабочее пространство MATLAB как переменная, имя которой вы вводите в поле BER variable name в BERTool. Переменная должна быть трехэлементным вектором, который перечисляет BER, количество битовых ошибок и количество обработанных битов.
Этот трехэлементный векторный формат поддерживается блоком Error Rate Calculation.
Советы для Подготовки Моделей. Вот некоторые советы для подготовки модели Simulink для использования с BERTool:
-
Чтобы избегать использования имени неопределенной переменной в диалоговом окне для блока Simulink на шагах, которые следуют, настройте переменные в рабочем пространстве MATLAB с помощью команды, такие как та ниже.
EbNo = 0; maxNumErrs = 100; maxNumBits = 1e8;
Вы можете также хотеть поместить ту же команду в коллбэк функции предварительной нагрузки модели, инициализировать переменные, если вы вновь открыли модель в будущем сеансе работы с MATLAB.
Когда вы используете BERTool, он вводит фактические значения на основе того, что вы вводите в графический интерфейс пользователя, таким образом, начальные значения выше несколько произвольны.
-
Чтобы смоделировать канал, используйте блок AWGN Channel в программном обеспечении Communications Toolbox этими параметрами:
-
Mode =
Signal to noise ratio (Eb/No)
-
Eb/No =
EbNo
-
-
Чтобы вычислить коэффициент ошибок, используйте блок Error Rate Calculation в программном обеспечении Communications Toolbox этими параметрами:
-
Проверяйте Stop simulation.
-
Target number of errors =
maxNumErrs
-
Maximum number of symbols =
maxNumBits
-
-
Чтобы отправить данные от блока Error Rate Calculation до рабочего пространства MATLAB, установите Output data на
Port
, присоедините блок To Workspace (Simulink) и установите параметр Limit data points to last последнего блока на1
. Параметр Variable name в блоке To Workspace (Simulink) должен совпадать со значением, которое вы вводите в поле BER variable name BERTool.Совет
Больше чем один блок To Workspace (Simulink) доступен. Обязательно выберите To Workspace (Simulink) из подбиблиотеки DSP System Toolbox™ / Sinks.
-
Если ваша модель вычисляет коэффициент ошибок символа вместо небольшого коэффициента ошибок, используйте блок Integer to Bit Converter в программном обеспечении Communications Toolbox, чтобы преобразовать символы вдребезги.
-
Обрабатываются основанные на системе координат симуляции, часто запускаемые быстрее, чем основанные на выборке симуляции для того же количества битов. Количество ошибок или количество обработанных битов могут превысить значения, которые вы вводите в BERTool, потому что симуляция всегда обрабатывает установленную сумму данных в каждой системе координат.
-
Если у вас есть существующая модель, которая использует блок AWGN Channel с помощью параметра Mode кроме
Signal to noise ratio (Eb/No)
, можно адаптировать блок, чтобы использовать режим Eb/No вместо этого. Чтобы узнать о том, как различные режимы блока связаны друг с другом, нажмите кнопку Help блока AWGN Channel, чтобы просмотреть онлайновую страницу с описанием. -
Если ваша модель использует функцию предварительной нагрузки или другой коллбэк, чтобы инициализировать переменные в рабочем пространстве MATLAB после загрузки, убедитесь, прежде чем вы будете использовать кнопку Run в BERTool, что одно из этих условий соблюдают:
-
Модель не находится в настоящее время в памяти. В этом случае BERTool загружает модель в память и запускает функции обратного вызова.
-
Модель находится в памяти (ли в окне или не), и переменные неповреждены.
Если вы очищаете или перезаписываете переменные модели и хотите восстановить их значения перед использованием кнопки Run в BERTool, можно использовать
bdclose
функция в командном окне MATLAB, чтобы очистить модель из памяти. Это заставляет BERTool перезагружать модель после того, как вы нажмете Run. Точно так же, если вы обновляете свою рабочую область путем изданияclear all
илиclear variables
команда, необходимо также очистить модель из памяти при помощиbdclose all
. -
Пример: Подготовьте Модель к Использованию с BERTool. Этот пример использует модель Simulink, которая настраивается для использования с BERTool. Пример также иллюстрирует, как сравнить эффективность BER симуляции Simulink теоретическими результатами BER. Пример принимает, что вам установили программное обеспечение Communications Toolbox.
Чтобы подготовить модель к использованию с BERTool, выполните эти шаги, с помощью точных чувствительных к регистру имен переменных как показано:
-
Откройте модель путем ввода следующей команды в командное окно MATLAB.
-
Чтобы инициализировать параметры в рабочем пространстве MATLAB и избегать использования неопределенных переменных как параметров блоков, введите следующую команду в командное окно MATLAB.
EbNo = 0; maxNumErrs = 100; maxNumBits = 1e8;
-
Чтобы гарантировать, что BERTool использует правильное количество шума каждый раз, это запускает симуляцию, откройте диалоговое окно для блока AWGN Channel путем двойного клика по блоку. Проверьте, что Es/No установлен в
EbNo
и нажмите OK. В этой конкретной модели Es/N0 эквивалентен Eb/N0, потому что тип модуляции является BPSK. -
Гарантировать, что BERTool использует правильный критерий остановки для каждой итерации,
-
Откройте диалоговое окно для блока Error Rate Calculation. Проверьте, что Target number of errors установлен в
maxNumErrs
, и что Maximum number of symbols установлен вmaxNumBits
. Нажмите OK. -
Время остановки симуляции должно быть установлено в
Inf
.
-
-
Позволять BERTool получить доступ к результатам BER, которые блок Error Rate Calculation вычисляет, блок To Workspace (Simulink),
BER
, соединяется с выходом блока Error Rate Calculation.Совет
Больше чем один блок To Workspace (Simulink) доступен. Обязательно выберите To Workspace (Simulink) из подбиблиотеки DSP System Toolbox / Sinks.
Использовать doc_bpsk
модель с BERTool, выполните эти шаги:
-
Откройте BERTool и перейдите к вкладке Monte Carlo.
-
Установите параметры на вкладке Monte Carlo как показано в следующем рисунке.
-
Нажмите Run.
BERTool тратит результаты вычисления некоторого времени и затем строит их.
-
Чтобы сравнить эти результаты симуляции с теоретическими результатами, перейдите к вкладке Theoretical в BERTool и установите параметры как показано ниже.
-
Нажмите Plot.
BERTool строит теоретическую кривую в Окне рисунка BER наряду с более ранними результатами симуляции.
Управляйте данными о BER
-
Экспорт наборов данных или сеансов BERTool
-
Импорт наборов данных или сеансов BERTool
-
Данные об управлении в средстве просмотра данных
Экспорт Наборов данных или Сеансов BERTool. BERTool позволяет вам экспортировать отдельные наборы данных в рабочее пространство MATLAB или в MAT-файлы. Одна опция для экспорта удобна для обработки данных вне BERTool. Например, чтобы создать очень индивидуально настраиваемый отображают данные об использовании на графике из BERTool, экспортируют набор данных BERTool в рабочее пространство MATLAB и используют любую из команд графического вывода в MATLAB. Другая опция для экспорта позволяет вам повторно импортировать данные в BERTool позже.
BERTool также позволяет вам сохранить целый сеанс, который полезен, если ваш сеанс содержит несколько наборов данных, к которым вы хотите возвратиться на более позднем сеансе.
В этом разделе описываются эти возможности:
Экспорт наборов данных
Чтобы экспортировать отдельный набор данных, выполните эти шаги:
-
В средстве просмотра данных выберите набор данных, который вы хотите экспортировать.
-
Выберите .
-
Установите Export to указывать на формат и место назначения данных.
-
Если вы хотите повторно импортировать данные в BERTool позже, необходимо выбрать
Workspace structure
илиMAT-file structure
создать структуру в рабочем пространстве MATLAB или MAT-файле, соответственно.Появляется новое поле под названием Structure name. Установите его на имя, которое вы хотите, чтобы BERTool использовал для структуры, которую это создает.
Если вы выбрали
Workspace structure
и вы хотите, чтобы BERTool использовал ваше выбранное имя переменной, даже если переменная тем именем уже существует в рабочей области, выберите Overwrite variables. -
Если вы не должны повторно импортировать данные в BERTool позже, удобный способ получить доступ к данным вне BERTool состоит в том, чтобы иметь BERTool, создают пару массивов в рабочем пространстве MATLAB. Один массив содержит значения Eb/N0, в то время как другой массив содержит значения BER. Чтобы выбрать эту опцию, установите Export to на
Workspace arrays
.Затем введите два имен переменных в полях под Variable names.
Если вы хотите, чтобы BERTool использовал ваши выбранные имена переменных, даже если переменные теми именами уже существуют в рабочей области, выберите Overwrite variables.
-
-
Нажмите OK. Если вы выбрали
MAT-file structure
, BERTool предлагает вам путь к MAT-файлу, который вы хотите создать.
Чтобы повторно импортировать структуру позже, смотрите Наборы данных Импорта.
Исследование экспортируемой структуры
Этот раздел кратко описывает содержимое структуры, которую BERTool экспортирует в рабочую область или в MAT-файл. Поля структуры обозначаются в приведенной ниже таблице. Полями, которые являются самыми важными для вас, когда это необходимо, чтобы управлять экспортированными данными, является paramsEvaled
и data
.
Имя поля | Значение |
---|---|
params |
Значения параметров в БЕРТОЛЕ ГИ, некоторые из которых могут быть невидимыми и следовательно не важными для расчетов. |
paramsEvaled |
Значения параметров, которые BERTool использует при вычислении набора данных. |
data |
Eb/N0, BER и количество битов обрабатываются. |
dataView |
Информация о внешнем виде в средстве просмотра данных. Используемый BERTool для переимпорта данных. |
cellEditabilities |
Указывает, имеет ли средство просмотра данных активный Confidence Level или запись Fit. Используемый BERTool для переимпорта данных. |
Поля параметра
params
и paramsEvaled
поля похожи друг на друга, за исключением того, что params
описывает точное состояние графический интерфейса пользователя тогда как paramsEvaled
указывает на значения, которые на самом деле используются для расчетов. Как пример различия, для теоретической системы с каналом AWGN, params
записи, но paramsEvaled
не использует параметр порядка разнообразия. Порядок разнообразия не используется в расчетах, потому что это важно только для систем с каналами Рейли. Как другой пример, если вы вводите [0:3]+1
в графический интерфейсе пользователя как область значений значений Eb/N0, params
указывает на [0:3]+1
в то время как paramsEvaled
указывает на 1 2 3 4
.
Длина и точное содержимое paramsEvaled
зависьте от набора данных, потому что только релевантная информация появляется. Если значение содержимого paramsEvaled
не ясно после контроля, один способ узнать больше состоит в том, чтобы повторно импортировать набор данных в BERTool и смотреть значения параметров, которые появляются в графический интерфейсе пользователя. Чтобы повторно импортировать структуру, следуйте инструкциям в Импорте Наборов данных или Сеансов BERTool.
Поле данных
Если ваша экспортируемая переменная рабочей области называется ber0
, поле ber0.data
массив ячеек, который содержит числовые результаты в этих векторах:
-
ber0.data{1}
перечисляет значения Eb/N0. -
ber0.data{2}
перечисляет значения BER, соответствующие каждому из значений Eb/N0. -
ber0.data{3}
указывает, для симуляции или полуаналитических результатов, сколько битов BERTool обработал при вычислении каждого из соответствующих значений BER.
Чтобы сохранить целый сеанс BERTool, выполните эти шаги:
-
Выберите .
-
Когда BERTool предлагает вам, введите путь к файлу, который вы хотите создать.
BERTool создает текстовый файл, который записывает все наборы данных в настоящее время в средстве просмотра данных, наряду с параметрами графический интерфейса пользователя, сопоставленными с наборами данных.
Примечание
Если ваш сеанс BERTool требует конкретных переменных рабочей области (таких как txsig
или rxsig
для вкладки Semianalytic), сохраните тех отдельно в MAT-файле с помощью save
команда в MATLAB.
Импорт Наборов данных или Сеансов BERTool. BERTool позволяет вам повторно импортировать отдельные наборы данных, которые вы ранее экспортировали в структуру, или перезагружать целые сеансы что вы ранее сохраненный. В этом разделе описываются эти возможности:
Чтобы узнать больше об экспорте наборов данных или сохранении сеансов от BERTool, смотрите Наборы данных Экспорта или Сеансы BERTool.
Чтобы импортировать отдельный набор данных, который вы ранее экспортировали от BERTool до структуры, выполните эти шаги:
-
Выберите .
-
Установите Import from на любой
Workspace structure
илиMAT-file structure
. Если вы выбираетеWorkspace structure
, введите имя переменной рабочей области в поле Structure name. -
Нажмите OK. Если вы выбираете
MAT-file
, BERTool предлагает вам выбирать файл, который содержит структуру, которую вы хотите импортировать.
После того, как вы отклоняете диалоговое окно Data Import (и диалоговое окно выбора файла, в случае MAT-файла), средство просмотра данных показывает недавно импортированный набор данных, и Окно рисунка BER строит его.
Открытие предыдущего сеанса BERTool
Чтобы заменить наборы данных в средстве просмотра данных с наборами данных от предыдущего сеанса BERTool, выполните эти шаги:
-
Выберите .
Примечание
Если BERTool уже содержит наборы данных, он спрашивает вас, хотите ли вы сохранить текущий сеанс. Если вы отвечаете не и продолжаете процесс загрузки, BERTool отбрасывает текущий сеанс после открытия нового сеанса из файла.
-
Когда BERTool предлагает вам, введите путь к файлу, который вы хотите открыть. Это должен быть файл, что вы ранее создали использование опции в BERTool.
После того, как BERTool читает файл сеанса, средство просмотра данных показывает наборы данных из файла.
Если ваш сеанс BERTool требует конкретных переменных рабочей области (таких как txsig
или rxsig
для вкладки Semianalytic), что вы сохраненный отдельно в MAT-файле, можно получить их использующий load
команда в MATLAB.
Данные об управлении в Средстве просмотра Данных. Средство просмотра данных дает вам гибкость, чтобы переименовать и удалить наборы данных и переупорядочить столбцы в средстве просмотра данных.
-
Чтобы переименовать набор данных в средстве просмотра данных, дважды кликните его имя в столбце BER Data Set и введите новое имя.
-
Чтобы удалить набор данных из средства просмотра данных, выберите его и выберите .
Примечание
Если набор данных произошел из вкладки Semianalytic или Theoretical, BERTool удаляет данные, не прося подтверждение. Вы не можете отменить эту операцию.
-
Чтобы переместить столбец в средство просмотра данных, перетащите заголовок столбца налево или направо с мышью. Например, изображение ниже показов мышь, перетаскивающая столбец BER слева от его положения по умолчанию. Когда вы отпускаете кнопку мыши, столбцы привязываются в место.