Полином Жегалкина - Zhegalkin polynomial

Жегалкин (также Жегалкин, Gégalkine или же Шегалкин[1]) многочлены образуют одно из многих возможных представлений операций Булева алгебра. Введен русским математиком Иван Иванович Жегалкин в 1927 году они кольцо многочленов над целые числа по модулю 2. В результате вырождения модульная арифметика приводят к тому, что полиномы Жегалкина проще обычных полиномов и не требуют ни коэффициентов, ни показателей. Коэффициенты избыточны, потому что 1 - единственный ненулевой коэффициент. Показатели избыточны, потому что в арифметическом модуле 2 Икс2 = Икс. Следовательно, такой многочлен, как 3Икс2у5z конгруэнтно и поэтому может быть переписано как, xyz.

Логический эквивалент

До 1927 года булева алгебра считалась исчислением логические значения с логическими операциями соединение, дизъюнкция, отрицание и др. Жегалкин показал, что все булевы операции могут быть записаны как обычные числовые многочлены, считая логические константы 0 и 1 целыми числами по модулю 2. Логическая операция соединения реализуется как арифметическая операция умножения. ху, и логично Эксклюзивный или как арифметическое сложение по модулю 2 (здесь записывается как Иксу чтобы избежать путаницы с обычным использованием + в качестве синонима для включающего или ∨). Логическое дополнение ¬Икс тогда получается из 1 и ⊕ как Икс⊕1. Поскольку ∧ и ¬ образуют достаточную основу для всей булевой алгебры, а это означает, что все другие логические операции могут быть получены как составные части этих базовых операций, из этого следует, что многочлены обычной алгебры могут представлять все булевы операции, что позволяет выполнять логические рассуждения. надежно апеллируя к знакомым законам элементарная алгебра без отвлечения внимания на отличия от алгебры средней школы, которые возникают с дизъюнкцией вместо сложения по модулю 2.

Примером приложения является представление логического порога 2 из 3 или средняя операция как полином Жегалкина хуyzzx, который равен 1, если хотя бы две переменные равны 1, и 0 в противном случае.

Формальные свойства

Формально Жегалкин моном является произведением конечного набора различных переменных (следовательно, без квадратов ), включая пустое множество, произведение которого обозначено 1. Имеется 2п возможные одночлены Жегалкина в п переменных, поскольку каждый моном полностью определяется наличием или отсутствием каждой переменной. А Полином Жегалкина является суммой (исключающим ИЛИ) набора мономов Жегалкина, причем пустое множество обозначается как 0. Наличие или отсутствие данного монома в многочлене соответствует коэффициенту этого монома, равному 1 или 0 соответственно. Мономы Жегалкина, будучи линейно независимый, пролет 2п-размерный векторное пространство над Поле Галуа GF(2) (NB: нет GF(2п), чье умножение совершенно иное). 22п векторы этого пространства, то есть линейные комбинации этих одночленов как единичные векторы, составляют многочлены Жегалкина. Точное совпадение с количеством Логические операции на п переменные, которые исчерпывают п-арных операций на {0,1}, дает прямой счетный аргумент в пользу полноты полиномов Жегалкина как булевого базиса.

Это векторное пространство не эквивалентно свободная булева алгебра на п генераторы, потому что ему не хватает дополнения (побитового логического отрицания) как операции (что эквивалентно, потому что ему не хватает верхнего элемента как константы). Это не означает, что пространство не закрыто из-за дополнений или отсутствует верх ( единичный вектор ) как элемент, а то, что линейные преобразования этого и аналогичным образом построенных пространств не должны сохранять дополнение и вершину. Те, которые их сохраняют, соответствуют булевым гомоморфизмам, например существует четыре линейных преобразования из векторного пространства многочленов Жегалкина от одной переменной в пространство без переменных, только два из которых являются булевыми гомоморфизмами.

Метод расчета

