R: Holt-Winters with daily data (forecast package)

荒凉一梦 提交于 2019-12-29 09:13:34

问题


In the following example, I am trying to use Holt-Winters smoothing on daily data, but I run into a couple of issues:

# generate some dummy daily data
mData = cbind(seq.Date(from = as.Date('2011-12-01'), 
         to = as.Date('2013-11-30'), by = 'day'), rnorm(731))

# convert to a zoo object
zooData = as.zoo(mData[, 2, drop = FALSE], 
                 order.by = as.Date(mData[, 1, drop = FALSE], format = '%Y-%m-%d'),
                 frequency = 7)

# attempt Holt-Winters smoothing
hw(x = zooData, h = 10, seasonal = 'additive', damped = FALSE, 
   initial = 'optimal', exponential = FALSE, fan = FALSE)

# no missing values in the data
sum(is.na(zooData))

This leads to the following error:

Error in ets(x, "AAA", alpha = alpha, beta = beta, gamma = gamma, damped = damped, : You've got to be joking. I need more data! In addition: Warning message: In ets(x, "AAA", alpha = alpha, beta = beta, gamma = gamma, damped = damped, : Missing values encountered. Using longest contiguous portion of time series

Emphasis mine.

Couple of questions: 1. Where are the missing values coming from? 2. I am assuming that the "need more data" arises from attempting to estimate 365 seasonal parameters?

Update 1:

Based on Gabor's suggestion, I have recreated a fractional index for the data where whole numbers are weeks.

I have a couple of questions.
1. Is this is an appropriate way of handling daily data when the periodicity is assumed to be weekly?
2. Is there is a more elegant way of handling the dates when working with daily data?

library(zoo)
library(forecast)

# generate some dummy daily data
mData = cbind(seq.Date(from = as.Date('2011-12-01'), 
                       to = as.Date('2013-11-30'), by = 'day'), rnorm(731))

# conver to a zoo object with weekly frequency
zooDataWeekly = as.zoo(mData[, 2, drop = FALSE], 
                 order.by = seq(from = 0, by = 1/7, length.out = 731))


# attempt Holt-Winters smoothing
hwData = hw(x = zooDataWeekly, h = 10, seasonal = 'additive', damped = FALSE, 
   initial = 'optimal', exponential = FALSE, fan = FALSE)
plot(zooDataWeekly, col = 'red')
lines(fitted(hwData))

回答1:


hw requires a ts object not a zoo object. Use

zooDataWeekly <- ts(mData[,2], frequency=7)

Unless there is a good reason for specifying the model exactly, it is usually better to let R select the best model for you:

fit <- ets(zooDataWeekly)
fc <- forecast(fit)
plot(fc)


来源:https://stackoverflow.com/questions/22113819/r-holt-winters-with-daily-data-forecast-package

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!