【论文阅读】Bi-Mamba+: Bidirectional Mamba for Time Series Forecasting

文章目录

    • 概要
    • 阅读
      • 背景知识
      • 引言
        • 创新之处
      • 研究方法
        • 概述
        • 方法部分的核心模块
            • 多尺度打补丁(Multi-Scale Patching)
            • Mamba:全局模式专家
            • Local Window Transformer(LWT):局部变化专家
            • 长短期路由器(Long-Short Router)
            • 预测模块(Forecasting Module)
            • 方法部分的总结
      • 实验和结果部分:
        • 1. 实验设置(Experimental Setup)
        • 2. 基线模型(Baselines)
        • 3. 评价指标(Metrics)
        • 4. 实验结果(Time Series Forecasting Results)
        • 5. 消融实验(Ablation Studies)
        • 6. 内存和速度分析(Memory and Speed Analysis)
      • 实验部分总结:
    • 小结

概要

https://arxiv.org/ pdf/2404.14757
https://github.com/XiongxiaoXu/Mambaformer-in-Time-Series

作者提出了名为Bi-Mamba+的新型时间序列预测模型,这篇论文的目标是解决时间序列预测中的长短期依赖问题。论文指出,传统的时间序列模型在处理长时和短时依赖时存在不足,无法同时有效捕捉全局的长程模式和局部的短程波动。

阅读

背景知识

时间序列预测广泛应用于天气预报、股票预测等领域。论文提到,许多时间序列可以分解为长程的全局模式和短期的局部波动。例如,超级计算机的执行时间可能因网络拥塞而产生极端值,这些局部的短期变化对预测是至关重要的。

举个例子,论文中提到了超级计算机的执行时间,它在长程上呈现出周期性的上升和下降趋势(全局模式),而在短程内可能出现由于网络拥堵而导致的执行时间异常(局部变化)。如果我们只关注其中一种特征,而忽略另一种特征,预测结果将不准确。
在这里插入图片描述

引言

作者提出了一个多尺度的混合模型,称为SST(State Space Transformer),这个模型有两个主要组件:

Mamba模型:这个模块被称为“全局模式专家”,用于从粗粒度的长程时间序列中提取全局模式。
Local Window Transformer(LWT):被称为“局部变化专家”,专注于在精细的短程时间序列中捕捉局部变化。

创新之处

多尺度打补丁方法(Multi-Scale Patching):通过对时间序列数据进行不同尺度的打补丁操作来调整数据的分辨率,使模型能够在不同粒度上进行预测。
长短期路由器:这个模块能动态学习并整合全局模式和局部变化的信息,确保模型能根据时间序列的特征自适应地调整重点。

研究方法

概述

作者在方法部分提出了一个多尺度的混合Mamba-Transformer架构,称为State Space Transformer(SST)。SST模型的核心思想是将时间序列分为长程全局模式和短程局部变化,分别由Mamba模型和Local Window Transformer(LWT)负责处理。为了实现这两者的有效结合,设计了一个长短期路由器来动态调整这两个专家模型的贡献。
在这里插入图片描述

方法部分的核心模块

在这里插入图片描述

多尺度打补丁(Multi-Scale Patching)

由于长程时间序列和短程时间序列在粒度上存在不同,作者引入了“打补丁”的概念来调整时间序列数据的分辨率。具体来说,通过聚合时间步长来形成“补丁”,从而降低或提高时间序列的分辨率。
对于长程时间序列,作者使用较大的补丁长度和较长的步幅,以生成低分辨率的时间序列。这使得模型可以忽略短期波动,专注于捕捉全局模式。
对于短程时间序列,使用较小的补丁长度和较短的步幅,生成高分辨率的时间序列,从而可以捕捉更细微的局部变化。
为什么这一步重要?
多尺度的处理使得模型能够在不同的时间范围内找到最适合的特征,从而更好地进行长短期的区分和分析。

Mamba:全局模式专家

Mamba模型是基于状态空间模型(State Space Models,SSM),专门用于处理长程时间序列中的全局模式。
状态空间模型通过对输入信号进行编码和解码,能够保留长期的相关信息,同时过滤掉短期的噪声。这使得Mamba特别适合用于长程序列的全局模式提取。
核心机制:Mamba依靠其递归机制,通过状态转移矩阵不断更新隐藏状态,保留与全局趋势相关的重要信息。它的复杂度为O(L),即随时间序列的长度线性增加,非常高效。
为什么使用Mamba?
Mamba的优势在于它能够长期保留全局模式,并且复杂度较低,适合处理长时间序列的数据。

Local Window Transformer(LWT):局部变化专家