Для вычисления полинома Жегалкина обычно используются различные известные методы.

Метод неопределенных коэффициентов

Методом неопределенных коэффициентов формируется линейная система, состоящая из всех кортежей функции и их значений. Решение линейной системы дает коэффициенты полинома Жегалкина.

Пример

Учитывая логическую функцию , выразим его в виде полинома Жегалкина. Эта функция может быть выражена как вектор-столбец

.

Этот вектор должен быть результатом умножения слева вектора неопределенных коэффициентов.

на 8x8 логическая матрица который представляет возможные значения, которые могут принимать все возможные конъюнкции A, B, C. Эти возможные значения приведены в следующей таблице истинности:

.

Информация в приведенной выше таблице истинности может быть закодирована в следующей логической матрице:

где "S" здесь означает "Серпинский", как в Серпинский треугольник, а нижний индекс 3 дает показатели его размера: .

С помощью математической индукции и блочно-матричного умножения можно доказать, что любая такая «матрица Серпинского» это собственное обратное.[примечание 1]

Тогда линейная система есть

который может быть решен для :

,

и полином Жегалкина, соответствующий является .

Использование канонической дизъюнктивной нормальной формы

Используя этот метод, каноническая дизъюнктивная нормальная форма (полностью развернутый дизъюнктивная нормальная форма ) вычисляется первым. Затем отрицания в этом выражении заменяются эквивалентным выражением с использованием суммы по модулю 2 переменной и 1. Знаки дизъюнкции меняются на сложение по модулю 2, скобки открываются, и результирующее логическое выражение упрощается. Это упрощение приводит к полиному Жегалкина.

Использование таблиц

Вычисление полинома Жегалкина для примера функции п табличным методом

Позволять быть выходами таблицы истинности для функции п из п переменные, такие, что индекс 's соответствует бинарной индексации minterms[заметка 2]. Рекурсивно определить функцию ζ следующим образом:

.

Обратите внимание, что

куда это биномиальный коэффициент уменьшенный по модулю 2.

потом

это я th коэффициент полинома Жегалкина, литералы которого в я th мономы такие же, как литералы в я th minterm, за исключением того, что отрицательные литералы удаляются (или заменяются на 1).

Ζ-преобразование является само по себе обратным, поэтому такая же таблица может использоваться для вычисления коэффициентов учитывая коэффициенты . Просто позволь

.

В терминах таблицы на рисунке скопируйте выходные данные таблицы истинности (в столбец с меткой п) в крайний левый столбец треугольной таблицы. Затем последовательно вычисляйте столбцы слева направо, применяя XOR к каждой паре вертикально смежных ячеек, чтобы заполнить ячейку сразу справа от верхней ячейки каждой пары. Когда вся треугольная таблица заполнена, верхняя строка считывает коэффициенты линейной комбинации, которая при упрощении (удаление нулей) дает многочлен Жегалкина.

Чтобы перейти от полинома Жегалкина к таблице истинности, можно заполнить верхнюю строку треугольной таблицы коэффициентами полинома Жегалкина (добавляя нули для любых комбинаций положительных литералов, не входящих в полином). Затем последовательно вычисляйте строки сверху вниз, применяя XOR к каждой паре горизонтально смежных ячеек, чтобы заполнить ячейку сразу до нижней части крайней левой ячейки каждой пары. Когда вся треугольная таблица заполнена, крайний левый столбец ее можно скопировать в столбец п таблицы истинности.

Отметим, что данный метод расчета соответствует принципу работы элементарный клеточный автомат называется Правило 102. Например, запустите такой клеточный автомат с восемью ячейками, настроенными с выходами таблицы истинности (или коэффициентами канонической дизъюнктивной нормальной формы) логического выражения: 10101001. Затем запустите клеточный автомат еще для семи поколений, сохраняя при этом запись состояния крайней левой ячейки. История этой ячейки тогда оказывается: 11000010, которая показывает коэффициенты соответствующего полинома Жегалкина.[2][3]

