Заглавная страница Избранные статьи Случайная статья Познавательные статьи Новые добавления Обратная связь FAQ Написать работу КАТЕГОРИИ: АрхеологияБиология Генетика География Информатика История Логика Маркетинг Математика Менеджмент Механика Педагогика Религия Социология Технологии Физика Философия Финансы Химия Экология ТОП 10 на сайте Приготовление дезинфицирующих растворов различной концентрацииТехника нижней прямой подачи мяча. Франко-прусская война (причины и последствия) Организация работы процедурного кабинета Смысловое и механическое запоминание, их место и роль в усвоении знаний Коммуникативные барьеры и пути их преодоления Обработка изделий медицинского назначения многократного применения Образцы текста публицистического стиля Четыре типа изменения баланса Задачи с ответами для Всероссийской олимпиады по праву Мы поможем в написании ваших работ! ЗНАЕТЕ ЛИ ВЫ?
Влияние общества на человека
Приготовление дезинфицирующих растворов различной концентрации Практические работы по географии для 6 класса Организация работы процедурного кабинета Изменения в неживой природе осенью Уборка процедурного кабинета Сольфеджио. Все правила по сольфеджио Балочные системы. Определение реакций опор и моментов защемления |
Комбинаторная логика: алфавит↑ ⇐ ПредыдущаяСтр 2 из 2 Содержание книги
Поиск на нашем сайте
Рассмотрим алфавит комбинаторной логики. Допускаются элементы четырех видов: 1) константы; 2) переменные; 3) комбинаторные выражения (или, иначе, термы); 4) специальные символы. При этом принимаются следующие обозначения. Константы( остающееся неизменным при всех изменениях ирасчетах ): c1, c2, … обозначаются малыми буквами латинского алфавита, возможно, с индексами. Переменные( величина, которая может принимать в процессе своего изменения различные значения ): x, y, … обозначаются малыми буквами латинского алфавита, возможно, с индексами. Выражения (термы): M, N, … обозначаются заглавными буквами латинского алфавита, возможно, с индексами. Допускается использование следующих специальных символов (взяты в кавычки и разделены запятыми): “(“, “)”.
Комбинаторная логика: построение термов Рассмотрим далее порядок конструирования допустимых для заданного алфавита комбинаторных выражений, или, иначе, термов Определение. Пусть М – непустое множество. Тогда n- местным предикатом, заданным на М, называется выражение, содержащее n переменных и обращающееся в высказывание при замене этих переменных элементами множества М. Рассмотрим примеры. Пусть М есть множество натуральных чисел N. Тогда выражения «x – простое число», «x – четное число», «x – больше 10» являются одноместными предикатами. При подстановке вместо x натуральных чисел получаются высказывания: «2 – простое число», «6 – простое число», «3 – четное число», «5 больше 10» и т.д. Выражения «x больше y», «x делит y нацело», «x плюс y равно 10» являются двухместными предикатами. (Конечно, последнее выражение можно было записать и так: «x+y=10»). Примеры трехместных предикатов, заданных на множестве натуральных чисел: число z лежит между «x и y», «x плюс y равно z», «|x-y|z».). Комбинаторные термы строятся по индукции (порядок построения можно считать определением) следующим образом: Базис индукции: любая переменная или константа является комбинаторным термом по определению. Шаг индукции: если M, N – произвольные комбинаторные термы и x – произвольная переменная, то справедливо, что: • выражение (MN) является допустимым комбинаторным термом. Заметим, что при этом комбинаторное выражение (MN) обозначает операцию аппликации (или применения функции к аргументу). Операции абстракции в комбинаторной логике не существует. Кроме того, примем, что никакой другой набор символов не является допустимым комбинаторным термом.
Комбинаторная логика: аксиомы После определения алфавита и порядка построения допустимых комбинаторных выражений посредством операции аппликации, перечислим аксиомы комбинаторной логики. Отметим, что употребляемый ниже символ “=” понимается в комбинаторной логике как обозначение отношения конвертируемости, которым связываются соединенные этим значком комбинаторные термы. Конвертируемость двух комбинаторных термов означает, что один комбинаторный терм может быть преобразован к другому. Отношение конвертируемости моделирует переобозначения и во многих отношениях, как отмечалось ранее, напоминает процесс программирования. Следующие аксиомы задают свойства отношения конвертируемости: (I) Ix = x; (K) Kxy = x; (S) Sxyz = xz(yz). Правила вывода Комбинаторная логика - это теория с единственным предикатом равенства, и все ее формулы имеют вид равенства двух термов. Смысл аксиом и правил вывода очевиден. (I) - аксиома рефлексивности равенства, а правила CR.1 и CR.2 - его транзитивность и симметричность. Оставшиеся два правила CR.3 и CR.4 - это конгруэнтность равенства. Аксиомы (K) и (S) постулируют существование двух базисных преобразований
Аксиома (I) означает существование комбинатора (функции) тождества, т.е. наличие тождественного преобразования, при котором любой аргумент отображается сам в себя. Аксиома (K) означает существование комбинатора (функции) взятия первой проекции, т.е. первого элемента упорядоченной пары или первого элемента списка. Интуитивно ясно, что эта аксиома близка языкам функционального программирования, оперирующим списками, и соответствует фундаментальной операции взятия головного (первого) элемента списка. Если восстановить опущенные скобки, они примут вид ((Kx)y) = x (((Sx)y)z) = ((xz)(yz)) С их помощью можно определять другие комбинаторы. Например, комбинатор тождественного преобразования, который в применении к любому терму x оставляет его неизменным, можно определить как SKK SKKx=Kx(Kx)=x В качестве другого примера можно привести комбинатор K(SKK), реализующий функцию проекции на второй аргумент: K(SKK)xy=SKKy=Ky(Ky)=y
Несколько проще это же преобразование можно задать с помощью комбинатора SK: SKxy=Ky(xy)=y
Таким образом, одно и то же соотношение вход-выход можно представить в языке комбинаторной логики различными алгоритмическими преобразованиями. В качестве дополнительной иллюстрации покажем, как средствами комбинаторной логики представить свойство коммутативности сложения. x+y=y+x
Легко проверить, что комбинатор S(S(KS)(S(KK)S))(KS), который мы для краткости обозначим посредством C, осуществляет следующее преобразование. Cxyz=xzy
Свойство коммутативности сложения в аппликативной записи имеет вид
Axy=Ayx.
Поскольку CAxy=Ayx, то же самое может быть представлено как Axy=CAxy. Так как переменные x и y играют лишь вспомогательную роль, они могут быть опущены. Результирующая запись, выражающая коммутативность операции A,выглядит очень просто. A=CA
Никакие переменные не нужны, поскольку по правилам комбинаторной логики для любых двух термов X и Y из A=CA выводимо AXY=AYX. A=CA ⇒ AX=CAX ⇒ AXY=CAXY ⇒ AXY=AYX
|
||||
Последнее изменение этой страницы: 2016-04-19; просмотров: 324; Нарушение авторского права страницы; Мы поможем в написании вашей работы! infopedia.su Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав. Обратная связь - 3.144.249.63 (0.006 с.) |