purrr auto.arima xreg комбинация - PullRequest
0 голосов
/ 30 августа 2018

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

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

Мои данные:

head(df)
nam period     sv
APA 2016-07-03 1895619
APA 2016-07-10 2100690
APA 2016-07-17 2059273
APA 2016-07-24 2073187
APA 2016-07-31 1951968

и мой код в R будет закончен ...

df %>% 
nest(-nam) %>% 
mutate(ts_data = map(data, tk_ts, select = sv, start = c(2016,26), frequency = 52)) %>% 
mutate(harmonics = map(ts_data, fourier, K=24)) %>% 
mutate(fitted = map2(.x = ts_data, .y =harmonics, .f= auto.arima, xreg , seasonal = F)) 

Я хочу получить эквивалентный этому коду:

harmonics <- fourier(db, K = 24)
# Fit regression model with ARIMA errors
fit <- auto.arima(db, xreg = harmonics, seasonal = F)
# Forecasts next 46 periods
newharmonics <- fourier(db, K = 24, h = 46)
fc <- forecast(fit, xreg = newharmonics )

Может ли кто-нибудь помочь мне закончить это? Спасибо с авансом

1 Ответ

0 голосов
/ 30 августа 2018

Я решил это. Достаточно было просто положить это в формулу

`auto_arima = function(df) {
harmonics <- fourier(df, K = 24)
# Fit regression model with ARIMA errors
fit <- auto.arima(df, xreg = harmonics, seasonal = FALSE)
# Forecasts next 46 period
newharmonics <- fourier(df, K = 24, h = 46)
fc <- forecast(fit, xreg = newharmonics)
fc_db = fc %>% as_data_frame() %>% select(`Point Forecast`) %>% 
mutate(period = seq.Date(as.Date("2017-10-15"), as.Date("2018-08-27"),by = "week"))
return(fc_db)
}

` а затем:

mutate(fitted = map(ts_data, auto_arima))

Sewe

...