WikiDer > Таблица транспонирования

Transposition table

А таблица транспонирования представляет собой кэш ранее замеченных позиций и связанных оценок в дереве игры, созданном программой компьютерной игры. Если позиция повторяется через другую последовательность ходов, значение позиции извлекается из таблицы, что позволяет избежать повторного поиска в дереве игры ниже этой позиции. Таблицы транспонирования в первую очередь полезны в игры с идеальной информацией (где все состояние игры всегда известно всем игрокам). Использование таблиц транспонирования существенно мемоизация применяется к поиску по дереву и является формой динамическое программирование.

Таблицы транспозиции обычно реализуются как хеш-таблицы кодирование текущей позиции на плате как хеш-индекса. Число возможных позиций, которые могут встречаться в дереве игры, является экспоненциальной функцией глубины поиска и может составлять от тысяч до миллионов или даже больше. Таким образом, таблицы транспонирования могут потреблять большую часть доступной системной памяти и обычно занимают большую часть объема памяти игровых программ.

Функциональность

Игровые программы работают, анализируя миллионы позиций, которые могут возникнуть в следующие несколько ходов игры. Обычно в этих программах используются стратегии, похожие на поиск в глубину, что означает, что они пока не отслеживают все проанализированные позиции. Во многих играх можно достичь определенной позиции более чем одним способом. Они называются транспозиции.[1] В шахматы, например, последовательность ходов 1. d4 Кf6 2. c4 g6 (видеть алгебраическая шахматная система обозначений) имеет 4 возможных перестановки, так как любой игрок может поменять порядок ходов. В общем, после п ходов, верхний предел возможных транспозиций равен (п!)2. Хотя многие из них являются недопустимыми последовательностями ходов, все же вероятно, что программа в конечном итоге проанализирует одну и ту же позицию несколько раз.

Чтобы избежать этой проблемы, используются таблицы транспонирования. Такая таблица - это хеш-таблица каждой из проанализированных позиций до определенной глубины. При обнаружении новой позиции программа проверяет таблицу, чтобы увидеть, была ли позиция уже проанализирована; это можно сделать быстро, с постоянной амортизацией. Если это так, таблица содержит значение, которое ранее было присвоено этой позиции; это значение используется напрямую. Если нет, значение вычисляется, и новая позиция вводится в хеш-таблицу.

Количество позиций, которые ищет компьютер, часто намного превышает ограничения памяти системы, в которой он работает; таким образом, не все позиции могут быть сохранены. Когда таблица заполняется, менее используемые позиции удаляются, чтобы освободить место для новых; это делает таблицу транспонирования своего рода тайник.

Вычисление, сохраненное поиском в таблице транспонирования, - это не просто оценка отдельной позиции. Вместо этого избегается оценка всего поддерева. Таким образом, записи таблицы транспонирования для узлов на меньшей глубине в дереве игры более ценны (поскольку размер поддерева, имеющего корень в таком узле, больше), и поэтому им придается большее значение, когда таблица заполняется и некоторые записи должны быть отброшены. .

Хэш-таблица, реализующая таблицу транспонирования, может использоваться не только для поиска транспозиций. В альфа – бета обрезкапоиск будет самым быстрым (фактически оптимальным), когда дочерний узел, соответствующий лучшему ходу, всегда считается первым. Конечно, заранее узнать лучший ход невозможно, но когда итеративное углубление , ход, который был признан лучшим при более мелком поиске, является хорошим приближением. Поэтому сначала пробуем этот ход. Для сохранения лучшего дочернего узла узла используется запись, соответствующая этому узлу в таблице транспонирования.

Использование таблицы транспонирования может привести к неверным результатам, если старательно не избежать проблемы взаимодействия графа с историей. Эта проблема возникает в некоторых играх, потому что история позиции может быть важной. Например, в шахматы игрок не может рокироваться, если король или ладья, на которую должна быть сделана рокировка, переместились в течение игры. Обычное решение этой проблемы - добавить права на рокировку как часть Зобристское хеширование ключ. Другой пример рисовать повторением: учитывая позицию, может быть невозможно определить, возникла ли она уже. Решение общей проблемы состоит в том, чтобы хранить информацию истории в каждом узле таблицы транспонирования, но это неэффективно и редко делается на практике.

Стратегии замены

Таблица транспонирования - это кэш, максимальный размер которого ограничен доступной системной памятью, и он может переполниться в любой момент. Фактически, ожидается переполнение, и количество позиций, кэшируемых в любой момент, может быть лишь небольшой частью (даже на несколько порядков меньше), чем количество узлов в дереве игры. Подавляющее большинство узлов не являются узлами транспозиции, то есть позициями, которые будут повторяться, поэтому эффективные стратегии замены, которые сохраняют потенциальные узлы транспозиции и заменяют другие узлы, могут привести к значительному уменьшению размера дерева. Замена обычно основана на глубине дерева и старении: узлы, расположенные выше в дереве (ближе к корню), предпочтительнее, потому что поддеревья ниже них больше и приводят к большей экономии; предпочтение отдается более новым узлам, поскольку более старые узлы больше не похожи на текущее положение, поэтому транспозиции к ним менее вероятны.

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

Размер и производительность

Хотя доля узлов, которые будут транспонированы, мала, дерево игры представляет собой экспоненциальную структуру, поэтому кэширование очень небольшого количества таких узлов может иметь существенное значение. В шахматах сообщалось о сокращении времени поиска на 0-50% в сложных позициях в середине игры и до 5 раз в конце игры.[2]

Связанные методы

  • Подобные методы могут использоваться для кэширования оценок определенных характеристик позиции. Например, пешка хеш-таблица может использоваться для хранения оценки пешка структуры в позиции. Поскольку количество исследуемых пешечных позиций обычно намного меньше, чем общее количество искомых позиций, хеш-таблица пешек имеет очень высокий частота попаданий, позволяя программе тратить больше времени на сложные оценки пешек, потому что они многократно используются повторно.
  • А таблица опровержения может использоваться для хранения последовательностей перемещений от корневого узла к листовым узлам. Это включает основная вариация и ответы на другие строки, показывающие, что они хуже. Таблицы опровержения иногда использовались вместо таблиц транспонирования в первые годы компьютерных шахмат, когда память была более ограниченной. Некоторые современные шахматные программы используют таблицы опровержения в дополнение к таблицам транспонирования для упорядочивания ходов.
  • Статические растровые изображения возможных ходов каждого типа фигуры на каждом участке доски могут быть кэшированы при инициализации программы, так что допустимые ходы фигуры (или вместе, все допустимые ходы для генерации ходов) могут быть извлечены из одной памяти load вместо последовательного перечисления. Они обычно используются в реализациях битовой доски.

Смотрите также

Примечания и ссылки

  1. ^ Таблицы транспонирования, Gamedev.net, Франсуа-Доминик Ларами.
  2. ^ Аткин, Л. и Слейт, Д., 1977, «Шахматы 4.5, шахматная программа Северо-Западного университета», в «Шахматные навыки человека и машины», Питер В. Фрей, изд. Спрингер-Верлаг, Нью-Йорк, Нью-Йорк

внешняя ссылка