MTGNN论文解读

news2025/2/7 20:29:34

模型架构

        MTGNN 由多个模块组合而成,目标是捕捉多变量时间序列中的空间(变量间)和时间(时序)依赖。

  • 图学习层:用于自适应地学习图的邻接矩阵,发现变量之间的关系。
  • 图卷积模块:根据邻接矩阵处理节点间的空间依赖。
  • 时间卷积模块:通过时间轴上的卷积提取时序特征。
  • 输出模块:将中间结果转换为最终预测结果。

1  图学习层 (Graph Learning Layer)

        图学习层通过数据自适应地学习邻接矩阵,以捕捉时间序列数据中的隐藏关系。传统方法使用相似性度量(如点积或欧几里得距离)来构造图,但这种方式导致 O(N²) 的计算复杂度,限制了对大图的处理能力。

        而作者采用采样策略,每次仅计算部分节点的关系,从而降低计算和内存成本。此外,传统方法生成的邻接矩阵是对称的(即 A[i,j]=A[j,i]),表示节点之间的关系是双向的。但时间序列中的依赖关系可能是单向的(例如,一条道路的拥堵可能会影响下游道路,但反过来未必成立)。通过如下公式即可确保邻接矩阵是单向的。

        上述公式中, M₁ 和 M₂ 为节点嵌入矩阵,α 是用于控制激活函数饱和率的超参数。M_{1}[i]M_{2}[j]^T表示道路 i 的流量对道路 j 流量的影响,M_{2}[j]M_{1}[i]^T表示道路 j 的流量对道路 i 流量的影响。如果M_{1}[i]M_{2}[j]^T-M_{2}[j]M_{1}[i]^T的值为正,则表示道路 i 对道路 j 的影响强于道路 j 对道路 i 的影响。如果结果为负,Relu 激活函数会将负值截断为 0,保留单向依赖关系的非负部分。

        其次,通过保留每个节点的前 k 个邻居,并将其他权重置为 0,可以进一步降低复杂度。

2 图卷积模块 (Graph Convolution Module)

        传统图卷积网络的一个严重限制是,随着图卷积层数趋于无穷,相邻节点的特征会逐渐融合,节点隐藏状态会收敛到一个单点。这是因为具有许多层的图卷积网络会达到随机游走的极限分布,而与初始节点状态无关,这就产生了过平滑问题(over-smoothing problem)。为解决这个问题,作者在传播过程中保留一定比例的节点原始状态,以便传播的节点状态既能保留局部性又能探索深层邻域。

        具体来说,作者设计的图卷积模块通过 Mix-hop 传播层融合节点和邻居的信息,以处理图中的空间依赖性。Mix-hop 传播层包括两部分:信息传播和信息选择。

  • 信息传播:保留一部分节点自身状态(通过 \beta 调节),同时以递归方式沿图结构传播邻居的信息。
  • 信息选择:通过线性变换筛选重要的节点特征,防止无用信息累积(通过 W^{(k)} 训练学习各层传播特征的权重)。

3 时间卷积模块 (Temporal Convolution Module)

        时间卷积模块由两个膨胀卷积层组成。一个膨胀卷积层后接 tanh 激活函数,用作过滤器;另一个膨胀卷积层后接 sigmoid 激活函数,用作门控控制。

        卷积核设置的大小一直是 CNN 的一个难题。太大会无法精细地表示短期信号模式,或者太小无法充分发现长期信号模式。因此,作者借鉴了图像处理中的 inception。由于时间信号往往具有几个固有周期,如 7、12、24、28 和 60,具有 1×1、1×3 和 1×5 滤波器尺寸的 inception 层堆叠不能很好地涵盖这些周期(太小)。因此,作者提出了一个由四个滤波器尺寸(即 1×2、1×3、1×6 和 1×7)组成的时间 inception 层。

        为了处理非常长的序列,作者采用了膨胀因果卷积。与上面结合形成扩张 inception 层。