LWT模型是传统Transformer的一个改进版本,专注于短期时间序列的局部变化。传统的Transformer在处理长时间序列时复杂度较高(O(L^2)),而LWT通过局部窗口机制降低了这种复杂度。
LWT的创新点在于,它使用一个固定大小的滑动窗口,使得每个时刻的输入只会关注局部的几个时间步长,而不是全局信息。这增强了模型对局部变化的敏感性,同时显著降低了计算复杂度。
LWT的复杂度从传统Transformer的O(L^2)降低到了O(wS),其中w是窗口的大小,S是短期时间序列的长度。
为什么使用LWT?
LWT能够专注于短期变化,并且通过窗口机制有效地控制计算成本,适合用于细粒度的短期预测。

长短期路由器(Long-Short Router)

为了将Mamba的长程全局模式和LWT的短程局部变化结合起来,作者设计了一个动态的路由器,称为长短期路由器。这个路由器的主要作用是根据输入时间序列的特点,动态地调整Mamba和LWT的权重,决定两者对预测的贡献。
具体来说,路由器会根据时间序列的输入,生成两个权重值(pL 和 pS),分别代表长程和短程时间序列的贡献比例。然后模型通过这些权重,将Mamba和LWT的输出进行加权平均,得到最终的预测结果。
为什么需要路由器?
不同的时间序列在不同的时间范围内可能需要不同的关注点。通过动态路由器,模型能够自适应地选择最合适的预测策略,从而提高预测的准确性。

预测模块(Forecasting Module)

最后的预测模块将长程时间序列的嵌入(来自Mamba)和短程时间序列的嵌入(来自LWT)进行拼接,并根据路由器的权重加权组合,得到最终的预测值。

方法部分的总结

SST模型通过多尺度打补丁、全局模式专家Mamba、局部变化专家LWT以及长短期路由器,巧妙地结合了长短期时间序列的特点,从而实现了对全局模式和局部变化的综合分析。该模型的核心创新点在于:

Mamba与Transformer的结合:通过让Mamba处理长程全局模式,LWT处理短程局部变化,使模型能同时兼顾两者。
长短期路由器的动态调节:根据输入动态调整模型的关注点,增强了模型的灵活性和泛化能力。

好,我们继续进入**实验和结果(Experiments and Results)**部分,看看作者是如何验证他们的模型的效果以及如何与其他模型进行比较的。

实验和结果部分:

这一部分是论文的核心之一,作者通过一系列实验来验证SST模型在时间序列预测任务中的优越性。实验的目标是展示SST模型在多个数据集上的表现,并与现有的最先进模型(SOTA)进行对比,证明其在准确性、效率和可扩展性方面的优势。

1. 实验设置(Experimental Setup)

作者在实验中使用了七个广泛应用的真实世界数据集,这些数据集涵盖了不同领域的时间序列数据。数据集包括:

  • ETT 数据集(ETTh1、ETTh2、ETTm1、ETTm2):这是电力变压器的历史数据,涵盖了电压、电流、负载等因素。
  • Weather 数据集:包含了气象站每10分钟记录的21种气象变量,如温度、湿度、气压等。
  • ECL 数据集:这是一个电力消耗数据集,提供了321个客户的每小时用电情况。
  • Traffic 数据集:记录了旧金山湾区公路的车流量情况。

通过这些不同类型的数据集,SST模型展示了其在广泛领域中的适用性。
在这里插入图片描述

2. 基线模型(Baselines)

为了评估SST模型的效果,作者将其与几种最先进的时间序列预测模型进行了比较,包括:

  • S-Mamba:这是基于Mamba的时间序列预测模型,主要用于处理长期依赖。
  • iTransformer:一种用于时间序列的Transformer变体,侧重于改进Transformer在序列数据上的性能。
  • PatchTST:基于打补丁技术的Transformer模型,用于处理长时间序列。
  • Crossformer:一种能够跨维度捕捉时间序列依赖性的模型。
  • DLinearFEDformer:用于长时间序列预测的经典深度学习模型。
3. 评价指标(Metrics)

作者使用了两个广泛使用的评估指标来衡量模型的预测效果:

  • MSE(Mean Squared Error,均方误差):MSE越低,说明预测的误差越小,模型的表现越好。
  • MAE(Mean Absolute Error,平均绝对误差):MAE同样用于衡量预测误差,越低越好。
4. 实验结果(Time Series Forecasting Results)

