基于集合经验模态分解的自适应调度期末水位预测方法转让专利

申请号 : CN201811291046.8

文献号 : CN109376937B

文献日 :

基本信息:

PDF:

法律信息:

相似专利:

发明人 : 王旭雷晓辉王佳王超权锦田雨王浩蔡思雨张城

申请人 : 中国水利水电科学研究院

摘要 :

本发明公开了一种基于自适应集合经验模态分解的调度期末水位预测方法,涉及水库运行调度及水利信息化技术领域。该方法充分考虑了调度期末水位序列的非稳态性,通过使用集合经验模态分解的方法将调度期末水位转化为多组稳态序列,实现了水文序列稳态化,为常规的预报方法提供了最基础的数据条件。另外,利用本发明提供的自适应预报模型进行预报时,是一种滚动预报作业,使得模型实现了实时校正,保证了模型的适应性,为精准预报保证了模型基础。所以,采用本发明提供的方法,建立的预测模型用于调度期末水位预测时,具有较高的精准性。

权利要求 :

1.一种基于集合经验模态分解的自适应调度期末水位预测方法,其特征在于,包括如下步骤:S1,数据预处理:提取一列长度为L连续多调度周期的调度期末水位序列为自变量LS,利用调度初期的初水位L0、t时刻水位Lt和t时刻余留期间的来水量W组成因变量集合X=[L0,Lt,W];

S2,自变量稳态化分解:将自变量LS序列,采用集合经验模态分解的方法分解,生成多组稳态本征模态函数IMF(n)和一组残余序列Res,共同组成自变量组合Y=[IMF(n),Res];

S3,确定预报因子:利用因变量集合X=[L0,Lt,W]与自变量组合Y的相关关系确定预报决策因子,按照如下步骤进行实施:S301,构建备选预报因子集合:将因变量集合X=[L0,Lt,W]中的三个影响因子序列L0、Lt和W,分别以单独,两两、共同的方式组合,共构成七组备选的预报因子集合,分别为F1=[L0]、F2=[Lt]、F3=[W]、F4=[L0,Lt]、F5=[L0,W]、F6=[Lt,W]、F7=[L0,Lt,W];

S302,分别对七组备选的预报因子集合与自变量组合Y=[IMF(n),Res]中每组数据进行相关性分析,得到相关因子;

S303,根据S302得到的相关因子,选取与Y=[IMF(n),Res]中每组序列相关性最大的备选预报因子作为每组自变量的最终预报因子F,完成预报因子的识别工作;

S4,根据每组自变量的最终预报因子构建自适应调度期末水位预报模型;

S5,根据所述预报模型对调度期末水位进行预报,得到自适应调度期末水位预报结果;

S4包括如下步骤:

S401,建立训练样本集:将预报根据样本数据量的大小确定模型训练期长度M和验证期的长度(L-M),由于模型为滚动预报,故预见期的步长为1个时间步长;

S402,建立三层BP人工神经Y=[IMF(n),Res]预测模型:将调度期末期水位序列自变量LS,基于经验模态方法分解出的IMF(n)、Res稳态序列,分别与各自的预报因子F建立n+1个预报模型,根据这些预报模型分别对调度期末期水位序列自变量LS进行预报,得到每组的预报值,分别为IMFf(n)、Resf;

S403,根据预报出来的每层预报值,按照如下公式计算M+1时刻预测的调度周期末的水库水位L(M+1)f:其中,IMFf(j)为第j层本征模态函数分量的预测值,Resf为预测的残余量;

S404,将预报出来L(M+1)f添加到训练样本中,跳至S401,进行下一轮的水位预报,直到完成L时刻的预测,得到L时刻预测的调度周期末的水库水位LLf;

S405,对比预报出的L(M+1)f...LLf与(M+1)到L时刻的调度期末水库水位LS,对其预报效果进行评价;

