當前位置: 首頁>>代碼示例>>Python>>正文


Python torchvision.models方法代碼示例

本文整理匯總了Python中torchvision.models方法的典型用法代碼示例。如果您正苦於以下問題:Python torchvision.models方法的具體用法?Python torchvision.models怎麽用?Python torchvision.models使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在torchvision的用法示例。


在下文中一共展示了torchvision.models方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: build_model

# 需要導入模塊: import torchvision [as 別名]
# 或者: from torchvision import models [as 別名]
def build_model(args):
  if not hasattr(torchvision.models, args.model):
    raise ValueError('Invalid model "%s"' % args.model)
  if not 'resnet' in args.model:
    raise ValueError('Feature extraction only supports ResNets')
  cnn = getattr(torchvision.models, args.model)(pretrained=True)
  layers = [
    cnn.conv1,
    cnn.bn1,
    cnn.relu,
    cnn.maxpool,
  ]
  for i in range(args.model_stage):
    name = 'layer%d' % (i + 1)
    layers.append(getattr(cnn, name))
  model = torch.nn.Sequential(*layers)
  model.cuda()
  model.eval()
  return model 
開發者ID:stanfordnlp,項目名稱:mac-network,代碼行數:21,代碼來源:extract_features.py

示例2: main

# 需要導入模塊: import torchvision [as 別名]
# 或者: from torchvision import models [as 別名]
def main():
    test_args = parse_args()

    args = joblib.load('models/%s/args.pkl' %test_args.name)

    folds = []
    losses = []
    scores = []
    for fold in range(args.n_splits):
        log_path = 'models/%s/log_%d.csv' %(args.name, fold+1)
        if not os.path.exists(log_path):
            continue
        log = pd.read_csv('models/%s/log_%d.csv' %(args.name, fold+1))
        loss, score = log.loc[log['val_loss'].values.argmin(), ['val_loss', 'val_score']].values
        print(loss, score)
        folds.append(str(fold+1))
        losses.append(loss)
        scores.append(score)
    results = pd.DataFrame({
        'fold': folds + ['mean'],
        'loss': losses + [np.mean(losses)],
        'score': scores + [np.mean(scores)],
    })
    print(results)
    results.to_csv('models/%s/results.csv' % args.name, index=False) 
開發者ID:4uiiurz1,項目名稱:kaggle-aptos2019-blindness-detection,代碼行數:27,代碼來源:make_results.py

示例3: make_layers

# 需要導入模塊: import torchvision [as 別名]
# 或者: from torchvision import models [as 別名]
def make_layers(cfg, batch_norm=False):
    """This is almost verbatim from torchvision.models.vgg, except that the
    MaxPool2d modules are configured with ceil_mode=True.
    """
    layers = []
    in_channels = 3
    for v in cfg:
        if v == 'M':
            layers.append(nn.MaxPool2d(kernel_size=2, stride=2, ceil_mode=True))
        else:
            conv2d = nn.Conv2d(in_channels, v, kernel_size=3, padding=1)
            modules = [conv2d, nn.ReLU(inplace=True)]
            if batch_norm:
                modules.insert(1, nn.BatchNorm2d(v))
            layers.extend(modules)
            in_channels = v
    return nn.Sequential(*layers) 
開發者ID:jhoffman,項目名稱:cycada_release,代碼行數:19,代碼來源:fcn8s.py

示例4: __init__

# 需要導入模塊: import torchvision [as 別名]
# 或者: from torchvision import models [as 別名]
def __init__(self):
        super(weightNet, self).__init__()
        self.resnet = ClassificationNetwork()
        self.resnet.load_state_dict(torch.load('models/'+str(args.network)+'.t7', map_location=lambda storage, loc: storage))
        print('loading ',str(args.network))

        self.conv1 = self.resnet.convnet.conv1
        self.conv1.load_state_dict(self.resnet.convnet.conv1.state_dict())
        self.bn1 = self.resnet.convnet.bn1
        self.bn1.load_state_dict(self.resnet.convnet.bn1.state_dict())
        self.relu = self.resnet.convnet.relu
        self.maxpool = self.resnet.convnet.maxpool
        self.layer1 = self.resnet.convnet.layer1
        self.layer1.load_state_dict(self.resnet.convnet.layer1.state_dict())
        self.layer2 = self.resnet.convnet.layer2
        self.layer2.load_state_dict(self.resnet.convnet.layer2.state_dict())
        self.layer3 = self.resnet.convnet.layer3
        self.layer3.load_state_dict(self.resnet.convnet.layer3.state_dict())
        self.layer4 = self.resnet.convnet.layer4
        self.layer4.load_state_dict(self.resnet.convnet.layer4.state_dict())
        self.layer4 = self.resnet.convnet.layer4
        self.layer4.load_state_dict(self.resnet.convnet.layer4.state_dict())
        self.avgpool = self.resnet.convnet.avgpool 
