IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 同步联邦学习 VS 异步联邦学习 -> 正文阅读

[人工智能]同步联邦学习 VS 异步联邦学习

FedAvg & ASYNCHRONOUS FEDERATED OPTIMIZATION

FedAvg

同步更新方案:

? There is a fixed set of K clients, each with a fixed local dataset.

? At the beginning of each round,a random fraction C of clients is selected, and the server sends the current global algorithm state to each of these
clients (e.g., the current model parameters). We only select a fraction of clients for efficiency, as our experiments show diminishing returns for adding more clients beyond a certain point.

? Each selected client then performs local computation based on the global state and its local dataset, and sends an update to the server.

? The server then applies these updates to its global state, and the process repeats.

引入SGD

最近大量深度学习的成功应用几乎完全依赖于随机梯度下降的变体进行优化;
许多进展可以理解为通过调整模型的结构(和损失函数),使其更易于使用简单的基于梯度的方法进行优化。
因此,我们很自然地从SGD开始建立联邦优化算法

FedAVG计算开销由三个关键参数控制:

C:每轮通信,执行计算的客户端比例,C=1表示所有用户均参与;
E:每轮通信,每个客户对其本地数据集进行的训练次数;
B:用于客户端更新的本地小批量大小。B=∞表示整个本地数据集被视为单个小批次。

基线算法——FedSGD = FedAVG|B=∞,E=1

SGD可以直接应用于联邦优化问题,即每轮通信在随机选择的客户端上进行一次批处理梯度计算
每个客户端使用其本地数据在当前模型上进行一步梯度下降,然后服务器对结果模型进行加权平均。

FedAVG
通过在平均模型之前多次迭代本地更新来为每个客户端增加更多的计算。

FedAVG算法

在这里插入图片描述

模型从相同的初始化开始很重要

在这里插入图片描述
实验说明:
? 使用θw+(1-θ)w’对两个模型w和w’的参数求平均值,研究不同θ时整个MNIST训练集的损失。
? 左图,w和w’使用不同的随机种子初始化;
? 右图,两个模型从相同的初始化开始。
? 水平线给出了由w或w0实现的最佳损耗。

结论:
右图:当从相同初始化开始两个模型,然后在不同数据子集上独立训练每个模型时,发现参数平均的效果出奇地好

FedAsync

同步联邦优化的问题:

the synchronous flavor of federated optimization is potentially unscalable, inefficient, and inflexible.
1、设备过多会导致服务器端网络拥塞。

2、由于计算能力和电池时间有限,任务调度因设备而异,因此很难在每个时期结束时同步所选设备。

3、服务器必须确定一个超时阈值来丢弃掉队者。如果幸存设备的数量太少,服务器可能必须丢弃包含接收更新的整个时期。

解决:异步联邦优化

key idea:use a weighted average to update the global model
The mixing weight can also be set adaptively as a function of the staleness.
每当服务器收到本地模型时,它就会立即更新全局模型。

问题公式化:

在这里插入图片描述
在这里插入图片描述

方法:

在服务器端,有两个并行异步运行的线程: 调度器和更新器。
? 在第t个全局时期,服务器接收本地训练的模型,更新全局模型:
? 因为更大的陈旧导致更新全局模型时更大的误差,所以减小α以减轻由陈旧性引起的误差。

系统概述

在这里插入图片描述
1 (调度程序)和 5 (更新程序) 异步并行,因此服务器可以随时在设备上触发训练任务,设备可以随时将本地更新的模型推送到服务器。

异步算法

在这里插入图片描述

实验结果表明:

? 当整体陈旧度较小时,FedAsync收敛速度和SGD一样快,比FedAvg还快。
? 当陈旧度较大时,FedAsync收敛较慢。最坏的情况下,FedAsync的收敛速度和FedAvg差不多。
? 当α太大时,收敛会不稳定。

相比FedAvg, FedAsync的优势

? Efficiency: FedAsync可随时接收更新,而FedAvg要等到足够的设备响应;
在陈旧度较小时,FedAsync收敛速度更快,最差陈旧度大时也跟FedAvg差不多。

? Flexibility: 如果一些设备端不再有资格执行培训任务(设备不再空闲、充电或未连接网络),
他们可以暂时保存工作空间,之后继续培训或将培训后的模型传送到服务器。

? Scalability: FedAsync 可以处理更多并行运行的设备端。
服务器只需要随机化工作人员的响应时间,以避免网络拥塞。

总结:

为了提高灵活性和可扩展性,作者提出了一种新的异步联邦优化算法。证明了对于强凸和非强凸问题,以及有限非凸问题,所提出的方法具有接近线性收敛的全局最优解。实验结果表明,该算法收敛速度快,能够容忍陈旧性。

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2021-07-31 16:38:15  更:2021-07-31 16:41:21 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年12日历 -2024/12/22 9:50:22-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码