Метод Паскаля

Использование метода Паскаля для вычисления полинома Жегалкина для булевой функции . В строке на русском внизу написано:
- побитовая операция «Исключающее ИЛИ»

Наиболее экономичным по объему вычислений и целесообразным для построения полинома Жегалкина вручную является метод Паскаля.

Строим стол, состоящий из колонны и ряды, где N - количество переменных в функции. В верхней строке таблицы размещаем вектор значений функции, то есть последний столбец таблицы истинности.

Каждая строка результирующей таблицы разбита на блоки (черные линии на рисунке). В первой строке блок занимает одну ячейку, во второй строке - две, в третьей - четыре, в четвертой - восемь и так далее. Каждый блок в определенной строке, которую мы будем называть «нижним блоком», всегда соответствует ровно двум блокам в предыдущей строке. Мы будем называть их «левый верхний блок» и «правый верхний блок».

Строительство начинается со второй линии. Содержимое левых верхних блоков переносится без изменений в соответствующие ячейки нижнего блока (зеленые стрелки на рисунке). Затем операция «сложение по модулю два» выполняется поразрядно над правым верхним и левым верхним блоками, и результат переносится в соответствующие ячейки правой части нижнего блока (красные стрелки на рисунке). Эта операция выполняется со всеми строками сверху вниз и со всеми блоками в каждой строке. После завершения построения в нижней строке находится строка чисел, являющихся коэффициентами полинома Жегалкина, записанная в той же последовательности, что и в методе треугольника, описанном выше.

Метод суммирования

Графическое представление коэффициентов полинома Жегалкина для функций с различным числом переменных.

По таблице истинности легко вычислить индивидуальные коэффициенты полинома Жегалкина. Для этого просуммируйте по модулю 2 значения функции в тех строках таблицы истинности, где переменные, не входящие в конъюнкцию (которая соответствует вычисляемому коэффициенту), принимают нулевые значения.

Предположим, например, что нам нужно найти коэффициент при xz конъюнкция для функции трех переменных . Нет переменной у в этом сочетании. Найдите входные наборы, в которых переменная у принимает нулевое значение. Это наборы 0, 1, 4, 5 (000, 001, 100, 101). Тогда коэффициент при конъюнкции xz является

Поскольку нет переменных с постоянным членом,

.

Для члена, который включает все переменные, сумма включает все значения функции:

Представим графически коэффициенты многочлена Жегалкина как суммы по модулю 2 значений функций в определенных точках. Для этого мы строим квадратную таблицу, где каждый столбец представляет значение функции в одной из точек, а строка - коэффициент полинома Жегалкина. Точка на пересечении некоторого столбца и строки означает, что значение функции в этой точке входит в сумму для данного коэффициента полинома (см. Рисунок). Мы называем эту таблицу , куда N - количество переменных функции.

Существует шаблон, позволяющий получить таблицу для функции N переменные, имея таблицу для функции переменные. Новый стол устроен как матрица 2 × 2 таблицы, а правый верхний блок матрицы очищается.

Теоретико-решеточная интерпретация

Рассмотрим столбцы таблицы как соответствующие элементы Логическая решетка размера . Для каждого столбца экспресс-номер M как двоичное число , тогда если и только если , куда означает побитовое ИЛИ.

Если строки таблицы пронумерованы сверху вниз числами от 0 до , то табличное содержание номера строки р это идеальный генерируется элементом решетки.

Кстати, обратите внимание, что общий рисунок таблицы это то из логическая матрица Серпинский треугольник. Также шаблон соответствует элементарный клеточный автомат называется Правило 60, начиная с крайней левой ячейки, установленной на 1, а все остальные ячейки очищены.

Использование карты Карно

Преобразование отображения Карно в полином Жегалкина.

