hammgen

Проверка четности и матрицы генератора для Кода Хемминга

Описание

пример

h = hammgen(m) возвращает m- n матрица проверки четности, h, для Кода Хемминга длины кодовой комбинации n = 2m–1. Длиной сообщения Кода Хемминга является nm. Бинарный примитивный полином, что функциональное использование, чтобы создать Код Хемминга является примитивным полиномом по умолчанию в GF (2^m). Для получения дополнительной информации этого полинома по умолчанию, смотрите gfprimdf функция.

пример

h = hammgen(m,poly) задает poly, бинарный примитивный полином для GF (2m). Функция использует poly создать Код Хемминга.

пример

[h,g] = hammgen(___) дополнительно возвращает k-by-n порождающая матрица, g, это соответствует матрице проверки четности h. Задайте любую из комбинаций входных аргументов от предыдущих синтаксисов.

пример

[h,g,n,k] = hammgen(___) также возвращает n, длина кодовой комбинации и k, длина сообщения, для Кода Хемминга.

Примеры

свернуть все

Сгенерируйте матрицу проверки четности, h, для Кода Хемминга длины кодовой комбинации 7. Функция использует примитивный полином по умолчанию в GF (8), чтобы создать Код Хемминга.

h = hammgen(3)
h = 3×7

     1     0     0     1     0     1     1
     0     1     0     1     1     1     0
     0     0     1     0     1     1     1

Сгенерируйте матрицы проверки четности для Кода Хемминга длины кодовой комбинации 15, задав примитивные полиномы 1+D+D4 и 1+D3+D4 в GF (16).

h1 = hammgen(4,'1+D+D^4')
h1 = 4×15

     1     0     0     0     1     0     0     1     1     0     1     0     1     1     1
     0     1     0     0     1     1     0     1     0     1     1     1     1     0     0
     0     0     1     0     0     1     1     0     1     0     1     1     1     1     0
     0     0     0     1     0     0     1     1     0     1     0     1     1     1     1

h2 = hammgen(4,'1+D^3+D^4')
h2 = 4×15

     1     0     0     0     1     1     1     1     0     1     0     1     1     0     0
     0     1     0     0     0     1     1     1     1     0     1     0     1     1     0
     0     0     1     0     0     0     1     1     1     1     0     1     0     1     1
     0     0     0     1     1     1     1     0     1     0     1     1     0     0     1

Удалите встроенные единичные матрицы 4 на 4 то есть, крайние левые четыре столбца в каждой матрице проверки четности.

h1 = h1(:,5:end)
h1 = 4×11

     1     0     0     1     1     0     1     0     1     1     1
     1     1     0     1     0     1     1     1     1     0     0
     0     1     1     0     1     0     1     1     1     1     0
     0     0     1     1     0     1     0     1     1     1     1

h2 = h2(:,5:end)
h2 = 4×11

     1     1     1     1     0     1     0     1     1     0     0
     0     1     1     1     1     0     1     0     1     1     0
     0     0     1     1     1     1     0     1     0     1     1
     1     1     1     0     1     0     1     1     0     0     1

Проверьте, что две получившихся матрицы отличаются.

isequal(h1,h2)
ans = logical
   0

Сгенерируйте матрицу проверки четности, h и порождающая матрица, g для Кода Хемминга длины кодовой комбинации 7. Также возвратите длину кодовой комбинации, n, и длина сообщения, k для Кода Хемминга. Функция использует примитивный полином по умолчанию в GF (8), чтобы создать Код Хемминга.

[h,g,n,k] = hammgen(3)
h = 3×7

     1     0     0     1     0     1     1
     0     1     0     1     1     1     0
     0     0     1     0     1     1     1

g = 4×7

     1     1     0     1     0     0     0
     0     1     1     0     1     0     0
     1     1     1     0     0     1     0
     1     0     1     0     0     0     1

n = 7
k = 4

Входные параметры

свернуть все

Количество строк в матрице проверки четности в виде целого числа, больше, чем или равный два. Функция использует это значение, чтобы вычислить длину кодовой комбинации и длину сообщения Кода Хемминга.

Типы данных: double

Бинарный примитивный полином в GF (2m) в виде одного из этих значений:

  • Вектор строки двоичных знаков из полиномиальных коэффициентов в порядке возрастающих степеней

  • Символьный вектор

  • Скаляр строки

Если poly задан как непримитивный полином, затем функция hammgen отображает ошибку.

Типы данных: double | char | string

Выходные аргументы

свернуть все

Матрица проверки четности для Кода Хемминга, возвращенного как m- n матрица двоичных значений для Кода Хемминга.

Типы данных: single | double

Порождающая матрица для Кода Хемминга, возвращенного как k- n матрица двоичных значений, соответствующих матрице проверки четности h.

Типы данных: single | double

Длина кодовой комбинации Кода Хемминга, возвращенного как положительное целое число. Это значение вычисляется как 2m–1.

Типы данных: single | double

Передайте длину Кода Хемминга, возвращенного как положительное целое число. Это значение вычисляется как nM.

Типы данных: single | double

Алгоритмы

hammgen использует функцию gftuple создать матрицу проверки четности путем преобразования каждого элемента в Поле Галуа (GF) к его полиномиальному представлению. В отличие от этого, gftuple, который выполняет расчеты в GF (2m) и процессы один m- кортеж за один раз, hammgen функция генерирует целую последовательность от 0 до 2m–1. Алгоритм расчета использует все ранее вычисленные значения, чтобы сгенерировать результат расчета. Если значение m меньше 25, и примитивный полином является примитивным полиномом по умолчанию для GF (2m), синтаксис hammgen (m) может быть быстрее, чем синтаксис hammgen (mpoly).

Смотрите также

Функции

Представлено до R2006a
Для просмотра документации необходимо авторизоваться на сайте