单机多卡并行计算填坑记:keras

keras的单机多卡并行计算简单粗暴,可是。。。。。。。

训练一时爽,重载火葬场,哭哭。下面上干货

首先单CPU/GPU模型转多GPU模型:

from keras.utils import multi_gpu_model
model = getmodel()#单卡模型
n_GPUs = 3# >=2
mode_M = multi_gpu_model(model,n_GPUs)# ok,转好了

是不是简单粗暴啊,然而问题来了,当训练完成之后该如何保存呢?注意mode_M在训练后还是并行模型,直接保存将不再适用单卡的载入和使用,必需要在同样的环境下才能读入,因此我们应该:

model.save("model.h5")

这样我们在载入模型时就不会出现某些神奇的问题比如只剩一层模型这样的骚操作。(哭哭)

可是当我们想保存检查点的时候,问题就来了,保存的全是并行模型(再哭哭)。为了解决这个问题可在多卡端将该模型转成单卡模型即可解决。

from keras.utils import multi_gpu_model
model_dir = ""
model = get_model()
n_GPUs = 2
model_M = multi_gpu_model(model,n_GPUs)
model_M.load_weights(model_dir)
model.summary()#验证一下
model.save(model_dir)

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值