開發者ID:tankche1,項目名稱:IDeMe-Net,代碼行數:25,代碼來源:onlyBasetwoLoss.py

示例5: build_model

# 需要導入模塊: import torchvision [as 別名]
# 或者: from torchvision import models [as 別名]
def build_model(args):
    if not hasattr(torchvision.models, args.model):
        raise ValueError('Invalid model "%s"' % args.model)
    if not 'resnet' in args.model:
        raise ValueError('Feature extraction only supports ResNets')

    cnn = getattr(torchvision.models, args.model)(pretrained=True)
    layers = [cnn.conv1, 
              cnn.bn1,
              cnn.relu,
              cnn.maxpool]
    for i in range(args.model_stage):
        name = 'layer%d' % (i + 1)
        layers.append(getattr(cnn, name))

    model = torch.nn.Sequential(*layers)
    model.cuda()
    model.eval()
    return model 
開發者ID:MILVLG,項目名稱:openvqa,代碼行數:21,代碼來源:clevr_extract_feat.py

示例6: _test_model

# 需要導入模塊: import torchvision [as 別名]
# 或者: from torchvision import models [as 別名]
def _test_model(self, model_config):
        """This test will build ResNeXt-* models, run a forward pass and
        verify output shape, and then verify that get / set state
        works.

        I do this in one test so that we construct the model a minimum
        number of times.
        """
        model = build_model(model_config)

        # Verify forward pass works
        input = torch.ones([1, 3, 32, 32])
        output = model.forward(input)
        self.assertEqual(output.size(), (1, 1000))

        # Verify get_set_state
        new_model = build_model(model_config)
        state = model.get_classy_state()
        new_model.set_classy_state(state)
        new_state = new_model.get_classy_state()

        compare_model_state(self, state, new_state, check_heads=True) 
開發者ID:facebookresearch,項目名稱:ClassyVision,代碼行數:24,代碼來源:models_resnext_test.py

示例7: __init__

# 需要導入模塊: import torchvision [as 別名]
# 或者: from torchvision import models [as 別名]
def __init__(self, name: str, frozen_start: bool, fp16: bool):
        super().__init__()
        if name.endswith('_wsl'):
            self.base = torch.hub.load('facebookresearch/WSL-Images', name)
        else:
            self.base = getattr(models, name)(pretrained=True)
        self.frozen_start = frozen_start
        self.fp16 = fp16
        if name == 'resnet34':
            self.out_features_l1 = 256
            self.out_features_l2 = 512
        else:
            self.out_features_l1 = 512
            self.out_features_l2 = 1024

        self.frozen = []
        if self.frozen_start:
            self.frozen = [self.base.layer1, self.base.conv1, self.base.bn1]
            for m in self.frozen:
                self._freeze(m) 
開發者ID:lopuhin,項目名稱:kaggle-kuzushiji-2019,代碼行數:22,代碼來源:models.py

示例8: __init__

# 需要導入模塊: import torchvision [as 別名]
# 或者: from torchvision import models [as 別名]
def __init__(
        self,
        name: str = "resnet50",
        visual_feature_size: int = 2048,
        pretrained: bool = False,
        frozen: bool = False,
    ):
        super().__init__(visual_feature_size)

        self.cnn = getattr(torchvision.models, name)(
            pretrained, zero_init_residual=True
        )
        # Do nothing after the final residual stage.
        self.cnn.fc = nn.Identity()

        # Freeze all weights if specified.
        if frozen:
            for param in self.cnn.parameters():
                param.requires_grad = False
            self.cnn.eval()

        # Keep a list of intermediate layer names.
        self._stage_names = [f"layer{i}" for i in range(1, 5)] 
