Я довольно плохо знаком с R. Я попытался прочитать анализ временных рядов и уже закончил
- Анализ временных рядов Шамвея и Стоффера и его приложения, 3-е издание ,
- Отличное прогнозирование Хиндмана : принципы и практика
- Использование R Аврил Коглан для анализа временных рядов
- А. Ян Маклеод и др. Анализ временных рядов с помощью R
- Прикладной анализ временных рядов доктора Марселя Деттлинга
Изменить: я не уверен, как справиться с этим, но я нашел полезный ресурс за пределами перекрестной проверки. Я хотел бы включить это здесь на случай, если кто-нибудь наткнется на этот вопрос.
У меня есть одномерный временной ряд количества потребляемых предметов (данные подсчета), измеряемых ежедневно в течение 7 лет. Вмешательство было применено к исследуемой популяции примерно в середине временного ряда. Ожидается, что это вмешательство не даст немедленного эффекта, а время наступления эффекта по существу неизвестно.
Используя forecast
пакет Hyndman, я приспособил модель ARIMA к использованию данных перед вмешательством auto.arima()
. Но я не уверен, как использовать это соответствие, чтобы ответить, имело ли место статистически значимое изменение тренда, и определить количество.
# for simplification I will aggregate to monthly counts
# I can later generalize any teachings the community supplies
count <- c(2464, 2683, 2426, 2258, 1950, 1548, 1108, 991, 1616, 1809, 1688, 2168, 2226, 2379, 2211, 1925, 1998, 1740, 1305, 924, 1487, 1792, 1485, 1701, 1962, 2896, 2862, 2051, 1776, 1358, 1110, 939, 1446, 1550, 1809, 2370, 2401, 2641, 2301, 1902, 2056, 1798, 1198, 994, 1507, 1604, 1761, 2080, 2069, 2279, 2290, 1758, 1850, 1598, 1032, 916, 1428, 1708, 2067, 2626, 2194, 2046, 1905, 1712, 1672, 1473, 1052, 874, 1358, 1694, 1875, 2220, 2141, 2129, 1920, 1595, 1445, 1308, 1039, 828, 1724, 2045, 1715, 1840)
# for explanatory purposes
# month <- rep(month.name, 7)
# year <- 1999:2005
ts <- ts(count, start(1999, 1))
train_month <- window(ts, start=c(1999,1), end = c(2001,1))
require(forecast)
arima_train <- auto.arima(train_month)
fit_month <- Arima(train_month, order = c(2,0,0), seasonal = c(1,1,0), lambda = 0)
plot(forecast(fit_month, 36)); lines(ts, col="red")
Существуют ли какие-либо ресурсы, специально посвященные анализу прерванных временных рядов в R? Я обнаружил, что это связано с ИТС в SPSS, но я не смог перевести это на R.
источник
Ответы:
Это называется анализом изменений. Пакет R
changepoint
может сделать это для вас: см. Документацию здесь (включая ссылки на литературу): http://www.lancs.ac.uk/~killick/Pub/KillickEckley2011.pdfисточник
Я бы предложил повторить меры иерархической модели. Этот метод должен обеспечить надежные результаты, так как каждый человек будет действовать как его / ее собственный контроль. Попробуйте проверить эту ссылку из UCLA.
источник
Для байесовского подхода вы можете использовать
mcp
для подгонки пуассоновской или биномиальной модели (поскольку у вас есть отсчеты по периодам с фиксированным интервалом) с авторегрессией, примененной к остаткам (в пространстве журнала). Затем сравните двухсегментную модель с односегментной моделью, используя перекрестную проверку.Прежде чем мы начнем, обратите внимание, что для этого набора данных эта модель не подходит, и перекрестная проверка выглядит нестабильной. Поэтому я бы воздержался от использования следующего в сценариях с высокими ставками, но это иллюстрирует общий подход:
Для данного набора данных это приводит к
То есть
elpd_diff/se_diff
соотношение около 7 в пользу нулевой модели (без изменений). Возможные улучшения включают в себя:sin()
илиcos()
.prior = list(cp_1 = dnorm(1999.8, 0.5)
.Подробнее о моделировании авторегрессии, делая сравнение модели и установки Priors на
mcp
сайте . Раскрытие информации: я разработчикmcp
.источник