6.9. ИТЕРАТИВНАЯ ОПТИМИЗАЦИЯ
Когда найдена функция критерия, группировка становится корректно поставленной задачей дискретной оптимизации: найти такие разделения множества выборок, которые приводят к экстремуму функции критерия. Поскольку множество выборок конечно, существует конечное число возможных разделений. Следовательно, теоретически задача группировки всегда может быть решена трудоемким перебором. Однако на практике такой подход годится лишь для самых простых задач. Существует приблизительно способов разделения множества из элементов на с подмножеств и этот экспоненциальный рост при большом просто давит. Например, скрупулезный поиск лучшего набора из пяти групп в случае 100 выборок потребует рассмотрения более чем 1067 разделений. Поэтому в большинстве применений перебор практически невозможен.
Наиболее часто используемым подходом для поиска оптимального разделения является итеративная оптимизация. Основная идея заключается в нахождении некоторого разумного начального разделения и в «передвижении» выборок из одной группы в другую, если это передвижение улучшает функцию критерия. Как и процедуры подъема на вершину к общем случае, такой подход гарантирует локальный, но не глобальный максимум. Различные начальные точки Могут привести к разным решениям, и никогда не известно, было ли найдено лучшее решение. Несмотря на эти ограничения, вычислительные требования выполнимы, и такой подход приемлем.
Рассмотрим использование итеративного улучшения для минимизации критерия суммы квадратов ошибок записанного как
здесь
где
Предположим, что выборка х, находящаяся в данный момент в группе X и передвигается в группу . Тогда изменяется на
увеличивается на
Приняв предположение, что (одиночных групп в разбиении не должно быть), такое же вычисление показывает, что изменяется на
уменьшается:
Эти соотношения значительно упрощают вычисления изменения функции критерия. Переход х из положителен, если уменьшение больше, чем увеличение . Это случай, если
что обычно получается, когда х ближе к , чем к Если перераспределение выгодно, наибольшее уменьшение в сумме квадратов ошибок достигается выбором группы, для которой минимально. Это приводит к следующей процедуре группировки:
Процедура: Базовая Минимальная Квадратичная Ошибка
1. Выбрать первоначальное разделение выборок на группы и вычислить и средние .
Цикл: 2. Выбрать следующую выборку — кандидата на передвижение х. Предполагается, что х находится в
3. Если перейти к Следующий; иначе вычислить
4. Передвинуть если для всех
5. Вновь вычислить
Следующий: 6. Если не изменилось после попыток, останов; иначе перейти к Цикл.
Если эту процедуру сравнить с процедурой Базовые Изоданные, описанной в п. 6.4.4, то ясно, что первая процедура в основном представляет собой последовательный вариант второй. Тогда как процедура Базовые Изоданные ждет, пока все выборок будут перегруппированы перед обновлением значений, процедура Базовая Минимальная Квадратичная Ошибка обновляет значения после перегруппировки каждой выборки. Экспериментально было замечено, что эта процедура более чувствительна к локальным минимумам; другой ее недостаток состоит в том, что результаты зависят от порядка, в котором выбираются кандидаты. Однако это по крайней мере пошаговая оптимальная процедура, и ее легко модифицировать для применения к задачам, в которых выборки получаются последовательно, а группировка должна производиться в масштабе реального времени.
Общая проблема для всех процедур подъема на вершину — это выбор начальной точки. К сожалению, не существует простого универсального решения этой проблемы. Один из подходов — взять с произвольных выборок в качестве центров групп и использовать их для разделения данных на основе минимума расстояния. Повторения с различными случайными выборками в качестве центров могут дать некоторое представление о чувствительности решения к выбору начальной точки. Другой подход состоит в нахождении начальной точки для группы из решения задачи с группами. Решение для задачи с одной группой — это среднее по всем выборкам; начальная точка для задачи с с группами может быть средняя для задачи с группами плюс выборка, которая находится дальше всех от ближайшего центра группы. Этот подход подводит нас к так называемым иерархическим процедурам группировок, которые простыми методами дают возможность получить очень хорошие начальные точки для итерационной оптимизации.