E(n) Equivariant Graph Neural Networks 项目教程
2026-01-21 05:21:24作者:贡沫苏Truman
1. 项目介绍
E(n) Equivariant Graph Neural Networks(EGNNs)是一个用于学习图神经网络的新模型,该模型具有旋转、平移、反射和排列的等变性。与现有方法相比,EGNNs在中间层不需要计算昂贵的高阶表示,同时仍然能够实现竞争性或更好的性能。此外,现有方法通常局限于3维空间中的等变性,而EGNNs可以轻松扩展到更高维空间。
该项目的主要贡献包括:
- 提出了E(n) Equivariant Graph Neural Networks模型。
- 在动力系统建模、图自编码器中的表示学习和预测分子属性等方面展示了其有效性。
2. 项目快速启动
环境准备
确保你已经安装了PyTorch 1.7.1。你可以通过以下命令安装PyTorch:
pip install torch==1.7.1
克隆项目
首先,克隆项目到本地:
git clone https://github.com/vgsatorras/egnn.git
cd egnn
运行示例代码
以下是一个简单的EGNN实现示例:
import egnn_clean as eg
import torch
# 定义参数
batch_size = 8
n_nodes = 4
n_feat = 1
x_dim = 3
# 创建虚拟变量 h, x 和全连接边
h = torch.ones(batch_size * n_nodes, n_feat)
x = torch.ones(batch_size * n_nodes, x_dim)
edges, edge_attr = eg.get_edges_batch(n_nodes, batch_size)
# 初始化EGNN
egnn = eg.EGNN(in_node_nf=n_feat, hidden_nf=32, out_node_nf=1, in_edge_nf=1)
# 运行EGNN
h, x = egnn(h, x, edges, edge_attr)
3. 应用案例和最佳实践
N-body系统实验
创建N-body数据集:
cd n_body_system/dataset
python -u generate_dataset.py --num-train 10000 --seed 43 --sufix small
运行实验:
# EGNN模型
python -u main_nbody.py --exp_name exp_1_egnn_vel --model egnn_vel --max_training_samples 3000 --lr 5e-4
# GNN模型
python -u main_nbody.py --exp_name exp_1_gnn --model gnn --max_training_samples 3000 --lr 1e-3
图自编码器实验
运行图自编码器实验:
# GNN Erdos & Renyi
python -u main_ae.py --exp_name exp1_gnn_erdosrenyi --model ae --dataset erdosrenyinodes_0.25_none --K 8 --emb_nf 8 --noise_dim 0
4. 典型生态项目
相关项目
- lucidrains/egnn-pytorch: 另一个E(n)-Equivariant Graph Neural Networks的PyTorch实现,可能用于Alphafold2的复制。
- 其他图神经网络项目: 如DGL(Deep Graph Library)和PyG(PyTorch Geometric),这些项目提供了丰富的图神经网络工具和模型。
通过这些项目,你可以进一步扩展和应用E(n) Equivariant Graph Neural Networks的能力。
登录后查看全文
热门项目推荐
相关项目推荐
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
LongCat-AudioDiT-1BLongCat-AudioDiT 是一款基于扩散模型的文本转语音(TTS)模型,代表了当前该领域的最高水平(SOTA),它直接在波形潜空间中进行操作。00- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
AtomGit城市坐标计划AtomGit 城市坐标计划开启!让开源有坐标,让城市有星火。致力于与城市合伙人共同构建并长期运营一个健康、活跃的本地开发者生态。01
CAP基于最终一致性的微服务分布式事务解决方案,也是一种采用 Outbox 模式的事件总线。C#00
热门内容推荐
最新内容推荐
3种实用方案解决软件试用期管理难题SMUDebugTool:重新定义AMD Ryzen硬件调试的开源解决方案企业级视频本地化:技术架构与商业落地指南4个效率优化维度:Kronos金融大模型资源配置与训练实战指南3步打造高效键盘效率工具:MyKeymap个性化配置指南RapidOCR:企业级本地化OCR工具的技术解析与应用实践开源小说下载工具:实现网络小说本地存储的完整方案Detect-It-Easy技术教程:精准识别PyInstaller打包文件的核心方法GDevelop零代码游戏开发:3大痛点解决方案与实战案例高效解决知识星球内容备份难题:完全掌握zsxq-spider从爬取到PDF的知识管理方案
项目优选
收起
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
653
4.23 K
deepin linux kernel
C
27
14
Ascend Extension for PyTorch
Python
488
599
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
390
280
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
937
854
Oohos_react_native
React Native鸿蒙化仓库
JavaScript
332
387
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.53 K
886
暂无简介
Dart
900
215
AscendNPU-IR是基于MLIR(Multi-Level Intermediate Representation)构建的,面向昇腾亲和算子编译时使用的中间表示,提供昇腾完备表达能力,通过编译优化提升昇腾AI处理器计算效率,支持通过生态框架使能昇腾AI处理器与深度调优
C++
123
194
昇腾LLM分布式训练框架
Python
141
167