Навигация
Главная
Поиск
Форум
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
Создание отчето... 65423
Модуль Forms 65184
Пример работы с... 64335
ТЕХНОЛОГИИ ДОСТ... 61831
Имитационное мо... 57753
Реклама
Сейчас на сайте
Гостей: 5
На сайте нет зарегистрированных пользователей

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

База данных склада на Delphi + Схема БД
Моделирование литейного цеха на GPSS + Пояснительная записка
Метод половинного деления для нахождения корня уровнения на Turbo Pascal...

Реклама



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

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


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



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 в подлинник...
Progressbar
Rss Parser
Панель поиска
Atb
C# в кратком изло...
Философия C++. Пр...
Report
Профессиональное ...
Java 2 - Эффектив...
SODA [Исходник на...
Экранная лупа
Анекдоты с ostrie.ru
Архив Апгрейтов с...
Доступа к БД Fire...
Самоучитель Прогр...
100 компонентов о...
Правила программи...
Visual Studio 200...

Топ загрузок
Приложение Клие... 100469
Delphi 7 Enterp... 87048
Converter AMR<-... 20078
GPSS World Stud... 12818
Borland C++Buil... 11830
Borland Delphi ... 8602
Turbo Pascal fo... 7039
Visual Studio 2... 4999
Калькулятор [Ис... 4799
FreeSMS v1.3.1 3542
Случайные статьи
Files must be var ...
VARIABLE (ОПРЕДЕЛИ...
Массивы
Ручная и автомати...
High Secure — это ...
Выработка решенияП...
Прочтите десятично...
Эстетический аспект
Подсистема STREAMS...
12.3. Пространство...
Руководство для ра...
Установка палагино...
ЛюбойЛюбой2
Обеспечение требуе...
STREAMS - очереди ...
Содержание
Как добавить в Ata...
Masterbatch
На вход поступает ...
Площадь треугольника
присвоения чрезмер...
Политика отключения
Какой хост способе...
Дырки в безопаснос...
Настройки программ...
Статистика



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


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