联邦学习FedAvg中模型聚合过程的理解分析

作者:Cyril_KI 时间:2023-09-28 02:29:48 

问题

联邦学习原始论文中给出的FedAvg的算法框架为:

联邦学习FedAvg中模型聚合过程的理解分析

参数介绍: K 表示客户端的个数, B表示每一次本地更新时的数据量, E 表示本地更新的次数, η表示学习率。

首先是服务器执行以下步骤:

联邦学习FedAvg中模型聚合过程的理解分析

对每一个本地客户端来说,要做的就是更新本地参数,具体来讲:

  • 把自己的数据集按照参数B分成若干个块,每一块大小都为B。

  • 对每一块数据,需要进行E轮更新:算出该块数据损失的梯度,然后进行梯度下降更新,得到新的本地 w 。

  • 更新完后 w w w将被传送到中央服务器,服务器整合所有客户端计算出的 w,得到最新的全局模型参数 wt+1

  • 客户端收到服务器发送的最新全局参数模型参数,进行下一次更新。

我们仔细观察server的最后一步:

联邦学习FedAvg中模型聚合过程的理解分析

联邦学习FedAvg中模型聚合过程的理解分析

聚合

那么针对聚合,就有以下两种情况。

1. 聚合所有客户端

服务器端每次将新的全局模型发送给全部客户端,并且聚合全部客户端的模型参数。如果客户端未被选中,那么一轮通信结束后,该客户端的模型为一轮通信开始时从服务器获得的初始模型。

设当前全局模型为 wt,服务器选中了 m个客户端(集合V),m个客户端本地更新完毕后,服务器端的聚合公式为:

联邦学习FedAvg中模型聚合过程的理解分析

也就是说,每一次聚合时服务器端都将所有客户端的模型考虑在内。

2. 仅聚合被选中的客户端

服务器每次只是将当前新的参数传递给被选中的模型,并且只是聚合被选中客户端的模型参数。

设当前全局模型为 wt,服务器选中了 m 个客户端(集合V),然后将wt只发送给这 m个客户端。 m m m个客户端训练完毕后,服务器端的聚合公式为:

联邦学习FedAvg中模型聚合过程的理解分析

3. 选择

虽然原始论文中对所有K个客户端都进行了聚合,但在真正实现时,感觉用第二种会更好一点,因为如果客户端数量很庞大,每一次通信都会有不小的代价,用第二种会明显降低通信成本。

来源:https://blog.csdn.net/Cyril_KI/article/details/122991420

标签:FedAvg,模型聚合,联邦学习
0
投稿

猜你喜欢

  • Django执行python manage.py makemigrations报错的解决方案分享

    2021-05-23 06:58:05
  • 使用go gin来操作cookie的讲解

    2023-09-12 14:21:49
  • 如何使用Python实现名片管理系统

    2022-11-24 03:13:09
  • 手把手教你Python yLab的绘制折线图的画法

    2023-03-11 21:21:43
  • Python folium的实用功能详解

    2021-08-27 10:07:21
  • Python基于分水岭算法解决走迷宫游戏示例

    2021-08-04 17:41:37
  • SQLSERVER 2005的ROW_NUMBER、RANK、DENSE_RANK的用法

    2024-01-21 02:58:02
  • Linux安装Python3如何和系统自带的Python2并存

    2023-08-25 03:42:09
  • Django实现学生管理系统

    2023-07-22 18:05:59
  • 简单介绍Python中的JSON模块

    2023-12-30 00:16:29
  • Python PyInstaller库基本使用方法分析

    2022-03-19 16:29:46
  • Python在Windows和在Linux下调用动态链接库的教程

    2022-01-10 04:55:51
  • PyCharm 设置数据库,查询数据库语句方式

    2024-01-19 22:05:07
  • Sublime中View in Browser功能不生效问题及解决

    2022-07-03 05:48:16
  • 通过python改变图片特定区域的颜色详解

    2021-09-17 11:01:22
  • 在Python中使用HTML模版的教程

    2023-01-17 23:30:38
  • VB.NET调用MySQL存储过程并获得返回值的方法

    2024-01-12 16:03:45
  • pandas.DataFrame.to_json按行转json的方法

    2022-11-09 11:24:23
  • python批量从es取数据的方法(文档数超过10000)

    2022-03-23 01:21:48
  • Python中的字典遍历备忘

    2021-12-08 05:59:37
  • asp之家 网络编程 m.aspxhome.com