Federated Graph Augmentation for Semisupervised Node Classification

文章目录

  • 1 本文的主要贡献
  • 2 FedGA 模型
  • 3 FedGA-L 模型
    • 3.1 模型的思想
    • 3.2 模型具体步骤
  • 4 实验

1 本文的主要贡献

解决图联邦学习中利用图拓扑结构和无标签节点数据的难题,提出了一种称为联合图增强(FedGA)的新方法,以更好地利用拓扑信息,然后在 FedGA 的基础上引入带标签注入的联合图增强(FedGA-L),以利用无标签节点数据。FedGA将图数据增强与边预测模型和节点分类模型相结合。
具体来说,首先通过链接预测模型增强客户端数据,然后在增强数据的基础上训练节点分类模型。此外,FedGA-L还通过结合伪标签和标签注入来增强图数据,从而提高半监督节点分类任务中未标签节点的利用率。

2 FedGA 模型

FedGA 模型旨在 1)增加客户端图的边连接数量以及 2) 从拓扑角度增强节点之间的信息以有利于所有的客户端。
在 FedGA 中,每个客户端拥有两个 GNN 模型:边连接预测和节点分裂任务。
具体算法:

  1. 每个客户端 C i C_i Ci 在本地图数据上训练一个边连接预测 GNN 模型。
  2. 从边集合 E i E_i Ei中选取一部分边作为正样本边子集 E i p o s E_i^{pos} Eipos,一部分不存在的边连接作为负样本 E i n e g E_i^{neg} Eineg
  3. 每个客户端使用作为输入,将作为标签,以训练边预测模型。
    FedGA 的模型框架如下图所示:
    在这里插入图片描述

3 FedGA-L 模型

为了更好的利用未标注的数据,提出了 FedGA-L 模型,它是 FedGA 的增强版。

3.1 模型的思想

使用预先训练好的分类模型给无标注的数据加上“伪标签”,然后将“伪标签”作为附加信息注入节点特征,以增强边预测能力更好的对节点进行分类任务。

3.2 模型具体步骤

  1. 标签注入(Label Injection):由于不同类别节点之间的连接会对分类模型在节点分类任务中的判断产生相反的影响,可以分为类内的边连接(interconnections)和类间的边连接(intraconnections)。类间连接降低了分类模型辨别节点类别的能力,而类内连接则增强了这一能力。

FedGA-L 模型框架如下图所示:
在这里插入图片描述

  1. 预训练和伪标注(Pretrain and Pseudolabel):由于半标注的数据集会导致维度的不一致,因此,第一步要对未标注的数据进行标签标注。本模型在进行数据增强操作之前提前进行分类模型的训练。
  2. 图增强(Graph Augmentation): 在 FedGA-L 模型中,数据聚合方式与 FedGA 模型相同。不同的是,将图连接信息加入图中依据概率矩阵中的概率由大到小。首先,在数据增强过程之后,必须在注入标签之前,将数据维度恢复到原始尺寸,以防止标签干扰训练最终节点分类模型。然后,第二轮基于训练模型进行训练前一阶段。由于数据维度保持不变在两个训练阶段,预训练模型可以直接使用,从而节省时间和计算资源在前一个训练阶段消耗。

4 实验

实验数据集
在这里插入图片描述

实验结果
在这里插入图片描述

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

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

相关文章

试编写函数fun的功能是:为一个偶数寻找两个素数,这两个素数之和等于该偶数,并将这两个素数通过形参指针传回主函数。

代码如下&#xff1a; #include <stdio.h> #include <math.h> void fun(int a, int *b, int *c) { int i,j,d,y;for (i3;i<a/2;ii2){y1; //y为标志变量for (j2;j<sqrt((double)i );j)if (i%j0) y0;if (y1){da-i; for (j2;j<sqrt((double)d );j)…

03Spring底层架构核心概念解析

为了感谢罕哥对我工作的帮助&#xff0c;特此记录下学习过程&#xff0c;期待成为和罕哥一样优秀的人 时间&#xff1a;2024.7.13 内容&#xff1a;spring源码课程3学习记录 一、BeanDefinition BeanDefinition表示Bean的定义&#xff0c;BeanDefinition中存在很多属性用来…

【python学习】python的知识点总结、特点和思考及解答(代码示例)

引言 python 是一种高级编程语言&#xff0c;具有简洁的语法和丰富的库&#xff0c;被广泛应用于Web开发、数据分析、人工智能、科学计算等领域 文章目录 引言一、python知识点总结1.1 基础语法1.1.1 变量和数据类型1.1.2 控制结构1.1.3 函数和模块 1.2 面向对象编程1.2.1 类和…

Linux CAN数据收发

在Linux环境下&#xff0c;使用SocketCAN进行CAN消息的发送和接收通常涉及到socket编程。 写了一个简单的示例&#xff0c;展示了如何实现CAN消息的发送&#xff08;tx&#xff09;和接收&#xff08;rx&#xff09;函数。 1. 包含必要的头文件 #include <stdio.h> …

如何通过成熟的外发平台,实现文档安全外发管理?

文档安全外发管理是企业信息安全管理的重要组成部分&#xff0c;它涉及到企业向外发送的文件&#xff0c;需要进行严格的控制和管理&#xff0c;防止敏感或机密信息的泄露。以下是一些关键考虑因素&#xff1a; 文件外发的挑战&#xff1a;企业在文件外发时面临的主要挑战包括…

Windows 电脑装机软件推荐

1.系统辅助&#xff1a; https://github.com/microsoft/PowerToys/releases 2.下载工具&#xff1a; Motrix