На рисунке показана функция трех переменных, п(А, B, C) в виде Карта Карно, который читатель может рассматривать как пример преобразования таких отображений в полиномы Жегалкина; общая процедура состоит из следующих шагов:

  • Мы рассматриваем все ячейки карты Карно в порядке возрастания количества единиц в их кодах. Для функции трех переменных последовательность ячеек будет 000–100–010–001–110–101–011–111. Каждая ячейка карты Карно связана с членом полинома Жегалкина в зависимости от позиций кода, в которых есть единицы. Например, ячейка 111 соответствует члену ABC, ячейка 101 соответствует члену AC, ячейка 010 соответствует члену B, а ячейка 000 соответствует члену 1.
  • Если в рассматриваемой ячейке 0, перейдите к следующей ячейке.
  • Если рассматриваемая ячейка равна 1, добавьте соответствующий член к многочлену Жегалкина, затем инвертируйте все ячейки в карте Карно, где этот член равен 1 (или принадлежит идеальный порожденные этим членом в булевой решетке одночленов) и переходят в следующую ячейку. Например, если при рассмотрении ячейки 110 в ней появляется единица, то к полиному Жегалкина добавляется член AB и инвертируются все ячейки карты Карно, для которых A = 1 и B = 1. Если единица находится в ячейке 000, то к полиному Жегалкина добавляется член 1 и инвертируется вся карта Карно.
  • Процесс преобразования можно считать завершенным, если после следующей инверсии все ячейки карты Карно становятся нулевыми или не учитываются.

Преобразование Мёбиуса

В Формула обращения Мебиуса связывает коэффициенты булевого выражения суммы минимальных членов и полинома Жегалкина. Это частичный вариант формулы Мёбиуса, а не теоретико-числовой. Формула обращения Мёбиуса для частичных порядков:

[4],

куда , |Икс| будучи Расстояние Хэмминга из Икс от 0. Поскольку в алгебре Жегалкина функция Мёбиуса схлопывается до константы 1.

Множество делителей заданного числа Икс также идеал порядка, порожденный этим числом: . Поскольку суммирование ведется по модулю 2, формулу можно переформулировать как

Пример

В качестве примера рассмотрим случай с тремя переменными. В следующей таблице показано отношение делимости:

Иксделители Икс
000000
001000, 001
010000, 010
011000, 001, 010, 011
100000, 100
101000, 001, 100, 101
110000, 010, 100, 110
111000, 001, 010, 011, 100, 101, 110, 111

потом

Приведенная выше система уравнений может быть решена относительно ж, и результат может быть получен путем обмена грамм и ж во всей вышеупомянутой системе.

В таблице ниже показаны двоичные числа вместе с соответствующими одночленами Жегалкина и булевыми минтермами:

Логический минтермABCЖегалкин моном
0001
001C
010B
011до н.э
100А
101AC
110AB
111ABC

Мономы Жегалкина естественным образом упорядочены по делимости, тогда как булевы минтермы сами себя упорядочивают не так естественно; каждый представляет собой исключительную восьмую из трех переменных Диаграмма Венна. Порядок мономов переносится на битовые строки следующим образом: задано и , пара битовых троек, тогда .

Тогда соответствие между булевой суммой терминов с тремя переменными и полиномом Жегалкина будет следующим:

.

Приведенную выше систему уравнений можно резюмировать как логическая матрица уравнение:

который Н. Дж. Вильдбергер называет преобразованием Буля – Мёбиуса.

Ниже показан «XOR электронная таблица Форма трансформации, идущая в направлении грамм к ж:

Связанных с работой

