首页 > 其他分享 >13-LSTM多步预测-静态模型预测

13-LSTM多步预测-静态模型预测

时间:2023-02-09 00:11:19浏览次数:36  
标签:13 seq 多步 forecasts print values series test LSTM

import pandas as pd
from sklearn.metrics import mean_squared_error
import math
import matplotlib.pyplot as plt
import datetime

def parser(x):
    return datetime.datetime.strptime(x, '%Y/%m/%d')

# 把数据拆分,线性数据变成四个一组的监督型数据
def series_to_supervised(data, n_in=1, n_out=1, dropnan=True):
    n_vars = 1 if type(data) is list else data.shape[1]
    df = pd.DataFrame(data)  # 数据多了行标和列标
    cols, names = [], []
    for i in range(n_in, 0, -1):
        cols.append(df.shift(i))
        names += [('var%d(t-%d)' % (j+1, 1)) for j in range(n_vars)]
    for i in range(0, n_out, 1):
        cols.append(df.shift(-i))
        if i == 0:
            names += [('var%d(t)' % (j+1)) for j in range(n_vars)]
        else:
            names += [('var%d(t+%d)' % (j+1, i)) for j in range(n_vars)]
    agg = pd.concat(cols, axis=1)
    agg.columns = names
    if dropnan:
        agg.dropna(inplace=True)
    return agg

# 拆分训练数据、测试数据
def prepare_data(series, n_test, n_lay, n_seq):
    raw_values = series.values
    raw_values = raw_values.reshape(len(raw_values), 1)
    # 转换成四个一组的监督型数据
    supervised = series_to_supervised(raw_values, n_lay, n_seq)
    supervised_values = supervised.values
    # 前3/4作为训练数据,后1/4作为测试数据
    train, test = supervised_values[:-n_test], supervised_values[-n_test:]
    return train, test

# persistence model预测
# 用上一次观察值作为之后n_seq的预测值
# 其实只是单纯的把上一次的观测值,重复三次写入一个包含三个元素的数组,作为一个包含三个元素的预测结果
def persistence(last_ob, n_seq):
    return [last_ob for i in range(n_seq)]

# 评估persistence model
def make_forecast(train, test, n_lay, n_seq):
    forecasts = []
    for i in range(len(test)):
        x, y = test[i, :n_lay], test[i, n_lay:]
        # 这里的预测其实就是抄上一次的观测值,把观测值变成一个数组列表
        forecast = persistence(x[-1], n_seq)
        forecasts.append(forecast)
    return forecasts

# 预测评估
# 计算预测结果的损失值,把抄写的观测值结果带入运算损失值,输出
def evaluate_forecasts(test, forecasts, n_lag, n_seq):
    for i in range(n_seq):
        actual = test[:, (n_lag + i)]
        predicted = [forecast[i] for forecast in forecasts]
        print('predicted')
        print(predicted)
        rmse = math.sqrt(mean_squared_error(actual, predicted))
        print('t+%d RMSE:%f' % ((i+1), rmse))

def plot_forecasts(series, forecasts, n_test):
    # 原始数据
    plt.plot(series.values)
    # 预测数据
    for i in range(len(forecasts)):
        off_s = len(series) - n_test + i - 1
        off_e = off_s + len(forecasts[i]) + 1
        xaxis = [x for x in range(off_s, off_e)]
        yaxis = [series.values[off_s]] + forecasts[i]
        print('xaxis')
        print(xaxis)
        print('yaxis')
        print(yaxis)
        print('series.values[off_s]')
        print(series.values[off_s])
        plt.plot(xaxis, yaxis, color='red')
    plt.show()

# 默认为False。如果设置squeeze=True则表示如果解析的数据只包含一列,则返回一个Series
series = pd.read_csv('../LSTM系列/Multi-Step LSTM预测1/data_set/shampoo-sales.csv', 
                    header=0, parse_dates=[0], index_col=0, date_parser=parser).squeeze('index')['Sales']


# 一步数据,预测3步
n_lag = 1
n_seq = 3
n_test = 10
train, test = prepare_data(series, n_test, n_lag, n_seq)
print('train data')
print(train)
print('test data')
print(test)
forecasts = make_forecast(train, test, n_lag, n_seq)
print('forecasts')
print(forecasts)
# 没有任何意义,只是为了教你如何进行多步的预测,数据全是根据最后观测值编造的
evaluate_forecasts(test, forecasts, n_lag, n_seq)
plot_forecasts(series, forecasts, n_test + 2)

标签:13,seq,多步,forecasts,print,values,series,test,LSTM
From: https://www.cnblogs.com/lotuslaw/p/17103806.html

相关文章

  • 5-LSTM模型开发
    """长短期记忆网络(LSTM)是一种循环神经网络(RNN)。这种类型的网络的一个好处是它可以学习和记住长序列,并且不依赖于预先指定的窗口滞后观察作为输入。在Keras中,这被称为......
  • 6-完整的LSTM案例
    importpandasaspdimportdatetimefromsklearn.metricsimportmean_squared_errorfromsklearn.preprocessingimportMinMaxScalerfromkeras.modelsimportSequ......
  • 黑苹果升级更新macOS 13 Ventura 问题整理
    原文来源于黑果魏叔官网,转载需注明出处。黑苹果资源下载请搜索:黑果魏叔​更新13发现以下几个问题,(beta1老问题)问题一:把自启软件关了,不然可能导致进系统闪退 问题二:关闭WiF......
  • 【LeeCode】131. 分割回文串
    【题目描述】给你一个字符串 ​​s​​,请你将 ​​s​​ 分割成一些子串,使每个子串都是 回文串 。返回 ​​s​​ 所有可能的分割方案。回文串 是正着读和反着读都......
  • 【CSP201312-4】有趣的数(数位DP)
    problem问题描述试题编号:201312-4试题名称:有趣的数时间限制:1.0s内存限制:256.0MB问题描述:问题描述我们把一个数称为有趣的,当且仅当:1.它的数字只包含0,......
  • 【CSP201312-3】最大的矩形,单调栈
    problem201312-3试题名称:最大的矩形时间限制:1.0s内存限制:256.0MB问题描述:问题描述在横轴上放了n个相邻的矩形,每个矩形的宽度是1,而第i(1≤i≤n)个矩形的高度......
  • 【CSP201312-2】ISBN号码,字符串,简单模拟
    problem试题编号:201312-2试题名称:ISBN号码时间限制:1.0s内存限制:256.0MB问题描述:问题描述每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字、......
  • 【CSP201312-1 】出现次数最多的数,排序后扫描并记录
    problem问题描述给定n个正整数,找出它们中出现次数最多的数。如果这样的数有多个,请输出其中最小的一个。输入格式输入的第一行只有一个正整数n(1≤n≤1000),表......
  • P1138 第 k 小整数
    第k小整数题目描述现有n个正整数,要求出这n个正整数中的第k个最小整数(相同大小的整数只计算一次)。输入格式第一行为n和k;第二行开始为n个正整数的值,整数......
  • 【CCCC】L3-013 非常弹的球 (30分)物理计算
    problemL3-013非常弹的球(30分)刚上高一的森森为了学好物理,买了一个“非常弹”的球。虽然说是非常弹的球,其实也就是一般的弹力球而已。森森玩了一会儿弹力球后突然想到,假......