Начните с самой прямой динамической сети, которая состоит из сети feedforward с коснувшейся линией задержки во входе. Это называется фокусируемой нейронной сетью с временной задержкой (FTDNN). Это - часть общего класса динамических сетей, названных фокусируемыми сетями, в которых движущие силы появляются только на входном слое статической многоуровневой сети feedforward. Следующая фигура иллюстрирует 2D слой FTDNN.
Эта сеть хорошо подходит для прогноза timeseries. Следующий пример использование FTDNN для предсказания классических временных рядов.
Следующая фигура является графиком нормированных данных об интенсивности, зарегистрированных от Далекого Инфракрасного Лазера в хаотичном состоянии. Это - часть одного из нескольких наборов данных, используемых в Соревновании Временных рядов Санта-Фе [WeGe94]. На соревновании цель состояла в том, чтобы использовать первые 1 000 точек временных рядов, чтобы предсказать следующие 100 точек. Поскольку наша цель состоит в том, чтобы просто проиллюстрировать, как использовать FTDNN в прогнозе, сеть обучена здесь, чтобы выполнить прогнозы "один шаг вперед". (Можно использовать получившуюся сеть в многоступенчатых вперед прогнозах, кормя прогнозами назад вход сети и продолжая выполнять итерации.)
Первый шаг должен загрузить данные, нормировать их и преобразовать их в последовательность времени (представленный массивом ячеек):
y = laser_dataset; y = y(1:600);
Теперь создайте сеть FTDNN, с помощью timedelaynet
команда. Эта команда похожа на feedforwardnet
команда, с дополнительным входом коснувшегося вектора линии задержки (первый вход). В данном примере используйте коснувшуюся линию задержки с задержками от 1 до 8 и используйте десять нейронов в скрытом слое:
ftdnn_net = timedelaynet([1:8],10); ftdnn_net.trainParam.epochs = 1000; ftdnn_net.divideFcn = '';
Расположите сетевые входные параметры и цели для обучения. Поскольку сеть имеет коснувшуюся линию задержки задержка имеющая 8, начните путем предсказания девятого значения временных рядов. Также необходимо загрузить коснувшуюся линию задержки с восемью начальными значениями временных рядов (содержавшийся в переменной Pi
):
p = y(9:end); t = y(9:end); Pi=y(1:8); ftdnn_net = train(ftdnn_net,p,t,Pi);
Заметьте, что вход к сети совпадает с целью. Поскольку сеть имеет минимальную задержку одного временного шага, это означает, что вы выполняете прогноз "один шаг вперед".
Во время обучения появляется следующее учебное окно.
Обучение остановилось, потому что максимальная эпоха была достигнута. Из этого окна можно отобразить ответ сети путем нажатия на Time-Series Response. Следующая фигура появляется.
Теперь симулируйте сеть и определите ошибку прогноза.
yp = ftdnn_net(p,Pi); e = gsubtract(yp,t); rmse = sqrt(mse(e)) rmse = 0.9740
(Обратите внимание на то, что gsubtract
общая функция вычитания, которая может работать с массивами ячеек.) Этот результат намного лучше, чем вы, возможно, получили использование линейного предиктора. Можно проверить это со следующими командами, которые проектируют линейный фильтр с тем же коснувшимся входом линии задержки как предыдущий FTDNN.
lin_net = linearlayer([1:8]); lin_net.trainFcn='trainlm'; [lin_net,tr] = train(lin_net,p,t,Pi); lin_yp = lin_net(p,Pi); lin_e = gsubtract(lin_yp,t); lin_rmse = sqrt(mse(lin_e)) lin_rmse = 21.1386
rms
ошибка 21.1386 для линейного предиктора, но 0.9740 для нелинейного предиктора FTDNN.
Одна хорошая функция FTDNN - то, что он не требует, чтобы динамическая обратная связь вычислила сетевой градиент. Это вызвано тем, что коснувшаяся линия задержки появляется только во входе сети и не содержит обратной связи или корректируемых параметров. Поэтому вы найдете, что эта сеть обучается быстрее, чем другие динамические сети.
Если у вас есть приложение для динамической сети, попробуйте линейную сеть сначала (linearlayer
) и затем FTDNN (timedelaynet
). Если никакая сеть не является удовлетворительной, попробуйте одну из более комплексных динамических сетей, обсужденных в остатке от этой темы.
Каждый раз нейронная сеть обучена, может привести к различному решению из-за различного начального веса и сместить значения и различные деления данных в обучение, валидацию и наборы тестов. В результате различные нейронные сети, обученные на той же проблеме, могут дать различные выходные параметры для того же входа. Чтобы гарантировать, что нейронная сеть хорошей точности была найдена, переобучайтесь несколько раз.
Существует несколько других методов для того, чтобы улучшить начальные решения, если более высокая точность желаема. Для получения дополнительной информации смотрите, Улучшают Мелкое Обобщение Нейронной сети и Стараются не Сверхсоответствовать.
Вы заметите в последнем разделе, что для динамических сетей существует существенное количество подготовки данных, которая требуется перед обучением или симуляцией сети. Это вызвано тем, что коснувшиеся линии задержки в сетевой потребности быть заполненным начальными условиями, который требует, чтобы часть исходного набора данных была удалена и переключена. Существует функция тулбокса, которая упрощает подготовку данных для динамического (временные ряды) сети - preparets
. Например, следующие линии:
p = y(9:end); t = y(9:end); Pi = y(1:8);
может быть заменен
[p,Pi,Ai,t] = preparets(ftdnn_net,y,y);
preparets
функционируйте использует сетевой объект, чтобы определить, как заполнить коснувшиеся линии задержки начальными условиями, и как сдвинуть данные, чтобы создать правильные входные параметры и цели, чтобы использовать в обучении или симуляции сети. Общая форма для вызова preparets
[X,Xi,Ai,T,EW,shift] = preparets(net,inputs,targets,feedback,EW)
Входные параметры для preparets
сетевой объект (net
), внешнее (необратная связь) вход к сети (inputs
), цель необратной связи (targets
), цель обратной связи (feedback
), и ошибочные веса (EW
) (см., Обучают Нейронные сети с Ошибочными Весами). Различие между внешним и сигналами обратной связи станет более ясным, когда сеть NARX будет описана в Ряду Времени проектирования Нейронные сети Обратной связи NARX. Для сети FTDNN нет никакого сигнала обратной связи.
Возвращаемые аргументы для preparets
временной сдвиг между сетевыми вводами и выводами (shift
), сетевой вход для обучения и симуляции (X
), начальные входные параметры (Xi
) для загрузки коснувшихся линий задержки для входных весов, начальный слой выходные параметры (Ai
) для загрузки коснувшихся линий задержки для весов слоя, учебные цели (T
), и ошибочные веса (EW
).
Используя preparets избавляет от необходимости вручную переключать входные параметры и цели, и загрузка коснулась линий задержки. Это особенно полезно для более комплексных сетей.