Навигация
Главная
Поиск
Форум
FAQ's
Ссылки
Карта сайта
Чат программистов

Статьи
-Delphi
-C/C++
-Turbo Pascal
-Assembler
-Java/JS
-PHP
-Perl
-DHTML
-Prolog
-GPSS
-Сайтостроительство
-CMS: PHP Fusion
-Инвестирование

Файлы
-Для программистов
-Компонеты для Delphi
-Исходники на Delphi
-Исходники на C/C++
-Книги по Delphi
-Книги по С/С++
-Книги по JAVA/JS
-Книги по Basic/VB/.NET
-Книги по PHP/MySQL
-Книги по Assembler
-PHP Fusion MOD'ы
-by Kest
Professional Download System
Реклама
Услуги

Автоматическое добавление статей на сайты на Wordpress, Joomla, DLE
Заказать продвижение сайта
Программа для рисования блок-схем
Инженерный калькулятор онлайн
Таблица сложения онлайн
Популярные статьи
OpenGL и Delphi... 65535
Форум на вашем ... 65535
HACK F.A.Q 65535
Бип из системно... 65535
Гостевая книга ... 65535
Invision Power ... 65535
Содержание сайт... 65535
Организация зап... 65535
Вызов хранимых ... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Создание отчето... 63867
Модуль Forms 63617
ТЕХНОЛОГИИ ДОСТ... 60460
Пример работы с... 59789
Имитационное мо... 55922
Реклама
Сейчас на сайте
Гостей: 5
На сайте нет зарегистрированных пользователей

Пользователей: 13,079
новичок: Openair
Новости
Реклама
Выполняем курсовые и лабораторные по разным языкам программирования
Подробнее - курсовые и лабораторные на заказ
Delphi, Turbo Pascal, Assembler, C, C++, C#, Visual Basic, Java, GPSS, Prolog, 3D MAX, Компас 3D
Заказать программу для Windows Mobile, Symbian

База данных склада на Delphi + Схема БД
Информационная система - транспортный парк на Turbo Pascal (База данных)...
Игра Sokoban на Delphi + Блок схемы

Реклама



Подписывайся на YouTube канал о программировании, что бы не пропустить новые видео!

ПОДПИСЫВАЙСЯ на канал о программировании
Упорядочивание по алфавиту
В задачах, где идет работа со словарем, полезно иметь предикат для сравнения слов в соответствии с алфавитным порядком. Рассмотрим предикат, который мы назовем 'меньше'. Если предикат 'меньше'(X,Y) используется в качестве целевого утверждения, то он истинен (т.е. согласуется с БЗ), если X и Y обозначают атомы, X по алфавиту предшествует Y. Так, предикат 'меньше'('арбуз','букварь') истинен, а 'меньше'('ветер','автомобиль') ложен. Точно так же должен быть ложен и предикат 'меньше'('картина','картина'). Сравнивая два слова, мы сравниваем их последовательно, буква за буквой и при сравнении каждой буквы определяем, какое из следующих условий имеет место.
Достигнут конец первого слова, но не достигнут конец второго слова. Это имеет место, например, в случае 'меньше'('пар','паровоз'). При возникновении такой ситуации предикат 'меньше' должен считаться истинным (т.е. согласованным с базой знаний).
Очередная литера в первом слове предшествует в алфавите соответствующей литере во втором слове. Например, 'меньше'('слово','слон'). Буква "в" в слове 'слово' предшествует в алфавите букве "н" в слове 'слон'. В этом случае предикат 'меньше' истинен.
Литера в первом слове совпадает с соответствующей литерой во втором слове. В этом случае следует использовать предикат 'меньше' для сравнения оставшихся литер в обоих словах. Например, если дано 'меньше' ('облако','одеяло'), то так как оба аргумента начинаются с буквы "о", необходимо взять в качестве следующей цели 'меньше'('блако','деяло').
.Одновременно достигнут конец первого и второго слов, как, например, в случае 'меньше'('яблоко','яблоко'). При возникновении такого условия предикат 'меньше' должен быть ложным, так как оба слова являются одинаковыми.
Обработаны все литеры второго слова, но еще остались литеры в первом слове, как, например, в случае 'меньше'('алфавитный','алфавит'). В такой ситуации предикат 'меньше' должен быть ложным.
После того как сформулированы перечисленные условия, задача перевода их на Пролог является довольно простой. Будем представлять слова в виде списков кодов символов. Для этого необходим встроенный предикат преобразования атома в терм-строку name(X,Y).
Первым утверждением в определении предиката 'меньше' является следующее правило:
'меньше'(X,Y):-name(X,L),name(Y,M),'меньше 1'(L,M).



