Навигация
Главная
Поиск
Форум
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
Создание отчето... 65535
Программируемая... 65535
Эмулятор микроп... 65535
Подключение Mic... 65535
Создание потоко... 65535
Приложение «Про... 65535
Оператор выбора... 65535
Модуль Forms 65535
Имитационное мо... 59261
Реклама
Сейчас на сайте
Гостей: 8
На сайте нет зарегистрированных пользователей

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

Моделирование автомойки на GPSS + Отчет + Блок схемы
Программа тестирования и обучающая программа по математике на Turbo Pasc...
Моделирование работы обрабатывающего участка цеха в GPSS

Реклама



Подписывайся на 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 Комментариев · 8487 Прочтений · Для печати

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


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



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

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

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

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

Пароль



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

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

Случайные загрузки
Crystal Button
База каталогов ( ...
CarGame [Исходник...
C++ Builder: Книг...
AboutSystem
Простой текстовый...
Comdrv
Работа с матрицами
Delphi 7: Для про...
Панель "Случайное...
Delphi. Готовые а...
Импорт новостей ...
Tetris 2002
Delphi 2005 для .NET
Page Promoter 7.7...
SMExport
SysInfo [Исходник...
C++ Стандартная б...
Использование Lis...
TDBF

Топ загрузок
Приложение Клие... 100511
Delphi 7 Enterp... 89955
Converter AMR<-... 20091
GPSS World Stud... 14744
Borland C++Buil... 12619
Borland Delphi ... 8902
Turbo Pascal fo... 7089
Калькулятор [Ис... 5102
Visual Studio 2... 5017
FreeSMS v1.3.1 3553
Случайные статьи
Диагональные элементы
9.3. Запись грамм...
СС/РР и Web-ориент...
Новые разработки в...
Приведем упрощенны...
Другие реализации ...
Использование ICQ
Фирма Adobe
Как привлечь 1000 ...
Работа с внешней п...
Стеки как структур...
Применение динамич...
Защищайте доступно...
Процедура LineTo -...
Пути повышения Lin...
Клавиатура и мышь
Outlook для iOS и ...
Тестер
Надстройки над OpenGL
Integer constant e...
Как программно пом...
Перенос WSUS из Se...
Работа с веб-серве...
Игра в планирование
Обработка исключит...
Статистика



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


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