D = дата( 29, июнь, 1982)

Последний пример иллюстрирует особый случай применения предиката functor. Цель functor( D, дата, 3) создает 'обобщенный' терм с главным функтором дата и тремя аргументами. Этот терм обобщенный, так как все три его аргумента - не конкретизированные переменные, чья имена генерируются пролог - системой. Например:

        D = дата( _5, _6, _7)

Затем эти три переменные конкретизируются при помощи трех целей аrg.

К рассматриваемому

множеству встроенных предикатов относится также и введенный в гл. 6 предикат

name

, предназначенный для синтеза и декомпозиция атомов. Для полноты изложения мы здесь напомним его смысл. Цель

        name( A, L)

истинна, если L - список кодов (в кодировке ASCII) символов, входящих в состав атома А.

Упражнения

7. 3.    Определите предикат конкрет(Терм) так, чтобы он принимал значение истина, когда в Tepм'e нет ни одной неконкретизированной переменной.

7. 4.    Процедура подставить из данного раздела производит, при наличии разных вариантов, лишь самую 'внешнюю' подстановку.

Модифицируйте эту процедуру так, чтобы она находила все возможные варианты при помощи автоматического перебора. Например:

        ?-  подставить( a+b, f( A+B), новый, НовыйТерм).

        А = а

        В = b

        НовыйТерм = f( новый);

        А = а+b

        В = а+b

        НовыйТерм = f( новый + новый)

Наша исходная версия нашла бы только первый из этих двух ответов.

7. 5.

Определите отношение

        включает( Tepмl, Терм2)

которое выполняется, если Терм1 является более общим, чем Терм2. Например:

        ?-  включает( X, с).

        yes

        ?-  включает( g( X), g( t( Y))).

        yes

        ?-  включает f( X,X), f( a,b)).

        no

Назад | Содержание | Вперёд

Назад | Содержание | Вперёд

7. 3.    Различные виды равенства

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

Вы читаете Prolog
Добавить отзыв
ВСЕ ОТЗЫВЫ О КНИГЕ В ИЗБРАННОЕ

0

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

Отметить Добавить цитату