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()

现在我们可以为我们的模型准备一个训练数据集。数据集本质上是字典的可迭代集合:每个字典代表一个时间序列,可能还有相关的特征。对于这 个例子,我们只有一个条目,由 "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')

请注意,预测结果以概率分布的形式显示:阴影区域分别代表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} }


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


最适合小白的AI自动化工作流平台
无需编码,轻松生成可复用、可变现的AI自动化工作流

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


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


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


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


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


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


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


最新版Sora2模型免费使用,一键生成无水印视频
最新版Sora2模型免费使用,一键生成无水印视频
最新AI工具、AI资讯
独家AI资源、AI项目落地

微信扫一扫关注公众号