【未完】【GNN筆記】EvolveGCN:Evolving Graph Convolutional Networks for Dynamics Graphs

Evolving Graph Convolutional Networks for Dynamics Graphs

視頻鏈接:《圖神經網絡》
相關系列:

  1. 《Dynamic Graph的分類》
  2. 《動態圖網絡之Dynamic Self-Attention Network》

文章目錄

  • Evolving Graph Convolutional Networks for Dynamics Graphs
    • 一、model
      • <font color=red>Q:在同一層不同時刻如何計算?
      • <font color=red>Q:同一時刻數據在不同層如何計算?
      • EvolveGCN-O
      • EvolveGCN-H
      • Q:兩種EvolveGCN該如何選擇?
      • Loss
  • 解讀代碼:EvolveGCN-O
    • 二、`run_exp.py`
      • 2.1 主函數
      • 2.2 設置網絡參數
      • 2.3 讀取數據集
        • 2.3.1 進入`class sbm_dataset()`
      • 2.4 建立預測任務
        • <font color=red>2.4.2 進入`class Link_Pred_Tasker`
      • 2.5 tran\val\test的分離器
        • 2.5.1 進入
      • 2.6
    • 三、model `egcn-o.py`
      • 3.1 class EGCN()
      • 3.2 class GRCU()
      • 3.3 class mat_GRU_cell()
      • 3.4 class mat_GRU_gate()
      • 3.5 class TopK()
  • 附錄、`utlis.py`
    • 導入
    • 數據集
      • `parameters_example.yaml`

區別

  • DySAT,是基于GNN和RNN的組合:在每個快照中使用GNN作為特征提取器聚合節點特征,然后在每個快照中使用RNN聚合時間特征來進一步聚合節點的特征
  • EvolveGCN:也是離散型動態GNN,是集成型的DGNN,將GNN和RNN結合在同一層,從而結合空間和時間信息的建模
    在這里插入圖片描述
  • EvolveGCN是采用集成DGNN的方法

一、model

采用快照的方法構圖,同DySAT一樣。

Q:在前面提到,EvolveGCN在每一層將GNN和RNN結合在同一層。那么是如何結合的呢?
A:普通GCN的公式如下圖所示,EvolveGCN的公式與之相同。但區別在于W的更新方式。
在這里插入圖片描述

Q:在同一層不同時刻如何計算?

第0層 t 1 t_1 t1?時刻的計算

  • input : A A A (鄰接矩陣) , H 1 0 H_1^0 H10? (節點特征) → \to 如下圖

  • init: W 0 ( 0 ) ∈ R 3 × 2 W_0^{(0)} \in \R^{3\times 2} W0(0)?R3×2 (權重參數) → \to 第一次初始化,如下圖
    在這里插入圖片描述

  • step1: W 0 ( 0 ) ∈ R 3 × 2 W^{(0)}_0 \in \R^{3\times 2} W0(0)?R3×2RNN–> W 1 ( 0 ) ∈ R 3 × 2 W^{(0)}_1 \in \R^{3\times 2} W1(0)?R3×2
    在這里插入圖片描述

  • step2: A 1 ? H 1 ( 0 ) ? W 1 0 A_1 \cdot H_1^{(0)}\cdot W_1^{0} A1??H1(0)??W10?GCN–> H 1 ( 1 ) H_1^{(1)} H1(1)?
    在這里插入圖片描述

  • 整體過程:如下圖所示
    在這里插入圖片描述

第0層 t 2 t_2 t2?時刻的計算
在這里插入圖片描述
model計算公式
在這里插入圖片描述

Q:同一時刻數據在不同層如何計算?

第0層 t 1 t_1 t1?時刻的過程
在這里插入圖片描述
第1層 t 1 t_1 t1?時刻的過程
在這里插入圖片描述

EvolveGCN-O

在這里插入圖片描述
在這里插入圖片描述

EvolveGCN-H

在這里插入圖片描述
在這里插入圖片描述
在上圖中,可以看到-H的GRU的輸入是 H , W H,W H,W,因此會存在數據維度不同的情況,因此設定了一個降維算法.
在這里插入圖片描述

