WikiDer > Алгоритм FKT
В Алгоритм FKT, названный в честь Фишер, Кастелейн, и Temperley, считает количество идеальное соответствие в планарный график за полиномиальное время. Эта же задача # P-complete для общих графиков. Подсчитывая количество совпадениядаже для плоских графов также является # P-полным. Ключевая идея - превратить проблему в Пфаффиан вычисление кососимметричная матрица полученный из плоского вложения графа. Пфаффиан этой матрицы затем эффективно вычисляется с использованием стандартных детерминантные алгоритмы.
История
Проблема подсчета плоских идеальных совпадений уходит корнями в статистическая механика и химия, где исходный вопрос был: если двухатомные молекулы адсорбируются на поверхности, образуя единый слой, сколькими способами они могут быть расположены?[1] В функция распределения является важной величиной, которая кодирует статистические свойства системы в состоянии равновесия и может использоваться для ответа на предыдущий вопрос. Однако пытаться вычислить функцию распределения по ее определению нецелесообразно. Таким образом, точное решение физической системы - это поиск альтернативной формы статистической суммы для этой конкретной физической системы, которую достаточно просто вычислить точно.[2] В начале 1960-х годов определение точно решаемый не был строгим.[3] Информатика дала строгое определение с введением полиномиальное время, который датируется 1965 годом. Точно так же обозначение not точно решаемый должен соответствовать # P-твердость, который был определен в 1979 году.
Другой тип физической системы, которую следует рассмотреть, состоит из димеры, который представляет собой полимер с двумя атомами. Модель димера подсчитывает количество димерных покрытий графа.[4] Еще одна физическая система, которую следует учитывать, - это соединение ЧАС2О молекулы в виде льда. Это можно смоделировать как направленное, 3-обычный граф, в котором ориентация ребер в каждой вершине не может быть одинаковой. Сколько ориентаций краев у этой модели?
По мотивам физических систем, включающих димеры, в 1961 году Кастелейн[5] и Темперли и Фишер[6] независимо нашел количество мозаики домино для м-к-п прямоугольник. Это эквивалентно подсчету количества точных совпадений для м-к-п решетчатый граф. К 1967 году Кастелейн обобщил этот результат на все плоские графы.[7][8]
Алгоритм
Объяснение
Основная идея заключается в том, что каждый ненулевой член в Пфаффиан из матрица смежности графа грамм соответствует идеальному совпадению. Таким образом, если можно найти ориентация из грамм выровнять все знаки условий в Пфаффиан (независимо от того + или же - ), то абсолютное значение Пфаффиан это просто количество идеальных совпадений в грамм. Алгоритм FKT выполняет такую задачу для плоского графа грамм. Ориентация, которую он находит, называется Пфаффовская ориентация.
Позволять грамм = (V, E) - неориентированный граф с матрица смежности А. Определять ВЕЧЕРА(п) быть множеством разбиений п элементов на пары, то количество совершаемых совпадений в грамм является
С этим тесно связан Пфаффиан для п к п матрица А
где sgn (M) это знак перестановки M. Пфаффовская ориентация грамм ориентированный граф ЧАС с (1, −1, 0) -матрица сопряжения B такой, что pf (B) = PerfMatch (грамм).[9] В 1967 году Кастелейн доказал, что планарные графы имеют эффективно вычислимую пфаффову ориентацию. В частности, для плоского графа грамм, позволять ЧАС быть направленной версией грамм где нечетное количество ребер ориентировано по часовой стрелке для каждой грани в плоском вложении грамм. потом ЧАС является пфаффовой ориентацией грамм.
Наконец, для любого кососимметричная матрица А,
где det (А) это детерминант из А. Этот результат обусловлен Кэли.[10] С детерминанты эффективно вычислимы, поэтому PerfMatch (грамм).
Описание высокого уровня
- Вычислить планарную встраивание из грамм.
- Вычислить остовное дерево Т1 входного графа грамм.
- Задайте произвольную ориентацию каждому ребру в грамм это также в Т1.
- Используйте планарное вложение для создания (неориентированного) графа Т2 с тем же набором вершин, что и двойственный граф из грамм.
- Создайте преимущество в Т2 между двумя вершинами, если их соответствующие грани в грамм разделить преимущество в грамм это не в Т1. (Обратите внимание, что Т2 это дерево.)
- Для каждого листа v в Т2 (это тоже не корень):
- Позволять е быть одиноким краем грамм в лицо, соответствующее v что еще не имеет ориентации.
- Дайте е ориентация, при которой количество ребер, ориентированных по часовой стрелке, нечетное.
- Удалять v из Т2.
- Вернуть абсолютное значение Пфаффиан из (1, −1, 0) -матрица сопряжения из грамм, который является квадратным корнем из определителя.
Обобщения
Сумму взвешенных точных совпадений также можно вычислить с помощью Матрица Тутте для матрицы смежности на последнем шаге.
Теорема Куратовского утверждает, что
- а конечный граф плоский если и только если он не содержит подграф гомеоморфный к K5 (полный график на пяти вершинах) или K3,3 (полный двудольный граф на две перегородки третьего размера).
Виджай Вазирани обобщил алгоритм FKT на графы, не содержащие подграфа, гомеоморфного K3,3.[11] Поскольку подсчет количества совершенных паросочетаний в общем графе # P-complete, требуется некоторое ограничение на входной граф, если только FP, функциональная версия п, равно #П. Подсчет совпадений, известный как Индекс Хосоя, также # P-полна даже для плоских графов.[12]
Приложения
Алгоритм FKT широко используется в голографические алгоритмы на плоских графах через ворота.[3] Например, рассмотрим упомянутую выше плоскую версию модели льда, которая имеет техническое название #PL-3-NAE-СИДЕЛ (где NAE означает «не все равны»). Valiant нашел алгоритм полиномиального времени для этой задачи, который использует матчи.[13]
Рекомендации
- ^ Хейс, Брайан (Январь – февраль 2008 г.), «Случайные алгоритмы», Американский ученый
- ^ Бакстер, Р. Дж. (2008) [1982]. Точно решенные модели в статистической механике (Третье изд.). Dover Publications. п. 11. ISBN 978-0-486-46271-4.
- ^ а б Цай, Цзинь-И; Лу, Пиньян; Ся, Минцзи (2010). Голографические алгоритмы с Matchgates захватывают точно управляемую планарную #CSP. Основы компьютерных наук (FOCS), 51-й ежегодный симпозиум IEEE 2010 г.. Лас-Вегас, Невада, США: IEEE. arXiv:1008.0683. Bibcode:2010arXiv1008.0683C.
- ^ Кеньон, Ричард; Окуньков, Андрей (2005). "Что такое димер?" (PDF). AMS. 52 (3): 342–343.
- ^ Кастелейн, П.В. (1961), "Статистика димеров на решетке. I. Число расположений димеров на квадратичной решетке", Physica, 27 (12): 1209–1225, Bibcode:1961Phy .... 27,1209K, Дои:10.1016/0031-8914(61)90063-5
- ^ Темперли, Х. Н. В.; Фишер, Майкл Э. (1961). «Проблема Димера в статистической механике - точный результат». Философский журнал. 6 (68): 1061–1063. Дои:10.1080/14786436108243366.
- ^ Кастелейн, П.В. (1963). «Статистика димеров и фазовые переходы». Журнал математической физики. 4 (2): 287–293. Bibcode:1963JMP ..... 4..287K. Дои:10.1063/1.1703953.
- ^ Кастелейн, П.В. (1967), "Теория графов и физика кристаллов", в Харари, Ф. (ред.), Теория графов и теоретическая физика, Нью-Йорк: Academic Press, стр. 43–110.
- ^ Томас, Робин (2006). Обзор пфаффовых ориентаций графов (PDF). Международный конгресс математиков. III. Цюрих: Европейское математическое общество. С. 963–984.
- ^ Кэли, Артур (1847). "Sur les определители gauches" [О косых детерминантах]. Журнал Крелля. 38: 93–96.
- ^ Вазирани, Виджай В. (1989). "Алгоритмы ЧПУ для вычисления числа точных совпадений в K3,3-бесплатные графики и связанные с ними задачи ». Информация и вычисления. 80 (2): 152–164. Дои:10.1016/0890-5401(89)90017-5. ISSN 0890-5401.
- ^ Джеррам, Марк (1987), «Двумерные системы мономер-димер вычислительно трудноразрешимы», Журнал статистической физики, 48 (1): 121–134, Bibcode:1987JSP .... 48..121J, Дои:10.1007 / BF01010403.
- ^ Валиант, Лесли Г. (2004). «Голографические алгоритмы (расширенное резюме)». Материалы 45-го ежегодного симпозиума IEEE по основам компьютерных наук. FOCS'04. Рим, Италия: Компьютерное общество IEEE. С. 306–315. Дои:10.1109 / FOCS.2004.34. ISBN 0-7695-2228-9.
внешняя ссылка
- Более подробную историю, информацию и примеры можно найти в главе 2 и разделе 5.3.2 Дмитрия Каменецкого. Кандидатская диссертация