Peramalan

Model ARIMA di Python

James Fulton

Climate informatics researcher

Memprediksi nilai berikutnya

Ambil model AR(1)

$y_t = a_1 y_{t-1} + \epsilon_t$

Prediksi nilai berikutnya

$y_t = 0.6\; \text{x} \; 10 + \epsilon_t$

$y_t = 6.0 + \epsilon_t$

Ketidakpastian prediksi

$ 5.0 < y_t < 7.0$

Model ARIMA di Python

Prediksi satu langkah ke depan

Model ARIMA di Python

Membuat prediksi satu langkah ke depan

# Make predictions for last 25 values
results = model.fit()

# Make in-sample prediction forecast = results.get_prediction(start=-25)
Model ARIMA di Python

Membuat prediksi satu langkah ke depan

# Make predictions for last 25 values
results = model.fit()

# Make in-sample prediction forecast = results.get_prediction(start=-25)
# forecast mean mean_forecast = forecast.predicted_mean

Rata-rata prediksi adalah seri pandas

2013-10-28    1.519368
2013-10-29    1.351082
2013-10-30    1.218016
Model ARIMA di Python

Interval kepercayaan

# Get confidence intervals of forecasts
confidence_intervals = forecast.conf_int()

Metode interval kepercayaan mengembalikan DataFrame pandas

                                 lower y                       upper y
2013-09-28                     -4.720471                     -0.815384
2013-09-29                     -5.069875                      0.112505
2013-09-30                     -5.232837                      0.766300
2013-10-01                     -5.305814                      1.282935
2013-10-02                     -5.326956                      1.703974
Model ARIMA di Python

Memplot prediksi

plt.figure()

# Plot prediction
plt.plot(dates, 
         mean_forecast.values, 
         color='red', 
         label='forecast')

# Shade uncertainty area plt.fill_between(dates, lower_limits, upper_limits, color='pink') plt.show()
Model ARIMA di Python

Memplot prediksi

Model ARIMA di Python

Prediksi dinamis

Model ARIMA di Python

Membuat prediksi dinamis

results = model.fit()
forecast = results.get_prediction(start=-25, dynamic=True)
# forecast mean
mean_forecast = forecast.predicted_mean

# Get confidence intervals of forecasts
confidence_intervals = forecast.conf_int()
Model ARIMA di Python

Peramalan out-of-sample

forecast = results.get_forecast(steps=20)
# forecast mean
mean_forecast = forecast.predicted_mean

# Get confidence intervals of forecasts
confidence_intervals = forecast.conf_int()
Model ARIMA di Python

Peramalan out-of-sample

forecast = results.get_forecast(steps=20)

Model ARIMA di Python

Ayo berlatih!

Model ARIMA di Python

Preparing Video For Download...