Алгебра логіки
Алгебра логіки (Булева алгебра, Булева логіка, двійкова логіка, двійкова алгебра, англ. Boolean algebra) — розділ математичної логіки, що вивчає систему логічних операцій над висловлюваннями.[1] В алгебрі логіки значенням змінних є значення істинності істина або хиба, які зазвичай визначаються як 1 і 0 відповідно. На відміну від елементарної алгебри, у якій значеннями змінних є числа, а основними операціями є додавання і множення, основними операціями булевої алгебри є кон'юнкція операція І (англ. AND) позначається як ∧, диз'юнкція АБО (англ. OR) позначається як ∨, і заперечення НІ (англ. NOT) позначається як ¬. Таким чином, формалізм для описання логічних відношень є аналогічним тому, як описуються числові відношення в елементарній алгебрі. Булеву алгебру запропонував Джордж Буль у своїй книзі Математичний аналіз логіки (1847), і більш детально в наступній книзі Дослідження законів думки[en] (1854).[2] Відповідно до Гантінгтона[en], термін «Булева алгебра» вперше запропонував Шеффер у 1913,[3] хоча Чарлз Сандерс Пірс у 1880 дав назву «Булева алгебра з однією сталою» першій главі своєї книги «Найпростіша математика».[4] Булева алгебра є фундаментальною основою для розвитку цифрової електроніки, і втілена в усіх мовах програмування. Вона також використовується в теорії множин і статистиці.[5] ВизначенняБазовими елементами, якими оперує алгебра логіки, є висловлювання. Висловлювання будуються над множиною {B, , , , 0, 1}, де B — непорожня множина, над елементами якої визначені три операції:
Так само використовуються назви
Унарна операція заперечення в тексті формул оформляється або у вигляді значка перед операндом (), або у вигляді риски над операндом (), що компактніше, але загалом менш помітно. ЗначенняТоді як в елементарній алгебрі вирази зазвичай виражаються в числах, в алгебрі логіки вони виражають значення істинності істина і хиба. Ці значення задають за допомогою бітів (або двійкових чисел), а саме 0 та 1. Вони не поводять себе так само як цілі числа 0 та 1, для яких 1 + 1 = 2, а можуть визначатися як елементи двоелементного поля GF(2)[en], що є цілочисельною арифметикою за модулем 2, для якої 1 + 1 = 0. Алгебра логіки також вивчає функції, що приймають значення в множині {0, 1}. Предмет вивченняСпочатку проблематика алгебри логіки перетиналася з проблематикою алгебри множин (теоретико-множинні операції). Проте із закінченням формування теорії множин (70-і роки 19 ст.), до складу якої входила алгебра множин, і подальшим розвитком математичної логіки, предмет алгебри логіки значно змінився. Сучасна алгебра логіки розглядає операції над висловлюваннями (див. Числення висловлень) як булеву функцію і вивчає відносно них такі питання, як:
ОпераціїБазові операціїЯк уже зазначалося, базовими операціями булевої алгебри (алгебри логіки) є такі логічні операції:
Альтернативним способом значення x∧y, x∨y, та ¬x можна представити в табличному вигляді для всіх можливих значень за допомогою таблиць істинності таким способом.
Якщо значення істинності 0 та 1 інтерпретувати як цілі числа, ці операції можна було задати як звичайні операції арифметики (де x + y використовує додавання, а xy використовує множення), або як функції мінімуму/максимуму: Можна вважати, що лише заперечення і одна з двох операцій, що залишилися, є базовими, оскільки наступні рівняння дозволяють визначити кон'юнкцію через операції заперечення та диз'юнкцію, і навпаки: Вторинні операціїТри булеві операції описані вище називають базовими або первинними, що означає, що вони можуть бути базисом для всіх інших булевих операцій, оскільки всі інші операції можна виразити через них за допомогою композиції. Серед операцій, які можна побудувати з базових операцій є такі: Ці визначення дають такі таблиці істинності, у яких показані значення цих операцій для всіх можливих вхідних значень.
Перша операція, x → y, називається імплікацією. Якщо x є істинним, тоді за значення виразу x → y приймається значення y. Але якщо x приймає хибне значення, то значення y можна було б ігнорувати; однак ця операція повинна повернути деяке логічне значення, і існує лише два варіанти вибору. То ж за визначенням, x → y є істиною коли x є хибним. Друга операція, x ⊕ y, називається виключною диз'юнкцією (часто задається як абревіатура XOR), аби відрізнити її від диз'юнкції. Вона є істиною, лише коли x та y різні. Третя операція, обернена до виключної диз'юнкції, називається еквівалентність або булева рівність: x ≡ y буде істиною, лише коли x та y мають однакове значення. Для двох даних операндів, кожен з яких має 22 = 4 можливих комбінації входів. Оскільки кожен вихід може мати два можливих значення, існує загалом 24 = 16 можливих булевих операцій. ЗакониЗаконом у булевій алгебрі може виступати тотожність між двома булевими виразами такого вигляду як x∨(y∨z) = (x∨y)∨z, де булевий вираз (або логічне висловлювання) визначається як вираз, що побудований зі змінних та констант 0 та 1 та операцій між ними ∧, ∨, та ¬. Це поняття можна поширити й до виразів, що містять інші булеві операції, такі як ⊕, →, та ≡, але для формулювання законів таке розширення операцій не є необхідним. Для таких цілей додають визначення булевої алгебри як будь-якої моделі булевих законів, і як засіб для виведення нових законів з наявних, як наприклад доведення, що x∨(y∧z) = x∨(z∧y) з y∧z = z∧y. Закони монотонностіБулева алгебра задовольняє багатьом відповідним законам звичайної алгебри, якщо зіставити операції ∨ з додаванням, а ∧ з множенням. Зокрема такі закони є спільними для обох типів алгебр:[6]
Такі закони є дійсними в булевій алгебрі, але не дійсні у звичайній алгебрі:
Якщо прийняти x = 2 в третьому наведеному вище законі, ми бачимо, що це не закон зі звичайної алгебри, оскільки 2 × 2 = 4. Решта п'ять законів можна фальсифікувати у звичайній алгебрі, якщо прийняти, що значення всіх змінних буде 1, наприклад, у законі абсорбції 1 ліва сторона відношення була б 1(1 + 1) = 2, а права частина рівняння була 1, і так далі. Усі ці закони, що розглядалися досі, були для кон'юнкції та диз'юнкції. Ці дві операції мають властивість, що за зміни будь-якого з аргументів вихід залишиться або незмінним, або змінить своє значення так само як вхід. Аналогічно, зміна значення будь-якої змінної з 0 на 1 ніколи не призведе до того, що вихід змінить своє значення з 1 на 0. Операції з такою властивістю називають монотонними. Таким робом, усі аксіоми досі були для монотонної булевої логіки. Немонотонність з'являється через операцію доповнення ¬, що наведено далі.[5] Закони немонотонностіОперація доповнення (заперечення) визначається такими двома законами. Усі властивості заперечення, зокрема закони, що наведені нижче, випливають з двох вищенаведених законів.[5] Як у звичайній, так і в булевій алгебрі, операція заперечення працює як обмін пари елементів, тому в обох алгебрах вона задовольняє закону подвійного заперечення (також називається законом інволюції). Але тоді як «звичайна алгебра» задовольняє таким двом законам: булева алгебра задовольняє законам де Моргана: ПовнотаЗакони, описані вище, визначають булеву алгебру в тому сенсі, що з них випливають усі інші наслідки. Для цього достатньо законів доповнення 1 та 2, разом із законами монотонності. Отже, їх можна вважати повною множиною законів або однією з можливих систем аксіоматизації булевої алгебри. Кожен закон булевої алгебри випливає логічним чином із цих аксіом. Крім того, булеві алгебри можна визначити як моделі з цих аксіом. Принцип двоїстостіПринцип: Якщо {X, R} — частково впорядкована множина, тоді {X, R(обернена)} також частково впорядкована множина. Ніякої магії у виборі символів для позначення логічних значень булевої алгебри не існує. Замість 0 і 1 можна було б використовувати, наприклад, α та β, доки ми робимо це послідовним чином повсюди, це досі залишатиметься булевою алгеброю, але з явними зовнішніми відмінностями. Припустимо також, що ми переназвали 0 та 1 відповідно на 1 та 0. Тоді це також залишатиметься булевою алгеброю, що навіть оперує з тими самими значеннями. Однак вона не буде ідентичною до нашої початкової булевої алгебри, оскільки тепер операція ∨ поводитиметься так, як поводила себе операція ∧ і навпаки. Тож, вони також матимуть зовнішні відмінності, які показують, що ми змінили позначення, не дивлячись на те, що ми досі використовуємо 0-і та 1-і. Але якщо в додаток до того, що ми замінили місцями імена змінних, ми замінимо місцями імена двох двійкових операцій, тепер немає ніякого сліду від того, що ми зробили. Кінцевий результат повністю не відрізняється від того, з чого ми почали. Ми помітимо, що колонки для операцій x∧y та x∨y у таблицях істинності змінили свої місця, але ця відмінність є незначною. Коли існує така пара операцій, для яких усе залишається незмінним, якщо всі пари були одночасно взаємно змінені, ми називаємо такі елементи кожної пари двоїстими один з одним. У такий спосіб, 0 та 1 є двоїстими, і операції ∧ та ∨ також є двоїстими. Принцип двоїстості, також називають двоїстістю де Моргана, за якою стверджують, що булева алгебра залишається незмінною, якщо взаємно замінити всі двоїсті пари. АксіомиЛогічні операціїПростим і найширше вживаним прикладом такої алгебричної системи є множина B, що складається всього з двох елементів:
Зазвичай у математичних виразах Хиба ототожнюється з логічним нулем, а Істина — з логічною одиницею, а операції заперечення (НІ), кон'юнкції (І) та диз'юнкції (АБО) визначаються у звичному нам розумінні. Легко показати, що на цій множині B можна задати чотири унарні та шістнадцять бінарних відношень і всі їх може бути отримано через суперпозицію трьох обраних операцій. Спираючись на цей математичний інструментарій, логіка висловлювань вивчає висловлювання і предикати. Також запроваджуються додаткові операції, такі як еквівалентність («тоді й лише тоді, коли»), імплікація («отже»), складання по модулю два («виключна диз'юнкція»), штрих Шефера , стрілка Пірса та інші. Логіка висловлювань послугувала основним математичним інструментом під час створення комп'ютерів. Вона легко перетворюється в бітову логіку: істинність висловлювання позначається одним бітом (0 — ХИБА, 1 — ІСТИНА); тоді операція набуває суті вирахування з одиниці; — немодульного додавання; & — множення; — рівності; — у буквальному розумінні сума за модулем 2 (виключне АБО — XOR); — сума не перевищує 1 (тобто A B = (A + B) <= 1). Згодом булеву алгебру було узагальнено від логіки висловлювань через запровадження характерних для логіки висловлювань аксіом. Це дозволило розглядати, наприклад, логіку кубітів, тризначну логіку (коли є три варіанти істинності висловлювання: «істина», «хиба» і «невизначено») тощо. Властивості логічних операцій
Існують методи спрощення логічної функції: наприклад, Карта Карно, метод Куайна — Мак-Класкі Представлення у вигляді діаграмДіаграма ВеннаДіаграма Венна[7] — це графічне представлення булевих операцій за допомогою зафарбованих областей, що перекриваються. По одній області для кожної змінної, всі області круглі, як показано на прикладах. Внутрішня й зовнішня частина області x відповідає значенням 1 (істина) та 0 (хиба) відповідно для змінної x. Зафарбована область показує значення операції для кожної комбінації цих областей, де зафарбована область означає 1, а не зафарбована — 0 (але в деяких книжках може зустрітися і навпаки). Діаграми Венна на малюнку знизу показують операції кон'юнкції x∧y, диз'юнкції x∨y, та доповнення ¬x. Для кон'юнкції, регіон у середині двох кругів зафарбований, що означає, що вираз x∧y дорівнює 1, коли обидві змінні мають значення 1. Інші області лишилися не зафарбованими, аби зазначити, що x∧y дорівнює 0 для всіх інших комбінацій. На другій діаграмі, що показує диз'юнкцію x∨y зафарбована область, що знаходиться в середині двох кіл одночасно. Третя діаграма представляє доповнення ¬x, де зафарбована область не в середині кола. Тут не показані діаграми для сталих 0 та 1, оскільки вони тривіальні та представляються незафарбованим або зафарбованим прямокутником, без кіл у середині. Однак ми б могли розмістити коло для змінної x у цих прямокутниках, у такому разі це б позначало функцію з одним аргументом, x, що позначає те саме значення, незалежно від x, що називається константною функцією. Що стосується результатів функцій, то константи й константні функції не відрізняються; їхня відмінність полягає в тому, що константа не приймає ніяких аргументів і називається нульовою операцією, тоді як константна функція приймає один аргумент, який ігнорується, і тому є унарною операцією. Діаграми Венна є корисними для візуалізації законів. Закони комутативності для ∧ та ∨ можна побачити із симетричності діаграм: бінарна операція, що не є комутативною не мала б симетричної діаграми, оскільки заміна місцями x та y призвело до горизонтального віддзеркалення діаграми, і відсутність комутативності б відзначилася в не симетричності діаграми. Ідемпотентність операцій ∧ та ∨ можна було б зобразити зсунувши два кола разом і зазначивши, що зафарбована область тоді стає цілим колом, як обох ∧ та ∨. Цифрові логічні колаЦифрова логіка застосовує булеву алгебру для 0 та 1 до електронної апаратури, що складається із з'єднаних між собою логічних елементів, і які утворюють електричну схему. Кожний елемент виконує булеву операцію, і в різних системах позначень позначається так, що його вигляд ідентифікує певну операцію. Форми позначень для елементів, що позначають кон'юнкцію (І-вентиль), диз'юнкцію (АБО-вентиль), і доповнення (інвертори) виглядають так.[8] Лінії по лівій стороні кожного елемента позначають вхідні з'єднання або порти. Значення на вході задається напругою. Для так званої логіки з «активним високим рівнем», 0 задається значенням напруги близьким до нуля або «землі», тоді як 1 задається значенням напруги близьким до джерела напруги; за активного низького рівня все буде навпаки. Лінія по правій стороні від кожного елемента задає вихідний порт, який переважно має ті самі узгодження щодо напруги, що й вхідні порти. Доповнення виконується інвертуючим вентилем. Трикутник позначає операцію, яка просто копіює вхід на вихід; невелике коло на виході позначає фактичну дію доповнення до входу. У цій системі позначень розташування кола біля будь-якого порту означає, що сигнал, проходячи через цей порт, буде інвертований пройшовши крізь нього, незалежно від того, вхідний це порт, чи вихідний. Принцип двоїстості, або правила де Моргана, можна розуміти як твердження: що доповнення всіх трьох портів вентиля І перетворює його на вентиль АБО і навпаки, як показано на рисунку нижче. Доповнення обох портів інвертора залишає операцію незмінною. ЗастосуванняАлгебра логіки як числення двох логічних значень є основою для комп'ютерних схем, програмування комп'ютерів і математичної логіки, а також вона використовується в інших галузях математики, таких як теорія множин та статистика.[5] Комп'ютериНа початку 20-го століття, декілька електротехніків інтуїтивним способом зрозуміли, що булева алгебра аналогічна поведінці певних електричних схем. Клод Шеннон формально довів, що така поведінка логічно еквівалентна булевій алгебрі в 1937 році. Сьогодні всі сучасні комп'ютери загального призначення виконують свої функції за допомогою булевої логіки двох значень; таким чином, їхні електричні кола є фізичним втіленням булевої алгебри для двох значень. Вони досягають це багатьма способами: за допомогою напруги на з'єднаннях у високочастотних схемах і ємнісних пристроях зберігання даних, за допомогою орієнтації магнітного поля у феромагнітних пристроях зберігання інформації, за допомогою перфорації в перфокартах або паперових стрічках, і так далі. (деякі перші комп'ютери використовували десяткові кола або механізми замість двозначної логіки в електричних колах.) Звісно, можна закодувати більше ніж два символи. Наприклад, можна використати відповідні значення в 0, 1, 2, і 3 вольта, аби закодувати алфавіт із чотирьох символів, або робити отвори різного розміру в перфокартах. На практиці, обмеження щодо швидкодії, малими розмірами, низьким енергоспоживанням об'єднуються так, що вирішальним фактором стають шуми. І стає важче відрізняти символи, коли в одному місці можуть виникнути декілька можливих символів. Замість того, щоб намагатися розрізнити чотири різні напруги на дроті, інженери цифрових схем зупинилися на двох значеннях напруги, високе і низьке. Комп'ютери використовують булеві схеми для двох значень з описаних вище причин. Самі типові архітектури комп'ютерів використовують упорядковані послідовності булевих значень, наприклад, у 32 або 64 значень, які називають бітами. 01101000110101100101010101001011. Під час програмування на машинному коді, мові асемблера, і певних інших мовах програмування, програмісти працюють з низькорівневою цифровою структурою з регістрів даних. Ці регістри працюють з рівнями напруги, за яких близьке до нуля значення напруги представляє булеве значення 0, і опорна напруга (часто +5V, +3.3V, +1.8V) задає булеве значення 1. Такі мови підтримують числові операції та логічні операції. У контексті, «числові» означає, що комп'ютер розглядатиме послідовність бітів як двійкові числа (числа з основою два) і виконуватиме арифметичні операції такі як додавання, віднімання, множення або ділення. «Логічні» відноситься до логічних булевих операцій диз'юнкції, кон'юнкції і заперечення між двома послідовностями біт, за яких кожен біт однієї послідовності простим способом порівнюється з відповідним бітом в іншій послідовності. Таким способом, програмісти мають можливість обирати як працювати, застосовуючи правила числової алгебри чи булевої алгебри залежно від потреби. Основною відмінною функцією між родинами операцій є існування операції переносу[en] в першій алгебрі, і відсутність в останній. ІсторіяЗасади алгебри логіки сформулював британський математик Джордж Буль у 1847 році. Алгебра Буля передувала сучасному розвитку абстрактної алгебри і математичної логіки; і вважають, що вона пов'язана з появою обох цих галузей.[9] В абстрактному тлумаченні, булева алгебра була розвинена в кінці 19-го століття, чому значно приклали зусилля математики Вільям Джевонс, Ернст Шредер, Едвард Гантінгтон[en] та інші, доки вона не досягла сучасного поняття (абстрактної) математичної структури.[9] Наприклад, емпіричні спостереження про те, що можливо маніпулювати виразами в алгебрі множин, якщо перевести їх у вирази булевої алгебри пояснюються в сучасних термінах, що алгебра множин це Булева алгебра. Насправді, М. Г. Стоун у 1936 довів, що кожна булева алгебра є ізоморфною полю множин. У 1930-х, під час вивчення перемикання електричних кіл[en], Клод Шеннон помітив, що в цій темі також можна використовувати закони булевої алгебри, і запропонував комутаційну алгебру, що дозволяє аналізувати та проєктувати схеми за допомогою алгебричних методів у термінах логічних елементів. Під час розробки схемотехніки сьогодні, немає великої потреби розглядати інші булеві алгебри, тому поняття «комутаційна алгебра» і «булева алгебра» часто використовуються як взаємозамінні.[10][11][12] Під час розробки схем комбінаційної логіки фундаментальною задачею є ефективна реалізація[en] булевих функцій. Сучасні засоби автоматизації проєктування електронних систем для інтегральних схем надвеликого рівня інтеграції часто покладаються на ефективне представлення булевих функцій, що називають (скороченими впорядкованими) двійковими діаграмами рішень для синтезу логіки та формальної верифікації.[13] Логічні вирази, які можна представити в класичному численні висловлювань мають еквівалентні вирази[en] в булевій алгебрі. Так, термін булева логіка іноді використовується для зазначення числення висловлювань, що здійснюється в такий спосіб.[14][15][16] Булевої алгебри не достатньо для роботи з логічними формулами, у яких використовують квантори, таких як у логіці першого порядку. Хоча розвиток математичної логіки не відповідає булевій, зв'язок між його алгеброю і логікою пізніше був закладений в основу алгебричної логіки, що також вивчає алгебричні системи багатьох інших логік.[9] Задача про ухвалення рішень про те, чи можуть змінні даної булевої формули (висловлювання) приймати такі значення, що формула буде розрахована як істина, називається задачею здійсненності булевих формул, і є дуже вадливою для теоретичної інформатики, що є першою задачею для якої було показано, що вона має складність NP-повної задачі. Тісно пов'язана з цим модель обчислення, що відома як булева схема[en] співвідносить часову складність (алгоритму) зі складністю схем[en]. Див. також
Примітки
Література
Посилання
|