рефераты конспекты курсовые дипломные лекции шпоры

Реферат Курсовая Конспект

Логика предикатов

Логика предикатов - раздел Программирование, Логическое программирование С Помощью Логики Предикатов Можно Выразить Связи Между Различными Вещами. Фор...

С помощью логики предикатов можно выразить связи между различными вещами. Формально высказывания в логике предикатов имеют вид:

P(t1,t2,…tn),

Где t1, t2, …, tn – аргументы,

 

P - отношение между аргументами.

Высказывание

Машина находится у дома.

В логике предикатов можно выразить так:

У(машина, дом).

 

 

(1) В(водитель, машина) И

у(машина, дом) (предпосылка)

(2) Если ( в(водитель, машине) И

У(машина, дом)

ТО у(водитель, дом) (предпосылка)

  (3) у(водитель, дом) (вывод; 1,2,МР)

 

 

При этом (1)- это два связанных связкой И факта.

(2)- это правило, которое означает, что при определенных условиях можно установить истинное высказывание, а (3)- это вывод на основе предпосылок.

 

 

Для того чтобы высказывания с переменными были истинными, они должны быть истинными в соответствии с их квантификацией для всех (") подставленых индивидов или хотя бы одного ($) индивида области индивидов. Например, утверждение

$ Х в(Х,машина)

 

выражает, что что-то (Х) находится в машине. С помощью подстановки индивидов для Х возможно установить истинность новых высказываний на основе таких фактов, как

 

в(водитель,машина).

В(собака,машина).

В(карта,машина).

 

Так как на Прологе кванторы существования не могут быть выражены явно, то используются специально для этого выделенные константы индивидов, например:

Человек(а) И у(а, дом).

Выражает, что существует человек –а, который находится у дома.

В случае, когда объект, существование которого должно зафиксироваться, зависит от другого, как, например, в высказывании:

Каждый человек имеет мать.

Нельзя мать просто выразить константой:

Если человек(Х) ТО мать(а, Х),

Потому что большинство людей имеют не одну и туже мать. Здесь применяется функция, например, f(X), где f(Х)- это зависящая от Х –мать:

Если человек(Х) ТО мать(f(Х), Х).

 

Формально-логические предпосылки являются фактами, которые описывают определенную область окружающего мира.

 

– Конец работы –

Эта тема принадлежит разделу:

Логическое программирование

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

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

Что будем делать с полученным материалом:

Если этот материал оказался полезным ля Вас, Вы можете сохранить его на свою страничку в социальных сетях:

Все темы данного раздела:

Логика высказываний
Формально-логические высказывания представляются с помощью букв, с которыми производятся логические операции. Например, предложение: Машина находится у дома. Является выс

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

Дизъюнкты
База данных составляется с помощью предикатов, каждый из которых описывается множеством дизъюнктов: Функтор(аргумент1, аргумент2, …):-условие1,условие2,… . Где функтор- имя предик

Константы и переменные
Константы должны начинаться с маленькой буквы, либо стоять в одинарных или бинарных кавычках, либо они являются числами: -mother -price -list‘f’ 169 1.4e-3  

Секции программы
Секция domains-(объявление областей определения). 1 Способ. имя области = d где d- любой тип. Например person=string nomer=integer

Обработка программ Турбо Прологом
Обработка программ ведется по принципу “поиска вглубь”.Это означает, что ТП всегда пытается доказать утверждение в дизъюнктах слева направо с помощью фактов и правил из базы данных. Целево

Возврат и отсечение
ТП в случае, если есть больше одного дизъюнкта для одного предиката, отмечает этот дизъюнкт точкой решения, чтобы он мог вернутся в эту точку и продолжить работу со следующим дизъюнктом, даже есла

Рекурсия
Вычисление факториала: .f(0)=1 f(n+1)=(n+1)*f(n) .predikrtes fak(integer, real) .clauses fak(0,1):-!. /* 0!=1 */ fak(N, Fak):- N>0, /*только

Работа с файлами
/* telefon book + file */ trace domains name,adr= string datad=c(name,adr) file=d predicates person(name,adr) getdata(file)

Изменения в базе данных
  asserta(факт) (dbasedom): (i)   Добавляет новый факт перед остальными фактами того жe предиката в оперативную базу данных. Факт должен быть

Арифметика
  Арифметические утверждения присваивания имеют следующий общий вид:   результат = операнд1 оператор операнд2   В качестве опера

Работа с данными типа string
  concat( строка1, строка2, строкаЗ) (string,string,string):(i,i,i)(i,i,o)(i,o,i)(o,i,i)   В зависимости от конкретизации выполняется лексикографическа

Преобразование типов
  Все предикаты преобразования типов действуют в обе стороны ((i,о) и (o,i)), а случай (i,i) проверяет истинность (не для предиката real). Преобразование между типам

Команды операционной системы
  Для выполнения команд system и dir необходимо, чтобы Турбо-Прологу была доступна дискета с COMMAND. СОМ.   system(команда) (string):(i)

Версии Турбо-Пролога
  Данные методические указания описывают версию 1.0. Уже доступная версия Турбо-Пролог 1.1 имеет следующие дополнительные возможности: - предикат makewindow

Внешняя среда системы Турбо-Пролог
  Турбо-Пролог после запуска предпологает определенную конфигурацию своих и пользовательских файлов. Различаются пять каталогов: 1. Турбо-каталог. Здесь дол

Хотите получать на электронную почту самые свежие новости?
Education Insider Sample
Подпишитесь на Нашу рассылку
Наша политика приватности обеспечивает 100% безопасность и анонимность Ваших E-Mail
Реклама
Соответствующий теме материал
  • Похожее
  • Популярное
  • Облако тегов
  • Здесь
  • Временно
  • Пусто
Теги