当前位置: 首页 > article >正文

论文笔记:Model-Contrastive Federated Learning

0 简介

论文:Model-Contrastive Federated Learning
代码:https://github.com/QinbinLi/MOON
相关链接:本文主要是将SimCLR对比学习的思想迁移到联邦学习中,关于SimCLR的介绍见https://blog.csdn.net/search_129_hr/article/details/130419626

1 核心思想

在这里插入图片描述
SimCLR对比学习的对象是:

  • 图像 x x x先经过数据增强后得到的 x i x_i xi x j x_j xj,然后经过特征提取器 R w ( ⋅ ) R_w(\cdot) Rw()得到的特征 z i z_i zi z j z_j zj,训练的参数就是特征提取器的参数 w w w
  • 总体想法是同一张图片增强后的图片得到的特征要相聚,不同图片增强后的图片得到的特征相离;

在这里插入图片描述

本文提出的联邦学习MOON对比学习的对象为:

  • w t w^t wt:the global model全局模型;
  • w i t w_i^t wit:客户端 P i P_i Pi的局部模型;
  • z prev = R w i t − 1 ( x ) z_{\text{prev}} = R_{w_i^{t-1}}(x) zprev=Rwit1(x):上一轮本地训练好的发往服务器的本地模型得到的表征(固定);
  • z glob = R w t ( x ) z_{\text{glob}} = R_{w^t}(x) zglob=Rwt(x):这轮开始时服务器发送到本地客户端的全局模型得到的表征(固定);
  • z = R w i t ( x ) z = R_{w_i^t}(x) z=Rwit(x):这轮正在被更新的本地模型得到的表征(不断更新),本文作者在符号系统上没有仔细推敲,图中用的 z local z_{\text{local}} zlocal,公式用的是 z z z

本文的目标是让 z z z靠近 z glob z_{\text{glob}} zglob (固定),让 z z z远离 z prev z_{\text{prev}} zprev (固定),通过如下损失函数来控制:
ℓ con  = − log ⁡ exp ⁡ ( sim ⁡ ( z , z glob  ) / τ ) exp ⁡ ( sim ⁡ ( z , z glob  ) / τ ) + exp ⁡ ( sim ⁡ ( z , z prev  ) / τ ) , \ell_{\text {con }}=-\log \frac{\exp \left(\operatorname{sim}\left(z, z_{\text {glob }}\right) / \tau\right)}{\exp \left(\operatorname{sim}\left(z, z_{\text {glob }}\right) / \tau\right)+\exp \left(\operatorname{sim}\left(z, z_{\text {prev }}\right) / \tau\right)}, con =logexp(sim(z,zglob )/τ)+exp(sim(z,zprev )/τ)exp(sim(z,zglob )/τ),
其中 τ \tau τ为温度系数,分子是正样本对 ( z , z glob ) (z , z_{\text{glob}}) (z,zglob) ,分母是正样本对 ( z , z glob ) (z , z_{\text{glob}}) (z,zglob) +负样本对 ( z , z prev ) (z , z_{\text{prev}}) (z,zprev)

ℓ = ℓ sup  ( w i t ; ( x , y ) ) + μ ℓ con  ( w i t ; w i t − 1 ; w t ; x ) \ell=\ell_{\text {sup }}\left(w_i^t ;(x, y)\right)+\mu \ell_{\text {con }}\left(w_i^t ; w_i^{t-1} ; w^t ; x\right) =sup (wit;(x,y))+μcon (wit;wit1;wt;x)
其中 ℓ sup  ( w i t ; ( x , y ) ) \ell_{\text {sup }}\left(w_i^t ;(x, y)\right) sup (wit;(x,y))为监督学习交叉熵损失,客户端的 x x x利用全局模型 z glob = R w t ( x ) z_{\text{glob}} = R_{w^t}(x) zglob=Rwt(x)进行预测得到 y ^ \hat{y} y^,然后和真实标签 y y y计算交叉熵Loss; μ \mu μ为超参数控制对比学习的权重。
在这里插入图片描述

2 伪代码

在这里插入图片描述

  • 理想情况下(IID),全局模型和本地模型训练得到的表征应该是一样好的,此时 ℓ con  \ell_{\text {con }} con 是一个常数,这样会得到FedAvg一样的效果。
  • 在这种意义上,MOON比FedAvg更具鲁棒性(能处理Non-IID的情况)。

http://www.kler.cn/news/16255.html

相关文章:

  • TPM-TPM-Profile-PTP协议-2
  • Vue3事件绑定
  • 【五一创作】50道Java面试题
  • Python的一些知识
  • 做了一年csgo搬砖项目,还清所有债务:会赚钱的人都在做这件事 !
  • 更轻更好用的蓝牙耳机,日常佩戴更舒适,QCY Crossky Link体验
  • Nginx:常见的面试题和答案
  • Delphi 内存分配
  • Java程序猿搬砖笔记(十二)
  • 记录和传播知识的重要性不亚于创造知识本身【专利所保护的,主要是`流程`、`工艺`和`方法`,不是一个具体的产品。】
  • 与贵州公安面对面|欧科云链天眼中国行,他们都说“行”
  • 点亮第一个LED灯
  • vue3+element-plus角色权限管理分配
  • 使用cube studio开发机器学习建模的pipeline
  • Java面试题字节流字符流
  • python-使用Qchart总结3-绘制曲线图
  • 马斯克们叫停 GPT-5,更像是场行为艺术
  • 【SpringBoot 应用打包与部署】
  • 为什么越来越多的企业选择云计算
  • 《Netty》从零开始学netty源码(四十六)之PooledByteBuf
  • 不能使用chatGPT?这3个平替甚至比chatGPT更强
  • 万字长文 - Nature 综述系列 - 给生物学家的机器学习指南 2 (传统机器学习方法如何选择)...
  • 《孙子兵法》中关于领导力的一个不错的描述
  • 创建NAT模式KVM虚拟机
  • spring常用的事务传播行为
  • CSS(二)-- 选择器的运用(针对基本选择器和复合选择器的详细解析)
  • 一文了解使用Moonbeam原生跨链的潜力项目
  • 【Java笔试强训 27】
  • 【Leetcode -86.分隔链表 -92.反转链表Ⅱ】
  • LeetCode_字符串_简单_415.字符串相加