Лучшие вопросы
Таймлайн
Чат
Перспективы
Алгоритм Кармаркара
Из Википедии, свободной энциклопедии
Remove ads
Алгоритм Кармаркара — это алгоритм, представленный Нарендрой Кармаркаром в 1984 году для решения задач линейного программирования. Это был первый достаточно эффективный алгоритм, который решал задачи за полиномиальное время. Метод эллипсоидов является также алгоритмом полиномиального времени, но он оказался неэффективным в практических приложениях.
Если — число переменных, и — число битов входных данных, алгоритм Кармаркара требует операций над числами с знаками, в то время как метод эллипсоидов требует таких операций. Время работы алгоритма Кармаркара равно
при использовании метода умножения Шёнхаге — Штрассена (см. «O» большое).
Алгоритм Кармаркара принадлежит классу методов внутренней точки — текущее допустимое решение не передвигается по границе области допустимых решений как в симплекс-методе, а движется по внутренним точкам области допустимых значений, улучшая с каждой итерацией аппроксимацию оптимального решения определённой дробью и приводя к оптимальному решению с рациональными данными[1].
Remove ads
Алгоритм
Суммиров вкратце
Перспектива
Рассмотрим задачу линейного программирования в матричной форме:
- максимизировать cTx
- при ограничениях Ax ⩽ b.
Алгоритм определяет очередное допустимое направление в сторону оптимального решения и отступает на множитель 0 < γ ⩽ 1.
Алгоритм Кармаркара весьма сложен. Заинтересованные читатели могут найти информацию по ссылкам[2][3][4] [5][6][7][8]. Упрощённая версия, носящая название «Метод аффинного масштабирования», анализируемая в других статьях[9], может быть описана кратко следующим образом. Заметьте, что метод аффинного масштабирования, когда используется для задач малых размеров, не является алгоритмом полиномиального времени. Для задач большого размера и сложных задач следует придерживаться исходного подхода. Кармаркар также расширил методологию[10][11][12][13] решения задач с целыми ограничениями и невыпуклых задач[14].
Вход: A, b, c, , Критерий остановки, .
do while критерий остановки не выполняется if then return неограниченное решение end if end do
Здесь
- «←» является сокращением «изменить на». Например, «largest ← item» означает, что значение переменной largest заменяется на значение переменной item.
- «return» прерывает работу алгоритма и выводит значение, которое записано после команды.
Remove ads
Пример
Суммиров вкратце
Перспектива

Пусть дана задача линейного программирования
- максимизировать
- при условиях
То есть имеются две переменные и 11 ограничений, соответствующих различным значениям . Рисунок показывает каждую итерацию алгоритма как красную точку. Ограничения показаны синими прямыми.
Remove ads
Дебаты о патентовании — Можно ли патентовать математику?
Суммиров вкратце
Перспектива
Во время, когда Наренда Кармаркар предложил свой алгоритм, он работал в AT&T. После внедрения алгоритма для оптимизации телефонной сети AT&T[15] там осознали, что он может иметь практическую важность. В апреле 1985 года AT&T быстро подала заявку на патент алгоритма Кармаркара, и это событие подлило масла в разгорающиеся дебаты вокруг патентования программного обеспечения[16]. Это привело в беспокойство многих математиков, как, например, Рональда Ривеста (он сам является одним из держателей патента на алгоритм RSA), выразившего мнение, что исследования, основанные на базе этого алгоритма, должны бы быть свободными. Даже ещё до утверждения патента некоторые утверждали, что существовал неосуществлённый прототип[англ.][17].
Математики, специализирующиеся в методах вычислений, такие как Филип Гилл (Philip Gill) и другие, утверждали, что алгоритм Кармаркара эквивалентен проективному барьерному методу Ньютона с логарифмической барьерной функцией, если правильно выбрать параметры[18]. Однако аргумент Гилла имеет недостаток, поскольку метод, который он описывает, даже не считается «алгоритмом», поскольку требует выбора параметров, которые не обусловлены внутренней логикой метода и полностью полагаются на внешнее управление, особенно что касается алгоритма Кармаркара[19]. Более того, вклад Кармаркара далёк от очевидного в свете всех предшествующих работ, включая работы Фиако — МакКормика (Fiacco–McCormick), Гилла (Gill) и других, перечисленных Зальцманом (Saltzman)[19][20][21]. Патент обсуждался в сенате США, был одобрен как признание существенной оригинальности работы Кармаркара и был оформлен как патент США 4744026 «Методы и аппаратура для эффективного распределения ресурсов» в мае 1988. AT&T поставил систему KORBX[22] [23], базирующуюся на этом патенте, Пентагону[24][25], который использовал её для решения математических задач, которые до этого считались неразрешимыми.
Оппоненты программного патентирования позднее заявляли, что патенты разрушили положительный цикл взаимодействия, который характеризовал связь исследователей в линейном программировании и производством, и, в частности, изолировали самого Кармаркара от математических исследований в его области[26].
Действие патента истекло в апреле 2006 года, и алгоритм в настоящее время является всеобщим достоянием.
Remove ads
Примечания
Литература
Wikiwand - on
Seamless Wikipedia browsing. On steroids.
Remove ads