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} }

编辑推荐精选

Vora

Vora

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

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

Refly.AI

Refly.AI

最适合小白的AI自动化工作流平台

无需编码,轻松生成可复用、可变现的AI自动化工作流

酷表ChatExcel

酷表ChatExcel

大模型驱动的Excel数据处理工具

基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。

AI工具酷表ChatExcelAI智能客服AI营销产品使用教程
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
AIWritePaper论文写作

AIWritePaper论文写作

AI论文写作指导平台

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

AI辅助写作AI工具AI论文工具论文写作智能生成大纲数据安全AI助手热门
博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

AI办公办公工具AI工具博思AIPPTAI生成PPT智能排版海量精品模板AI创作热门
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

下拉加载更多