開發者ID:kdexd,項目名稱:virtex,代碼行數:25,代碼來源:visual_backbones.py

示例9: parseArgs

# 需要導入模塊: import torchvision [as 別名]
# 或者: from torchvision import models [as 別名]
def parseArgs():
	parser = argparse.ArgumentParser(prog=sys.argv[0],
				description="Run popular imagenet models.")

	parser.add_argument("-m",
		type=str,
		default="resnet50",
		choices=["alexnet", "densenet121", "densenet161", "densenet169",
			"densenet201", "googlenet", "mnasnet0_5", "mnasnet0_75",
			"mnasnet1_0", "mnasnet1_3", "mobilenet_v2", "resnet18",
			"resnet34", "resnet50", "resnet101", "resnet152", "resnext50_32x4d",
			"resnext101_32x8d", "wide_resnet50_2", "wide_resnet101_2",
			"shufflenet_v2_x0_5", "shufflenet_v2_x1_0", "shufflenet_v2_x1_5",
			"shufflenet_v2_x2_0", "squeezenet1_0", "squeezenet1_1", "vgg11",
			"vgg11_bn", "vgg13", "vgg13_bn", "vgg16", "vgg16_bn", "vgg19",
			"vgg19_bn", "inception_v3"],
		help="Model.")

	parser.add_argument("-b",
		type=int,
		default=32,
		help="Batch size.")

	args = parser.parse_args()
	return args 
開發者ID:adityaiitb,項目名稱:pyprof2,代碼行數:27,代碼來源:imagenet.py

示例10: __init__

# 需要導入模塊: import torchvision [as 別名]
# 或者: from torchvision import models [as 別名]
def __init__(self, in_channels, backbone, out_channels_gcn=(85, 128), kernel_sizes=(5, 7)):
        super(ResnetGCN, self).__init__()
        resnet = getattr(torchvision.models, backbone)(pretrained=False)

        if in_channels == 3: conv1 = resnet.conv1
        else: conv1 = nn.Conv2d(in_channels, 64, kernel_size=7, stride=2, padding=3, bias=False)
        self.initial = nn.Sequential(
            conv1,
            resnet.bn1,
            resnet.relu,
            resnet.maxpool)
        
        self.layer1 = resnet.layer1
        self.layer2 = resnet.layer2
        self.layer3 = nn.Sequential(
            BottleneckGCN(512, 1024, kernel_sizes[0], out_channels_gcn[0], stride=2),
            *[BottleneckGCN(1024, 1024, kernel_sizes[0], out_channels_gcn[0])]*5)
        self.layer4 = nn.Sequential(
            BottleneckGCN(1024, 2048, kernel_sizes[1], out_channels_gcn[1], stride=2),
            *[BottleneckGCN(1024, 1024, kernel_sizes[1], out_channels_gcn[1])]*5)
        initialize_weights(self) 
開發者ID:yassouali,項目名稱:pytorch_segmentation,代碼行數:23,代碼來源:gcn.py

示例11: get_resnet_pretrained

# 需要導入模塊: import torchvision [as 別名]
# 或者: from torchvision import models [as 別名]
def get_resnet_pretrained(self, archi_type, feat_length, grayscale=True):
        from torchvision import models
        model = getattr(models, archi_type)(pretrained=True)
        in_features = model.fc.in_features
        if grayscale:
        # replace the first convolution layer     
            stride = model.conv1.kernel_size
            padding = model.conv1.padding
            kernel_size = model.conv1.kernel_size
            out_channels = model.conv1.out_channels
            del model.conv1
            model.conv1 = nn.Conv2d(1, out_channels, kernel_size, stride, padding)
        # replace the FC layer
        del model.fc
        model.fc = nn.Linear(in_features, feat_length, bias=True)                            
        return model 
開發者ID:Nicholasli1995,項目名稱:VisualizingNDF,代碼行數:18,代碼來源:ndf.py

示例12: make_layers