В том же году, что и работа Жегалкина (1927 г.), американский математик Эрик Темпл Белл опубликовал сложную арифметизацию булевой алгебры на основе Ричард Дедекинд Идеальная теория и общая модульная арифметика (в отличие от арифметики по модулю 2). Гораздо более простой арифметический характер многочленов Жегалкина был впервые замечен на Западе (независимо, общение между советскими и западными математиками в ту эпоху было очень ограниченным) американским математиком. Маршалл Стоун в 1936 году, когда он заметил, когда писал свой знаменитый Каменная двойственность Теорема о том, что предположительно слабая аналогия между Булевы алгебры и кольца Фактически, его можно было сформулировать как точную эквивалентность как для конечных, так и для бесконечных алгебр, что привело его к существенной реорганизации своей работы в течение следующих нескольких лет.

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

Примечания

  1. ^ В качестве базового случая
    куда здесь используется для обозначения единичная матрица размера . Индуктивное предположение
    .
    Тогда индуктивный шаг:
    ,
    куда обозначает Кронекер продукт,
    ,
    или, в терминах продукта Кронекера:
    . ∎
  2. ^ Минтерм является булевым аналогом одночлена Жегалкина. Для п-переменный контекст, есть Мономы Жегалкина и Булевы минтермы тоже. Минтерм для п-переменный контекст состоит из И-произведения п литералы, каждый из которых является либо переменной в контексте, либо НЕ-отрицанием такой переменной. Более того, для каждой переменной в контексте должен появиться ровно один раз в каждом минтерме соответствующий литерал (либо утверждение, либо отрицание этой переменной). Таблица истинности для булевой функции п переменных имеет ровно rows, входные данные каждой строки естественно соответствуют minterm, контекст которого является набором независимых переменных этой булевой функции. (Каждый вход 0 соответствует переменной с отрицанием; каждый вход 1 соответствует утвержденной переменной.)
    Любое логическое выражение может быть преобразовано в форму суммы-minterms путем многократного распределения AND относительно OR, NOT относительно AND или OR (через тождества Де Моргана), отмены двойного отрицания (см. нормальная форма отрицания ); а затем, когда будет получена сумма произведений, умножьте произведения с недостающими литералами на экземпляры закон исключенного среднего содержащие недостающие литералы; затем - наконец - снова распределите И по отношению к ИЛИ.
    Обратите внимание, что для данного контекста существует формальное соответствие между мономами Жегалкина и булевыми минтермами. Однако соответствие не является логической эквивалентностью. Например, для контекста {А, B, C} существует формальное соответствие между мономом Жегалкина AB и логический minterm , но они логически не эквивалентны. (Подробнее об этом примере см. Во второй таблице в разделе «Преобразование Мёбиуса». Один и тот же набор битовых строк используется для индексации как набора логических минтермов, так и набора мономов Жегалкина.)

Рекомендации

  1. ^ Штайнбах, Бернд; Постхофф, Кристиан (2009). "Предисловие". Написано во Фрайберге, Германия. Логические функции и уравнения - примеры и упражнения (1-е изд.). Дордрехт, Нидерланды: Springer Science + Business Media Б.В. п. XV. ISBN  978-1-4020-9594-8. LCCN  2008941076.
  2. ^ В.П. Супрун. Табличный метод полиномиального разложения булевых функций // Кибернетика. - 1987. - №1. - С. 116-117.
    Транслитерация: В.П. Супрун. Табличный метод полиномиального разложения бульевых функций // Кибернетика. - 1987. - №1. - С. 116-117.
    Перевод: В.П. Супрун Табличный метод полиномиального разложения булевых функций // Кибернетика. - 1987. - №1. - с. 116-117.
  3. ^ В.П. Супрун. Основы теории булевых функций. - М .: Ленанд / URSS. - 2017. - 208 с.
    Транслитерация: В.П. Супрун. Основы теории булевых функций. - М .: Ленанд / УРСС. - 2017. - 208 с.
    Перевод: В.П. Супрун Основы теории булевых функций. - М .: Ленанд / УРСС. - 2017. - 208 с.
  4. ^ Обращение Мёбиуса. Энциклопедия математики. URL: http://encyclopediaofmath.org/index.php?title=M%C3%B6bius_inversion&oldid=50404