QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2199|回复: 0
打印 上一主题 下一主题

【回归预测-Lstm预测】基于长短期记忆网络LSTM实现电价时间序列单步预测附matlab代码

[复制链接]
字体大小: 正常 放大
杨利霞        

5273

主题

82

听众

17万

积分

  • TA的每日心情
    开心
    2021-8-11 17:59
  • 签到天数: 17 天

    [LV.4]偶尔看看III

    网络挑战赛参赛者

    网络挑战赛参赛者

    自我介绍
    本人女,毕业于内蒙古科技大学,担任文职专业,毕业专业英语。

    群组2018美赛大象算法课程

    群组2018美赛护航培训课程

    群组2019年 数学中国站长建

    群组2019年数据分析师课程

    群组2018年大象老师国赛优

    跳转到指定楼层
    1#
    发表于 2022-9-8 10:28 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    【回归预测-Lstm预测】基于长短期记忆网络LSTM实现电价时间序列单步预测附matlab代码$ `4 b) J( q' O: l5 m
    ) I. @  M( u) s) m# J6 r" T2 c
    1 内容介绍
    9 P' M) m1 h& i! w1 V​时间序列数据往往反映了某个事件发展的规律,蕴含着丰富的潜在信息。长短期记忆(LSTM)神经网络由于其网络结构的特殊性可以储存信息,解决长期依赖问题,常被用于时间序列预测。对LSTM的研究有利于高效挖掘出时序数据中的重要信息,对社会、经济等各个方面的发展均有着重要的影响。
    0 ?% g8 q4 W1 `" w' b9 U9 P; d; F% V) ?  b
    2 部分代码# r  Q0 v4 Y7 |$ F) Q0 C3 r
    clear, clc, close all;
    8 Y. J. v1 g  e% V. S. s! ?; N$ W4 o% d5 B0 s  w" E* r
    data=xlsread('西班牙电价.csv');- u8 a- }0 i3 U% o8 [' ~0 f
    2 v# e+ L, n) c% ?" k2 }
    data1=data;
    9 C# G% X# I; F+ J2 ~' ?' v3 L8 v# J- ?$ K: O; ?
    numTimeStepsTrain = floor(89);%89数据训练 ,3个用来验证  c) g- b. p/ {2 V# }, g- _( P

    - P" J* t- r; O# fdataTrain = data(1:numTimeStepsTrain+1,;% 训练样本
    7 O8 N( _! @7 C5 p
    , h1 Y- x: x! o# M* ~: W3 B. M3 ~dataTest = data(numTimeStepsTrain:end,; %测试样本 0 i& t4 Z9 v9 ]6 ?* o* w
    0 a3 o1 e+ P) H/ w' V9 x
    %训练数据标准化处理
    - `5 D  n9 \9 O& x. J$ J- \7 u' Q7 N
    mu = mean(dataTrain,'ALL');
    : Y% J, m9 }" o- J( d( z: L2 B4 w# K& z8 `% h9 Q
    sig = std(dataTrain,0,'ALL');
    ! |8 m6 _5 e* l* R4 t3 {* w
    8 R7 s1 q4 X  @) ?" H  a% U, BdataTrainStandardized = (dataTrain - mu) / sig;
    " v9 k; H9 T; ^- L9 [1 x5 A& ?- f) S3 E3 |! {% C
    XTrain = dataTrainStandardized(1:end-1,;% 训练输入 - c9 G: C) \- g
    ) X9 K: D* n& k! x
    YTrain = dataTrainStandardized(2:end,;% 训练输出
    8 C+ B2 X+ N7 b& H6 ?) P- u$ y
    - X+ X+ v; a. z) H' Y/ d%% define the Deeper LSTM networks
    0 _- H" R0 L7 S9 D: l& o1 Q' y. P9 P
    numFeatures= 1;%输入节点
    . A0 G  V8 k. p4 Q$ j
    / s8 C- j6 R( @8 fnumResponses = 1;%输出节点) Q$ w% w- @+ k3 T* P1 j+ i1 z
    , x3 ^& [4 [: ?
    numHiddenUnits = 500;%隐含层神经元节点数 % h9 i( j; E& n7 b6 G

    1 H4 @8 [# Y/ N9 f: Efigure(1)
    & H: B9 F. U2 g, ?: k  R- K7 s
    ' B$ q- b6 k# M" _plot(dataTrain(1:end-1,1));hold on;
    5 B+ w# `5 p- h( l
    - O  b* ]( a( h# h8 N7 K, f' b, lidx = (numTimeStepsTrain)numTimeStepsTrain+numTimeStepsTest1);
    8 S; F* p1 U6 B9 ?! |, i3 K6 ]6 S; |( u+ L  z
    plot(idx,[(data(numTimeStepsTrain,1))' YPred1(1,],'--d');
    6 B: O* H/ i; R! k5 R' _2 ]4 s0 @
    % N) {% j9 A4 Xxlabel("时间/天")) a' v* Q! x/ }
    7 x; _2 n! ]1 x- l  B# t. n
    ylabel("电价")- D2 h8 C! A2 t; e! o) C6 Y% m
    % Q; k4 ]" E* H  r
    legend('实际值','预测值')$ H! V% `/ }4 }( I: {& c; L
    / m& i* s/ ~$ @% S! S
    figure(2)2 w4 R! h1 m7 A4 M3 @& F4 Z3 F; s2 z. }

      C+ A" L# e4 b, E- l8 z- Xsubplot(2,1,1)" ^  F$ D' i. X$ V

    9 |$ F% f" N* L* r) Tplot(YTest(1,)
    ' n" w; W" N; Q/ s: h& e' D2 O
    hold on
    ( w8 S2 T# j4 N# f% C( s
    . |. r8 M4 C9 E- v0 t$ Nplot(YPred(1,,'.-'): ^- o) S. q3 H4 v+ }, H6 A' h

    2 K3 B+ ~9 ^5 r) [9 R7 ihold off
    ; w" s5 E& z) }6 l: y9 I
    ) A/ E4 `& r' Wlegend(["实际值" "预测值"])
    1 Y0 T4 v$ W. m$ ^
    6 q+ b" S) i) J2 h0 \2 b5 mxlabel("时间/天")
    # i' a8 K# u; l# t/ L! K% n! h- l- N* S/ O! g9 g4 E1 Z
    ylabel("电价")0 b: ?, b0 m  b

    % S+ u$ B; g! s1 |4 kylim([5000 20000])( {' }) B2 c2 m% [, W
    / g- e5 @8 L2 q, O; {
    subplot(2,1,2): T/ P( k- p  H$ B: j6 V
    . b: P! Z! l9 D% z4 i% Z
    stem(YPred(1, - YTest(1,)( @; E, o# B7 w

    ! S5 |- T: }% O. A; p! H- Exlabel("时间/天")/ r: }- n3 X) H, Z; e- `" J! m) ~0 @
    " u& a" C% X4 G1 ^" x: m
    ylabel("误差")
    * H  @! j( f+ i  Q& A
    % ]6 j6 e2 O3 q7 J$ ]title("误差百分数 = " + error)
    4 v) E1 s7 C& b0 J
    . j! ]4 e% K$ s* o3 运行结果; `8 w& o$ V0 x/ u8 Z# v4 D: {2 @
    111.png
    & C8 Q7 z; |3 w
    / v+ N! {4 U: y
    . D, D5 b9 r0 H+ e' r
    6 I) n  \$ A, A# z; r, d4 参考文献. A* D& g. C2 B3 q- z" s
    [1]魏昱洲, 许西宁. 基于LSTM长短期记忆网络的超短期风速预测[J]. 电子测量与仪器学报, 2019(2):8.
    , T& q; Z; A* _
    / S4 y- G( d+ o% F" Z1 Y( f9 [! B博主简介:擅长智能优化算法、神经网络预测、信号处理、元胞自动机、图像处理、路径规划、无人机、雷达通信、无线传感器等多种领域的Matlab仿真,相关matlab代码问题可私信交流。
    & R9 i4 K6 p* z部分理论引用网络文献,若有侵权联系博主删除。: r# j/ x+ w2 L4 a- a: F" g
    ————————————————3 `$ m+ D& v5 m0 T# w8 p. Z: ~
    版权声明:本文为CSDN博主「matlab_dingdang」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。/ v( E( Y9 k6 W/ K- D+ Y, W7 ?
    原文链接:https://blog.csdn.net/matlab_dingdang/article/details/126754796
      x! Z: t# ]5 N: I# N9 n' ?  [9 G- X: Y7 p

    # t/ G$ Y8 j7 p( N( u  _

    22.png (19.79 KB, 下载次数: 539)

    22.png

    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2026-4-10 17:03 , Processed in 0.325754 second(s), 54 queries .

    回顶部