原理+论文+实战:60篇由浅入深的时间序列预测/分类教程汇总_fcanet时序预测-程序员宅基地

技术标签: tensorflow  python  时间序列预测  时间序列分析(Time Series)  时间序列分类  


时间序列预测模型顶会论文资源汇总(2022.04.04更新)

包含时间序列预测,时间序列分类,时间序列异常检测,时空预测,时序推荐等领域的热门模型,以及Transformer应用于时间序列分析的变体和优化。

博文地址:【时序】时间/时空序列分类/预测/异常检测模型顶会论文资源汇总
Github仓库地址:https://github.com/datamonday/TimeSeriesMoonlightBox


教程汇总与源码获取(2021)

发布该篇博客之后,从去年至今收到了很多私信询问如何入门时间序列分析以及源码,今天终于有时间把过去一年中所学习的知识点和踩过的坑做个梳理,仅供参考,并将总结后的教程和源码,放到GitHub。主要包括以下部分:1)Python;2)TensorFlow/Keras;3)时间序列分析入门教程;4)CNN;5)LSTM;6)时序分类;7)时序预测;8)注意力机制。

Github:https://github.com/datamonday/Time-Series-Analysis-Tutorial,欢迎Star,Fork!持续更新中

其它仓库:

  1. PythonTricks:Python进阶知识点总结。
  2. CPP-Learning:C/C++及CS知识点总结。
  3. ROS-Learning:机器人操作系统相关知识总结(Linux + Git + Vim + ROS)。
  4. ML-Algorithm-Source-Code:机器学习常用算法源码实现。
  5. CV-Learning:计算机视觉相关算法及论文总结。
  6. CG-Learning:计算机图形学相关知识总结。
  7. NeuroComputing:神经计算与脑机接口相关知识总结。
  8. EDA-Beginner:电子设计自动化相关知识总结。
  9. FR-AttSys:人脸识别考勤系统设计。
  10. MDRL-Notes:机器学习、深度学习、强化学习算法相关知识总结。

前言

最一段时间都在学习时间序列预测和时间序列分类相关的知识,一开始拿到任务感觉无从下手,论文看不懂,代码不会写。经过近三个月的摸索,也算是入门的小白了,这篇博文算是个人经过踩坑,去粗取精之后的经验总结。通过4篇博客、9篇论文、32篇实战教程,梳理出了一套系统化的时间序列预测和时间序列分类任务的入门指南。文中提及的博客论文和教程全部内容字数大约在50万字到100万字之间。既是对这段时间所学知识的梳理总结,也希望给有需要的同学提供帮助。水平有限,如有问题欢迎指出,谢谢。


适合人群】:

  • 没有时间序列预测/分类相关的经验的小白

代码环境】:

  • python 3.7.6
  • tensorflow 2.1.0

注意事项】:

  • 因为tensorflow 2.0版本开始集成了keras,成为了 tensorflow.keras API,因此不用额外安装,并且无需 import keras

  • 本文提及文章的神经网络编写部分使用Keras深度学习框架。

  • 本文提及文章的所有代码均在Jupyter Notebook中编写,并测试通过。

  • 本文提及的所有文章中,参考资料均在每篇文章的文末给出。


行文顺序】:

  • 原理篇:逻辑顺序

  • 论文篇:时间顺序

  • 实战篇:逻辑顺序+时间顺序

  • 注:本文提及的网络架构、论文、教程都是按照由浅入深介绍的,教程部分(三、实战篇)有些教程是有相互关联的。


主要内容】:时间序列任务分为时间序列预测时间序列分类两种类型,本文主要内容如下:

  • LSTM 及其不同的网络架构处理时间序列预测/分类任务;
  • CNN 及其不同的网络架构处理时间序列预测/分类任务;
  • CNN-LSTM 网络处理时间序列预测/分类任务;
  • ConvLSTM 网络处理时间序列预测/分类任务;
  • DeepConvLSTM 网络处理时间序列分类任务;
  • LSTM-FCN 网络处理时间序列分类任务;
  • Multivariate LSTM-FCNs 网络处理时间序列分类任务


一、原理篇

本部分所有标题都设置了对应文章超链接,直接点击传送。