wls2下的centos使用桥接模式连接宿主机网络独立静态ip

前提&#xff1a;wsl2已安装&#xff0c;可正常更新 1.在控制面板中&#xff0c;打开开启或关闭windows功能&#xff0c;将里面的 Hyper-V功能打开&#xff0c;此处涉及重启 2. 按一下win键&#xff0c;输入hy&#xff0c;上面可以看到Hyper-V Manager,点进去 3.选择右边的 Vi…

Fiddler抓包

一个不错的文档&#xff1a;萌新要入行-CSDN博客 测试之路&#xff1a;3年经验来面试20K的测试岗&#xff0c;连基本功都不会&#xff0c;还不如去招应届生 Fiddler教程&#xff1a;https://www.cnblogs.com/zhangyangcheng/articles/15218175.html Fiddler安装教程&#xff1…

为什么Spring选择使用容器来管理对象,而不是直接使用new

为什么Spring选择使用容器来管理对象&#xff0c;而不是直接使用new 在Java应用程序开发中&#xff0c;对象的创建和管理是一项基础且关键的任务。传统上&#xff0c;开发者习惯于使用new关键字直接在代码中实例化对象。然而&#xff0c;随着应用程序规模的扩大和复杂度的增加…

Linux内存从0到1学习笔记(8.20 ION (二))

五,使用ION 5.1 User Space使用ION 通常,用户空间设备访问库将使用 ION 分配大的连续媒体缓冲区。例如,静态相机库可能会分配一个捕获缓冲区供相机设备使用。一旦缓冲区完全填充了视频数据,库可以将缓冲区传递给内核,以由 JPEG 编码器硬件模块处理。 用户空间的 C/C++ …

F5理念左移,实现API安全的全生命周期管理

API是我们现代数字生活中隐形的中枢神经系统&#xff0c;从远程医疗到在线银行&#xff0c;实时API让世界变得更美好。不可否认的是&#xff0c;当应用程序和架构发生变化时&#xff0c;攻击面也会随之变化。传统的安全措施&#xff0c;比如WAF、DDoS和Bot防护仍然必不可少&…

【深度学习图片】图片清洗,只留下图像中只有一张人脸的,而且人脸是全的

环境&#xff1a; conda install pytorch torchvision torchaudio pytorch-cuda11.8 -c pytorch -c nvidia -ypip install onnx1.15 onnxruntime-gpu1.17pip install insightface0.7.3pip install opencv-pythonpip install gradio图片清洗&#xff0c;只留下图像中只有一张人脸…

java中传引用问题

在 Java 中&#xff0c;所有对象都是通过引用传递的&#xff0c;而基本数据类型是通过值传递的。 引用传递&#xff1a; 当一个对象作为参数传递给方法时&#xff0c;传递的是对象的引用。对这个对象引用进行的修改会影响到原始对象。例如&#xff1a; public class Test {p…

CentOS Mysql8 数据库安装

添加mysql yum仓库 这里安装的是8.0版本&#xff0c;如需其他版本在此查看mysql版本列表 wget https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm sudo rpm -Uvh mysql80-community-release-el7-3.noarch.rpm安装mysql sudo yum install mysql-server …

新能源汽车缩写含义

汽车类型的缩写及其对应的英文全称和中文解释的表格&#xff1a; 缩写英文全称中文解释EVElectric Vehicle电动车HEVHybrid Electric Vehicle混合动力电动车BEVBattery Electric Vehicle纯电动车PHEVPlug-in Hybrid Electric Vehicle插电式混合动力电动车ICEVInternal Combust…

在eclipse中使用Junit单元测试的准备工作和基本介绍

JUnit准备工作和基本介绍 JUnit是一个Java语言的单元测试框架。。多数Java的开发环境都已经集成了JUnit作为单元测试的工具。 Junit 测试也是程序员测试&#xff0c;即所谓的白盒测试&#xff0c;它需要程序员知道被测试的代码如何完成功能&#xff0c;以及完成什么样的功能 …

sqlalchemy事件监听

sqlalchemy事件监听 SQLAlchemy 中的事件监听允许您在特定事件发生时执行自定义的 Python 代码。这些事件可以是与ORM(对象关系映射)或核心组件相关的操作,比如表、类、会话或事务的插入、更新、删除等操作。通过事件监听,您可以实现日志记录、审计或执行业务规则等功能。…

Ubuntu24.04 NFS 服务配置

1、NFS 介绍 NFS 是 Network FileSystem 的缩写&#xff0c;顾名思义就是网络文件存储系统&#xff0c;它允许网络中的计算机之间通过 TCP/IP 网络共享资源。通过 NFS&#xff0c;我们本地 NFS 的客户端应用可以透明地读写位于服务端 NFS 服务器上的文件&#xff0c;就像访问本…

宠物空气净化器哪款品牌好?口碑好的猫用空气净化器排名

猫咪每年掉毛两次&#xff0c;一次掉半年的现象真让人头疼。作为一位5年资深铲屎官&#xff0c;特别是在掉毛季节&#xff0c;猫毛无处不在&#xff0c;对此深有体会。宠物空气净化器已成为铲屎官们的救星&#xff0c;能迅速清理家中的宠物毛发和异味&#xff0c;是养猫家庭的必…

关于APPCRASH的问题处理

最近小编遇到了APPCRASH的问题,打开任意一个exe可执行文件运行时候,windows记录是APPCRASH的问题. 因为是第一次遇到,当时就懵逼了,通过查找资料,现在把这类问题总结一下: 1.软件不兼容引起的crash,通常我们启用兼容性运行就可以解决,前提是以前在其他版本的系统上运行,现在换…