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

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

Обработка программ Турбо Прологом

Обработка программ Турбо Прологом - раздел Программирование, Логическое программирование Обработка Программ Ведется По Принципу “Поиска Вглубь”.это Означает, Что Тп В...

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

Целевое утверждение:

wopros:-math(Math,"Мария"),

сопоставляется с фактом из базы:

math ("Евдокия","Мария").

Такое сопоставление называется унификациейи предполагает, чтобы были одинаковы функторы, очередность и количество аргументов и соответственно типы.

Переменная Math конкретизуется константой "Евдокия". Такая конкретизация распространяется на весь дизъюнкт и только на него. Передача значений изнутри дизъюнкта другим утверждениям возможна только через голову дизъюнкта. Например, определим кто является ребенком:

.predicates rebjonok(string)

.math(string,string)

.clauses .math(“Евдокия”,”Мария”).

rebjonok(X):-math(Math,X).

goal rebjonok(A), write(A), write(Math).

 

При выполнении переменная А сцепляется с переменной Х дизъюнкта rebjonok(X), который определяет, что кто-то является ребенком если у него есть мать. А утверждение math(Math,X) сопостовляется с фактом math(“Евдокия”,”Мария”), вследствии чего переменная Math конкретизируется значением Евдокия, а Х – Мария.

Переменная Х сцеплена с переменной А целевого утверждения, и соответственно А тоже конкретизируется Мария. Предикат write(А) выводит это на экран. Второй предикат write пытается вывести неконкретизированную переменную Math , т.к. ее значение не передовалось через голову rebjonok ‘вверх’ к целевому утверждению, т.е. переменная конкретизирована и больше не используется. В таких случаях вместо переменной ставится анонимная переменная _(подчерк): аргумент должен быть, но не важно какой:

rebjonok(X):-math( _ , X).

 

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

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

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

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

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

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

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

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

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

Логика предикатов
С помощью логики предикатов можно выразить связи между различными вещами. Формально высказывания в логике предикатов имеют вид: P(t1,t2,…tn), Где t1, t2, …, tn – аргументы,

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

Дизъюнкты
База данных составляется с помощью предикатов, каждый из которых описывается множеством дизъюнктов: Функтор(аргумент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
Реклама
Соответствующий теме материал
  • Похожее
  • Популярное
  • Облако тегов
  • Здесь
  • Временно
  • Пусто
Теги