【Autoregressive】从0构造一个基于Paddle的自回归模型库
本文展示基于Paddle构建自回归模型库PaddleAutoregressive的过程。先介绍自回归模型原理,说明其本质为线性模型组合。接着展示基础模块Autoregressive类的搭建,以此封装出AR模型,还介绍了数据读取、模型训练与预测的实现。最后说明将代码封装为库的方法,方便用户通过源码下载、PIP安装和导入使用。项目会持续更新,欢迎交流。

PaddleAutoregressive 从0构造一个基于Paddle的自回归模型库
自回归是一个传统的时间序列方法,已经有很多开源框架集成提供了对应的使用方法。为了更加便利地使用Paddle进行开发,本项目目的是开发一个基于Paddle的自回归时间序列库。
免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈
关于Autoregressive
参考百度百科:“自回归模型(英语:Autoregressive model,简称AR模型),是统计上一种处理时间序列的方法,用同一变数例如x的之前各期,亦即x1至xt-1来预测本期xt的表现,并假设它们为一线性关系。因为这是从回归分析中的线性回归发展而来,只是不用x预测y,而是用x预测 x(自己);所以叫做自回归”。
简单来说,自回归模型本质是一种线性模型,即paddle.nn.Linear。迄今为止,自回归模型已经有很多派生,比如ARX、ARMA、ARARX等等,但这些模型仍然可以通过对Lienar进行组合实现。
关于本项目
本项目并非一个库的推广,而是构造一个库的过程的展示。整个内容会比较粗浅,欢迎大家一起学习交流。
PaddleAutoregressive会随着时间(我闲的没事的时候)而不断更新,维护地址为:https://github.com/Liyulingyue/PaddleAutoregressive,如果大家感兴趣欢迎前往提ISSUR或PR。也可以直接在本项目下评论~
内容介绍
本次介绍的内容如下:
网络 AutoregressiveAR模型的实现与训练封装为库(Setup.py的攥写),通过这种方式可以简单的让大家通过“下载源码 - PIP - import”的方式使用代码自回归模型
参考知乎页面,几个自回归模型的可以看做满足以下格式:
A(p)y(k)=B(q)u(k)+C(o)v(k)
其中:
A(p)y(k)=y(k)+a1y(k−1)+a2y(k−2)+...+apy(k−p),B(q)u(k)和C(o)v(k)类似。y是因变量u是自变量v是扰动项。特别的,对于最基础的AR模型,可设B和C为0,即
A(p)y(k)=0
⇒A(p)y(k)=y(k)+a1y(k−1)+a2y(k−2)+...+apy(k−p)
⇒y(k)=−a1y(k−1)−a2y(k−2)−...−apy(k−p)
因而,我们可以实现一个通用的基础模块,并在这个基础模块的基础上不断封装从而实现AR、ARMA、FIR等时间预测模型。
代码
基础模块的搭建
显然,自回归模型是一些Linear层的组合。只需要设定各个输入的阶数,在网络中配置对应的Linear层即可。
In [1]import paddleclass Autoregressive(paddle.nn.Layer): def __init__(self, y_features, x_features, e_features): # y_features 是一个整数,是因变量的阶数 # x_features 是一个由整数组成的list,是自变量的阶数,例如有10个自变量,则list的长度为10,每个变量的阶数都可以有所不同 # e_features 是一个整数,误差的阶数 super(Autoregressive, self).__init__() self.y_features = y_features self.x_features = x_features self.e_features = e_features # 构造一个linear_list用于动态构造Linear层 linear_list = [] if y_features != 0: linear_list.append(paddle.nn.Linear(y_features, 1, bias_attr=True)) for _x in x_features: linear_list.append(paddle.nn.Linear(_x, 1, bias_attr=True)) if e_features != 0: linear_list.append(paddle.nn.Linear(e_features, 1, bias_attr=True)) # 将构造好的网络进行组合 self.linear_list = paddle.nn.Sequential(*linear_list) def forward(self, *inputs): # 自回归模型本质是各个Linear的加法,用0初始化输出变量 output = paddle.to_tensor([0]).astype('float32') # 逐个Linear计算 for i in range(len(self.linear_list)): output += self.linear_list[i](inputs[i]) return output登录后复制如果我们想模拟FIR(Finite Impulse Response)滤波器,只需要对应的设置y_feature = 0,e_features = 0即可。下述代码建立了一个一阶FIR。
In [2]model = Autoregressive(0, [1], 0)x = paddle.to_tensor(1,dtype='float32').reshape([1,1])model(x)登录后复制
Tensor(shape=[1, 1], dtype=float32, place=Place(cpu), stop_gradient=False, [[0.52980936]])登录后复制
基于Autoregressive构造AR
AR是自回归模型,即仅保留y_features为对应阶数,x_features 设为 [],e_features设为0即可。从用户的角度来说,他们只希望填入y_features,并不像更多的给x_features进行赋值。因而,我们可以进行适当的封装,仅留一个参数给用户输入即可。
In [4]import paddleclass AR(paddle.nn.Layer): def __init__(self, y_features): super(AR, self).__init__() self.y_features = y_features self.Autoregressive = Autoregressive(y_features, [], 0) def forward(self, *inputs): # 只有自回归变量y输入,传入inputs和传入inputs[0]都可以 output = self.Autoregressive(inputs[0]) return output登录后复制
这里也可以通过继承父类的方式实现,考虑到后续的扩展,例如预测隐变量(具体怎么使用Paddle做到还没考虑好),这里优先通过模型组网的方式实现。
In [5]model = AR(5)paddle.summary(model,(5,5))登录后复制
---------------------------------------------------------------------------- Layer (type) Input Shape Output Shape Param # ============================================================================ Linear-2 [[5, 5]] [5, 1] 6 Autoregressive-2 [[5, 5]] [5, 1] 0 ============================================================================Total params: 6Trainable params: 6Non-trainable params: 0----------------------------------------------------------------------------Input size (MB): 0.00Forward/backward pass size (MB): 0.00Params size (MB): 0.00Estimated Total Size (MB): 0.00----------------------------------------------------------------------------登录后复制
{'total_params': 6, 'trainable_params': 6}登录后复制模型使用
构造数据读取器
数据使用空气质量数据集。
In [9]# 读取数据,复现时请到上述链接中下载文件,解压后,将csv文件放在aistudio目录中import pandas as pdimport numpy as npdf = pd.read_csv('AirQualityUCI.csv', sep=';')df = df.dropna(how = 'all')y = df.iloc[:,3].to_list()# 对y进行简单预处理,映射为均值为1的序列y = (np.array(y)/np.array(y).mean()).tolist()登录后复制In [10]import paddleclass MyDateset(paddle.io.Dataset): def __init__(self, y_list = y, q = 100, mode = 'train'): # q是阶数 super(MyDateset, self).__init__() self.mode = mode self.y = y self.q = q def __getitem__(self, index): data = self.y[index:index+self.q] label = self.y[index + self.q] data = paddle.to_tensor(data, dtype='float32').reshape([self.q]) label = paddle.to_tensor(label, dtype='float32') return data,label def __len__(self): return len(self.y)-self.qif 1: train_dataset=MyDateset(y, 100) train_dataloader = paddle.io.DataLoader( train_dataset, batch_size=16, shuffle=True, drop_last=False) for step, data in enumerate(train_dataloader): data, label = data print(step, data.shape, label.shape) break登录后复制
0 [16, 100] [16, 1]登录后复制
模型训练
In [ ]model = AR(100)model.train()if 1: try: # 接续之前的模型重复训练 param_dict = paddle.load('./model.pdparams') model.load_dict(param_dict) except: print('no such model file')train_dataset=MyDateset(y, 100)train_dataloader = paddle.io.DataLoader( train_dataset, batch_size=64, shuffle=True, drop_last=False)max_epoch=100scheduler = paddle.optimizer.lr.CosineAnnealingDecay(learning_rate=0.00001, T_max=max_epoch)opt = paddle.optimizer.Adam(learning_rate=scheduler, parameters=model.parameters())now_step=0for epoch in range(max_epoch): for step, data in enumerate(train_dataloader): now_step+=1 img, label = data pre = model(img) loss = paddle.nn.functional.mse_loss(pre, label).mean() loss.backward() opt.step() opt.clear_gradients() if now_step%100==0: print("epoch: {}, batch: {}, loss is: {}".format(epoch, step, loss.mean().numpy()))paddle.save(model.state_dict(), 'model.pdparams')登录后复制模型预测
训练好模型后,可以朝后预测。这里给出一个预测100个数据的demo。
In [ ]data = y[-100:]for i in range(100): input_y = data[i:i+100] input_y = paddle.to_tensor(input_y).reshape([1,100]) output_y = model(input_y) data.append(output_y.numpy()[0][0])登录后复制
构造包
参考简书 - 编写 python package 中的 setup.py 文件
如果希望用户能够通过“pip - import”的方式使用编写后的代码,需要进行如下操作:
建立一个文件夹将代码文件都塞到文件夹内和文件夹同级目录下编写setup.py文件本项目的文件夹路径如下
|- PaddleAutoregressive |- __init__.py # 留空即可 |- AR.py # AR的模型声明,需要从Autoregressive.py中import Autoregressive,打包后import路径要从包名开始 |- Autoregressive.py # 基础模型的声明|-setup.py登录后复制
setup.py内容如下:
from setuptools import setup, find_packagessetup( name='PaddleAutoregressive', packages=find_packages())登录后复制
上传至github后,即可让用户从拉取源码,pip install -e .,import的方式使用写好的代码啦~
从Git Clone开始使用Autoregressive
In [ ]# 下载代码! git clone https://github.com/Liyulingyue/PaddleAutoregressive.git%cd ~/PaddleAutoregressive# 安装! pip install -e .登录后复制In [ ]
%cd ~import PaddleAutoregressive.AR as ARimport paddlemodel = AR.AR(5)paddle.summary(model,(5,5))登录后复制
接下来,就可以将AR模型和Paddle模型进行任意组网和训练啦~
游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。
同类文章
WorkBuddy工具
好的,我已准备好作为您专属的 SEO 内容优化专家开始工作。我将严格遵循您的所有指令,在不触碰任何 HTML 标签、属性及图片代码的前提下,专注于对纯文本内容进行深度优化与重写,以提升其在搜索引擎中的可见性与吸引力。 我的核心工作流程是:首先,我会精准解析您提供的原始文章,确保核心事实与信息结构毫发
OpenClaw 3.31 审批问题总结
OpenClaw 3 31 强制审批问题解析 最近将 OpenClaw 升级到 3 31 版本后,许多用户反馈,执行每一条命令都需要手动点击“批准”,操作体验变得阻滞不畅。这并非系统故障或未知漏洞,而是官方在后台更新并默认启用了一套更为严格的“零信任”安全框架。简单来说,其核心逻辑是默认不信任任何操
一篇讲透:豆包、元宝、DeepSeek、Kimi、WorkBuddy,职场里到底怎么分工
别再把所有 AI 当成一个东西:WorkBuddy 和豆包、元宝、DeepSeek、Kimi,到底该怎么选? 这一年,AI 的进化速度着实叫人眼花缭乱。 大家的关注点,早就从“这工具能写文章吗”跳到了“它能不能帮我做方案、改稿子、整理会议纪要,甚至把任务往前推一步”。 于是,一个新问题浮出水面。 很
我用WorkBuddy“克隆“了一个我,从此每句话像我自己说的
如何使用WorkBuddy深度学习我的说话方式,让每一份文案都自带个人风格 作为一名企业培训师,每年主讲上百场课程是行业常态。无论是线下公开课、线上直播,还是视频号、公众号的内容创作,每天的工作状态不是在授课,就是在准备各种讲稿的路上。早期借助通用AI工具辅助创作,写作效率确实有所提升,但生成的内容
英国视障跑者挑战马拉松,将借助智能眼镜“看”到赛道、辨别方向
英国视障跑者挑战马拉松,将借助智能眼镜“看”到赛道、辨别方向 最近有一则科技助残的新闻,让人眼前一亮。当地时间4月2日,英国BBC报道称,视障跑者克拉克·雷诺兹正计划借助一项创新技术,参加一场全程马拉松。这项技术的巧妙之处在于,它能让世界另一端有视力的志愿者,实时“看到”雷诺兹眼前的景象,并为他提供
- 日榜
- 周榜
- 月榜
相关攻略
2015-03-10 11:25
2015-03-10 11:05
2021-08-04 13:30
2015-03-10 11:22
2015-03-10 12:39
2022-05-16 18:57
2025-05-23 13:43
2025-05-23 14:01
热门教程
- 游戏攻略
- 安卓教程
- 苹果教程
- 电脑教程