4 学习算法 (Learning Algorithm)

        Chiang 等人应用图聚类算法将图划分为子图,并在划分后的子图上训练图卷积网络,以此来解决内存瓶颈问题。但是作者的模型训练的同时也在学习潜在的图结构,因此模型不能提前对图结构进行聚类。

        那么该如何修改?在每次迭代时,随机把节点分成若干组,基于采样节点学习子图结构,每组节点相互独立学习,训练结束后构建全局图。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C语言:函数栈帧的创建和销毁

目录 1.什么是函数栈帧2.理解函数栈帧能解决什么问题3.函数栈帧的创建和销毁的过程解析3.1 什么是栈3.2 认识相关寄存器和汇编指令3.3 解析函数栈帧的创建和销毁过程3.3.1 准备环境3.3.2 函数的调用堆栈3.3.3 转到反汇编3.3.4 函数栈帧的创建和销毁 1.什么是函数栈帧 在写C语言…

VSCode便捷开发

一、常用插件 Vue 3 Snippets、Vetur、Vue - Official 二、常用开发者工具 三、Vue中使用Element-UI 安装步骤: 1、在VSCode的终端执行如下指令: npm i element-ui -S 2、在main.js中全局引入: import Vue from vue; import ElementUI from …

二、tsp学习笔记——LINUX SDK编译

开发环境:window11 wsl ubuntu24.04 lypwslDESKTOP-39T8VTC:~$ lsb_release -a No LSB modules are available. Distributor ID: Ubuntu Description: Ubuntu 24.04.1 LTS Release: 24.04 Codename: noble linux_sdk同步 tspi_linux_sdk_repo_202…

分析用户请求K8S里ingress-nginx提供的ingress流量路径

前言 本文是个人的小小见解,欢迎大佬指出我文章的问题,一起讨论进步~ 我个人的疑问点 进入的流量是如何自动判断进入iptables的四表?k8s nodeport模式的原理? 一 本机环境介绍 节点名节点IPK8S版本CNI插件Master192.168.44.1…

初阶数据结构:树---堆

