Алгоритм Кармаркара

Материал из testwiki
Перейти к навигации Перейти к поиску

Алгоритм Кармаркара — это алгоритм, представленный Нарендрой Кармаркаром в 1984 году для решения задач линейного программирования. Это был первый достаточно эффективный алгоритм, который решал задачи за полиномиальное время. Метод эллипсоидов является также алгоритмом полиномиального времени, но он оказался неэффективным в практических приложениях.

Если n — число переменных, и L — число битов входных данных, алгоритм Кармаркара требует O(n3,5L) операций над числами с O(L) знаками, в то время как метод эллипсоидов требует O(n6L) таких операций. Время работы алгоритма Кармаркара равно

O(n3,5L2logLloglogL)

при использовании метода умножения Шёнхаге — Штрассена (см. «O» большое).

Алгоритм Кармаркара принадлежит классу методов внутренней точки — текущее допустимое решение не передвигается по границе области допустимых решений как в симплекс-методе, а движется по внутренним точкам области допустимых значений, улучшая с каждой итерацией аппроксимацию оптимального решения определённой дробью и приводя к оптимальному решению с рациональными данными[1].

Алгоритм

Рассмотрим задачу линейного программирования в матричной форме:

максимизировать cTx
при ограничениях Axb.

Алгоритм определяет очередное допустимое направление в сторону оптимального решения и отступает на множитель 0 < γ ⩽ 1.

Алгоритм Кармаркара весьма сложен. Заинтересованные читатели могут найти информацию по ссылкам[2][3][4] [5][6][7][8]. Упрощённая версия, носящая название «Метод аффинного масштабирования», анализируемая в других статьях[9], может быть описана кратко следующим образом. Заметьте, что метод аффинного масштабирования, когда используется для задач малых размеров, не является алгоритмом полиномиального времени. Для задач большого размера и сложных задач следует придерживаться исходного подхода. Кармаркар также расширил методологию[10][11][12][13] решения задач с целыми ограничениями и невыпуклых задач[14].

  Вход:  A, b, c, x0, Критерий остановки, γ.
  k0
  do while критерий остановки не выполняется
     vkbAxk
     Dvdiag(v1k,,vmk)
     hx(ATDv2A)1c
     hvAhx
     if hv0 then
        return неограниченное решение
     end if
     αγmin{vik/(hv)i(hv)i<0,i=1,,m}
     xk+1xk+αhx
     kk+1
  end do

Здесь

  • «←» является сокращением «изменить на». Например, «largest ← item» означает, что значение переменной largest заменяется на значение переменной item.
  • «return» прерывает работу алгоритма и выводит значение, которое записано после команды.

Пример

Пример решения

Пусть дана задача линейного программирования

максимизировать x1+x2
при условиях 2px1+x2p2+1, p=0,0,0,1,0,2,,0,9,1,0.

То есть имеются две переменные x1,x2 и 11 ограничений, соответствующих различным значениям p. Рисунок показывает каждую итерацию алгоритма как красную точку. Ограничения показаны синими прямыми.

Дебаты о патентовании — Можно ли патентовать математику?

Во время, когда Наренда Кармаркар предложил свой алгоритм, он работал в AT&T. После внедрения алгоритма для оптимизации телефонной сети AT&T[15] там осознали, что он может иметь практическую важность. В апреле 1985 года AT&T быстро подала заявку на патент алгоритма Кармаркара, и это событие подлило масла в разгорающиеся дебаты вокруг патентования программного обеспечения[16]. Это привело в беспокойство многих математиков, как, например, Рональда Ривеста (он сам является одним из держателей патента на алгоритм RSA), выразившего мнение, что исследования, основанные на базе этого алгоритма, должны бы быть свободными. Даже ещё до утверждения патента некоторые утверждали, что существовал неосуществлённый Шаблон:Не переведено 5[17].