# 需要導入模塊: import torchvision [as 別名]
# 或者: from torchvision import models [as 別名]
def make_layers(cfg, batch_norm=False):
	"""This is almost verbatim from torchvision.models.vgg, except that the
	MaxPool2d modules are configured with ceil_mode=True.
	"""
	layers = []
	in_channels = 3
	for v in cfg:
		if v == 'M':
			layers.append(nn.MaxPool2d(kernel_size=2, stride=2, ceil_mode=True))
		else:
			conv2d = nn.Conv2d(in_channels, v, kernel_size=3, padding=1)
			modules = [conv2d, nn.ReLU(inplace=True)]
			if batch_norm:
				modules.insert(1, nn.BatchNorm2d(v))
			layers.extend(modules)
			in_channels = v
	return nn.Sequential(*layers) 
開發者ID:Luodian,項目名稱:MADAN,代碼行數:19,代碼來源:fcn8s.py

示例13: test_channel_dependency

# 需要導入模塊: import torchvision [as 別名]
# 或者: from torchvision import models [as 別名]
def test_channel_dependency(self):
        outdir = os.path.join(prefix, 'dependency')
        os.makedirs(outdir, exist_ok=True)
        for name in model_names:
            print('Analyze channel dependency for %s' % name)
            model = getattr(models, name)
            net = model().to(device)
            dummy_input = torch.ones(1, 3, 224, 224).to(device)
            channel_depen = ChannelDependency(net, dummy_input)
            depen_sets = channel_depen.dependency_sets
            d_set_count = 0
            for d_set in depen_sets:
                if len(d_set) > 1:
                    d_set_count += 1
                    assert d_set in channel_dependency_ground_truth[name]
            assert d_set_count == len(channel_dependency_ground_truth[name])
            fpath = os.path.join(outdir, name)
            channel_depen.export(fpath) 
開發者ID:microsoft,項目名稱:nni,代碼行數:20,代碼來源:test_compression_utils.py

示例14: __init__

# 需要導入模塊: import torchvision [as 別名]
# 或者: from torchvision import models [as 別名]
def __init__(self, args):
        super(AlexNetFc, self).__init__()
        self.base_model = torchvision.models.alexnet(pretrained=True)
        self.features = self.base_model.features
        self.classifier = nn.Sequential()
        for i in range(6):
            self.classifier.add_module("classifier" + str(i), self.base_model.classifier[i])
        self.feature_layers = nn.Sequential(self.features, self.classifier)

        self.hash_bit = args.hash_bit
        feature_dim = self.base_model.classifier[6].in_features
        self.fc1 = nn.Linear(feature_dim, feature_dim)
        self.activation1 = nn.ReLU()
        self.fc2 = nn.Linear(feature_dim, feature_dim)
        self.activation2 = nn.ReLU()
        self.fc3 = nn.Linear(feature_dim, self.hash_bit)
        self.last_layer = nn.Tanh()
        self.dropout = nn.Dropout(0.5)
        self.hash_layer = nn.Sequential(self.fc1, self.activation1, self.fc2, self.activation2, self.fc3,
                                        self.last_layer) 
開發者ID:yuanli2333,項目名稱:Hadamard-Matrix-for-hashing,代碼行數:22,代碼來源:network.py

示例15: __build_model

# 需要導入模塊: import torchvision [as 別名]
# 或者: from torchvision import models [as 別名]
def __build_model(self):
        """Define model layers & loss."""

        # 1. Load pre-trained network:
        model_func = getattr(models, self.backbone)
        backbone = model_func(pretrained=True)

        _layers = list(backbone.children())[:-1]
        self.feature_extractor = torch.nn.Sequential(*_layers)
        freeze(module=self.feature_extractor, train_bn=self.train_bn)

        # 2. Classifier:
        _fc_layers = [torch.nn.Linear(2048, 256),
                      torch.nn.Linear(256, 32),
                      torch.nn.Linear(32, 1)]
        self.fc = torch.nn.Sequential(*_fc_layers)

        # 3. Loss:
        self.loss_func = F.binary_cross_entropy_with_logits 
開發者ID:PyTorchLightning,項目名稱:pytorch-lightning,代碼行數:21,代碼來源:computer_vision_fine_tuning.py


注:本文中的torchvision.models方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。