Методы эвристического поиска
Методы эвристического поиска относятся к группе комбинаторных методов, основную идею которых составляет замена полного перебора всех решений их частичным перебором, что осуществляется путем отбрасывания некоторых подмножеств вариантов, то есть допустимых решений, заведомо не дающих оптимума; перебор при этом ведется лишь среди остающихся вариантов, являющихся в определенном смысле «перспективными». Таким образом, основная идея всех методов эвристического поиска при всем их разнообразии базируется на использовании конечности множества вариантов и переходе от полного перебора к сокращенному (направленному) перебору. Важную роль при этом играют правила оценки и отбрасывания неперспективных множеств вариантов.
В основе метода ветвей и границ лежит идея последовательного разбиения множества допустимых решений на подмножества. На каждом шаге метода элементы разбиения подвергаются проверке для выяснения, содержит данное подмножество оптимальное решение или нет. Проверка осуществляется посредством вычисления оценки снизу для целевой функции на данном подмножестве. Если оценка снизу не меньше рекорда — наилучшего из найденных решений, то подмножество может быть отброшено. Проверяемое подмножество может быть отброшено еще и в том случае, когда в нем удается найти наилучшее решение. Если значение целевой функции на найденном решении меньше рекорда, то происходит смена рекорда. По окончанию работы алгоритма рекорд является результатом его работы.
Если удается отбросить все элементы разбиения, то рекорд — оптимальное решение задачи. В противном случае, из неотброшенных подмножеств выбирается наиболее перспективное (например, с наименьшим значением нижней оценки), и оно подвергается разбиению. Новые подмножества вновь подвергаются проверке и т.д. Вычисление нижней границы является важнейшим элементом данной схемы.
Эффективность поиска многократно возрастает, если выбор пути будет производиться не случайным образом или с помощью фиксированного правила, а с учетом перспективности выбранного пути.
При поиске методом подъема на холм двигаемся по дереву аналогично поиску в глубину, но выбор расширяемого узла производится на основе некоторой эвристической оценки оставшегося пути до цели. Чем лучше эвристическая оценка, тем выше эффективность поиска. Например, эвристической оценкой при нахождении пути от одного города к другому может служить расстояние между ними, замеренное прямой линией по карте.
Алгоритм подъема на холм:
создать одноэлементную очередь, включающую путь нулевой длины.
пока головной путь в очереди не оканчивается целью и пока очередь не пуста повторять:
удалить головной путь из очереди
создать новые пути, расширяя его
удалить из новых путей все циклические
отсортировать новые пути по эвристике, частичный путь с мин расстоянием до цели должен оказаться в голове очереди
добавить новые пути в голову очереди
если полный путь найден, показать его, иначе сообщить о неудаче.
Проблемы метода
Например, поиск в горах в туманную погоду, нужно подняться на самую высокую вершину, используя компас и альтиметр. С помощью компаса определяется несколько направлений, поочередно делаются попытки восхождения в этих направлениях, наблюдая за показаниями альтиметра. Выбирается направление, обеспечивающее макс набор высоты.
Локальные максимумы. Выбираем направление из т. А на север, обеспечивающее макс набор высоты, и приходим в т. В, являющуюся локальным максимумом.
Платформы. Не можем выбрать направление из т. А, так как все направления дают одинаковый прирост высоты.
Острые лезвия. Сколько бы ни выбирали направлений, это не гарантирует выбора верного направления.
Метод луча рассматривает не одно лучшее продолжение, а несколько наиболее перспективных путей. Алгоритм подобен поиску в ширину за исключением того, что расширяются не все узлы, а w лучших, где w – ширина луча. Введение этого параметра позволяет уйти от экспоненциального роста количества рассматриваемых узлов.
Метод «Первый - лучший». Если в процессе поиска дальнейшее продвижение невозможно, то откат производится не на предыдущий уровень, как при подъеме на холм, а в узел, имеющий лучшую эвристическую оценку.
- Министерство образования и науки Российской Федерации
- Лабораторная работа № 1
- Данные и знания
- Синтаксис языка Пролог
- Семантика языка Пролог
- Алгоритм работы Пролог-машины.
- Пример построения базы правил на Пролог
- Задание на лабораторную работу
- Лабораторная работа № 2
- Использование списков в Пролог.
- Использование накапливающего параметра
- Управление перебором
- Задание на лабораторную работу
- Лабораторная работа № 3
- Представление задачи в терминах пространства состояний
- Слепые методы поиска
- Методы эвристического поиска
- Поиск оптимального пути
- 3.4 Задание на лабораторную работу
- Лабораторная работа № 4
- Основные понятия теории игр
- Представление игры в матричной форме
- Представление игры в виде игрового дерева
- Задание на лабораторную работу