Невозможно получить соответствующий прогноз, используя statsmodel для HoltWinters - PullRequest
0 голосов
/ 10 декабря 2018

Я пытаюсь поэкспериментировать с HoltWinters, используя некоторые случайные данные.Однако, используя statsmodel api, я не могу предсказать следующие X точек данных.

Вот мой пример кода.Я не могу понять API Предсказание и что оно означает под start и end.

import numpy as np
import matplotlib.pyplot as plt
from statsmodels.tsa.holtwinters import ExponentialSmoothing


data = np.linspace(start=15, stop=25, num=100)
noise = np.random.uniform(0, 1, 100)

data = data + noise

split = int(len(data)*0.7)
data_train = data[0:split]
data_test = data[-(len(data) - split):]

model = ExponentialSmoothing(data_train)
model_fit = model.fit()

# make prediction
pred = model_fit.predict(split+1, len(data))

test_index = [i for i in range(split, len(data))]

plt.plot(data_train, label='Train')
plt.plot(test_index, data_test, label='Test')
plt.plot(test_index, pred, label='Prediction')
plt.legend(loc='best')
plt.show()

enter image description here

Я получил странный график для прогноза и считаю, что он как-то связан с моим пониманием predict API.

1 Ответ

0 голосов
/ 27 декабря 2018

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

Если вы сделаете:

model = ExponentialSmoothing(data_train, trend='add')

тогда вы получите тренд и, скорее всего, он будет выглядеть так, как вы ожидаете.

Например:

# Simulate some data
np.random.seed(12346)
dta = pd.Series(np.arange(100) + np.sin(np.arange(100)) * 5 + np.random.normal(scale=4, size=100))

# Perform exponention smoothing, no trend
mod1 = sm.tsa.ExponentialSmoothing(dta)
res1 = mod1.fit()
fcast1 = res1.forecast(30)

plt.plot(dta)
plt.plot(fcast1, label='Model without trend')

# Perform exponention smoothing, with a trend
mod2 = sm.tsa.ExponentialSmoothing(dta, trend='add')
res2 = mod2.fit()
fcast2 = res2.forecast(30)

plt.plot(fcast2, label='Model with trend')
plt.legend(loc='lower right')

дает следующее:

plots of forecast, with and without trend

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...