Это правило сначала преобразует слова в списки, используя предикат name, и затем с помощью предиката 'меньше 1' сравнивает списки на соответствие алфавиту. Определение предиката 'меньше 1' состоит из утверждений, реализующих приведенный набор условий. Первое условие является истинным, когда первый аргумент есть пустой список, а второй аргумент - это произвольный не пустой список. Два последних условия описывают ситуации, когда предикат ложен, т.е. не согласуется с базой данных, так что если мы не предусмотрим никаких соответствующих им фактов или правил, то при используемом механизме поиска в БЗ доказательство согласованности любого целевого утверждения, для которого эти условия справедливы, закончится неудачей. Собирая все правила вместе, получаем:
'меньше'(X,Y):-name(X,Y),name(Y,M),'меньше 1'(L,M).
'меньше 1'([X|_],[Y|_]):-X 'меньше 1'([H|Q],[H|G]):-'меньше 1'(Q,G).
?-'меньше'('студент','служащий'). ?-'меньше'('инженер','студент').
no yes
?-'меньше'('дом','домовой').
yes


Опубликовал Kest November 13 2009 16:51:29 · 0 Комментариев · 8091 Прочтений · Для печати

• Не нашли ответ на свой вопрос? Тогда задайте вопрос в комментариях или на форуме! •


Комментарии
Нет комментариев.
Добавить комментарий
Имя:



smiley smiley smiley smiley smiley smiley smiley smiley smiley
Запретить смайлики в комментариях

Введите проверочный код:* =
Рейтинги
Рейтинг доступен только для пользователей.

Пожалуйста, залогиньтесь или зарегистрируйтесь для голосования.

Нет данных для оценки.
Гость
Имя

Пароль



Вы не зарегистрированны?
Нажмите здесь для регистрации.

Забыли пароль?
Запросите новый здесь.
Поделиться ссылкой
Фолловь меня в Твиттере! • Смотрите канал о путешествияхКак приготовить мидии в тайланде?
Загрузки
Новые загрузки
iChat v.7.0 Final...
iComm v.6.1 - выв...
Visual Studio 200...
CodeGear RAD Stud...
Шаблон для новост...

Случайные загрузки
Самоучитель PHP 5...
PHP 5
Info
Visual Basic for ...
Панель Календарь
CoolHints2k
Delphi 2005 для .NET
Открытие Cd-ROM'a...
Dnavigator
DemoEdit [Исходни...
Программирование ...
Реализация ЭЦП по...
C++ Builder 6 СПР...
Панель "ссылки"
FatScrollbar
Zoom [Исходник на...
Фундаментальные а...
BSButton
Рисование PopupMenu
Экранная лупа

Топ загрузок
Приложение Клие... 100447
Delphi 7 Enterp... 85787
Converter AMR<-... 20067
GPSS World Stud... 12518
Borland C++Buil... 11571
Borland Delphi ... 8503
Turbo Pascal fo... 7023
Visual Studio 2... 4989
Калькулятор [Ис... 4739
FreeSMS v1.3.1 3535
Случайные статьи
экономия места на ...
• L2TP не содержит...
Как купить гель ла...
Стандарт ITU-T V.34
Integer constant e...
7.2. Оценка произв...
В программе предпо...
3.1. Обработка шаб...
Задающие устройства
Юрист по арбитражн...
write(X)
Веселый отдых
Монтирование NFS
Этап 6 - выделение...
Закрытые данные ка...
Чтобы узнать, для ...
Для простого разве...
Звуковая карта
Библиотека STL - ч...
Настраиваемый клас...
• Инициализация во...
Всё о баннерах
Структурная обрабо...
8.4. Сканирующий а...
• Использование Wi...
Статистика



Друзья сайта
Программы, игры


Полезно
В какую объединенную сеть входит классовая сеть? Суммирование маршрутов Занимают ли таблицы память маршрутизатора?