Математики, специализирующиеся в методах вычислений, такие как Филип Гилл (Philip Gill) и другие, утверждали, что алгоритм Кармаркара эквивалентен проективному барьерному методу Ньютона с логарифмической барьерной функцией, если правильно выбрать параметры[18]. Однако аргумент Гилла имеет недостаток, поскольку метод, который он описывает, даже не считается «алгоритмом», поскольку требует выбора параметров, которые не обусловлены внутренней логикой метода и полностью полагаются на внешнее управление, особенно что касается алгоритма Кармаркара[19]. Более того, вклад Кармаркара далёк от очевидного в свете всех предшествующих работ, включая работы Фиако — МакКормика (Fiacco–McCormick), Гилла (Gill) и других, перечисленных Зальцманом (Saltzman)[19][20][21]. Патент обсуждался в сенате США, был одобрен как признание существенной оригинальности работы Кармаркара и был оформлен как патент США 4744026 «Методы и аппаратура для эффективного распределения ресурсов» в мае 1988. AT&T поставил систему KORBX[22] [23], базирующуюся на этом патенте, Пентагону[24][25], который использовал её для решения математических задач, которые до этого считались неразрешимыми.

Оппоненты программного патентирования позднее заявляли, что патенты разрушили положительный цикл взаимодействия, который характеризовал связь исследователей в линейном программировании и производством, и, в частности, изолировали самого Кармаркара от математических исследований в его области[26].

Действие патента истекло в апреле 2006 года, и алгоритм в настоящее время является всеобщим достоянием.

Примечания

Шаблон:Примечания

Литература

Шаблон:Методы оптимизации Шаблон:Rq

  1. Шаблон:Статья
  2. Шаблон:Cite web
  3. Шаблон:Cite web
  4. Шаблон:Cite web
  5. Karmarkar N. K., An InteriorPoint Approach to NPComplete Problems Part I, AMS series on Contemporary Mathematics 114, p. 297308 (June 1990). http://www.ams.org/books/conm/114/conm114-endmatter.pdf Шаблон:Wayback
  6. Karmarkar, N. K., Riemannian Geometry Underlying Interior Point Methods for Linear programming, AMS series on Contemporary Mathematics 114, p. 5175 (June 1990). http://www.ams.org/books/conm/114/conm114-endmatter.pdf Шаблон:Wayback
  7. Karmarkar N. K., Lagarias, J. C., Slutsman, L., Wang, P., Power Series Variants of KarmarkarType Algorithm, AT & T technical Journal 68, No. 3, May/June (1989).
  8. Шаблон:Cite web
  9. Шаблон:Статья
  10. Karmarkar, N. K., Interior Point Methods in Optimization, Proceedings of the Second International Conference on Industrial and Applied Mathematics, SIAM, p. 160181 (1991).
  11. Karmarkar, N. K. Kamath, A. P., A continuous Approach to Deriving Upper Bounds in Quadratic Maximization Problems with Integer Constraints, Recent Advances in Global Optimization, p. 125140, Princeton University Press (1992).
  12. Karmarkar, N. K., Thakur, S. A., An Interior Point Approach to a Tensor Optimisation Problem with Application to Upper Bounds in Integer Quadratic Optimization Problems, Proceedings of Second Conference on Integer Programming and Combinatorial Optimisation, (May 1992).
  13. Kamath, A., Karmarkar, N. K., A Continuous Method for Computing Bounds in Integer Quadratic Optimisation Problems, Journal of Global Optimization (1992).
  14. Karmarkar, N. K., Beyond Convexity: New Perspectives in Computational Optimization. Springer Lecture Notes in Computer Science LNCS 6457, Dec 2010.
  15. Sinha L.P., Freedman, B. A., Karmarkar, N. K., Putcha, A., Ramakrishnan K. G., Overseas Network Planning, Proceedings of the Third International Network Planning Symposium, NETWORKS' 86, Tarpon Springs, Florida (June 1986).
  16. Шаблон:Статья
  17. Шаблон:Cite web
  18. Шаблон:Статья
  19. 19,0 19,1 Шаблон:Статья
  20. Mark A. Paley (1995). «The Karmarkar Patent: Why Congress Should „Open the Door“ to Algorithms as Patentable Subject Matter». 22 COMPUTER L. REP. 7.
  21. Шаблон:Статья
  22. Шаблон:Статья
  23. Шаблон:Cite web
  24. Шаблон:Cite web
  25. Шаблон:Cite web
  26. Шаблон:Статья