iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Informer时序模型(自定义项目)
  • 471
分享到

Informer时序模型(自定义项目)

python深度学习机器学习 2023-08-31 05:08:47 471人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

开源项目 说明 读完代码解析篇,我们针对开源项目中的模型预测方法做一下介绍。作者在GitHub上给出了模型预测方法以及Q、K图的做法,这里提供下载链接首先,在不更改任何参数的情况下跑完代码,会在项目文

开源项目

说明

  • 读完代码解析篇,我们针对开源项目中的模型预测方法做一下介绍。作者在GitHub上给出了模型预测方法以及Q、K图的做法,这里提供下载链接
  • 首先,在不更改任何参数的情况下跑完代码,会在项目文件夹中生成两个子文件夹
  • checkpoints文件夹中包含训练完成的模型,后缀名为.pth,该模型文件包含完整的模型架构与各层权重,可以通过torch.load函数加载模型
  • results文件夹中包含metrics.npypred.npytrue.npy三个文件,pred.npy表示模型预测值,true.npy表示序列真实值
  • 我们可以先将pred.npytrue.npy文件作图进行对比,观察模型效果
setting = 'infORMer_power data_ftMS_sl96_ll48_pl24_dm512_nh8_el2_dl1_df2048_atprob_fc5_ebtimeF_dtTrue_mxTrue_exp_0'pred = np.load('./results/'+setting+'/pred.npy')true = np.load('./results/'+setting+'/true.npy')print(pred.shape)print(true.shape)import matplotlib.pyplot as pltplt.figure()plt.plot(true[0,:,-1], label='GroundTruth')plt.plot(pred[0,:,-1], label='Prediction')plt.legend()plt.show()

输出:
请添加图片描述

  • 如果想要得到模型对后面时间序列的预测值,有2种方式:
    • 第1种:在PyCharm模型训练之前将参数'--do_predict''store_true'变为'store_false',这样在代码运行完以后results文件夹中会多出一个文件real_prediction.npy,该文件中即是模型预测的序列值。
    • 第2种:在模型训练完以后(在jupyter notebook)中使用exp.predict(setting, True)得到预测值
      输出
      请添加图片描述

在Kaggle上使用

  • 在Kaggle上我们可以使用免费的GPU来训练模型,达到加速效果,这里把作者的代码解析一遍。

下载项目文件

!git clone https://github.com/zhouhaoyi/Informer2020.git!git clone Https://github.com/zhouhaoyi/ETDataset.git!ls

导入包

from utils.tools import dotdictimport matplotlib.pyplot as pltfrom exp.exp_informer import Exp_Informerimport torch

参数传导

  • 这个地方与在pycharm中不一样,请注意!
args = dotdict()args.model = 'informer' # model of experiment, options: [informer, informerstack, informerlight(TBD)]args.data = 'ETTh1' # dataargs.root_path = './ETDataset/ETT-small/' # root path of data fileargs.data_path = 'ETTh1.csv' # data fileargs.features = 'M' # forecasting task, options:[M, S, MS]; M:multivariate predict multivariate, S:univariate predict univariate, MS:multivariate predict univariateargs.target = 'OT' # target feature in S or MS taskargs.freq = 'h' # freq for time features encoding, options:[s:secondly, t:minutely, h:hourly, d:daily, b:business days, w:weekly, m:monthly], you can also use more detailed freq like 15min or 3hargs.checkpoints = './informer_checkpoints' # location of model checkpointsargs.seq_len = 96 # input sequence length of Informer encoderargs.label_len = 48 # start token length of Informer decoderargs.pred_len = 24 # prediction sequence length# Informer decoder input: concat[start token series(label_len), zero padding series(pred_len)]args.enc_in = 7 # encoder input sizeargs.dec_in = 7 # decoder input sizeargs.c_out = 7 # output sizeargs.factor = 5 # probsparse attn factorargs.d_model = 512 # dimension of modelargs.n_heads = 8 # num of headsargs.e_layers = 2 # num of encoder layersargs.d_layers = 1 # num of decoder layersargs.d_ff = 2048 # dimension of fcn in modelargs.dropout = 0.05 # dropoutargs.attn = 'prob' # attention used in encoder, options:[prob, full]args.embed = 'timeF' # time features encoding, options:[timeF, fixed, learned]args.activation = 'gelu' # activationargs.distil = True # whether to use distilling in encoderargs.output_attention = False # whether to output attention in ecoderargs.mix = Trueargs.padding = 0args.freq = 'h'args.batch_size = 32 args.learning_rate = 0.0001args.loss = 'mse'args.lradj = 'type1'args.use_amp = False # whether to use automatic mixed precision trainingargs.num_workers = 0args.itr = 1args.train_epochs = 6args.patience = 3args.des = 'exp'args.use_gpu = True if torch.cuda.is_available() else Falseargs.gpu = 0args.use_multi_gpu = Falseargs.devices = '0,1,2,3'

检查GPU