如果对下文提及的原理比较熟悉,可以直接跳过。


1.1 CNN

1. 零基础入门深度学习(4) - 卷积神经网络

  • 文章日期:2017/08/28
  • 内容梗概:CNN算法原理+数学推导+代码实现

1.2 RNN

2. 零基础入门深度学习(5) - 循环神经网络

  • 文章日期:2017/08/28
  • 内容梗概:RNN算法原理+数学推导+代码实现

1.3 LSTM

3. Understanding LSTM Networks

  • 文章日期:2015/08/27
  • 适合人群:了解LSTM的基本原理。

相信大家看过的很多介绍LSTM原理的文章都用到了这篇文章的配图。比如:
在这里插入图片描述


4. 零基础入门深度学习(6) - 长短时记忆网络(LSTM)

  • 文章日期:2017/08/28
  • 内容梗概:LSTM算法原理+数学推导+代码实现

这三篇文章(本篇+之前同系列两篇)应该是我目前遇到的讲解得最详细最全面思路最清晰的文章,由浅入深,原理+推导+代码,墙裂推荐。


二、论文篇

本部分主要内容:

  • 时间序列分类任务数据集构建(人类活动识别)
  • CNN-LSTM 网络
  • ConvLSTM 网络
  • DeepConvLSTM 网络
  • LSTM-FCN 网络

本部分可以先跳过,直接看实战篇,如果对其中的网络架构有疑问或者有些内容看不懂,再阅读这些论文也可以。


2.1 WISDM 实验室论文

1. Activity Recognition using Cell Phone Accelerometers

WISDM实验室应该是最早开始做基于手机传感器的人类活动识别的实验室,手机的数据只有3个特征(3轴传感器数据)。这篇论文是该实验室的第一篇论文,主要介绍了关于数据集的构建与处理


