|
|
@@ -27,12 +27,12 @@ def create(name, pretrained, channels, classes): |
|
|
|
Returns: |
|
|
|
pytorch model |
|
|
|
""" |
|
|
|
config = os.path.join(os.path.dirname(__file__), 'models', '%s.yaml' % name) |
|
|
|
config = os.path.join(os.path.dirname(__file__), 'models', '%s.yaml' % name) # model.yaml path |
|
|
|
model = Model(config, channels, classes) |
|
|
|
if pretrained: |
|
|
|
ckpt = '%s.pt' % name # checkpoint filename |
|
|
|
google_utils.attempt_download(ckpt) # download if not found locally |
|
|
|
state_dict = torch.load(ckpt)['model'].state_dict() |
|
|
|
state_dict = torch.load(ckpt, map_location=torch.device('cpu'))['model'].state_dict() |
|
|
|
state_dict = {k: v for k, v in state_dict.items() if model.state_dict()[k].numel() == v.numel()} # filter |
|
|
|
model.load_state_dict(state_dict, strict=False) # load |
|
|
|
return model |