news 2026/5/11 22:10:50

基于带外源输入的非线性自回归网络(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/5/6 1:56:25

HY-MT1.5-7B API接口开发指南:RESTful服务部署步骤

HY-MT1.5-7B API接口开发指南:RESTful服务部署步骤 1. 引言 随着全球化进程的加速,高质量、低延迟的机器翻译能力已成为多语言应用的核心需求。腾讯开源的混元翻译大模型 HY-MT1.5 系列,凭借其卓越的语言理解与生成能力,在多个国…

作者头像 李华
网站建设 2026/5/10 17:33:48

HY-MT1.5-7B长文本翻译断裂?上下文保持部署优化教程

HY-MT1.5-7B长文本翻译断裂?上下文保持部署优化教程 在大模型驱动的自然语言处理时代,高质量、多语言、低延迟的翻译能力成为跨语言应用的核心需求。腾讯开源的混元翻译大模型 HY-MT1.5 系列,凭借其对33种主流语言及5种民族语言/方言的支持&…

作者头像 李华
网站建设 2026/5/1 14:07:02

行业共振:GEO如何驱动垂直领域内容生态的重塑

引言:垂直领域的GEO革命当生成式人工智能逐渐渗透到各行各业,一个不容忽视的趋势是:通用AI平台与垂直领域专业需求之间的鸿沟日益显著。据行业调查,超过70%的专业用户表示,通用生成式AI在其专业领域提供的信息“不够精…

作者头像 李华
网站建设 2026/5/11 1:20:29

Qwen3-VL论文复现:研究生如何用10块钱搞定实验?

Qwen3-VL论文复现:研究生如何用10块钱搞定实验? 1. 为什么选择Qwen3-VL做实验? 作为一名研一学生,当我第一次看到Qwen3-VL论文时就被它的多模态能力吸引了。这个模型不仅能理解图片内容,还能进行视觉问答、图像描述甚…

作者头像 李华
网站建设 2026/5/9 18:24:24

Qwen3-VL多模态入门:没GPU也能学,1块钱起步体验

Qwen3-VL多模态入门:没GPU也能学,1块钱起步体验 引言:为什么选择Qwen3-VL入门多模态AI? 多模态AI是当前最热门的技术方向之一,它能让AI同时理解文字、图片甚至视频。但很多初学者常被两个门槛劝退:一是需…

作者头像 李华
网站建设 2026/5/11 13:30:36

基于自回归整合滑动平均模型(ARIMA)的时间序列预测

基于自回归整合滑动平均模型(ARIMA)的时间序列预测最近在折腾时间序列预测的项目,发现ARIMA这玩意儿虽然老派但确实能打。今天咱们就抛开教科书上的复杂公式,用实际代码和通俗解释聊聊怎么用它做预测。先扔个结论:ARIMA的核心就是三句话——看…

作者头像 李华