首页 游戏 软件 资讯 排行榜 专题
首页
AI
【Autoregressive】从0构造一个基于Paddle的自回归模型库

【Autoregressive】从0构造一个基于Paddle的自回归模型库

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

【autoregressive】从0构造一个基于paddle的自回归模型库 - 游乐网

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)=B(q)u(k)+C(o)v(k)

其中:

A(p)y(k)=y(k)+a1y(k1)+a2y(k2)+...+apy(kp)A(p)y(k)=y(k)+a1y(k−1)+a2y(k−2)+...+apy(k−p),B(q)u(k)B(q)u(k)和C(o)v(k)C(o)v(k)类似。yy是因变量uu是自变量vv是扰动项。

特别的,对于最基础的AR模型,可设BB和CC为0,即

A(p)y(k)=0A(p)y(k)=0

A(p)y(k)=y(k)+a1y(k1)+a2y(k2)+...+apy(kp)⇒A(p)y(k)=y(k)+a1y(k−1)+a2y(k−2)+...+apy(k−p)

y(k)=a1y(k1)a2y(k2)...apy(kp)⇒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模型进行任意组网和训练啦~

来源:https://www.php.cn/faq/1410004.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

openclaw在飞书测试报错access not configured.
AI
openclaw在飞书测试报错access not configured.

常见报错解析:“Access Not Configured”故障排除指南 许多开发者和团队成员在使用OpenClaw集成飞书时,都曾遭遇过一个典型的中断提示:“access not configured”(访问未配置)。该提示会明确显示您的飞书账户ID及一组唯一的配对验证码,并指出需要联系机器人所有

热心网友
04.02
OpenClaw 常用指令速查
AI
OpenClaw 常用指令速查

OpenClaw 常用指令大全与使用详解 openclaw status:此命令是查看OpenClaw系统整体健康状态的核心指令,执行后即获取服务运行状况的全面报告,是日常运维的首要诊断工具。 openclaw gateway restart:在修改网关配置后,必须运行此指令以重启网关服务,使配置文

热心网友
04.02
OpenClaw 操控浏览器
AI
OpenClaw 操控浏览器

如何通过 OpenClaw 实现 Chrome 浏览器自动化操控 在软件开发与自动化测试领域,持续学习是常态。本文旨在详细介绍如何利用 OpenClaw 连接并控制一个已开启的 Chrome 浏览器实例,实现点击、文本输入、文件上传、页面滚动、屏幕截图以及执行 JavaScript 等自动化操作。整

热心网友
04.01
# OpenClaw QQ 机器人接入完整指南
AI
# OpenClaw QQ 机器人接入完整指南

项目概述 你是否希望将强大的 AI 助手带入日常聊天?本教程将指导你完成搭建流程,让你能在 QQ 上直接调用 OpenClaw 智能助手,实现无门槛的 AI 对话体验。 架构说明 ┌─────────────┐ ┌──────────────┐ ┌─────────────┐ │ QQ 用户 │ ─

热心网友
04.01
OpenClaw 保姆级 window部署
AI
OpenClaw 保姆级 window部署

一 下载并安装Node js,全程保持默认设置 首先,请前往Node js官方网站的下载中心:https: nodejs org zh-cn download。根据您的操作系统(Windows Mac Linux)下载对应的安装程序。运行安装向导时,整个过程非常简单,您只需连续点击“下一步”按钮

热心网友
04.01

最新APP

火柴人传奇
火柴人传奇
动作冒险 04-01
街球艺术
街球艺术
体育竞技 04-01
飞行员模拟
飞行员模拟
休闲益智 04-01
史莱姆农场
史莱姆农场
休闲益智 04-01
绝区零
绝区零
角色扮演 04-01

热门推荐

《洛克王国世界》星光对决轮椅打法 星光对决怎么打
游戏攻略
《洛克王国世界》星光对决轮椅打法 星光对决怎么打

《洛克王国世界》星光对决平民攻略:手残党也能轻松通关的“轮椅流”阵容打法 在《洛克王国世界》中,星光对决玩法以其较高难度让不少玩家感到棘手。许多玩家都在寻找一套无需复杂操作、容错率高的“轮椅式”打法,以实现稳定通关。本文将为你详细拆解一套经过大量实战验证的平民阵容与傻瓜式流程,即使是操作有限的玩家也

热心网友
04.06
王者荣耀新赛季何时开启
游戏攻略
王者荣耀新赛季何时开启

王者荣耀新赛季开启时间:全网玩家热议的焦点 每当新赛季的号角吹响,峡谷必将迎来一场全面的革新。全新的版本机制、平衡性调整、丰厚的赛季奖励以及紧张刺激的段位重置,共同构成了玩家们每个季度最期待的盛宴。因此,新赛季的具体开启时间,自然成为了所有召唤师最为核心的关注点。 王者荣耀新赛季具体什么时候开始?

热心网友
04.06
《洛克王国世界》地图矿产分布一览
游戏攻略
《洛克王国世界》地图矿产分布一览

《洛克王国世界》地图矿产分布一览:老玩家带你精准挖宝 在《洛克王国世界》中实现资源积累与装备打造,矿石采集是至关重要的经济来源和生存技能。幸运的是,游戏内各大地图板块均蕴藏着丰富且种类各异的矿物资源。然而,对于矿石的具体产出地点、外观特征以及刷新规律,许多新手甚至部分资深探险家依然存在疑惑。 为此,

热心网友
04.06
如何直接打开126邮箱登录链接-126邮箱登录链接怎样直接打开
手机教程
如何直接打开126邮箱登录链接-126邮箱登录链接怎样直接打开

在信息高速流转的今天,电子邮箱已成为我们工作与生活中的核心沟通工具。作为国内领先的邮件服务提供商,126邮箱以其卓越的稳定性、丰富的功能与出色的用户体验,赢得了数亿用户的信赖。本文将为您详细介绍如何快速找到并直接打开126邮箱的官方登录链接,实现一键安全登录,助您高效管理邮件,畅享无缝沟通体验。 一

热心网友
04.06
咕咕三国是什么游戏
游戏攻略
咕咕三国是什么游戏

咕咕三国:深度体验真实三国策略世界的沉浸式手游 提到三国题材,你会联想到哪些经典场景?是谋士运筹帷幄的智慧交锋,还是名将沙场征战的铁血豪情?《咕咕三国》这款策略手游正将这段恢弘历史完美融入游戏世界,不仅再现了那段波澜壮阔的岁月,更为玩家提供了一个可以亲身调度兵马、施展战略的互动平台,让每个人都能在指

热心网友
04.06