TCN-GRU这个组合模型算是把时间序列预测的两个经典结构玩出了花——时间卷积负责抓局部特征,GRU来捕捉时序依赖关系。咱直接上代码看看核心部分怎么搭的
TCN-GRU基于时间卷积网络-门控循环单元的多变量回归组合预测模型 Matlab语言 可直接运行 1.多输入单输出模型属于个人提出非常新颖但不保证精度组合方式如图2网络结构所示。 GRU也可以换成LSTM或BiLSTMMatlab版本要求2021B及以上。 评价指标包括R2、MSE、RMSE、MAE、MAPE等可完全满足您的需求 2.直接替换Excel数据即可用注释清晰适合新手小白 3.附赠示例数据输入格式如图3所示运行main文件一键出图 4.商品仅包含模型代码价格不包含讲解后可保证运行但程序类商品不支持退换 5.模型只是提供一个衡量数据集精度的方法因此无法保证替换数据就一定得到您满意的结果function layers buildTCN_GRU() numFeatures 5; % 输入特征数 numFilters 64; % 卷积核数量 filterSize 3; % 卷积核尺寸 layers [ sequenceInputLayer(numFeatures) % TCN部分 convolution1dLayer(filterSize, numFilters, Padding, same) layerNormalizationLayer() spatialDropoutLayer(0.05) reluLayer() convolution1dLayer(filterSize, numFilters*2, Padding, same) layerNormalizationLayer() spatialDropoutLayer(0.1) reluLayer() % GRU部分 gruLayer(128, OutputMode,sequence) dropoutLayer(0.2) fullyConnectedLayer(1) regressionLayer() ]; end这段代码最妙的地方在哪儿看那个Paddingsame没这保证了卷积后序列长度不变不会破坏时间步结构。后面的layerNormalization比BatchNorm更适合小样本数据毕竟时间序列数据量通常不大。数据预处理这块示例代码里用了自动化的归一化处理data readmatrix(dataset.xlsx); [~, ~, scaler] normalize(data(:,1:end-1)); % 只归一化特征列 trainData data(1:800,:); testData data(801:end,:);注意输出列最后一列没做归一化这样预测结果反归一化时更方便。不过实际用的时候得根据自己的数据分布调整特别是当输出值范围很大时可能需要单独处理。训练参数设置直接决定了模型收敛速度options trainingOptions(adam, ... MaxEpochs, 150, ... LearnRateSchedule,piecewise, ... LearnRateDropPeriod,50, ... Verbose,false);这个学习率分段策略挺实用前50轮用默认0.001快速下降中期降到0.0001微调最后再降到0.00001。不过遇到震荡严重的情况可能需要加上梯度裁剪。运行完主程序后预测效果可视化做得挺直观TCN-GRU基于时间卷积网络-门控循环单元的多变量回归组合预测模型 Matlab语言 可直接运行 1.多输入单输出模型属于个人提出非常新颖但不保证精度组合方式如图2网络结构所示。 GRU也可以换成LSTM或BiLSTMMatlab版本要求2021B及以上。 评价指标包括R2、MSE、RMSE、MAE、MAPE等可完全满足您的需求 2.直接替换Excel数据即可用注释清晰适合新手小白 3.附赠示例数据输入格式如图3所示运行main文件一键出图 4.商品仅包含模型代码价格不包含讲解后可保证运行但程序类商品不支持退换 5.模型只是提供一个衡量数据集精度的方法因此无法保证替换数据就一定得到您满意的结果!预测对比图左边是真实值和预测值的重叠曲线右边是误差分布直方图。注意看x轴的刻度间隔说明模型在趋势捕捉上表现不错但在极值点预测上还有提升空间。想换LSTM试试直接把代码里的gruLayer换成bilstmLayer(128, OutputMode,sequence)双向结构可能会提升对历史信息的利用不过训练时间也会翻倍。实测某个工业数据集上MAPE从3.2%降到了2.8%但训练时长从15分钟涨到40分钟值不值就得看具体需求了。最后提醒几个新手常见坑Excel数据列顺序必须和模型输入维度对应时间序列数据要提前做好滑窗处理预测步长不要超过训练数据的时间周期遇到NAN值先用movmean做移动平均填充模型虽好但别指望万能。有个用户拿电力负荷数据跑出了0.97的R2换成股票价格预测直接掉到0.3这锅真不能全让模型背。记住数据质量决定上限模型调参只是逼近这个上限而已。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2439413.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!