本文展示基于Paddle构建自回归模型库PaddleAutoregressive的过程。先介绍自回归模型原理,说明其本质为线性模型组合。接着展示基础模块Autoregressive类的搭建,以此封装出AR模型,还介绍了数据读取、模型训练与预测的实现。最后说明将代码封装为库的方法,方便用户通过源码下载、PIP安装和导入使用。项目会持续更新,欢迎交流。
☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜
自回归是一个传统的时间序列方法,已经有很多开源框架集成提供了对应的使用方法。为了更加便利地使用Paddle进行开发,本项目目的是开发一个基于Paddle的自回归时间序列库。
参考百度百科:“自回归模型(英语: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。也可以直接在本项目下评论~
本次介绍的内容如下:
参考知乎页面,几个自回归模型的可以看做满足以下格式:
A(p)y(k)=B(q)u(k)+C(o)v(k)
其中:
特别的,对于最基础的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]])
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: 6
Trainable params: 6
Non-trainable params: 0
----------------------------------------------------------------------------
Input size (MB): 0.00
Forward/backward pass size (MB): 0.00
Params size (MB): 0.00
Estimated Total Size (MB): 0.00
----------------------------------------------------------------------------
{'total_params': 6, 'trainable_params': 6}
数据使用空气质量数据集。
In [9]# 读取数据,复现时请到上述链接中下载文件,解压后,将csv文件放在aistudio目录中import pandas as pdimport numpy as np
df = 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,
batc
h_size=16,
shuffle=True,
drop_last=False) for step, data in enumerate(train_dataloader):
data, label = data print(step, data.shape, label.shape) break0 [16, 100] [16, 1]
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”的方式使用编写后的代码,需要进行如下操作:
本项目的文件夹路径如下
|- PaddleAutoregressive |- __init__.py # 留空即可 |- AR.py # AR的模型声明,需要从Autoregressive.py中import Autoregressive,打包后import路径要从包名开始 |- Autoregressive.py # 基础模型的声明|-setup.py
setup.py内容如下:
from setuptools import setup, find_packages setup( name='PaddleAutoregressive', packages=find_packages() )
上传至github后,即可让用户从拉取源码,pip install -e .,import的方式使用写好的代码啦~
# 下载代码! git clone https://github.com/Liyulingyue/PaddleAutoregressive.git %cd ~/PaddleAutoregressive# 安装! pip install -e .In [ ]
%cd ~import PaddleAutoregressive.AR as ARimport paddle model = AR.AR(5) paddle.summary(model,(5,5))
接下来,就可以将AR模型和Paddle模型进行任意组网和训练啦~
# python
# git
# ai
# 百度
# csv文件
# cos
# yy
# pip安装
相关栏目:
【
Google疑问12 】
【
Facebook疑问10 】
【
网络优化91478 】
【
技术知识72672 】
【
云计算0 】
【
GEO优化84317 】
【
优选文章0 】
【
营销推广36048 】
【
网络运营41350 】
【
案例网站102563 】
【
AI智能45237 】
相关推荐:
Claude怎么用新功能代码调试_Claude代码调试使用【方法】
Jasper AI如何做SEO优化 Jasper AI结合SurferSEO用法【教程】
DesignGen: 5个AI模型革新服装设计,快速实现创意
谷歌 Nano Banana:免费AI图像生成的强大工具
Gemini怎样写精准提示词_Gemini提示词编写方法【步骤】
Zapier MCP:AI赋能工作流,释放Claude强大潜能
SEO优化利器:利用AI提升标签的关键词密度
MetaGPT:AI驱动的软件开发团队,颠覆传统编码模式
如何用ChatGPT准备面试 模拟面试问答与职场话术练习教程
AI在销售CRM软件中的角色:提升效率和客户互动
医疗专家如何利用课程和内容赋能女性对抗癌症
蚂蚁阿福官方网站入口_网页版在线解读体检报告
如何通过文心一言进行地道的文言文翻译
XRAI Glass:AI赋能的增强现实眼镜,对话新体验
歌曲分析:The Killers乐队的《Mr. Brightside》歌词深度解析
Depseek如何让提示词包含上下文_Depseek上下文补充提示词写法【步骤】
AI写作鱼怎么一键生成论文大纲_AI写作鱼大纲生成与逻辑梳理【技巧】
Canva AI 辅助 KDP 封面设计:轻松创建畅销书笔记本
Shopify着陆页:用AI工具快速提升营销效果
Gamma做年终总结PPT怎么用_Gamma做年终总结PPT使用方法详细指南【教程】
LTX Studio:AI电影制作平台深度评测与应用指南
如何用 ChatGPT 批量处理 Excel 复杂公式
千问怎么设置快捷指令_千问指令创建与一键调用【技巧】
MAKA AI排版怎样设置动画效果_MAKA AI排版动画添加与参数调整【技巧】
稿定设计AI抠图怎样调整透明度_稿定设计AI透明度滑块与渐变设置【攻略】
Vidu AI:使用Q1模型轻松创建电影级短片
2025年最佳AI流程图工具:效率提升秘籍
冷邮件营销新策略:工作坊模式助力B2B销售增长
ChatGPT 提示词工程:结构化指令编写指南
AI数字人教程:轻松打造专属YouTube虚拟形象
ChatGPT一键生成PPT怎么加内容_ChatGPTPPT内容添加【方法】
AI Buildr: 构建 AI 应用的终极指南
利用AI自动化回复Google Voice短信:终极指南
百度ai助手怎么取消 百度ai助手取消显示设置
tofai官网网页版入口 tofai最新网页版登录链接
构建AI工作流:利用BuildShip低代码平台赋能Gemini和Google Cloud
GravityWrite:AI驱动的内容创作,提升排名和效率
n8n:零代码AI自动化平台的终极指南和免费VPS设置
5分钟教你用AI将任何文章改写成儿童易懂版
AI游戏革命:文本驱动,无限可能
Excel Copilot:AI驱动的强大新功能与实用案例解析
百度ai助手悬浮球怎么关 百度ai助手悬浮窗去除方法
利用AI在五分钟内高效生成潜在客户:UpLead深度教程
AI虚拟网红打造指南:轻松制作专属社交媒体形象
钉钉ai划词工具怎样查看划词历史_钉钉ai划词工具历史记录查询【指南】
ChatGPT高级图像编辑教程:黑白转换、裁剪与GIF动画制作
文心一言解读法律条文教程 文心一言专业领域应用
软件工程师必备的AI工具:提升效率的六款利器
零基础玩转千问AI,轻松实现月入万元的最新方法!
AI代码助手的崛起:软件工程的未来展望与实用指南
2025-07-16
南京市珐之弘网络技术有限公司专注海外推广十年,是谷歌推广.Facebook广告全球合作伙伴,我们精英化的技术团队为企业提供谷歌海外推广+外贸网站建设+网站维护运营+Google SEO优化+社交营销为您提供一站式海外营销服务。