S406,若评价效果符合设定的阈值,则自适应模型建立完成,该模型用于对未来时段调度期末水库水位进行预报,否则,重新调整BP神经网络的模型参数,重新建模直至模型完成建立;

S303中,通过T检验,选取与Y=[IMF(n),Res]中每组序列相关性最大的备选预报因子作为每组自变量的最终预报因子F。

2.根据权利要求1所述的基于集合经验模态分解的自适应调度期末水位预测方法,其特征在于,S405中,所述对其预报效果进行评价,评价指标包括纳什效率系数、相对误差和合格率;

所述纳什效率系数Nash按照如下公式进行计算:

其中,Lf为预测的调度期末水位, 为实际调度期末水位的均值,Nash越接近1,预报越精准;

所述相对误差MARE按照如下公式进行计算:

其中,N为 的序列长度,MARE越接近0,说明实测与预报值越接近,预报效果越精准,当MARE<20%时,预报效果较好;

所述合格率QR按照如下公式进行计算:

其中,n为合格预报次数;m为预报总次数,当QR>80%时,认为预报效果较好。

说明书 :

基于集合经验模态分解的自适应调度期末水位预测方法

技术领域

[0001] 本发明涉及水库运行调度及水利信息化技术领域,尤其涉及一种基于自适应集合经验模态分解的调度期末水位预测方法。

背景技术

[0002] 调度期末水位是水库调度的重要组成部分,调度期末水位预测对水库调度的余留效益、风险评估等都有重要的意义。水库调度期末水位具有趋势性、周期性和随机性,呈非稳态序列,同时该水位受气候变量、来水量多少、下垫面情况、调度决策者的调度方式等多因素影响,隐藏多种确定性的和不确定性的多层信息,故要准确的预报该水位,需要对多种影响因素进行深入挖掘。
[0003] 当前,对调度期末水位预测方法较少,主要是通过预报径流量,调度规则推求调度期末的水位,或者通过不同的智能优化算法如人工神经网络、支持向量机、线性回归等进行自回归模型预测水位。然而这些智能优化算法是一个黑箱模型,对水位的非稳态识别比较困难,另外,由于这些智能优化算法忽略了水位过程中的水文物理机理,所以,对水位进行自相关分析,会导致预报过拟合,出现失真现象。

发明内容

