Алгоритм AnyBoost
Материал из MachineLearning.
(→Описание алгоритма) |
|||
Строка 5: | Строка 5: | ||
'''Алгоритм AnyBoost''' | '''Алгоритм AnyBoost''' | ||
- | Рассмотрим задачу классификации на два класса, <tex>Y=\{-1,+1\}</tex>. | + | Рассмотрим задачу классификации на два класса, <tex>Y=\{-1,+1\}</tex>. <tex>\mathcal{F}</tex> - множество базовых классификаторов, все их линейные комбинации содержатся в множестве <tex>\mathrm{lin}(\mathcal{F})</tex>. Для <tex>F,G\in\mathrm{lin}(\mathcal{F})</tex> введено скалярное умножение: <tex>(F,G)=\frac{1}{m}\sum^{m}_{i=1}{F(x_i)G(x_i)}</tex>, где <tex>X^l =\{(x_i,y_i)\}</tex> - обучающая выборка. Функция потерь <tex></tex> определяется через дифференцируемую функцию выброса <tex>C:\mathbb{R} \to \mathbb{R}</tex>. |
- | + | #Инициализация <tex>F_0=0</tex>; | |
- | + | #Для всех <tex>t=0,..,T</tex> пока не выполнено условие выхода из цикла; | |
- | + | ##Получение нового классификатора <tex>f_{t+1}</tex>, увеличивающего значение <tex>-(С(F_t),f_{t+1})</tex>; | |
- | + | ##Если <tex>-(С(F_t),f_{t+1})\le 0</tex> выходим из цикла и возвращаем <tex>F_t</tex>; | |
- | + | ##Выбор веса <tex>w_{t+1}</tex> | |
- | + | ##Уточнение классификатора <tex>F_{t+1}=F_{t}+w_{t+1}f_{t+1}</tex> | |
+ | #Возвращаем <tex>F_{T+1}</tex> | ||
==См. также== | ==См. также== |
Версия 13:13, 7 февраля 2010
Данная статья является непроверенным учебным заданием.
До указанного срока статья не должна редактироваться другими участниками проекта MachineLearning.ru. По его окончании любой участник вправе исправить данную статью по своему усмотрению и удалить данное предупреждение, выводимое с помощью шаблона {{Задание}}. См. также методические указания по использованию Ресурса MachineLearning.ru в учебном процессе. |
Алгоритм AnyBoost - класс алгоритмов, представляющих бустинг как процесс градиентного спуска. В основе алгоритма лежит последовательное уточнение функции, представляющей собой линейную комбинацию базовых классификаторов, с тем чтобы минимизировать функцию потерь. В класс AnyBoost входят практически все алгоритмы бустинг как частные случаи.
Содержание[убрать] |
Описание алгоритма
Алгоритм AnyBoost
Рассмотрим задачу классификации на два класса, . - множество базовых классификаторов, все их линейные комбинации содержатся в множестве . Для введено скалярное умножение: , где - обучающая выборка. Функция потерь определяется через дифференцируемую функцию выброса .
- Инициализация ;
- Для всех пока не выполнено условие выхода из цикла;
- Получение нового классификатора , увеличивающего значение ;
- Если выходим из цикла и возвращаем ;
- Выбор веса
- Уточнение классификатора
- Возвращаем
См. также
Литература
- Mason L., Baxter J., Bartlett P., Frean M. Boosting algorithms as gradient descent. — Advances in Neural Information Processing Systems. — MIT Press, 2000. — T. 12. — 512--518 с.