2. Cell Phone-Based Biometric Identification](https://blog.csdn.net/weixin_39653948/article/details/104566905)

这篇论文是该实验室的第二篇论文,主要介绍了 数据收集以及将时间序列数据转换为样本的过程,值得借鉴。

该实验室还有3篇论文,个人感觉参考意义不大,可以先不看。


2.2 UCI-HAR 数据集论文

1. Human Activity Recognition on Smartphones using a Multiclass Hardware-Friendly SVM

这篇论文是创建该数据集的实验室发表的有关人类活动识别的第一篇论文,主要介绍了使用监督机器学习方法通过手机传感器信号来识别人类活动(6类,分别是站立,行走,放置,行走,上楼和在下楼)进行分类。使用9个特征(6轴传感器+3个分离信号(身体重力加速度))。


2. A Public Domain Dataset for Human Activity Recognition Using Smartphones

这篇论文介绍了 UCI-HAR Dataset数据集是如何创建的,很有借鉴意义,如果做时间序列分类任务的话,是必读论文


2.3 CNN-LSTM 论文

1. Long-term Recurrent Convolutional Networks for Visual Recognition and Description

  • 论文被引:3634
  • 论文年份:2015
  • 论文原文:https://arxiv.org/abs/1411.4389

该论文提出的网络架构最初被称为长期循环卷积网络(LRCN),现在使用“CNN LSTM”来指代使用CNN作为前端的LSTM。该网络架构最初用于生成图像的文本描述的任务。关键是CNN,该CNN在图像分类任务上进行了预训练,使得可以用作字幕生成的特征提取器。


2. Show and Tell: A Neural Image Caption Generator

  • 论文被引:3378
  • 论文年份:2015
  • 论文原文:https://arxiv.org/abs/1411.4555

该论文提出的网络架构用于语音识别和自然语言处理问题,其中CNN用作音频和文本输入数据上的特征提取器,之后输入到LSTM进行进一步处理。

这两篇论文是CNN-LSTM网络家族的开篇之作,是必读论文。


2.4 ConvLSTM 论文

1. Convolutional LSTM Network: A Machine Learning Approach for Precipitation Nowcasting

这篇论文是最先提出 ConvLSTM 网络架构的论文,该论文是用于预测相对短时间内某个地区未来的降雨强度,属于必读论文。


2.5 DeepConvLSTM 论文

1. Deep Convolutional Neural Networks On Multichannel Time Series For Human Activity Recognition

在基准数据集上对所提方法与现有方法的比较进行了广泛的研究。结果表明,该方法是一种很有竞争力的HAR问题求解算法。该论文还研究了CNN的效率,并得出结论:CNN对于在线人类活动识别是足够快的


2. Deep Convolutional and LSTM RNN for Multimodal Wearable Activity Recognition

该论文提出了DeepConvLSTM网络架构:由卷积层和LSTM循环层组成的深度学习框架,它能够自动学习特征表示并对它们的激活之间的时间依赖性进行建模。通过业内的标准的人类活动识别数据集(OPPORTUNITY和Skoda)进行实验,证明此框架适用于可​​穿戴传感器数据的活动识别。属于必读论文。


2.6 LSTM-FCN 论文

1. LSTM Fully Convolutional Networks for Time Series Classification

  • 论文被引:211
  • 论文年份:2017
  • 论文原文:https://arxiv.org/abs/1709.05206

该论文提出的模型在显著地提高全卷积网络性能的同时保证模型大小只有很少的增加,并且几乎不需要对数据集进行预处理。提出的长短期记忆-全卷积网络 (LSTM-FCN) 与其他网络相比,具有最新的性能。利用注意力-长短期记忆-全卷积网络 (ALSTM-FCN),探讨了注意力机制在时间序列分类中的应用。利用注意力机制可以可视化LSTM细胞的决策过程。此外,还提出了微调的方法来提高训练模型的性能。对模型的性能进行了全面的分析,并与其他技术进行了比较。


2. Multivariate LSTM-FCNs for Time Series Classification

  • 论文被引:70
  • 论文年份:2018
  • 论文原文:https://arxiv.org/abs/1801.04503

该论文提出将现有的单变量时间序列分类模型长短期记忆-全卷积网络(LSTM-FCN)和注意力-长短期记忆-全卷积网络(ALSTM-FCN)通过在全卷积块上增加一个压缩和激励块来进一步提高分类精度,从而转化为多变量时间序列分类模型。提出的模型在少量预处理的情况下优于大多数最新模型。所提出的模型能有效地处理各种复杂的多元时间序列分类任务,如活动识别或动作识别。此外,所提出的模型在满足实时要求(小,快),可以部署在内存受限的系统上。


三、实战篇

3.1 时间序列任务 入门篇

本部分不涉及具体的数据集,使用构造的数字序列;目的是通过程序了解网络架构和定义方法。



3.2 时间序列预测 基础篇


3.3 时间序列预测 进阶篇



3.3 时间序列分类 基础篇


3.4 时间序列分类 进阶篇 ( 更新中···)


四. 调参篇


五. 相关论文( 更新中···)

  1. Energy consumption prediction using machine learning a review
  2. Electric Energy Consumption Prediction by Deep Learning with State Explainable Autoencoder
  3. Diffusion Convolutional Recurrent Neural Network: Data-Driven Traffic Forecasting
  4. 【CMU & AWS 2020】Forecasting Big Time Series: Theory and Practice(Part I)
  5. 【CMU & AWS 2020】Forecasting Big Time Series: Theory and Practice(Part II)
  6. A review of data-driven building energy consumption prediction studies
  7. A Comparative Study of Time Series Forecasting Methods for Short T erm Electric Energy Consumption Prediction in Smart Buildings

六. 注意力机制(2020/10/29更新)

  1. Attention Is All You Need(Transformer)
  2. 【Attention】注意力机制简介
  3. 【Attention】注意力机制的直观理解
  4. 【Attention】图解 Attention
  5. 【Attention】注意力机制概述
  6. 【Transformer】How Transformers Work
  7. 【Transformer】图解 Transformer

公众号

欢迎关注公众号,获取更多干货内容!
在这里插入图片描述


以上是三个多月以来对时间序列预测和分类任务的总结,仅供参考。如果给你带来了帮助,请动动手指点个赞;如果对文中内容存疑,欢迎指出交流,谢谢各位人才。

刚开始的时候,无从下手,走了很多弯路。经过这段时间的试错和摸索,算是总结出了一些经验。上文提到的论文,是个人认为帮助比较大的论文,如果在做时间序列预测或分类任务的话最好看一下,理解其中的建模思路和网络架构的优缺点,以便快速上手。

实战篇的代码主要参考澳大利亚博主Jason Brownlee的博客文章,在此表示感谢。博客地址:传送门


版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_39653948/article/details/105571760

智能推荐

蓝凌EIS智慧协同平台saveImg接口存在任意文件上传漏洞_蓝凌eis智慧协同平台文件上传漏洞-程序员宅基地

文章浏览阅读979次。蓝凌智慧协同平台eis集合了非常丰富的模块,满足组织企业在知识、协同、项目管理系统建设等需求。_蓝凌eis智慧协同平台文件上传漏洞

LLaVA-1.5-程序员宅基地

文章浏览阅读193次。与InstructBLIP或Qwen-VL在数亿甚至数十几亿的图像文本配对数据上训练的、专门设计的视觉重新采样器相比,LLaVA用的是最简单的LMM架构设计,只需要在600K个图像-文本对上,训练一个简单的完全连接映射层即可。结果表明,LLaVA-1.5不仅可以使用更少的预训练和指令微调数据,而且还可以利用最简单的架构、学术计算和公共数据集来实现最佳的性能——在12个基准中的11个上取得了SOTA。为了解决这个问题,研究人员建议在VQA问题的末尾,添加一个可以明确输出格式的提示,进而让模型生成简短回答。

ORACLE基本数据类型总结_oracle 数值类型最大值-程序员宅基地

文章浏览阅读442次。2013-08-17 21:04 by 潇湘隐者, 100246 阅读, 5 评论, 收藏, 编辑 ORACLE基本数据类型(亦叫内置数据类型 built-in datatypes)可以按类型分为:字符串类型、数字类型、日期类型、LOB类型、LONG RAW& RAW类型、ROWID & UROWID类型。在讲叙字符串类型前,先要讲一下编码。字符串类型的数据可依编码方式分成_oracle 数值类型最大值

10种机器学习算法_决策树和mlp-程序员宅基地

文章浏览阅读315次。作为数据科学家的实践者,我们必须了解一些通用机器学习的基础知识算法,这将帮助我们解决所遇到的新领域问题。本文对通用机器学习算法进行了简要的阐述,并列举了它们的相关资源,从而帮助你能够快速掌握其中的奥妙。▌1.主成分分析(PCA)/ SVDPCA是一种无监督的方法,用于对由向量组成的数据集的全局属性进行理解。本文分析了数据点的协方差矩阵,以了解哪些维度(大部分情况)/数据点(少数情况)更为重要,即它..._决策树和mlp

桥接模式的实现-程序员宅基地

文章浏览阅读148次。在这个示例中,我们使用std::shared_ptr来管理Implementor对象的生命周期,确保在不再需要时自动释放资源。通过智能指针的使用,我们避免了手动管理内存的复杂性,提高了代码的可靠性和可维护性。希望这个示例能帮助你理解如何使用智能指针来实现桥接模式。当使用智能指针来实现桥接模式时,我们可以利用std::shared_ptr或std::unique_ptr来管理对象的生命周期,确保资源的正确释放。

制造业敏感文件外发不安全?一招解锁更高效的加密方式!-程序员宅基地

文章浏览阅读440次,点赞11次,收藏8次。云盒子在制造业上有丰富的部署经验,在面向制造类企业的重要文件,可以通过审计、授权、文件加密进行多重保护,使得图纸文件、专利技术、采购订单等敏感数据等到有效保护,做到无处可泄,同时安全可靠,也不会对日常工作效率有影响 ,实现真正有效的企业文件保护的目的,达到既防止机密文件外泄和扩散,又支持内部知识积累和文件共享的目的。云盒子的加密方式是通过将本地文件数据上传到云盘进行统一加密存储,而不是对设备加密,通过【本地加密】+【云加密】双重组合下,不管用什么设备打开文件都受到管控,使管理者管理起来能够更高效。

随便推点

计算几何讲义——计算几何中的欧拉定理-程序员宅基地

文章浏览阅读188次。在处理计算几何的问题中,有时候我们会将其看成图论中的graph图,结合我们在图论中学习过的欧拉定理,我们可以通过图形的节点数(v)和边数(e)得到不是那么好求的面数f。 平面图中的欧拉定理: 定理:设G为任意的连通的平面图,则v-e+f=2,v是G的顶点数,e是G的边数,f是G的面数。证明:其实有点类似几何学中的欧拉公式的证明方法,这里采用归纳证明的方法。对m..._怎么证明平面图欧拉定理

c语言中各种括号的作用,C语言中各种类型指针的特性与用法介绍-程序员宅基地

文章浏览阅读750次。C语言中各种类型指针的特性与用法介绍本文主要介绍了C语言中各种类型指针的特性与用法,有需要的朋友可以参考一下!想了解更多相关信息请持续关注我们应届毕业生考试网!指针为什么要区分类型:在同一种编译器环境下,一个指针变量所占用的内存空间是固定的。比如,在16位编译器环境 下,任何一个指针变量都只占用8个字节,并不会随所指向变量的类型而改变。虽然所有的指针都只占8个字节,但不同类型的变量却占不同的字节数..._c语言带括号指针

缅甸文字库 缅甸语字库 缅甸字库算法_0x103c-程序员宅基地

文章浏览阅读9.5k次。字库交流 QQ:2229691219 缅甸语比较特殊、缅甸语有官方和民间之分,二者不同的是编码机制不同,因此这2种缅甸语的字串翻译、处理引擎、字库都是不同的。我们这里只讨论官方语言。 缅文、泰文等婆罗米系文字大多是元音附标文字,一般辅音字母自带默认元音可以发音,真正拼写词句时元音像标点符号一样附标在辅音上下左右的相应位置。由于每个元音位于辅音的具体位置是有自己的规则的,当只书写..._0x103c

Python+django+vue校园二手闲置物品拍卖系统pycharm毕业设计项目推荐_基于python+django+vue实现的校园二手交易平台-程序员宅基地

文章浏览阅读200次。在校园,随着学生数量的增多,存在许多生活和学习物品,许多学习用品经过一学期学习之后往往被闲置,一些出于一时喜欢而购买的物品使用机会少而被闲置,还有一些物品以低廉的价格卖给资源回收站,造成巨大的资源浪费。校园闲置物品拍卖系统使用python技术,MySQL数据库进行开发,系统后台使用django框架进行开发,具有低耦合、高内聚的特点,其中校园用户通过人脸识别的方法增加系统安全性,在闲置物品推荐中,使用协同过滤算法进行商品推荐。系统的开发,帮助高校有效的对闲置物品进行管理,提高了闲置物品销售的效率。_基于python+django+vue实现的校园二手交易平台

【推荐系统论文精读系列】(十)--Wide&Deep Learning for Recommender Systems_引用《wide & deep learning for recommender systems》-程序员宅基地

文章浏览阅读1.1k次,点赞3次,收藏3次。文章目录Wide & Deep Learning for Recommender Systems一、摘要二、介绍三、推荐系统综述四、Wide&Deep学习4.1 Wide部分4.2 Deep部分4.3 联合训练 Wide&Deep ModelPreferenceWide & Deep Learning for Recommender Systems一、摘要具有非线性特征转化能力的广义线性模型被广泛用于大规模的分类和回归问题,对于那些输入数据是极度稀疏的情况下。通过使用交_引用《wide & deep learning for recommender systems》

c++ sleep函数_Linux 多线程应用中如何编写安全的信号处理函数-程序员宅基地

文章浏览阅读171次。关于代码的可重入性,设计开发人员一般只考虑到线程安全,异步信号处理函数的安全却往往被忽略。本文首先介绍如何编写安全的异步信号处理函数;然后举例说明在多线程应用中如何构建模型让异步信号在指定的线程中以同步的方式处理。Linux 多线程应用中编写安全的信号处理函数在开发多线程应用时,开发人员一般都会考虑线程安全,会使用 pthread_mutex 去保护全局变量。如果应用中使用了信号,而且信号的产生不..._linux c++ sleep 不被中断

推荐文章

热门文章

相关标签