WikiDer > Последовательная минимальная оптимизация

Sequential minimal optimization
Последовательная минимальная оптимизация
Учебный классАлгоритм оптимизации для обучения опорных векторных машин
Худший случай спектакльO (п³)

Последовательная минимальная оптимизация (SMO) - алгоритм решения квадратичное программирование (QP) проблема, возникающая при обучении машины опорных векторов (SVM). Это было изобретено Джон Платт в 1998 г. Microsoft Research.[1] SMO широко используется для обучения опорных векторных машин и реализуется популярными LIBSVM инструмент.[2][3] Публикация алгоритма SMO в 1998 году вызвала большой ажиотаж в сообществе SVM, так как ранее доступные методы обучения SVM были намного сложнее и требовали дорогостоящих сторонних решателей QP.[4]

Проблема оптимизации

Рассмотрим двоичная классификация проблема с набором данных (Икс1, у1), ..., (Иксп, уп), куда Икся - входной вектор и уя ∈ {-1, +1} - соответствующая ему двоичная метка. Мягкая маржа Машина опорных векторов обучается путем решения задачи квадратичного программирования, которая выражается в двойная форма следующее:

при условии:

куда C является гиперпараметром SVM и K(Икся, Иксj) это функция ядра, оба предоставлены пользователем; а переменные находятся Множители Лагранжа.

Алгоритм

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

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

Алгоритм работает следующим образом:

  1. Найдите множитель Лагранжа что нарушает Условия Каруша – Куна – Таккера (ККТ) для задачи оптимизации.
  2. Выберите второй множитель и оптимизируем пару .
  3. Повторяйте шаги 1 и 2 до схождения.

Когда все множители Лагранжа удовлетворяют условиям KKT (в пределах заданного пользователем допуска), проблема решена. Хотя этот алгоритм гарантирует сходимость, эвристика используется для выбора пары множителей, чтобы ускорить скорость сходимости. Это критично для больших наборов данных, так как есть возможные варианты для и .

Связанных с работой

Первый подход к разделению больших задач обучения SVM на серию более мелких задач оптимизации был предложен Бернхард Бозер, Изабель Гийон, Владимир Вапник.[5] Он известен как «алгоритм фрагментирования». Алгоритм начинается со случайного подмножества данных, решает эту проблему и итеративно добавляет примеры, которые нарушают условия оптимальности. Одним из недостатков этого алгоритма является то, что необходимо решать QP-задачи масштабированием по количеству SV. В реальных разреженных наборах данных SMO может быть более чем в 1000 раз быстрее, чем алгоритм разделения на части.[1]

В 1997 г. Э. Осуна, Р. Фройнд, и Ф. Джироси доказал теорему, которая предлагает совершенно новый набор алгоритмов QP для SVM.[6] В силу этой теоремы большая проблема КП может быть разбита на серию более мелких подзадач КП. Последовательность подзадач QP, которые всегда добавляют хотя бы одного нарушителя Условия Каруша – Куна – Таккера (ККТ) гарантированно сойдется. Алгоритм разделения на фрагменты подчиняется условиям теоремы и, следовательно, будет сходиться.[1] Алгоритм SMO можно рассматривать как частный случай алгоритма Osuna, где размер оптимизации равен двум, и оба множителя Лагранжа заменяются на каждом шаге новыми множителями, которые выбираются с помощью хорошей эвристики.[1]

Алгоритм SMO тесно связан с семейством алгоритмов оптимизации, называемых Методы Брегмана или методы строкового действия. Эти методы решают задачи выпуклого программирования с линейными ограничениями. Это итерационные методы, в которых каждый шаг проецирует текущую первичную точку на каждое ограничение.[1]

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

Рекомендации

  1. ^ а б c d е Платт, Джон (1998). «Последовательная минимальная оптимизация: быстрый алгоритм для обучения машин опорных векторов» (PDF). CiteSeerX 10.1.1.43.4376. Цитировать журнал требует | журнал = (помощь)
  2. ^ Чанг, Чи-Чжун; Лин, Чи-Джен (2011). «LIBSVM: библиотека для машин с векторной поддержкой». Транзакции ACM по интеллектуальным системам и технологиям. 2 (3).
  3. ^ Занни, Лука (2006). «Параллельное программное обеспечение для обучения крупномасштабных машин с опорными векторами на многопроцессорных системах» (PDF).
  4. ^ Рифкин, Райан (2002). Все старое снова новое: свежий взгляд на исторические подходы в машинном обучении (Кандидатская диссертация). Массачусетский Институт Технологий. п. 18. HDL:1721.1/17549.
  5. ^ Boser, B.E .; Guyon, I.M .; Вапник, В. Н. (1992). «Алгоритм обучения оптимальных классификаторов маржи». Материалы пятого ежегодного семинара по теории вычислительного обучения - COLT '92. п. 144. CiteSeerX 10.1.1.21.3818. Дои:10.1145/130385.130401. ISBN 978-0897914970.
  6. ^ Osuna, E .; Freund, R .; Джирози, Ф. (1997). «Улучшенный алгоритм обучения опорных векторных машин». Нейронные сети для обработки сигналов [1997] VII. Материалы семинара IEEE 1997 г.. С. 276–285. CiteSeerX 10.1.1.392.7405. Дои:10.1109 / ННСП.1997.622408. ISBN 978-0-7803-4256-9.