Критерій Поста

Критерій Поста — одна з центральних теорем математичної логіки, описує необхідні та достатні умови функціональної повноти множини булевих функцій. Був сформульований американським математиком Емілем Постом в 1921. Отже, для того щоб наша система була повною, необхідно і достатньо, щоб вона містила хоча б одну нелінійну функцію, хоча б одну несамодвоїсту, хоча б одну немонотонну, хоча б одну функцію, яка не зберігатиме нуль та хоча б одну функцію, що не зберігає одиницю.

Постановка задачі

Булева n-арна функція, це функція , де  булева множина.

Кількість n-арних булевих функцій дорівнює , а загалом, існує нескінченна кількість булевих функцій.

Загальновідомо, що довільна булева функція може бути представлена у вигляді:

Тому природним є питання: чи є функціонально повною деяка множина функцій?

Замкнені класи

Ідея теореми Поста в тому, щоб розглядати множину всіх булевих функцій як алгебру відносно операції суперпозиції, її називають алгеброю Поста. Підалгебрами цієї алгебри є всі замкнені класи булевих функцій.

Основними в теоремі Поста є 5 замкнених класів що називаються передповними класами.

Критерій

Множина булевих функцій є функціонально повною тоді і тільки тоді, коли вона не міститься повністю ні в одному з передповних класів.

Доведення

Необхідність умови випливає з функціональної замкненості та неповноти классів монотонних, лінійних, самодвоїстих функцій та функції, які зберігають 0 та 1. Для доведення достатності необхідно показати, що за допомогою функцій, які не належать деяким з класів , , можна побудувати деяку повну систему функцій. Прикладом повної системи є заперечення та кон'юнкція. Дійсно довільна булева функція може бути представлена у вигляді ДДНФ, тобто у вигляді кон'юнкції, диз'юнкції та заперечення. Відповідна система є функціонально повною. Можна виключити з неї диз'юнкцію так що вона буде представлена як суперпозиція та : .
Спочатку побудуємо константи. Почнемо з константи 1. Нехай , де - функція, що не зберігає нуль. Тоді , тобто . Можливі два випадки:

1. . В цьому випадку формула реалізує 1.
2. . Тоді формула реалізує заперечення. В цьому випадку розглянемо несамодвоїсту функцію . Маємо:
.
Відповідно,. Нехай тепер . Тоді:
.

Таким чином, , звідки або . Якщо , то ми побудували константу 1. В іншому випадку реалізує нуль, а тому . Константа 0 будується аналогічно, тільки замість треба брати - функцію, що не зберігає 1.

За допомогою немонотонної функції підстановкою в неї констант можна побудувати заперечення. Нехай - немонотонна функція. Тоді існують набори та , такі, що переслідує , тобто , а , . Оскільки , то у є декілька, наприклад, елементів, які рівні 0, в той час як у ті ж самі елементи рівні 1. Візьмемо набір та замінимо в ньому перший такий нульовий елемент на 1, отримаємо : , який відрізняється від тільки одним елементом. Повторюючи цю операцію разів, отримаємо послідовність наборів , в якій кожні два сусідніх набори відрізняються один від одного тільки одним елементом. В цьому ланцюжку знайдуться два таких набори , що та . Нехай ці набори відрізняються -м (значення змінної ), а решта елементів однакові. Підставимо у ці значення. Тоді отримаємо функцію , яка залежить тільки від . Тоді , . Звідси, маємо, що .

Побудуємо кон’юнкцію за допомогою підстановки у нелінійну функцію констант та використання заперечення. Нехай - нелінійна функція. Тоді в її поліномі Жегалкіна існує нелінійний доданок, який містить кон'юнкцію принаймні двох змінних. Нехай, для визначеності, це та . Тоді:

,

до того ж ≠ 0. Відповідно,

.

Нехай та

.

Тоді нехай

.

Тоді

(функцію можна виразити за допомогою ).

Приклади

Приклад 1

Перевірити повноту системи

Розглянемо формулу

хyF
001
011
100
111

Розглянемо формулу

xV
01
10

Побудуємо таблицю Поста( якщо функція входить у функціонально замкнений клас, то в таблиці Поста у відповідній комірці ставиться знак "+", інакше - "-"

Т0Т1SML
F-+---
V----+

Система є повною.

Приклад 2

Перевірити на повноту систему:

Розглянемо

xyzF
000101
001101
010001
011001
100110
101111
110001
111001

Перевірка на лінійність:

xyzB
0001001
0010001
0101100
0110100
1001111
1010100
1101010
1110001

Перевірка на лінійність:

xyC
0010
0111
1000
1100

Перевірка на лінійність:

Т0Т1MSL
F-+---
B-+---
C+----

Отже система є повною.

Приклад 3

Перевірити на повноту систему

Розглянемо

xyzF
000110
001111
010110
011111
100001
101001
110010
111011

Перевіримо на лінійність:

xyzP
000101
001110
010000
011011
100011
101011
110110
111110

Перевіримо на лінійність:


xyB
00111
01011
10011
11000

Перевіримо на лінійність:

T0T1MSL
F++---
P-----
B-----

Отже, система - повна.

This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.