[0004] 本发明的目的在于提供一种基于自适应集合经验模态分解的调度期末水位预测方法,从而解决现有技术中存在的前述问题。
[0005] 为了实现上述目的,本发明采用的技术方案如下:
[0006] 一种基于集合经验模态分解的自适应调度期末水位预测方法,包括如下步骤:
[0007] S1,数据预处理:提取一列长度为L连续多调度周期的调度期末水位序列为自变量LS,利用调度初期的初水位L0、t时刻水位Lt和t时刻余留期间的来水量W组成因变量集合X=[L0,Lt,W];
[0008] S2,自变量稳态化分解:将自变量LS序列,采用集合经验模态分解的方法分解,生成多组稳态本征模态函数IMF(n)和一组残余序列Res,共同组成自变量组合Y=[IMF(n),Res];
[0009] S3,确定预报因子:利用因变量集合X=[L0,Lt,W]与自变量组合Y的相关关系确定预报决策因子,按照如下步骤进行实施:
[0010] S301,构建备选预报因子集合:将因变量集合X=[L0,Lt,W]中的三个影响因子序列L0、Lt和W,分别以单独,两两、共同的方式组合,共构成七组备选的预报因子集合,分别为F1=[L0]、F2=[Lt]、F3=[W]、F4=[L0,Lt]、F5=[L0,W]、F6=[Lt,W]、F7=[L0,Lt,W];
[0011] S302,分别对七组备选的预报因子集合与自变量组合Y=[IMF(n),Res]中每组数据进行相关性分析,得到相关因子;
[0012] S303,根据S302得到的相关因子,选取与Y=[IMF(n),Res]中每组序列相关性最大的备选预报因子作为每组自变量的最终预报因子F,完成预报因子的识别工作;
[0013] S4,根据每组自变量的最终预报因子构建自适应调度期末水位预报模型;
[0014] S5,根据所述预报模型对调度期末水位进行预报,得到自适应调度期末水位预报结果。
[0015] 优选地,S303中,通过T检验,选取与Y=[IMF(n),Res]中每组序列相关性最大的备选预报因子作为每组自变量的最终预报因子F。
[0016] 优选地,S4包括如下步骤:
[0017] S401,建立训练样本集:将预报根据样本数据量的大小确定模型训练期长度M和验证期的长度(L-M),由于模型为滚动预报,故预见期的步长为1个时间步长;
[0018] S402,建立三层BP人工神经Y=[IMF(n),Res]预测模型:将调度期末期水位序列自变量LS,基于经验模态方法分解出的IMF(n),Res稳态序列,分别与各自的预报因子F建立n+1个预报模型,根据这些预报模型分别对调度期末期水位序列自变量LS进行预报,得到每组的预报值,分别为IMFf(n)、Resf;
[0019] S403,根据预报出来的每层预报值,按照如下公式计算M+1时刻预测的调度周期末的水库水位L(M+1)f:
[0020]
[0021] 其中,IMFf(j)为第j层本征模态函数分量的预测值,Resf为预测的残余量;
[0022] S404,将预报出来L(M+1)f添加到训练样本中,跳至S401,进行下一轮的水位预报,直到完成L时刻的预测,得到L时刻预测的调度周期末的水库水位LLf;
[0023] S405,对比预报出的L(M+1)f...LLf与(M+1)到L时刻的调度期末水库水位LS,对其预报效果进行评价;
[0024] S406,若评价效果符合设定的阈值,则自适应模型建立完成,该模型用于对未来时段调度期末水库水位进行预报,否则,重新调整BP神经网络的模型参数,重新建模直至模型完成建立。
[0025] 优选地,S405中,所述对其预报效果进行评价,评价指标包括纳什效率系数、相对误差和合格率;
[0026] 所述纳什效率系数Nash按照如下公式进行计算:
[0027]
[0028] 其中,Lf为预测的调度期末水位, 为实际调度期末水位的均值,Nash越接近1,预报越精准;
[0029] 所述相对误差MARE按照如下公式进行计算:
[0030]
[0031] 其中,N为 的序列长度,MARE越接近0,说明实测与预报值越接近,预报效果越精准,常认为MARE<20%时,预报效果较好;
[0032] 所述合格率QR按照如下公式进行计算:
[0033]
[0034] 其中,n为合格预报次数;m为预报总次数,当QR>80%时,认为预报效果较好。
[0035] 本发明的有益效果是:本发明实施例提供的基于自适应集合经验模态分解的调度期末水位预测方法,充分考虑了调度期末水位序列的非稳态性,通过使用集合经验模态分解的方法将调度期末水位转化为多组稳态序列,实现了水文序列稳态化,为常规的预报方法提供了最基础的数据条件。另外,利用本发明提供的自适应预报模型进行预报时,是一种滚动预报作业,使得模型实现了实时校正,保证了模型的适应性,为精准预报保证了模型基础。所以,采用本发明提供的方法,建立的预测模型用于调度期末水位预测时,具有较高的精准性。

附图说明

[0036] 图1为本发明提供的基于自适应集合经验模态分解的调度期末水位预测方法流程示意图;
[0037] 图2为本发明采用的集合经验模态分解方法流程示意图;
[0038] 图3为基于集合经验模态分解方法对水位序列进行分解后的序列示意图;
[0039] 图4为自适应调度期末水位预测效果示意图。

具体实施方式

