取PyTorch中两个网络的权重平均值

pat*_*_ai 6 python neural-network deep-learning pytorch

假设在PyTorch我有model1model2它有相同的架构.他们接受了相同数据的进一步培训,或者一个模型是othter的早期版本,但它在技术上与问题无关.现在,我想设置的权重model是的权重的平均model1model2.我怎么能在PyTorch中这样做?

Lit*_*one 7

beta = 0.5 #The interpolation parameter    
params1 = model1.named_parameters()
params2 = model2.named_parameters()

dict_params2 = dict(params2)

for name1, param1 in params1:
    if name1 in dict_params2:
        dict_params2[name1].data.copy_(beta*param1.data + (1-beta)*dict_params2[name1].data)

model.load_state_dict(dict_params2)
Run Code Online (Sandbox Code Playgroud)

取自pytorch论坛.您可以抓取参数,转换并加载它们,但要确保尺寸匹配.

此外,我真的很想知道你的发现与这些..

  • 谢谢 :) !通常在 stackoverflow 中,当您链接到外部源时,您还希望重新复制答案中的相关信息,因为该链接最终可能会成为死链接,或者其中的信息可能会发生变化。我赞成,但如果您可以通过重新复制链接到的页面的相关部分来提供完整的答案,我将能够接受答案。 (2认同)
  • @patapouf_ai 不知道。谢谢。 (2认同)