ฉันมีสวนสัตว์ซีรีส์ที่มีค่าหายไปมากมาย ฉันอ่านที่auto.arima
สามารถระบุค่าที่หายไปเหล่านี้ได้หรือไม่ ทุกคนสามารถสอนฉันถึงวิธีการทำได้หรือไม่? ขอบคุณมาก!
นี่คือสิ่งที่ฉันได้ลอง แต่ไม่ประสบความสำเร็จ:
fit <- auto.arima(tsx)
plot(forecast(fit))
ฉันมีสวนสัตว์ซีรีส์ที่มีค่าหายไปมากมาย ฉันอ่านที่auto.arima
สามารถระบุค่าที่หายไปเหล่านี้ได้หรือไม่ ทุกคนสามารถสอนฉันถึงวิธีการทำได้หรือไม่? ขอบคุณมาก!
นี่คือสิ่งที่ฉันได้ลอง แต่ไม่ประสบความสำเร็จ:
fit <- auto.arima(tsx)
plot(forecast(fit))
คำตอบ:
ก่อนอื่นให้ระวังว่าforecast
คำนวณการคาดการณ์ภายนอกตัวอย่าง แต่คุณสนใจในการสังเกตในตัวอย่าง
ตัวกรองคาลมานจัดการกับค่าที่หายไป ดังนั้นคุณสามารถใช้รูปแบบสภาพพื้นที่ของรูปแบบ ARIMA จากการส่งออกที่ส่งกลับโดยforecast::auto.arima
หรือและผ่านมันไปstats::arima
KalmanRun
แก้ไข (แก้ไขในรหัสตามคำตอบโดย stats0007)
ในรุ่นก่อนหน้าฉันเอาคอลัมน์ของสถานะการกรองที่เกี่ยวข้องกับชุดข้อมูลที่สังเกต แต่ฉันควรใช้เมทริกซ์ทั้งหมดและดำเนินการเมทริกซ์ที่สอดคล้องกันของสมการสังเกต . (ขอบคุณที่ @ stats0007 สำหรับความคิดเห็น) ด้านล่างฉันอัปเดตรหัสและพล็อตตาม
ฉันใช้ts
วัตถุเป็นชุดตัวอย่างแทนzoo
แต่ควรเหมือนกัน:
require(forecast)
# sample series
x0 <- x <- log(AirPassengers)
y <- x
# set some missing values
x[c(10,60:71,100,130)] <- NA
# fit model
fit <- auto.arima(x)
# Kalman filter
kr <- KalmanRun(x, fit$model)
# impute missing values Z %*% alpha at each missing observation
id.na <- which(is.na(x))
for (i in id.na)
y[i] <- fit$model$Z %*% kr$states[i,]
# alternative to the explicit loop above
sapply(id.na, FUN = function(x, Z, alpha) Z %*% alpha[x,],
Z = fit$model$Z, alpha = kr$states)
y[id.na]
# [1] 4.767653 5.348100 5.364654 5.397167 5.523751 5.478211 5.482107 5.593442
# [9] 5.666549 5.701984 5.569021 5.463723 5.339286 5.855145 6.005067
คุณสามารถพล็อตผลลัพธ์ (ทั้งชุดและตลอดทั้งปีโดยไม่มีข้อสังเกตในตัวอย่างกลาง):
par(mfrow = c(2, 1), mar = c(2.2,2.2,2,2))
plot(x0, col = "gray")
lines(x)
points(time(x0)[id.na], x0[id.na], col = "blue", pch = 19)
points(time(y)[id.na], y[id.na], col = "red", pch = 17)
legend("topleft", legend = c("true values", "imputed values"),
col = c("blue", "red"), pch = c(19, 17))
plot(time(x0)[60:71], x0[60:71], type = "b", col = "blue",
pch = 19, ylim = range(x0[60:71]))
points(time(y)[60:71], y[60:71], col = "red", pch = 17)
lines(time(y)[60:71], y[60:71], col = "red")
legend("topleft", legend = c("true values", "imputed values"),
col = c("blue", "red"), pch = c(19, 17), lty = c(1, 1))
คุณสามารถทำซ้ำตัวอย่างเดียวกันโดยใช้ Kalman นุ่มนวลแทนตัวกรอง Kalman สิ่งที่คุณต้องเปลี่ยนคือบรรทัดเหล่านี้:
kr <- KalmanSmooth(x, fit$model)
y[i] <- kr$smooth[i,]
การจัดการกับข้อสังเกตที่ขาดหายไปโดยวิธีการของตัวกรองคาลมานบางครั้งก็ตีความว่าเป็นการคาดการณ์ของซีรีส์; เมื่อใช้คาลมานอย่างราบรื่นการสังเกตที่หายไปจะถูกเติมด้วยการสอดแทรกในซีรีย์ที่สังเกต
makeARIMA
กำหนดเมทริกซ์ของแบบฟอร์มพื้นที่ของรัฐและฉันจะบอกว่าคอลัมน์ที่ถ่ายโดยid
ถูกต้อง เวกเตอร์ในสมการการสังเกตถูกกำหนดmakeARIMA
เป็น: Z <- c(1, rep.int(0, r - 1L), Delta)
โดยที่Delta
เวกเตอร์ที่มีค่าสัมประสิทธิ์ของตัวกรองที่แตกต่างกัน หากไม่มีตัวกรองที่แตกต่างกัน (เช่นตัวแบบ ARMA length(tmp)==1
) id
ควรเป็น 1 มิฉะนั้นคอลัมน์แรกจะเกี่ยวข้องกับซีรี่ส์ที่แตกต่างในขณะที่องค์ประกอบถัดไปในZ
การรับค่า 1 จะเกี่ยวข้องกับดัชนีที่ควรดำเนินการ
นี่จะเป็นทางออกของฉัน:
# Take AirPassengers as example
data <- AirPassengers
# Set missing values
data[c(44,45,88,90,111,122,129,130,135,136)] <- NA
missindx <- is.na(data)
arimaModel <- auto.arima(data)
model <- arimaModel$model
#Kalman smoothing
kal <- KalmanSmooth(data, model, nit )
erg <- kal$smooth
for ( i in 1:length(model$Z)) {
erg[,i] = erg[,i] * model$Z[i]
}
karima <-rowSums(erg)
for (i in 1:length(data)) {
if (is.na(data[i])) {
data[i] <- karima[i]
}
}
#Original TimeSeries with imputed values
print(data)
@ Javlacalle:
ขอบคุณสำหรับการโพสต์ของคุณน่าสนใจมาก!
ฉันมีคำถามสองข้อสำหรับวิธีการแก้ปัญหาของคุณหวังว่าคุณสามารถช่วยฉัน:
ทำไมคุณถึงใช้ KalmanRun แทน KalmanSmooth ฉันอ่าน KalmanRun ถือเป็นการคาดการณ์ในขณะที่การประเมินจะราบรื่น
ฉันยังไม่ได้รับส่วนรหัสของคุณ ทำไมคุณไม่ใช้ส่วนประกอบทั้งหมดใน. Z ฉันหมายถึงตัวอย่างเช่น. Z ให้ 1, 0,0,0,0,1, -1 -> 7 ค่า นี่หมายถึง. smooth (ในกรณีของคุณสำหรับรัฐ KalmanRun) ให้คอลัมน์แก่ฉัน 7 คอลัมน์ อย่างที่ฉันเข้าใจคอลัมน์ที่เป็น 1 หรือ -1 เข้าไปในโมเดล
สมมติว่าหมายเลขแถว 5 หายไปใน AirPass จากนั้นฉันจะนำผลรวมของแถว 5 ดังนี้: ฉันจะเพิ่มมูลค่าจากคอลัมน์ 1 (เพราะ Z ให้ 1), ฉันจะไม่เพิ่มคอลัมน์ 2-4 (เพราะ Z บอกว่า 0), ฉันจะเพิ่มคอลัมน์ 5 แล้วฉันจะ เพิ่มค่าลบของคอลัมน์ 7 (เพราะ Z บอกว่า -1)
ทางออกของฉันผิดหรือเปล่า? หรือว่าพวกเขาทั้งสองตกลง คุณสามารถอธิบายให้ฉันฟังเพิ่มเติมได้ไหม?