循环神经网络案例(2)——利用MATLAB搭建循环神经网络进行厄尔尼诺指数预测

时间序列是按时间顺序组织的数字序列,是数据分析中重要的处理对象之一。时间序列的主要特点是数据获取方式一般具有客观性,能反映某种现象的变化趋势或统计指标,进而预测未来走向,这在本质上也是一个回归预测的问题。长短期记忆网络(LSTM)是一种常用的循环神经网络,适合处理有更长时间跨度的内部记忆,被广泛应用于时间序列分析,能够保持数据的内在持续性,反映数据的细粒度走势,具有良好的预测效果。

一、数据集介绍

厄尔尼诺-南方涛动(ENSO)是影响全球极端气候的重要因子,因此预估ENSO海温在全球变暖下的变化也是预估未来全球变暖下全球极端气候变化的重要因素之一。遗憾的是,最近20年来多次的全球耦合模式比较计划(CMIP)尽管对气候平均态和ENSO本身的模拟都取得了长足的进步,但是对未来增暖情形下ENSO海温异常强度的变化都存在显著的模式间差异。最近CMIP5预估的ENSO海温增强或减弱的模式个数基本相当,模式间的标准差远大于多模式集合平均的结果。因此揭示各模式预估ENSO海温振幅变化存在显著差异的核心物理过程是未来进一步改进模式、提高模式预估可信度的必要途径。
MATLAB自带了enso的数据集,只需要load就可加载:

load enso

加载后,工作区增加了month和pressure两个168*1的数据。我们可以利用plot函数绘制enso的时间序列数据,绘制代码如下:

load enso
figure;plot(month,pressure,'k:',month,pressure,'r*');

运行图像:
在这里插入图片描述

二、通过样条算法进行曲线拟合

通过MATLAB提供的fit函数可以方便进行曲线拟合及预测分析,主要代码如下:

close all;clear all;clc;
rand('seed',10)  %设置随机数种子
%加载数据
load enso
data_x=month;data_y=pressure;
%样条拟合
[res1,res2,res3]=fit(data_x,data_y,'smoothingspline');
%绘图
figure;
subplot(2,1,1)
plot(data_x,data_y,'r*');
hold on;
plot(res1,data_x,data_y);
title(sprintf('样条分析-RMSE=%.2f',res2.rmse));
subplot(2,1,2)
stem(data_x,res3.residuals)
xlabel('Time');ylabel('Error'
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wendy_ya

您的鼓励将是我创作的最大动力~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值