args.use_gpu = True if torch.cuda.is_available() and args.use_gpu else Falseif args.use_gpu and args.use_multi_gpu:    args.devices = args.devices.replace(' ','')    device_ids = args.devices.split(',')    args.device_ids = [int(id_) for id_ in device_ids]    args.gpu = args.device_ids[0]

定义数据加载

# Set augments by using data namedata_parser = {    'ETTh1':{'data':'ETTh1.csv','T':'OT','M':[7,7,7],'S':[1,1,1],'MS':[7,7,1]},    'ETTh2':{'data':'ETTh2.csv','T':'OT','M':[7,7,7],'S':[1,1,1],'MS':[7,7,1]},    'ETTm1':{'data':'ETTm1.csv','T':'OT','M':[7,7,7],'S':[1,1,1],'MS':[7,7,1]},    'ETTm2':{'data':'ETTm2.csv','T':'OT','M':[7,7,7],'S':[1,1,1],'MS':[7,7,1]},}if args.data in data_parser.keys():    data_info = data_parser[args.data]    args.data_path = data_info['data']    args.target = data_info['T']    args.enc_in, args.dec_in, args.c_out = data_info[args.features]

训练模型

args.detail_freq = args.freqargs.freq = args.freq[-1:]Exp = Exp_Informerfor ii in range(args.itr):    # setting record of experiments    setting = '{}_{}_ft{}_sl{}_ll{}_pl{}_dm{}_nh{}_el{}_dl{}_df{}_at{}_fc{}_eb{}_dt{}_mx{}_{}_{}'.format(args.model, args.data, args.features,                 args.seq_len, args.label_len, args.pred_len,                args.d_model, args.n_heads, args.e_layers, args.d_layers, args.d_ff, args.attn, args.factor, args.embed, args.distil, args.mix, args.des, ii)    # set experiments    exp = Exp(args)        # train    print('>>>>>>>start training : {}>>>>>>>>>>>>>>>>>>>>>>>>>>'.format(setting))    exp.train(setting)        # test    print('>>>>>>>testing : {}<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<<'.format(setting))    exp.test(setting)    torch.cuda.empty_cache()
  • 到这里模型训练完毕

预测

  • 运行完会在results文件夹中生成real_prediction.npy序列预测数据
import ossetting = 'informer_ETTh1_ftM_sl96_ll48_pl24_dm512_nh8_el2_dl1_df2048_atprob_fc5_ebtimeF_dtTrue_mxTrue_exp_0'exp = Exp(args)exp.predict(setting, True)prediction = np.load('./results/'+setting+'/real_prediction.npy')plt.figure()plt.plot(prediction[0,:,-1], label='Prediction')plt.legend()plt.show()

自定义项目

数据处理

  • 首先将数据集放入项目data文件夹中,然后修改'--data''--root_path''--data_path''--data_path'参数。
  • 比如在这里,我使用的是power data.csv数据集(下载链接),那么我的参数应该修改成这样:
parser.add_argument('--data', type=str, default='power data')parser.add_argument('--root_path', type=str, default='./data/')parser.add_argument('--data_path', type=str, default='power data.csv')
  • 然后修改预测类型,这里我使用多变量预测单变量,所以--features参数选择MS;预测的变量名称为总有功功率,所以修改'--target'参数;时间采样为15分钟,所以将'--freq'参数改为t即:
parser.add_argument('--features', type=str, default='MS')parser.add_argument('--target', type=str, default='总有功功率')parser.add_argument('--freq', type=str, default='t')
  • 我想序列长度为192(2天),有标签预测序列长度为96(1天),无标签预测序列长度为48(半天),修改参数'--seq_len''--label_len''--pred_len'为:
parser.add_argument('--seq_len', type=int, default=192)parser.add_argument('--label_len', type=int, default=96)parser.add_argument('--pred_len', type=int, default=48)
  • 接下来跳到数据处理方式data_parser,参照项目原有处理方式进行填写:
data_parser = {'power data':{'data':'power data.csv','T':'总有功功率','M':[5,5,5],'S':[1,1,1],'MS':[5,5,1]},}
  • 找到exp_informer.py文件,_get_data类中data_dict参数,使用Dataset_Custom对数据进行处理,即:
data_dict = {'power data':Dataset_Custom,}
  • 到这里数据处理修改结束

模型参数

  • 这里我希望模型运行结束后生成预测序列文件,所以我将'--do_predict'参数修改为'store_false',即:
parser.add_argument('--do_predict', action='store_false')
  • 其他参数,比如学习率等等,大家可以根据任务要求自行修改,这里我就不再赘述了。

在Kaggle上使用

  • 将项目放在Kaggle上使用GPU加速运算,这里我将基于此数据的Kaggle项目分享给大家,大家可以参照我的项目搭建自己的模型。

来源地址:https://blog.csdn.net/qq_20144897/article/details/127314218

--结束END--

本文标题: Informer时序模型(自定义项目)

