pytorch-ts

pytorch-ts

概率时间序列预测开源框架

PyTorchTS是一个基于PyTorch的开源时间序列预测框架,利用GluonTS作为后端API。它提供先进的概率模型,支持数据处理和回测。该框架适用于单变量和多变量时间序列预测,安装简便,易于使用。PyTorchTS为数据科学家和研究人员提供了高效的时间序列分析工具。

PyTorchTS时间序列预测深度学习概率模型PyTorchGithub开源项目

PyTorchTS

PyTorchTS 是一个基于 PyTorch 的概率时间序列预测框架,通过使用 GluonTS 作为其后端 API,并用于加载、转换和回测时间序列数据集,提供最先进的 PyTorch 时间序列模型。

安装

$ pip3 install pytorchts

快速入门

这里我们通过 GluonTS README 来突出显示 API 的变化。

import matplotlib.pyplot as plt import pandas as pd import torch from gluonts.dataset.common import ListDataset from gluonts.dataset.util import to_pandas from pts.model.deepar import DeepAREstimator from pts import Trainer

这个简单的例子说明了如何在一些数据上训练模型,然后使用它进行预测。首先,我们需要收集一些数据:在这个例子中,我们将使用提及 AMZN 股票代码的推文数量。

url = "https://raw.githubusercontent.com/numenta/NAB/master/data/realTweets/Twitter_volume_AMZN.csv" df = pd.read_csv(url, header=0, index_col=0, parse_dates=True)

前 100 个数据点如下所示:

df[:100].plot(linewidth=2) plt.grid(which='both') plt.show()

png

现在我们可以为我们的模型准备一个训练数据集。数据集本质上是字典的可迭代集合:每个字典代表一个时间序列,可能还有相关的特征。对于这个例子,我们只有一个条目,由 "start" 字段指定,它是第一个数据点的时间戳,以及包含时间序列数据的 "target" 字段。对于训练,我们将使用截至 2015 年 4 月 5 日午夜的数据。

training_data = ListDataset( [{"start": df.index[0], "target": df.value[:"2015-04-05 00:00:00"]}], freq = "5min" )

预测模型是一个 predictor 对象。获得预测器的一种方法是通过训练相应的估计器。实例化估计器需要指定它将处理的时间序列的频率,以及要预测的时间步数。在我们的例子中,我们使用 5 分钟的数据,所以 freq="5min",我们将训练一个模型来预测下一个小时,所以 prediction_length=12。模型在每个时间点的输入将是大小为 input_size=43 的向量。我们还指定了一些最小的训练选项,特别是在 device 上训练 epoch=10

device = torch.device("cuda" if torch.cuda.is_available() else "cpu") estimator = DeepAREstimator(freq="5min", prediction_length=12, input_size=19, trainer=Trainer(epochs=10, device=device)) predictor = estimator.train(training_data=training_data, num_workers=4)
    45it [00:01, 37.60it/s, avg_epoch_loss=4.64, epoch=0]
    48it [00:01, 39.56it/s, avg_epoch_loss=4.2, epoch=1] 
    45it [00:01, 38.11it/s, avg_epoch_loss=4.1, epoch=2] 
    43it [00:01, 36.29it/s, avg_epoch_loss=4.05, epoch=3]
    44it [00:01, 35.98it/s, avg_epoch_loss=4.03, epoch=4]
    48it [00:01, 39.48it/s, avg_epoch_loss=4.01, epoch=5]
    48it [00:01, 38.65it/s, avg_epoch_loss=4, epoch=6]   
    46it [00:01, 37.12it/s, avg_epoch_loss=3.99, epoch=7]
    48it [00:01, 38.86it/s, avg_epoch_loss=3.98, epoch=8]
    48it [00:01, 39.49it/s, avg_epoch_loss=3.97, epoch=9]

在训练过程中,将显示有关进度的有用信息。要全面了解可用选项,请参阅 DeepAREstimator(或其他估计器)和 Trainer 的源代码。

现在我们准备进行预测:我们将预测 2015 年 4 月 15 日午夜之后的一小时。

test_data = ListDataset( [{"start": df.index[0], "target": df.value[:"2015-04-15 00:00:00"]}], freq = "5min" )
for test_entry, forecast in zip(test_data, predictor.predict(test_data)): to_pandas(test_entry)[-60:].plot(linewidth=2) forecast.plot(color='g', prediction_intervals=[50.0, 90.0]) plt.grid(which='both')

png

请注意,预测结果以概率分布的形式显示:阴影区域分别代表50%和90%的预测区间,以中位数(深绿色线)为中心。

开发

pip install -e .
pytest test

引用

如需引用本仓库:

