参数服务器(PS)

参数服务器(parameter server)

作用:用来管理和共享模型参数,将模型参数存储在一个或多个中央服务器上,并通过网络将这些参数共享给参与训练的各个计算节点

PS架构中有两个角色:parameter server和worker

parameter server将被视为master节点,保存模型的权重和反向计算的梯度值,并使用优化器通过 Worker 上传的梯度值对模型进行更新。

worker充当计算节点负责模型训练,执行网络的正反向计算,反向计算的梯度值通过 Push 接口上传至 Server 中,通过 Pull 接口把 Server 更新好的模型下载到 Worker 本地。

整个系统的工作流程分为4个阶段:

  1. Pull Weights: 所有worker从参数服务器获取权重参数
  2. Push Gradients: 每一个worker使用本地的训练数据训练本地模型,生成本地梯度,之后将梯度上传参数服务器
  3. Aggregate Gradients:收集到所有计算节点发送的梯度后,对梯度进行求和
  4. Model Update:计算出累加梯度,参数服务器使用这个累加梯度来更新位于集中服务器上的模型参数

将模型划分为N个参数服务器,每个参数服务器负责更新1/N的模型参数。实际上是将模型参数分片(sharded model)并存储在多个参数服务器上,可以缓解参数服务器一侧的网络瓶颈问题,使得参数服务器之间的通信负载减少,提高整体的通信效率。

注意:

  • 数据分配:每个worker分配到的数据通常是不相同的,这是为了确保数据的多样性和模型的泛化能力。
  • 参数分配:在参数服务器架构中,所有的worker共享同一套模型参数,这些参数存储在参数服务器上,worker通过网络获取和更新这些参数。
  • 6
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PS(Parameter Server)是一种分布式训练框架,可以实现多台计算机的协同计算,提高模型训练的速度和效果。 在PS多PC协同计算中,一台计算机被指定为参数服务器,负责存储和更新模型的参数。其他计算机作为工作节点,负责接收参数服务器的指令,并参与模型的训练和优化。 在训练过程中,各个工作节点不断地将本地计算的梯度传递给参数服务器参数服务器根据传递的梯度来更新模型的参数。这样,多个工作节点可以同时参与训练,每个工作节点只需计算一部分样本的梯度,大大减少了计算量和训练时间。 PS多PC协同计算具有以下优点: 1. 加速训练过程:多台计算机同时进行模型训练,大大加快了训练速度,可处理更大规模的数据集和复杂的模型。 2. 分布式存储:参数服务器负责存储模型参数,工作节点只需传递梯度,减少了通信开销。 3. 灵活性:可以根据需要动态扩展计算节点,实现弹性计算,根据任务的需求进行资源的分配。 4. 容错性:当某个计算节点出现故障时,可以通过备份节点恢复工作,整体系统的稳定性更高。 5. 可拓展性:PS框架可以在分布式环境中轻松部署和管理,支持跨平台的参数传输和模型更新。 总而言之,PS多PC协同计算是一种高效的分布式训练框架,可加速模型训练过程,并在处理大规模数据集和复杂模型时发挥其优势。它具有分布式存储、灵活性、容错性和可拓展性等优点,是目前深度学习领域广泛应用的一种技术。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值