Q:兩種EvolveGCN該如何選擇?

如果節點有信息,-H效果要好,因為考慮了節點的特征變化
如果節點信息?較少,-O效果好,因為他更關系圖結構的變化

Loss

在這里插入圖片描述

解讀代碼:EvolveGCN-O

二、run_exp.py

2.1 主函數

  1. argparser參數
    在這里插入圖片描述
  2. 設置隨機數
    在這里插入圖片描述
  3. 調用相關函數
    在這里插入圖片描述
  4. 建立損失函數和訓練器
    在這里插入圖片描述

2.2 設置網絡參數

在這里插入圖片描述
當下默認args.model=‘egcn_o’,查看其他變量

變量含義備注
args.num_hist_steps5hist_steps
args.gcn_parameters[‘feats_per_node’]100
args.gcn_parameters[‘layer_1_feats’]100
args.gcn_parameters[‘layer_2_feats’]100
args.gcn_parameters[‘lstm_l1_feats’]100
args.gcn_parameters[‘lstm_l2_feats’]100
args.gcn_parameters[‘cls_feats’]100

2.3 讀取數據集

函數調用流程

  1. 主函數中的調用語句dataset = build_dataset(args) # 構建數據集
  2. 在build_dataset中調用sbm.sbm_dataset(args) 讀取數據集
    在這里插入圖片描述在這里插入圖片描述
2.3.1 進入class sbm_dataset()
  1. sbm_dataset中的Namespace的作用
    在這里插入圖片描述
    在這里插入圖片描述
  2. args.sbm_args中的dict內容為
    在這里插入圖片描述
  3. 建立邊的數據結構
    在這里插入圖片描述
  4. 隨機產生節點特征
    在這里插入圖片描述
  5. 總結class.attribute
變量keyvalue含義
self.ecols‘FromNodeId’0
‘ToNodeId’1
‘Weight’2
‘TimeStep’3
self.max_time49時間序列中最大值
self.min_time0時間序列中最小值
self.num_classes1類別數
self.edges{‘idx’:tensor.shape(4870863,3), ‘vals’:tensor.shape(4870863)}self.edges[‘idx’][0]=tensor([0, 2, 0])
self.num_nodes1000節點個數
self.feats_per_node3節點特征個數
self.nodes_featsrandn((1000,3))節點隨機特征
self.num_non_existing-38708631000**2 -4870863

2.4 建立預測任務

# build the taskertasker = build_tasker(args,dataset)  # 預測任務link_pred
  1. 調用build_tasker()函數,這里的dataset見2.3節
    在這里插入圖片描述
2.4.2 進入class Link_Pred_Tasker

在這里插入圖片描述
注釋:
在這里插入圖片描述

2.5 tran\val\test的分離器

  1. 調用函數splitter = sp.splitter(args,tasker) # 訓練,測試,驗證集
2.5.1 進入

在這里插入圖片描述

2.6

三、model egcn-o.py

3.1 class EGCN()

3.2 class GRCU()

3.3 class mat_GRU_cell()

3.4 class mat_GRU_gate()

3.5 class TopK()

附錄、utlis.py

導入

def create_parser():parser = argparse.ArgumentParser(formatter_class=argparse.RawTextHelpFormatter)parser.add_argument('--config_file',default='experiments/parameters_example.yaml', type=argparse.FileType(mode='r'), help='optional, yaml file containing parameters to be used, overrides command line parameters')return parser

注釋:

  1. 《ArgumentParser()用法解析》
  2. 《argparse之參數formatter_class》,
  3. 《yaml文件格式說明及編寫教程》
  4. 《argparse.FileType實例講解》, 用argparse.FileType,除了可以實現輸入參數為文件外(遇到不存在的文件,會提示錯誤,這樣就不用自己去判斷文件是否存在了),還可以很好的實現通過命令行管道來接收數據。

class Namespace(object):'''helps referencing object in a dictionary as dict.key instead of dict['key']'''def __init__(self, adict):self.__dict__.update(adict)

注釋: 1. 《 dict 詳解》, 《__dict__的用法》

數據集

parameters_example.yaml

在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/80151.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/80151.shtml
英文地址,請注明出處:http://en.pswp.cn/web/80151.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Go語言之路————并發