@software{pytorchgithub, author = {Kashif Rasul}, title = {{P}yTorch{TS}}, url = {https://github.com/zalandoresearch/pytorch-ts}, version = {0.6.x}, year = {2021}, }

科学文章

我们使用此框架实现了以下模型:

@INPROCEEDINGS{rasul2020tempflow, author = {Kashif Rasul and Abdul-Saboor Sheikh and Ingmar Schuster and Urs Bergmann and Roland Vollgraf}, title = {{M}ultivariate {P}robabilistic {T}ime {S}eries {F}orecasting via {C}onditioned {N}ormalizing {F}lows}, year = {2021}, url = {https://openreview.net/forum?id=WiGQBFuVRv}, booktitle = {International Conference on Learning Representations 2021}, }
@InProceedings{pmlr-v139-rasul21a, title = {{A}utoregressive {D}enoising {D}iffusion {M}odels for {M}ultivariate {P}robabilistic {T}ime {S}eries {F}orecasting}, author = {Rasul, Kashif and Seward, Calvin and Schuster, Ingmar and Vollgraf, Roland}, booktitle = {Proceedings of the 38th International Conference on Machine Learning}, pages = {8857--8868}, year = {2021}, editor = {Meila, Marina and Zhang, Tong}, volume = {139}, series = {Proceedings of Machine Learning Research}, month = {18--24 Jul}, publisher = {PMLR}, pdf = {http://proceedings.mlr.press/v139/rasul21a/rasul21a.pdf}, url = {http://proceedings.mlr.press/v139/rasul21a.html}, }
@misc{gouttes2021probabilistic, title={{P}robabilistic {T}ime {S}eries {F}orecasting with {I}mplicit {Q}uantile {N}etworks}, author={Adèle Gouttes and Kashif Rasul and Mateusz Koren and Johannes Stephan and Tofigh Naghibi}, year={2021}, eprint={2107.03743}, archivePrefix={arXiv}, primaryClass={cs.LG} }

编辑推荐精选

音述AI

音述AI

全球首个AI音乐社区

音述AI是全球首个AI音乐社区,致力让每个人都能用音乐表达自我。音述AI提供零门槛AI创作工具,独创GETI法则帮助用户精准定义音乐风格,AI润色功能支持自动优化作品质感。音述AI支持交流讨论、二次创作与价值变现。针对中文用户的语言习惯与文化背景进行专门优化,支持国风融合、C-pop等本土音乐标签,让技术更好地承载人文表达。

QoderWork

QoderWork

阿里Qoder团队推出的桌面端AI智能体

QoderWork 是阿里推出的本地优先桌面 AI 智能体,适配 macOS14+/Windows10+,以自然语言交互实现文件管理、数据分析、AI 视觉生成、浏览器自动化等办公任务,自主拆解执行复杂工作流,数据本地运行零上传,技能市场可无限扩展,是高效的 Agentic 生产力办公助手。

lynote.ai

lynote.ai

一站式搞定所有学习需求

不再被海量信息淹没,开始真正理解知识。Lynote 可摘要 YouTube 视频、PDF、文章等内容。即时创建笔记,检测 AI 内容并下载资料,将您的学习效率提升 10 倍。

AniShort

AniShort

为AI短剧协作而生

专为AI短剧协作而生的AniShort正式发布,深度重构AI短剧全流程生产模式,整合创意策划、制作执行、实时协作、在线审片、资产复用等全链路功能,独创无限画布、双轨并行工业化工作流与Ani智能体助手,集成多款主流AI大模型,破解素材零散、版本混乱、沟通低效等行业痛点,助力3人团队效率提升800%,打造标准化、可追溯的AI短剧量产体系,是AI短剧团队协同创作、提升制作效率的核心工具。

seedancetwo2.0

seedancetwo2.0

能听懂你表达的视频模型

Seedance two是基于seedance2.0的中国大模型,支持图像、视频、音频、文本四种模态输入,表达方式更丰富,生成也更可控。

nano-banana纳米香蕉中文站

nano-banana纳米香蕉中文站

国内直接访问,限时3折

输入简单文字,生成想要的图片,纳米香蕉中文站基于 Google 模型的 AI 图片生成网站,支持文字生图、图生图。官网价格限时3折活动

扣子-AI办公

扣子-AI办公

职场AI,就用扣子

AI办公助手,复杂任务高效处理。办公效率低?扣子空间AI助手支持播客生成、PPT制作、网页开发及报告写作,覆盖科研、商业、舆情等领域的专家Agent 7x24小时响应,生活工作无缝切换,提升50%效率!

堆友

堆友

多风格AI绘画神器

堆友平台由阿里巴巴设计团队创建,作为一款AI驱动的设计工具,专为设计师提供一站式增长服务。功能覆盖海量3D素材、AI绘画、实时渲染以及专业抠图,显著提升设计品质和效率。平台不仅提供工具,还是一个促进创意交流和个人发展的空间,界面友好,适合所有级别的设计师和创意工作者。

图像生成热门AI工具AI图像AI反应堆AI工具箱AI绘画GOAI艺术字堆友相机
码上飞

码上飞

零代码AI应用开发平台

零代码AI应用开发平台,用户只需一句话简单描述需求,AI能自动生成小程序、APP或H5网页应用,无需编写代码。

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

下拉加载更多