本文链接: https://www.lsjlt.com/news/383945.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Informer时序模型(自定义项目)
    开源项目 说明 读完代码解析篇,我们针对开源项目中的模型预测方法做一下介绍。作者在Github上给出了模型预测方法以及Q、K图的做法,这里提供下载链接首先,在不更改任何参数的情况下跑完代码,会在项目文...
    99+
    2023-08-31
    python 深度学习 机器学习
  • Visual Studio自定义项目模版
    以 Visual Studio 2017 为例。在 Visual Studio 中用户项目模版就是我们俗称的自定义项目模版。 用户项目模版位置 在Visual Studio中打开[工...
    99+
    2024-04-02
  • Visual Studio怎么自定义项目模版
    这篇“Visual Studio怎么自定义项目模版”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Visual&nb...
    99+
    2023-07-02
  • VS2019 自定义项目模板的实现方法
    前言: 使用“宇宙最强IDE”开发项目时,都需要根据不同情况选择一个项目模板,来满足开发需求:如下 VS为我们提供了基础的项目模板,但现有项目模板未包含基础功能如:日志输出、审计日...
    99+
    2024-04-02
  • .NET Core自定义项目模板的全过程
    前言: 前面介绍 自定义项目模板 中介绍了一种简单的方式——通过创建项目导出为项目模板方式实现。本次将采用dotenet cil(手脚架)来创建项目模板。 那么,我们首先看下当前do...
    99+
    2024-04-02
  • 怎么在VS2019中自定义一个项目模板
    怎么在VS2019中自定义一个项目模板?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。一、自定义项目模板创建 本次我们来创建一个实现了基础功能的webapi模板 创建自定义的项目...
    99+
    2023-06-14
  • 怎么在C++项目中利用priority_queue自定义排序
    这篇文章给大家介绍怎么在C++项目中利用priority_queue自定义排序,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。首先,无论 priority_queue 中存储的是基础数据类型(int、double 等),...
    99+
    2023-06-06
  • Django怎么自定义模型字段
    在Django中,可以通过继承models.Field类来自定义模型字段。下面是一个简单的示例,展示如何自定义一个名为CustomC...
    99+
    2024-03-01
    Django
  • 怎么在c#项目中自定义MarkupExtension
    这篇文章给大家介绍怎么在c#项目中自定义MarkupExtension,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Markup Extension,顾名思义,就是对xaml的扩展,在XAML中,规定如果属性以{}开始...
    99+
    2023-06-06
  • 如何在Android项目中自定义title
    这篇文章给大家介绍如何在Android项目中自定义title,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。首先编写title的布局文件,title.xml:<xml version="1.0&...
    99+
    2023-05-31
    android roi title
  • Android自定义模拟时钟控件
    本文实例为大家分享了Android自定义模拟时钟控件的具体代码,供大家参考,具体内容如下 自定义view—透明模拟时钟显示 项目中要用到模拟时钟的显示,查了一些资料根据自...
    99+
    2024-04-02
  • SpringBoot项目启动时增加自定义Banner的简单方法
    目录前言制作Banner总结前言 最近有小伙伴推荐给博客启动的时候加上自定义Banner,开始我还不太明白他说的是那部分,后面给我发了这样一个文件,陌溪瞬间就懂了 /////////...
    99+
    2024-04-02
  • 在python中自定义模块时需要注意哪些事项
    在python中自定义模块时需要注意哪些事项?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Python主要用来做什么Python主要应用于:1、Web开发;2、数据科学研究;3...
    99+
    2023-06-14
  • Java项目中如何自定义抽象类
    今天就跟大家聊聊有关Java项目中如何自定义抽象类,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。在面向对象的概念中,所有的对象都是通过类来描绘的,但是反过来,并不是所有的类都是用来描...
    99+
    2023-05-31
    java 抽象类 ava
  • JAVA在项目中怎么自定义异常
    这篇文章主要讲解了“JAVA在项目中怎么自定义异常”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JAVA在项目中怎么自定义异常”吧!JAVA项目中自定义异常1.数据返回处理类@Datapub...
    99+
    2023-06-20
  • 如何在java 8项目中自定义collector
    本篇文章给大家分享的是有关如何在java 8项目中自定义collector,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。需求:将 一个容器List<Bean> 按照...
    99+
    2023-05-31
    java8 collector ava
  • Java 项目中如何实现自定义ArrayList
    本篇文章为大家展示了Java 项目中如何实现自定义ArrayList,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Java 中模仿源码自定义ArrayList最近看了下ArrayList的源码,抽空...
    99+
    2023-05-31
    java 自定义 arraylist
  • 微信小程序自定义模态框
    本文实例为大家分享了微信小程序自定义模态框的具体代码,供大家参考,具体内容如下 效果展示 可在模态框中添加图片输入框 代码展示-wxml <button class="sho...
    99+
    2024-04-02
  • MySQl中如何自定义时间排序
    今天就跟大家聊聊有关MySQl中如何自定义时间排序,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。MySQl时间自定义排序 SELEC...
    99+
    2024-04-02
  • 详解MindSpore自定义模型损失函数
    目录一、技术背景二、MindSpore内置的损失函数三、自定义损失函数四、自定义其他算子五、多层算子的应用六、重定义reduction一、技术背景 损失函数是机器学习中直接决定训练结...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作