Go語言之路————并發 前言協程管道SelectsyncWaitGroup鎖 前言 我是一名多年Java開發人員&#xff0c;因為工作需要現在要學習go語言&#xff0c;Go語言之路是一個系列&#xff0c;記錄著我從0開始接觸Go&#xff0c;到后面能正常完成工作上的業務開發的過程&#xff0c;如…

Gmsh劃分網格|四點矩形

先看下面這段官方自帶腳本 /*********************************************************************** Gmsh tutorial 1** Variables, elementary entities (points, curves, surfaces), physical* entities (points, curves, surfaces)********************************…

leetcode0215. 數組中的第K個最大元素-medium

1 題目&#xff1a;數組中的第K個最大元素 官方標定難度&#xff1a;中 給定整數數組 nums 和整數 k&#xff0c;請返回數組中第 k 個最大的元素。 請注意&#xff0c;你需要找的是數組排序后的第 k 個最大的元素&#xff0c;而不是第 k 個不同的元素。 你必須設計并實現時…

rocketmq 環境配置[python]

因本人是 python 開發&#xff0c;macbook 開發。windows 可以采取配置遠程 linux 解釋器或者 pycharm 專業版的 docker 解釋器進行開發 M1 芯片 本地運行 rocketmq rocketmq Python 開源地址&#xff1a; https://github.com/apache/rocketmq-client-python 因為需要 linu…

OCCT知識筆記之OCAF框架詳解

OCAF框架在OCCT項目中的構建與使用指南 Open CASCADE Application Framework (OCAF)是Open CASCADE Technology (OCCT)中用于管理CAD數據的核心框架&#xff0c;它提供了一種結構化方式來組織和管理復雜的CAD數據&#xff0c;如裝配體、形狀、屬性(顏色、材料)和元數據等。本文…

go-數據庫基本操作

1. 配置數據庫 package mainimport ("gorm.io/driver/mysql""gorm.io/gorm" ) #配置表結構 type User struct {ID int64 json:"id" gorm:"primary_key" // 主鍵ID自增長Username stringPassword string } #配置連接接信息 func…

【含文檔+PPT+源碼】基于大數據的交通流量預測系統

技術棧說明 技術棧&#xff1a; 后端&#xff1a;Django&#xff08;后端是前后端分離的&#xff09; 前端&#xff1a;Vue.js ElementUI 開發工具&#xff1a; Python3.9以上 Pycharm MySQL5.7/MySQL8 VSCode 項目演示視頻 基于大數據的交通流量預測系統

海盜王3.0的數據庫3合1并庫處理方案

原版的海盜王數據庫有3個accountserver&#xff0c;gamedb&#xff0c;tradedb&#xff0c;對應到是賬號數據庫&#xff0c;游戲數據庫&#xff0c;商城數據庫。 一直都有個想法&#xff0c;如何把這3個庫合并到一起&#xff0c;這樣可以實現一些功能。 涉及到sqlserver的數據庫…

Apollo Client 1.6.0 + @RefreshScope + @Value 刷新問題解析

問題描述 在使用 Apollo Client 1.6.0 結合 Spring Cloud 的 RefreshScope 和 Value 注解時&#xff0c;遇到以下問題&#xff1a; 項目啟動時第一次屬性注入成功后續配置變更時&#xff0c;Value 屬性會刷新&#xff0c;但總是刷新為第一次的舊值&#xff0c;而不是最新的配…

LearnOpenGL --- 你好三角形

你好&#xff0c;三角形的課后練習題 文章目錄 你好&#xff0c;三角形的課后練習題一、創建相同的兩個三角形&#xff0c;但對它們的數據使用不同的VAO和VBO 一、創建相同的兩個三角形&#xff0c;但對它們的數據使用不同的VAO和VBO #include <glad/glad.h> #include &…

STM32F407VET6實戰:CRC校驗

CRC校驗在數據傳輸快&#xff0c;且量大的時候使用。下面是STM32F407VET6HAL庫使用CRC校驗的思路。 步驟實現&#xff1a; CubeMX配置 c // 在CubeMX中啟用CRC模塊 // AHB總線時鐘自動啟用 HAL庫代碼 c // 初始化&#xff08;main函數中&#xff09; CRC_HandleTypeDef …

Vue3中實現輪播圖

目錄 1. 輪播圖介紹 2. 實現輪播圖 2.1 準備工作 1、準備至少三張圖片&#xff0c;并將圖片文件名改為數字123 2、搭好HTML的標簽 3、寫好按鈕和圖片標簽 ?編輯 2.2 單向綁定圖片 2.3 在按鈕里使用方法 2.4 運行代碼 3. 完整代碼 1. 輪播圖介紹 首先&#xff0c;什么是…

Linux遠程連接服務

遠程連接服務器簡介 遠程連接服務器通過文字或圖形接口方式來遠程登錄系統&#xff0c;讓你在遠程終端前登錄linux主機以取得可操作主機接口&#xff08;shell&#xff09;&#xff0c;而登錄后的操作感覺就像是坐在系統前面一樣。 遠程連接服務器的功能 分享主機的運算能力 遠…

MySQL面試知識點詳解

一、MySQL基礎架構 1. MySQL邏輯架構 MySQL采用分層架構設計&#xff0c;主要分為&#xff1a; 連接層&#xff1a;處理客戶端連接、授權認證等 服務層&#xff1a;包含查詢解析、分析、優化、緩存等 引擎層&#xff1a;負責數據存儲和提取&#xff08;InnoDB、MyISAM等&am…

牛客網NC22000:數字反轉之-三位數

牛客網NC22000:數字反轉之-三位數 &#x1f50d; 題目描述 時間限制&#xff1a;C/C/Rust/Pascal 1秒&#xff0c;其他語言2秒 空間限制&#xff1a;C/C/Rust/Pascal 32M&#xff0c;其他語言64M &#x1f4dd; 輸入輸出說明 輸入描述: 輸入一個3位整數n (100 ≤ n ≤ 999)…

C++跨平臺開發:突破不同平臺的技術密碼

Windows 平臺開發經驗 開發環境搭建 在 Windows 平臺進行 C 開發&#xff0c;最常用的集成開發環境&#xff08;IDE&#xff09;是 Visual Studio。你可以從Visual Studio 官網下載安裝包&#xff0c;根據安裝向導進行安裝。安裝時&#xff0c;在 “工作負載” 界面中&#xff…

[250516] OpenAI 升級 ChatGPT:GPT-4.1 及 Mini 版上線!

目錄 ChatGPT 迎來重要更新&#xff1a;GPT-4.1 和 GPT-4.1 mini 正式上線用戶如何訪問新模型&#xff1f;技術亮點與用戶體驗優化 ChatGPT 迎來重要更新&#xff1a;GPT-4.1 和 GPT-4.1 mini 正式上線 OpenAI 宣布在 ChatGPT 平臺正式推出其最新的 AI 模型 GPT-4.1 和 GPT-4.…

計算機指令分類和具體的表示的方式

1.關于計算機的指令系統 下面的這個就是我們的一個簡單的計算機里面涉及到的指令&#xff1a; m就是我們的存儲器里面的地址&#xff0c;可以理解為memory這個意思&#xff0c;r可以理解為rom這樣的單詞的首字母&#xff0c;幫助我們去進行這個相關的指令的記憶&#xff0c;不…

前端腳手架開發指南:提高開發效率的核心操作

前端腳手架通過自動化的方式可以提高開發效率并減少重復工作&#xff0c;而最強大的腳手架并不是現成的那些工具而是屬于你自己團隊量身定制的腳手架&#xff01;本篇文章將帶你了解腳手架開發的基本技巧&#xff0c;幫助你掌握如何構建適合自己需求的工具&#xff0c;并帶著你…

SpringBoot常用注解詳解

文章目錄 1. 前言2. 核心注解2.1 SpringBootApplication2.2 Configuration2.3 EnableAutoConfiguration2.4 ComponentScan2.5 Bean2.6 Autowired2.7 Qualifier2.8 Primary2.9 Value2.10 PropertySource2.11 ConfigurationProperties2.12 Profile 3. Web開發相關注解3.1 Control…