[0040] 为了使本发明的目的、技术方案及优点更加清楚明白,以下结合附图,对本发明进行进一步详细说明。应当理解,此处所描述的具体实施方式仅仅用以解释本发明,并不用于限定本发明。
[0041] 为了解决水位为非稳态序列限制常规预报方法的预报,来水不确定性无法量化的问题。本发明提供了一种自适应集合经验模态分解的调度期末水位预测方法,有效地将调度期末水位稳态化,挖掘了响应其水位的影响因素,显性化和量化了来水不确定性对水库调度期末水位的影响,同时自适应的预报模型,使预报模型保持不断地更新,适应调度期末的水位变化过程,保持模型的稳定性。
[0042] 如图1所示,本发明实施例提供了一种基于集合经验模态分解的自适应调度期末水位预测方法,包括如下步骤:
[0043] S1,数据预处理:提取一列长度为L连续多调度周期的调度期末水位序列为自变量LS,利用调度初期的初水位L0、t时刻水位Lt和t时刻余留期间的来水量W组成因变量集合X=[L0,Lt,W];
[0044] S2,自变量稳态化分解:将自变量LS序列,采用集合经验模态分解的方法分解,生成多组稳态本征模态函数IMF(n)和一组残余序列Res,共同组成自变量组合Y=[IMF(n),Res];
[0045] S3,确定预报因子:利用因变量集合X=[L0,Lt,W]与自变量组合Y的相关关系确定预报决策因子,按照如下步骤进行实施:
[0046] S301,构建备选预报因子集合:将因变量集合X=[L0,Lt,W]中的三个影响因子序列L0、Lt和W,分别以单独,两两、共同的方式组合,共构成七组备选的预报因子集合,分别为F1=[L0]、F2=[Lt]、F3=[W]、F4=[L0,Lt]、F5=[L0,W]、F6=[Lt,W]、F7=[L0,Lt,W];
[0047] S302,分别对七组备选的预报因子集合与自变量组合Y=[IMF(n),Res]中每组数据进行相关性分析,得到相关因子;
[0048] S303,根据S302得到的相关因子,选取与Y=[IMF(n),Res]中每组序列相关性最大的备选预报因子作为每组自变量的最终预报因子F,完成预报因子的识别工作;
[0049] S4,根据每组自变量的最终预报因子构建自适应调度期末水位预报模型,并对构建的模型进行评价,如果预报结果符合设定的阈值,则将构建的模型作为最终预报模型,否则,重新调整BP神经网络的模型参数,重新建模直至模型完成建立;
[0050] S5,根据所述最终预报模型对调度期末水位进行预报,得到调度期末水位预报结果。
[0051] 上述方法中,充分考虑了调度期末水位序列的非稳态性,使用集合经验模态分解的方法将调度期末水位转化为多组稳态序列,实现了水文序列稳态化,为常规的预报方法提供了最基础的数据条件。
[0052] 本发明中,S303中,通过T检验,选取与Y=[IMF(n),Res]中每组序列相关性最大的备选预报因子作为每组自变量的最终预报因子F。
[0053] 本发明的一个优选实施例中,S4可以包括如下步骤:
[0054] S401,建立训练样本集:将预报根据样本数据量的大小确定模型训练期长度M和验证期的长度(L-M),由于模型为滚动预报,故预见期的步长为1个时间步长;
[0055] S402,建立三层BP人工神经Y=[IMF(n),Res]预测模型:将调度期末期水位序列自变量LS,基于经验模态方法分解出的IMF(n),Res稳态序列,分别与各自的预报因子F建立n+1个预报模型,根据这些预报模型分别对调度期末期水位序列自变量LS进行预报,得到每组的预报值,分别为IMFf(n)、Resf;
[0056] S403,根据预报出来的每层预报值,按照如下公式计算M+1时刻预测的调度周期末的水库水位L(M+1)f:
[0057]
[0058] 其中,IMFf(j)为第j层本征模态函数分量的预测值,Resf为预测的残余量;
[0059] S404,将预报出来L(M+1)f添加到训练样本中,跳至S401,进行下一轮的水位预报,直到完成L时刻的预测,得到L时刻预测的调度周期末的水库水位LLf;
[0060] S405,对比预报出的L(M+1)f...LLf与(M+1)到L时刻的调度期末水库水位LS,对其预报效果进行评价;
[0061] S406,若评价效果符合设定的阈值,则自适应模型建立完成,该模型用于对未来时段调度期末水库水位进行预报,否则,重新调整BP神经网络的模型参数,重新建模直至模型完成建立。
[0062] 可见,本发明中,通过一种滚动预报作业的方式建立自适应预报模型,可以使得模型实现实时校正,保证了模型的适应性,为该模型用于未来时段调度期末水库水位精准预报保证了基础。
[0063] 其中,S405中,所述对其预报效果进行评价,评价指标包括纳什效率系数、相对误差和合格率;
[0064] 所述纳什效率系数Nash按照如下公式进行计算:
[0065]
[0066] 其中,Lf为预测的调度期末水位, 为实际调度期末水位的均值,Nash越接近1,预报越精准;
[0067] 所述相对误差MARE按照如下公式进行计算:
[0068]
[0069] 其中,N为 的序列长度,MARE越接近0,说明实测与预报值越接近,预报效果越精准,常认为MARE<20%时,预报效果较好;
[0070] 所述合格率QR按照如下公式进行计算:
[0071]
[0072] 其中,n为合格预报次数;m为预报总次数,当QR>80%时,认为预报效果较好。
[0073] 具体实施例
[0074] 本发明中,选取黄河上游龙羊峡水库的调度期末水位预测过程作为实施例,对本发明内容的效果进行验证,具体采用如下步骤进行实施:
[0075] 步骤1,数据预处理。
[0076] 选用黄河上游龙羊峡水库2010年1月1日~2016年12月31日,调度周期为月的调度期末期水位序列为自变量LS,同期调度周期的调度期初水位L0,实时水位序列Lt和t时刻余留期来水量W组成一系列的因变量集合X=[L0,Lt,W];
[0077] 步骤2,自变量稳态化分解。
[0078] 确定基于自适应集合经验模态分解方法的基本参数:噪声方差(Nstd=0.2)、噪声组数(NE=100)、迭代次数(MaxIter=500),将自变量LS序列,采用集合经验模态分解的方法分解(可参见图2),生成n层稳态本征模态函数IMF(1),IMF(2),...,IMF(n)和1层残余序列Res,每组序列均为离散函数,为不同频率的线性或非线性的序列,共同组成自变量组合Y=[IMF(1),IMF(2),...,IMF(n),Res],具体的关系式如下:
[0079]
[0080] 其中,n为本征模态函数的分量数,IMF(j)为第j层的本征模态序列。
[0081] 在本发明的实施例中,分解黄河上游龙羊峡水库2010年1月1日~2016年12月31日逐日LS,其中,分解后,生成11层从高频到低频的稳态序列,第1层的本征模态序列IMF(1)的结果如图3所示,从图3可以看出,分解的序列为高频的稳态序列作为预报模型的输入。
[0082] 步骤3,确定预报因子。通过因变量集合X=[L0,Lt,W]与自变量Y的相关关系确定预报决策因子,包括以下子步骤:
[0083] (3-1)构建备选预报因子集合。将因变量集合X=[L0,Lt,W]中的三个影响因子序列L0、Lt和W,分别以单独,两两、共同的方式组合,共构成7组备选的预报因子集合,分别为F1=[L0]、F2=[Lt]、F3=[W]、F4=[L0,Lt]、F5=[L0,W]、F6=[Lt,W]、F7=[L0,Lt,W]。
[0084] (3-2)分别分析7组备选的预报因子集合与自变量组合Y=[IMF(n),Res]中每组数据进行相关性分析,按照下式计算相关系数;
[0085]
[0086] 其中,Cov(X,Y)为X与Y的协方差,Var[X]为X的方差,Var[Y]为Y的方差。
[0087] (3-3)设定α=0.025的显著水平,对序列和气象因子的相关系数进行T检验,计算如下式,通过假设检验的因子被认为显著相关。选取与Y=[IMF(n),Res]中每组序列相关性最大的备选预报因子作为每组自变量的最终的预报因子F,完成预报因子的识别工作;
[0088]
[0089] 其中,n为资料样本数,r为皮尔逊相关系数相关系数。
[0090] 步骤4,构建自适应调度期末水位预报模型,按照如下步骤进行实施:
[0091] (4-1)建立训练样本集。将预报根据样本数据量的大小确定模型训练期长度M和验证期的长度(L-M)。由于模型为滚动预报,故预见期的步长为1个时间步长,在本发明实施例中,训练期可以为2010年1月1日~2014年12月31日,验证期可以为2015年1月1日~2016年12月31日。
[0092] (4-2)建立三层BP人工神经Y=[IMF(n),Res]预测模型。包含输入层、隐含层和输出层。设置BP人工神经网络参数。
[0093] 将调度期末期水位序列自变量LS,基于经验模态方法分解出的IMF(n),Res稳态序列,分别与各自的预报因子F建立n+1个预报模型,根据这些预报模型分别对调度期末期水位序列自变量LS进行预报,得到每组的预报值,分别为IMFf(n)、Resf。
[0094] (4-3)根据预报出来的每层预报值计算M+1时刻预测的调度周期末的水库水位L(M+1)f,计算式如下:
[0095]
[0096] 其中IMFf(j)为第j层本征模态函数分量的预测值,Resf为预测的残余量。
[0097] (4-4)将预报出来L(M+1)f添加到训练样本中,跳至步骤(4-1),进行下一轮的水位预报,直到完成L时刻的预测,得到L时刻预测的调度周期末的水库水位LLf。
[0098] (4-5)对比预报出的L(M+1)f...LLf与(M+1)到L时刻的调度期末水库水位LS,对其预报效果进行评价,评价指标有如下三个:
[0099] 纳什效率系数:
[0100]
[0101] 其中,Lf为预测的调度期末水位, 为实际调度期末水位的均值。Nash越接近1,预报越精准。
[0102] 相对误差:
[0103]
[0104] 其中,N为 的序列长度。MARE越接近0,说明实测与预报值越接近,预报效果越精准,常认为MARE<20%时,效果较好。
[0105] 合格率:
[0106]
[0107] 其中,n为合格预报次数;m为预报总次数。当QR>80%时,可认为预报效果较好。
[0108] 在本发明实施例中,模型的预报结果如图4所示,评价结果如下表所示:
[0109]
[0110] (4-6)由图4和上表可以看出,调度期末水位预报效果好,则自适应模型建立完成,即可采用该模型对未来的时段调度期末水库水位进行预报。
[0111] 通过采用本发明公开的上述技术方案,得到了如下有益的效果:本发明实施例提供的基于自适应集合经验模态分解的调度期末水位预测方法,充分考虑了调度期末水位序列的非稳态性,使用集合经验模态分解的方法将调度期末水位转化为多组稳态序列,实现了水文序列稳态化,为常规的预报方法提供了最基础的数据条件。另外,利用本发明提供的自适应预报模型进行预报时,是一种滚动预报作业,使得模型实现了实时校正,保证了模型的适应性,为精准预报保证了模型基础。所以,采用本发明提供的方法,建立的预测模型用于调度期末水位预测时,具有较高的精准性。
[0112] 以上所述仅是本发明的优选实施方式,应当指出,对于本技术领域的普通技术人员来说,在不脱离本发明原理的前提下,还可以做出若干改进和润饰,这些改进和润饰也应视本发明的保护范围。