实验结果表明,SST模型在多个数据集上都优于其他最先进的模型,尤其是在长程和短程时间序列的预测上表现得非常出色。

  • SST vs. S-Mamba:SST模型相比于基于Mamba的模型(S-Mamba)在长程和短程预测中表现更加优异,特别是在更长的预测窗口下(例如,未来720步的预测),SST模型在误差方面减少了13%以上。
  • SST vs. iTransformer:与iTransformer相比,SST在多个数据集上都展示了更低的MSE和MAE,说明其在捕捉全局模式和局部变化方面有更好的平衡。
  • 效率和扩展性:SST模型的线性复杂度使得它在处理大规模时间序列时更加高效,且内存占用较低。相比其他模型,如传统的Transformer,SST模型在输入长度大于3000步的情况下依然可以保持良好的扩展性,而其他模型则容易出现内存溢出问题。
5. 消融实验(Ablation Studies)

消融实验的目的是验证SST模型中每个组成部分的重要性。作者进行了以下几种实验:

  • 仅使用Mamba或LWT:实验表明,仅使用Mamba或者LWT时,模型的表现明显不如SST模型,因为它们分别只能捕捉全局模式或局部变化,缺乏对两者的综合处理能力。
  • 去除打补丁机制:去除打补丁机制后,模型在捕捉不同时间尺度上的特征时效果较差,这验证了多尺度打补丁方法在提升预测性能中的关键作用。
  • 去除长短期路由器:如果去掉路由器,模型无法动态调整长程和短程预测的贡献,导致效果下降。

消融实验的结果说明,SST的每个组件(Mamba、LWT、多尺度打补丁、长短期路由器)都是至关重要的,缺少任何一个都会导致性能的下降。

6. 内存和速度分析(Memory and Speed Analysis)

作者还对SST模型在实际应用中的内存使用计算速度进行了分析。结果表明,SST在处理长时间序列时具有良好的扩展性,并且由于其线性复杂度,在内存和计算时间上都显著优于传统的Transformer模型。例如,当时间序列的长度增加到6000步时,SST依然能够正常运行,而传统Transformer模型早在336步时就因内存问题而失败。

实验部分总结:

  • 性能方面:SST模型在多个数据集上的表现优于现有的最先进模型,尤其是在长程和短程预测任务中。通过引入全局模式和局部变化的专家模型,SST能够平衡不同时间尺度上的特征,从而提高预测的准确性。
  • 效率方面:得益于Mamba模型的递归机制和LWT的局部窗口机制,SST在时间序列长度增加时依然保持了较低的复杂度和良好的扩展性。
  • 创新性方面:SST模型通过多尺度打补丁和动态路由器的结合,成功解决了长短期时间序列的异质性问题,展示了其在大规模时间序列预测中的潜力。

小结

提示:这里可以添加总结

例如:

提供先进的推理,复杂的指令,更多的创造力。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/894300.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

pikachu靶场SQL-Inject中的“delete“注入、“http header“注入、盲注、宽字节注入

"delete"注入 抓包发现在留言时有messagehhhh&submitsubmit两个参数,但并未涉及到数据库操作。除此之外,在删除留言时URL中拼接了?id的参数 构造?id59有报错回显 利用报错注入函数来查询数据,有空格编译不通过&#xff0c…

Agent智能体?我们要的到底是什么

What is an agent? ❝ 近年来,大型语言模型(LLM)的能力越来越强,应用范围也越来越广泛,其中一个热门方向就是智能体(Agent)。但在这一切的背后,我们真正追求的是什么?是…

SSM框架学习(七、MyBatis-Plus高级用法:最优化持久层开发)

目录 一、MyBatis-Plus快速入门 1.简介 2.快速入门 二、MyBatis-Plus核心功能 1.基于Mapper接口CRUD (1)Insert 方法 (2)Delete方法 (3)Update 方法 (4)Select方法 2.基于Serv…

解决在Windows中安装tensorflow2.10无法检测到GPU的问题

解决在Windows中安装tensorflow2.10无法检测到GPU的问题 官方给出的Windows本地安装方式 更新显卡驱动到最新。安装anaconda或miniconda作为python环境的管理工具。创建新的环境tf:conda create --name tf python3.9,然后进入改环境:conda …

【学习笔记】理解 C++ 中 reinterpret_cast 和 C 风格类型转换的区别

【学习笔记】理解 C 中 reinterpret_cast 和 C 风格类型转换的区别 在 C 中,类型转换是一个常见的操作,特别是当我们需要在不同类型之间进行数据操作时。本篇笔记将通过两个具体的例子来讨论 reinterpret_cast 和 C 风格的类型转换的区别。 示例 1&…

【uniapp】设置公共样式,实现公共背景等

目录 1、 全局渐变背景色 2.1 创建common目录 2.2 在common下新建style和images等目录 2.3 在style下新建common-style.scss 2.4 common-style输入全局渐变颜色 2.5 引入样式 2.6 业务页面引入 2.7 展示 2、全局字体颜色 2.1 新建base-style.scss文件 2.2 设置base-…

【动手学深度学习】7.6. 残差网络(ResNet)(个人向笔记)

