Экспоненциальное сглаживание
Теория экспоненциального сглаживания
Этот материал распространяется на условиях лицензии Creative Commons Attribution/Share-Alike License 3.0 (Unported). Это означает, что вы можете размещать этот контент на своем сайте или создавать на его основе собственный (в том числе и в коммерческих целях), при условии сохранения оригинального лицензионного соглашения. Кроме того, Вы должны отметить автора этой работы, путем размещения HTML ссылки на оригинал работы https://planetcalc.ru/587/. Пожалуйста оставьте без изменения все ссылки на других авторов данной работы или работы, на основе которой создана данная работа (если таковые имеются в спроводительном тексте).
Я тут было собрался написать еще одну статью о технических индикаторах и рассказать про экспоненциальное скользящее среднее (exponential moving average, EMA), однако получилось так, что, изучая теорию этого индикатора, я наткнулся на довольно интересные вещи, относящиеся все-таки больше к статистике, нежели к рынку акций или forex.
Поскольку на этом сайте статистика уже затрагивалась, я решил написать отдельную статью на эту тему, а именно, статью, посвященную методу экспоненциального сглаживания (exponential smoothing) в анализе рядов динамики (time series)
Тема рядов динамики уже затрагивалась в статье Сезонные колебания. Индексы сезонности. Метод постоянной средней, и там было сказано, в частности, что расчет средних индексов сезонности методов постоянной средней может применяться для рядов динамики, где отсутствуют какие-либо тенденции повышения/понижения, либо же они незначительны. Иными словами, наблюдаемая величина колеблется около какого-то постоянного значения.
Что это значит? Это значит, что постоянное среднее, оно постоянное, и поэтому не может захватить тенденцию.
Проиллюстрируем это графиком
Вообще говоря, все методы усреднения направлены на то, чтобы исключить «шум» от случайного разброса данных, что позволяет более явно выявить тенденцию, либо же сезонные или циклические изменения, то есть внутреннюю структуру данных, кажущихся случайными, и использовать это для построения модели с последующим анализом и прогнозированием будущих значений — но, как видим, метод простого усреднения не работает при наличии явно выраженной тенденции, и спрогнозировать с его помощью ничего нельзя.
Нужно уметь получать не одно, постоянное, среднее, а, опять-таки, ряд средних, который бы пытался отражать тенденцию изменения данных. Ну и самым популярным (и простым) методом для получения таких рядов стал метод экспоненциального сглаживания.
На словах его можно описать так — При прогнозировании, более новым значениям наблюдаемой величины присваивается больший вес по сравнению с более старыми значениями. При этом более старым значениями присваиваются экспоненциально убывающие веса.
Теперь опишем это определение формулами.
Традиционно обозначим наблюдаемую величину как , а сглаженное среднее как .
Тогда,
не определено
и, обобщенно
где, принимает значение из диапазона [0;1)
Откуда берется экспонента — раскроем предыдущие средние
и, обобщенно
, для t > 2
Таким образом, веса перед — это бесконечно убывающая геометрическая прогрессия с множителем
И чем дальше S, тем меньше на нее влияют начальные значения.
Предположим, что , посмотрим, как меняется его вклад для различных S.
Для S2 берется как есть, а вот в S3 при коэффициенте альфа равном 0.5, вклад y1 будет всего только 250, в S4 — 125, и так далее.
При этом большое значение имеет выбор коэффициента . Если поиграться с параметром «a» в калькуляторе (см. выше), то становится ясно, что чем выше его значение, тем быстрее отсчет фактически перестает влиять на сглаженное среднее, и наоборот - чем ниже, тем дольше сохраняется его влияние.
Соответственно, при малых , метод получения S2 оказывает большое влияние на результат. Присвоение это только один из методов. В качестве альтернативы начальным значением может выступать простое среднее по первым нескольким значениям y, например.
Но как же выбрать ? Какой показатель больше всего подходит для моделирования данного ряда динамики? Никаких математических формул по точному расчету нет. Этот показатель чаще всего выбирается методом подбора, или методом «проб и ошибок» (англ. trial and errors). Я еще пару раз видел название «метод научного тыка» :)
Метод заключается в том, что берется несколько значений и потом среди них выбирается одно лучшее. Что же является критерием «лучшести» в нашем случае?
Таким критерием является минимизация среднеквадратической ошибки (mean of squared errors). Ошибка — это отклонение фактического значения от прогнозного. Для каждого значения S ее возводят в квадрат, чтобы избавиться от влияния знака, и затем вычисляют среднее по всем значениям. Тот показатель , для которого среднее значение минимально и является лучшим из нескольких.
Теперь пару слов про прогнозирование.
Следующее значение ряда прогнозируется прямо по формуле
В случае если надо получить прогноз на большее число отсчетов, используется техника под названием bootstrapping (даже не знаю, какой адекватный русский термин здесь подойдет). Последнее известное значение «y» принимается за константу, и используется в рекурсивной формуле
Теперь применим полученные знания при расчете сглаженного среднего для графика, приведенного в начале статьи. Чтобы было интереснее, рассчитаем сглаженное среднее сразу для трех значений , и заодно посчитаем среднеквадратическую ошибку.
На графике для справки показано следующее прогнозируемое значение, т. е. сглаженные средние продлены на один отсчет дальше фактических данных.
Кстати, замечу, что для данных по умолчанию в калькуляторе выше лучшим значением будет 0.7
При равном 1 (вообще это выколотый случай) сглаживание вырождается в повтор предпоследнего значения, что при большом разбросе соседних значений далеко не всегда дает минимум среднеквадратической ошибки.
Комментарии