news 2026/6/26 10:09:48

基于带外源输入的非线性自回归网络(NARX)的时间序列预测 NARX时间序列 matlab 代码 注

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
基于带外源输入的非线性自回归网络(NARX)的时间序列预测 NARX时间序列 matlab 代码 注

基于带外源输入的非线性自回归网络(NARX)的时间序列预测 NARX时间序列 matlab 代码 注:暂无Matlab版本要求 -- 推荐 2018B 版本及以上

最近在折腾时间序列预测,发现NARX网络对付非线性数据效果挺有意思。这玩意儿全名叫带外源输入的非线性自回归网络,听着复杂其实跟咱们平时用的循环神经网络有点像,但多了外部变量输入这个buff。

先上段Matlab实战代码热热身:

% 数据准备(假设已有时间序列数据) load engine_data % 自带示例数据集 inputSeries = con2seq(exInput); % 外部输入序列 targetSeries = con2seq(exOutput); % 目标输出序列 % 创建NARX网络 delay = 2; % 延迟阶数 hiddenLayerSize = 10; narxNet = narxnet(1:delay,1:delay,hiddenLayerSize); % 数据预处理 [Xs,Xi,Ai,Ts] = preparets(narxNet,inputSeries,{},targetSeries); % 训练配置 narxNet.divideFcn = 'divideblock'; % 按块划分数据集 narxNet.trainParam.epochs = 100; narxNet.trainParam.min_grad = 1e-5; % 开练! [net,tr] = train(narxNet,Xs,Ts,Xi,Ai); % 预测未来三步 prediction = net(Xs,Xi,Ai);

这里有几个关键点值得唠唠。延迟阶数相当于给网络开了个时间窗口,比如delay=2时网络会同时看t-1和t-2时刻的数据。hiddenLayerSize别设太大,我之前试过设50结果过拟合得亲妈都不认识,10-20层足够应对多数场景。

数据预处理里的preparets函数是个隐藏大佬,自动帮咱们处理输入输出对齐问题。要是自己手动处理时间延迟数据,代码量至少翻三倍。不过要注意输出序列会比输入短delay个点,新手容易在这儿翻车。

训练时强烈推荐用divideblock代替默认的随机划分,时间序列讲究时间连贯性,乱序划分会让模型学了个寂寞。早停法(Epochs设个合理值)也是个防过拟合的利器,毕竟这网络的学习能力堪比黑洞,稍不留神就把噪声都吃进去了。

预测部分有个坑需要注意:当用预测值继续滚动预测时,记得把网络输出重新接入输入层。这里给个多步预测的扩展代码:

% 转成开环网络做多步预测 narxNetClosed = narxNet; narxNetOpen = removedelay(narxNetClosed); [predictionsOpen,xiOpen,aiOpen] = narxNetOpen(Xs,Xi,Ai); % 可视化对比 figure plot(cell2mat([targetSeries; predictionsOpen])) legend('真实值','预测值') title('NARX预测效果')

这个removedelay操作相当于把闭环改成开环,让网络能持续用自己预测的结果作为下一步输入。不过实际用起来会发现预测误差会逐渐累积,所以长期预测还是要配合其他方法。

最后说下数据归一化这个玄学问题。虽然示例代码里没体现,但遇到量纲差异大的输入特征时,建议加上:

% 手动归一化 inputSeries = (inputSeries - mean(inputSeries))./std(inputSeries); targetSeries = (targetSeries - mean(targetSeries))./std(targetSeries);

别完全依赖工具箱自带的归一化,特别是当训练集和测试集分布不一致时,手动控制更靠谱。我上次有个项目没注意这个细节,预测结果直接飞出了银河系。

总的来说NARX网络就像个带记忆的智能漏斗,能把时间信息和外部变量搅和在一起榨出预测规律。不过别指望它通吃所有场景,遇到高频震荡数据还是得上LSTM之类的专业选手。下次有机会再聊聊怎么用NARX网络预测股票走势——当然,亏了别找我(手动狗头)

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/12 17:54:55

HY-MT1.5-7B长文本翻译断裂?上下文拼接优化部署解决方案

HY-MT1.5-7B长文本翻译断裂?上下文拼接优化部署解决方案 1. 背景与问题提出 随着多语言交流需求的快速增长,高质量、低延迟的机器翻译系统成为智能应用的核心组件。腾讯开源的混元翻译大模型 HY-MT1.5 系列,包含 HY-MT1.5-1.8B 和 HY-MT1.5-…

作者头像 李华
网站建设 2026/6/13 2:34:35

HY-MT1.5-1.8B边缘部署实战:IoT设备集成实时翻译功能详细步骤

HY-MT1.5-1.8B边缘部署实战:IoT设备集成实时翻译功能详细步骤 随着物联网(IoT)设备在全球范围内的广泛应用,多语言实时交互需求日益增长。传统云端翻译方案存在延迟高、隐私泄露风险和网络依赖等问题,难以满足边缘场景…

作者头像 李华
网站建设 2026/6/20 0:30:03

HY-MT1.5显存不足怎么办?量化部署方案让1.8B模型跑在4090D

HY-MT1.5显存不足怎么办?量化部署方案让1.8B模型跑在4090D 1. 背景与挑战:大模型翻译的落地瓶颈 随着多语言交流需求的激增,高质量、低延迟的翻译模型成为智能应用的核心组件。腾讯开源的混元翻译大模型 HY-MT1.5 系列,包含 HY-…

作者头像 李华
网站建设 2026/6/25 16:34:26

腾讯混元HY-MT1.5技术架构解析:Decoder-only设计优势

腾讯混元HY-MT1.5技术架构解析:Decoder-only设计优势 1. 引言:翻译大模型的演进与腾讯混元的突破 随着全球化进程加速,高质量、低延迟的机器翻译需求日益增长。传统翻译系统多依赖Encoder-Decoder架构(如Transformer Base&#…

作者头像 李华
网站建设 2026/6/25 17:12:18

ESPIDF 修改Blufi设备名称说明(IDF5-5)

修改 BluFi 设备名称说明 📋 方法概述 通过修改 ESP-IDF 框架中的 BLUFI_DEVICE_NAME 宏定义来更改蓝牙配网时的默认设备名称。 🔍 文件位置 文件路径: ESP-IDF/components/bt/host/bluedroid/api/include/api/esp_blufi.h 或者根据你的 ESP-IDF 安装路径: Windows: …

作者头像 李华
网站建设 2026/6/16 22:20:40

3kw通信电源设计

3kw通信电源设计全套资料,采用全砖模块设计方式,输出48v 60A。包含原理图、PCB、BOM,还有变压器和电感设计。源代码完整,适合相关专业学习参考。以下文章为示例仅供参考! 设计一个3kW的通信电源,尤其是采用…

作者头像 李华