1. ResNet精读论文视频的Introduction部分 深度卷积神经网络好,好在可以叠加很多层,每一层都可以提取不一样的特征但是网络特别深的时候,梯度要么爆炸要么消失,我们能做的就是将参数随机初始化做好,或者是在中间加一些…

ai聊天对话页面-uniapp

流式传输打字机效果,只支持uniapp内使用 ,下载地址 https://download.csdn.net/download/qq_54123885/89899859

Java基于SpringBoot微信小程序的跳蚤市场系统设计与实现(lw+数据库+讲解等)

项目运行截图 技术框架 后端采用SpringBoot框架 Spring Boot 是一个用于快速开发基于 Spring 框架的应用程序的开源框架。它采用约定大于配置的理念,提供了一套默认的配置,让开发者可以更专注于业务逻辑而不是配置文件。Spring Boot 通过自动化配置和约…

WT2003H语音芯片MCU下载方案助力电动车智能化升级:实现多功能语音提示+报警功能

一:产品市场 随着科技的发展,电瓶车在技术革新上也在不断进步,如今许多厂家,都会加入语音提示功能,能在倒车、喇叭、故障时发出语音报警,提示骑行者电量不足、倒车请注意、故障语音提示等;唯创…

微信小程序引入组件教程

1、安装 node.js 下载网址:https://nodejs.org 2.通过 npm 安装 npm init -y npm i vant/weapp -S --production 3、修改 app.json 将 app.json 中的 “style”: “v2” 去除 4、修改 project.config.json 关于修改 project.config.json 的详细内容&#x…

Linux系统重建Grub引导的方法

一、问题出现的原因 在安装双系统时,我们都是先安装Windows系统,再安装Linux系统,这样在启动计算机时,两个系统都可以被引导启动,并在开机界面可以进行选择。这是因为Linux使用的操作系统引导加载器Grub可以引导如Win…

Qt- QSS风格选择器常用属性选择器样式表盒子

1. 风格设置 Qt 提供了 3 种整体风格,使用 QStyleFactory::keys() 来获取 (windowsvista 、Windows 、Fusion) 可以在 main.cpp 中调用 setStyle 方法对应用程序进行全局风格的设置 int main(int argc, char *argv[]) {QApplication a(arg…

Unity中使用Json导入项目无法识别Newtonsoft.Json

Unity导入项目无法识别Newtonsoft.Json 因为项目中用到了JSON解析,所以引入了一个解析类库 using Newtonsoft.Json.Linq; 换了台设备之后,导入这个项目之后,这个引用就标红了,找不到类库。 因为是C#报错所以研究了半天visual stu…

自动驾驶系列—深入解析自动驾驶系统验车平台:确保车辆交付质量的关键工具

🌟🌟 欢迎来到我的技术小筑,一个专为技术探索者打造的交流空间。在这里,我们不仅分享代码的智慧,还探讨技术的深度与广度。无论您是资深开发者还是技术新手,这里都有一片属于您的天空。让我们在知识的海洋中…

LeetCode刷题日记之贪心算法(二)

目录 前言买卖股票的最佳时机II跳跃游戏跳跃游戏II总结 前言 在上一篇贪心算法的学习中,我们探讨了贪心算法的基本思路和逻辑框架。在这篇文章中,我将继续分享几道经典的LeetCode贪心算法题,并探讨其背后的解题思路和技巧。希望通过这些题目…

Java入门-创建对象

Java包管理器 包(package)的导入 Java体系非常庞大,为了管理更多的代码互不侵犯,采用了一个叫“包管理”的机制来管理代码,简单来说就是把不同的Java代码放在不同的文件夹里,这个文件夹就是“包”。对于使…

【Linux】【命令】查找(grep/find)与统计(wc)

查找与统计 grepfindwcExamples grep grep 命令用于在文件中或者标准输出中搜索特定字符串,并显示匹配结果。 grep 全称:Global Regular Expression Print 基本语法: grep [OPTION]... PATTERN [FILE] ...默认情况下,PATTERN 是…

Agentic RAG(基于智能体的检索增强生成)是检索增强生成(Retrieval-Augmented Generation,RAG)技术的一种高级形式

Agentic RAG(基于智能体的检索增强生成)是检索增强生成(Retrieval-Augmented Generation,RAG)技术的一种高级形式,它通过引入人工智能代理(Agent)的概念,为语言模型赋予了…

2024.10月18日- Vue2组件开发(3)

Vue组件开发 一、 ref属性 如果在vue里,想要获取DOM对象,并且不想使用JS的原生语法,那么就可以使用ref属性。ref属性的用法: 1)在HTML元素的开始标记中,或者在Vue子组件中的开始标记中定义,相…