Топ питань
Часова шкала
Чат
Перспективи
Критерій Поста
З Вікіпедії, вільної енциклопедії
Remove ads
Критерій Поста — одна з центральних теорем математичної логіки, описує необхідні та достатні умови функціональної повноти множини булевих функцій. Був сформульований американським математиком Емілем Постом в 1921. Отже, для того щоб наша система була повною, необхідно і достатньо, щоб вона містила хоча б одну нелінійну функцію, хоча б одну несамодвоїсту, хоча б одну немонотонну, хоча б одну неафінну, хоча б одну функцію, яка не зберігатиме нуль та хоча б одну функцію, що не зберігає одиницю.
Ця стаття потребує істотної переробки. (2 грудня 2024) |
Було запропоновано приєднати цю статтю або розділ до Ґратка Поста, але, можливо, це варто додатково обговорити. Пропозиція з червня 2024. |
Remove ads
Постановка задачі
Булева n-арна функція, це функція , де — булева множина.
Кількість n-арних булевих функцій дорівнює , а загалом, існує нескінченна кількість булевих функцій.
Довільна булева функція може бути представлена у вигляді:
- ДНФ (використовується такий набір операцій: кон'юнкція (), диз'юнкція (), заперечення ());
- поліному Жегалкіна.
Тому природним є питання: чи є функціонально повною деяка множина функцій?
Remove ads
Замкнені класи
Ідея теореми Поста в тому, щоб розглядати множину всіх булевих функцій як алгебру відносно операції суперпозиції, її називають алгеброю Поста. Підалгебрами цієї алгебри є всі замкнені класи булевих функцій.
Основними в теоремі Поста є 5 замкнених класів що називаються передповними класами.
Критерій
Множина булевих функцій є функціонально повною тоді і тільки тоді, коли вона не міститься повністю ні в одному з передповних класів.
Доведення
Узагальнити
Перспектива
Необхідність умови випливає з функціональної замкненості та неповноти класів монотонних, лінійних, самодвоїстих функцій та функції, які зберігають 0 та 1. Для доведення достатності необхідно показати, що за допомогою функцій, які не належать деяким з класів , , можна побудувати деяку повну систему функцій. Прикладом повної системи є заперечення та кон'юнкція. Дійсно довільна булева функція може бути представлена у вигляді ДДНФ, тобто у вигляді кон'юнкції, диз'юнкції та заперечення. Відповідна система є функціонально повною. Можна виключити з неї диз'юнкцію так що вона буде представлена як суперпозиція та : .
Спочатку побудуємо константи. Почнемо з константи 1. Нехай , де - функція, що не зберігає нуль. Тоді , тобто . Можливі два випадки:
- 1. . В цьому випадку формула реалізує 1.
- 2. . Тоді формула реалізує заперечення. В цьому випадку розглянемо несамодвоїсту функцію . Маємо:
- .
- Відповідно,. Нехай тепер . Тоді:
- .
Таким чином, , звідки або . Якщо , то ми побудували константу 1. В іншому випадку реалізує нуль, а тому . Константа 0 будується аналогічно, тільки замість треба брати - функцію, що не зберігає 1.
За допомогою немонотонної функції підстановленням в неї констант можна побудувати заперечення. Нехай - немонотонна функція. Тоді існують набори та , такі, що переслідує , тобто , а , . Оскільки , то у є декілька, наприклад, елементів, які рівні 0, в той час як у ті ж самі елементи рівні 1. Візьмемо набір та замінимо в ньому перший такий нульовий елемент на 1, отримаємо : , який відрізняється від тільки одним елементом. Повторюючи цю операцію разів, отримаємо послідовність наборів , в якій кожні два сусідніх набори відрізняються один від одного тільки одним елементом. В цьому ланцюжку знайдуться два таких набори , що та . Нехай ці набори відрізняються -м (значення змінної ), а решта елементів однакові. Підставимо у ці значення. Тоді отримаємо функцію , яка залежить тільки від . Тоді , . Звідси, маємо, що .
Побудуємо кон’юнкцію за допомогою підстановлення у нелінійну функцію констант та використання заперечення. Нехай - нелінійна функція. Тоді в її поліномі Жегалкіна існує нелінійний доданок, який містить кон'юнкцію принаймні двох змінних. Нехай, для визначеності, це та . Тоді:
- ,
до того ж ≠ 0. Відповідно,
- .
Нехай та
- .
Тоді нехай
- .
Тоді
(функцію можна виразити за допомогою ).
Remove ads
Приклади
Узагальнити
Перспектива
Приклад 1
Перевірити повноту системи
Розглянемо формулу
Розглянемо формулу
Побудуємо таблицю Поста( якщо функція входить у функціонально замкнений клас, то в таблиці Поста у відповідній комірці ставиться знак "+", інакше - "-"
Система є повною.
Приклад 2
Перевірити на повноту систему:
Розглянемо
Перевірка на лінійність:
Перевірка на лінійність:
Перевірка на лінійність:
Отже система є повною.
Приклад 3
Перевірити на повноту систему
Розглянемо
Перевіримо на лінійність:
Перевіримо на лінійність:
Перевіримо на лінійність:
Отже, система - повна.
Ця стаття не містить посилань на джерела. (грудень 2010) |
Remove ads
Wikiwand - on
Seamless Wikipedia browsing. On steroids.
Remove ads