目录 一、树的概念 二、树的构成 (一)、树的基本组成成分 (二)、树的实现方法 三、树的特殊结构------二叉树 (一)、二叉树的概念 (二)、二叉树的性质 (三&#…

feign 远程调用详解

在平常的开发工作中,我们经常需要跟其他系统交互,比如调用用户系统的用户信息接口、调用支付系统的支付接口等。那么,我们应该通过什么方式进行系统之间的交互呢?今天,简单来总结下 feign 的用法。 1:引入依…

Sentinel的安装和做限流的使用

一、安装 Release v1.8.3 alibaba/Sentinel GitHubA powerful flow control component enabling reliability, resilience and monitoring for microservices. (面向云原生微服务的高可用流控防护组件) - Release v1.8.3 alibaba/Sentinelhttps://github.com/alibaba/Senti…

讯飞智作 AI 配音技术浅析(三):自然语言处理

自然语言处理(NLP)是讯飞智作 AI 配音技术的重要组成部分,负责将输入的文本转换为机器可理解的格式,并提取出文本的语义和情感信息,以便生成自然、富有表现力的语音。 一、基本原理 讯飞智作 AI 配音的 NLP 技术主要包…

wxWidgets生成HTML文件,带图片转base64数据

编译环境大家可以看我之前的文章,CodeBlocks + msys2 + wx3.2,win10 这里功能就是生成HTML文件,没用HTML库,因为是自己固定的格式,图片是一个vector,可以动态改变数量的。 效果如下: #include <wx/string.h> #include <wx/file.h> #include <wx/ima…

【matlab基本使用笔记】

ctrl a i 代码格式化 fzero求非线性函数的根 arrayfun将函数应用于每个数组元素 format long长格式输出 format long g取消科学计数法 linspace logspace 一、界面使用 1.创建matlab脚本 利用.m后缀的脚本文件&#xff08;又称为m文件&#xff09;编程&#xff1a; 点击…

机器学习--python基础库之Matplotlib (1) 超级详细!!!

机器学习--python基础库Matplotlib 机器学习--python基础库Matplotlib0 介绍1 实现基础绘图-某城市温度变化图1.1绘制基本图像1.2实现一些其他功能 2 再一个坐标系中绘制多个图像3 多个坐标系显示-plt.subplots(面向对象的画图方法)4 折线图的应用场景 机器学习–python基础库M…

bat脚本实现自动化漏洞挖掘

bat脚本 BAT脚本是一种批处理文件&#xff0c;可以在Windows操作系统中自动执行一系列命令。它们可以简化许多日常任务&#xff0c;如文件操作、系统配置等。 bat脚本执行命令 echo off#下面写要执行的命令 httpx 自动存活探测 echo off httpx.exe -l url.txt -o 0.txt nuc…

一文解释nn、nn.Module与nn.functional的用法与区别

&#x1f308; 个人主页&#xff1a;十二月的猫-CSDN博客 &#x1f525; 系列专栏&#xff1a; &#x1f3c0;零基础入门PyTorch框架_十二月的猫的博客-CSDN博客 &#x1f4aa;&#x1f3fb; 十二月的寒冬阻挡不了春天的脚步&#xff0c;十二点的黑夜遮蔽不住黎明的曙光 目录 …

Unity VideoPlayer播放视屏不清晰的一种情况

VideoPlayer的Rnder Texture可以设置Size,如果你的视屏是1920*1080那么就设置成1920*1080。 如果设置成其他分辨率比如800*600会导致视屏不清晰。

【玩转全栈】--创建一个自己的vue项目

目录 vue介绍 创建vue项目 vue页面介绍 element-plus组件库 启动项目 vue介绍 Vue.js 是一款轻量级、易于上手的前端 JavaScript 框架&#xff0c;旨在简化用户界面的开发。它采用了响应式数据绑定和组件化的设计理念&#xff0c;使得开发者可以通过声明式的方式轻松管理数据和…

揭秘区块链隐私黑科技:零知识证明如何改变未来

文章目录 1. 引言&#xff1a;什么是零知识证明&#xff1f;2. 零知识证明的核心概念与三大属性2.1 完备性&#xff08;Completeness&#xff09;2.2 可靠性&#xff08;Soundness&#xff09;2.3 零知识性&#xff08;Zero-Knowledge&#xff09; 3. 零知识证明的工作原理4. 零…

堆的实现——堆的应用(堆排序)

文章目录 1.堆的实现2.堆的应用--堆排序 大家在学堆的时候&#xff0c;需要有二叉树的基础知识&#xff0c;大家可以看我的二叉树文章&#xff1a;二叉树 1.堆的实现 如果有⼀个关键码的集合 K {k0 , k1 , k2 , …&#xff0c;kn−1 } &#xff0c;把它的所有元素按完全⼆叉树…

Ubuntu20.04 本地部署 DeepSeek-R1

一、下载ollama 打开 ollama链接&#xff0c;直接终端运行提供的命令即可。如获取的命令如下&#xff1a; curl -fsSL https://ollama.com/install.sh | sh确保是否安装成功可在终端输入如下命令&#xff1a; ollama -v注意&#xff1a; 如遇到Failed to connect to github.…

2025年2月6日笔记

第 12 届蓝桥杯 C 青少组中 / 高级组选拔赛&#xff08; STEMA &#xff09; 2020 年 11 月 22 日 真题第一题 解题思路&#xff1a; 第一&#xff1a;因为有整数集合的求和字样&#xff08;所以用for循环来做&#xff09; 第二&#xff1a;题中让我们累加1到N&#xff0c;所…

Linux: 网络基础

1.协议 为什么要有协议&#xff1a;减少通信成本。所有的网络问题&#xff0c;本质是传输距离变长了。 什么是协议&#xff1a;用计算机语言表达的约定。 2.分层 软件设计方面的优势—低耦合。 一般我们的分层依据&#xff1a;功能比较集中&#xff0c;耦合度比较高的模块层…