Fetch the repository succeeded.
import argparse
import os
import torch
import torch.nn.parallel
import torch.optim
import torch.utils.data
import torch.utils.data.distributed
from repvgg import get_RepVGG_func_by_name, repvgg_model_convert
parser = argparse.ArgumentParser(description='RepVGG Conversion')
parser.add_argument('load', metavar='LOAD', help='path to the weights file')
parser.add_argument('save', metavar='SAVE', help='path to the weights file')
parser.add_argument('-a', '--arch', metavar='ARCH', default='RepVGG-A0')
def convert():
args = parser.parse_args()
if 'plus' in args.arch:
from repvggplus import get_RepVGGplus_func_by_name
train_model = get_RepVGGplus_func_by_name(args.arch)(deploy=False, use_checkpoint=False)
else:
repvgg_build_func = get_RepVGG_func_by_name(args.arch)
train_model = repvgg_build_func(deploy=False)
if os.path.isfile(args.load):
print("=> loading checkpoint '{}'".format(args.load))
checkpoint = torch.load(args.load)
if 'state_dict' in checkpoint:
checkpoint = checkpoint['state_dict']
elif 'model' in checkpoint:
checkpoint = checkpoint['model']
ckpt = {k.replace('module.', ''): v for k, v in checkpoint.items()} # strip the names
print(ckpt.keys())
train_model.load_state_dict(ckpt)
else:
print("=> no checkpoint found at '{}'".format(args.load))
if 'plus' in args.arch:
train_model.switch_repvggplus_to_deploy()
torch.save(train_model.state_dict(), args.save)
else:
repvgg_model_convert(train_model, save_path=args.save)
if __name__ == '__main__':
convert()
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。