亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 網站 > 幫助中心 > 正文

pytorch之inception

2024-07-09 22:43:01
字體:
來源:轉載
供稿:網友

如下所示:

from __future__ import print_function from __future__ import divisionimport torchimport torch.nn as nnimport torch.optim as optimimport numpy as npimport torchvisionfrom torchvision import datasets, models, transformsimport matplotlib.pyplot as pltimport timeimport osimport copyimport argparseprint("PyTorch Version: ",torch.__version__)print("Torchvision Version: ",torchvision.__version__)# Top level data directory. Here we assume the format of the directory conforms #  to the ImageFolder structure

數據集路徑,路徑下的數據集分為訓練集和測試集,也就是train 以及val,train下分為兩類數據1,2,val集同理

data_dir = "/home/dell/Desktop/data/切割圖像"# Models to choose from [resnet, alexnet, vgg, squeezenet, densenet, inception]model_name = "inception" # Number of classes in the datasetnum_classes = 2#兩類數據1,2# Batch size for training (change depending on how much memory you have)batch_size = 32#batchsize盡量選取合適,否則訓練時會內存溢出# Number of epochs to train for num_epochs = 1000# Flag for feature extracting. When False, we finetune the whole model, #  when True we only update the reshaped layer paramsfeature_extract = True# 參數設置,使得我們能夠手動輸入命令行參數,就是讓風格變得和Linux命令行差不多parser = argparse.ArgumentParser(description='PyTorch inception')parser.add_argument('--outf', default='/home/dell/Desktop/dj/inception/', help='folder to output images and model checkpoints') #輸出結果保存路徑parser.add_argument('--net', default='/home/dell/Desktop/dj/inception/inception.pth', help="path to net (to continue training)") #恢復訓練時的模型路徑args = parser.parse_args()


訓練函數

def train_model(model, dataloaders, criterion, optimizer, num_epochs=25,is_inception=False):  since = time.time()  val_acc_history = []    best_model_wts = copy.deepcopy(model.state_dict())  best_acc = 0.0  print("Start Training, InceptionV3!")   with open("acc.txt", "w") as f1:    with open("log.txt", "w")as f2:      for epoch in range(num_epochs):        print('Epoch {}/{}'.format(epoch+1, num_epochs))        print('*' * 10)        # Each epoch has a training and validation phase        for phase in ['train', 'val']:          if phase == 'train':            model.train() # Set model to training mode          else:            model.eval()  # Set model to evaluate mode              running_loss = 0.0          running_corrects = 0              # Iterate over data.          for inputs, labels in dataloaders[phase]:            inputs = inputs.to(device)            labels = labels.to(device)                # zero the parameter gradients            optimizer.zero_grad()                # forward            # track history if only in train            with torch.set_grad_enabled(phase == 'train'):                            if is_inception and phase == 'train':                # From https://discuss.pytorch.org/t/how-to-optimize-inception-model-with-auxiliary-classifiers/7958                outputs, aux_outputs = model(inputs)                loss1 = criterion(outputs, labels)                loss2 = criterion(aux_outputs, labels)                loss = loss1 + 0.4*loss2              else:                outputs = model(inputs)                loss = criterion(outputs, labels)                  _, preds = torch.max(outputs, 1)                  # backward + optimize only if in training phase              if phase == 'train':                loss.backward()                optimizer.step()                # statistics            running_loss += loss.item() * inputs.size(0)            running_corrects += torch.sum(preds == labels.data)          epoch_loss = running_loss / len(dataloaders[phase].dataset)          epoch_acc = running_corrects.double() / len(dataloaders[phase].dataset)              print('{} Loss: {:.4f} Acc: {:.4f}'.format(phase, epoch_loss, epoch_acc))          f2.write('{} Loss: {:.4f} Acc: {:.4f}'.format(phase, epoch_loss, epoch_acc))          f2.write('/n')          f2.flush()                     # deep copy the model          if phase == 'val':            if (epoch+1)%50==0:              #print('Saving model......')              torch.save(model.state_dict(), '%s/inception_%03d.pth' % (args.outf, epoch + 1))            f1.write("EPOCH=%03d,Accuracy= %.3f%%" % (epoch + 1, epoch_acc))            f1.write('/n')            f1.flush()          if phase == 'val' and epoch_acc > best_acc:            f3 = open("best_acc.txt", "w")            f3.write("EPOCH=%d,best_acc= %.3f%%" % (epoch + 1,epoch_acc))            f3.close()            best_acc = epoch_acc            best_model_wts = copy.deepcopy(model.state_dict())          if phase == 'val':            val_acc_history.append(epoch_acc)  time_elapsed = time.time() - since  print('Training complete in {:.0f}m {:.0f}s'.format(time_elapsed // 60, time_elapsed % 60))  print('Best val Acc: {:4f}'.format(best_acc))  # load best model weights  model.load_state_dict(best_model_wts)  return model, val_acc_history #是否更新參數def set_parameter_requires_grad(model, feature_extracting):  if feature_extracting:    for param in model.parameters():      param.requires_grad = Falsedef initialize_model(model_name, num_classes, feature_extract, use_pretrained=True):  # Initialize these variables which will be set in this if statement. Each of these  #  variables is model specific.  model_ft = None  input_size = 0  if model_name == "resnet":    """ Resnet18    """    model_ft = models.resnet18(pretrained=use_pretrained)    set_parameter_requires_grad(model_ft, feature_extract)    num_ftrs = model_ft.fc.in_features    model_ft.fc = nn.Linear(num_ftrs, num_classes)    input_size = 224  elif model_name == "alexnet":    """ Alexnet    """    model_ft = models.alexnet(pretrained=use_pretrained)    set_parameter_requires_grad(model_ft, feature_extract)    num_ftrs = model_ft.classifier[6].in_features    model_ft.classifier[6] = nn.Linear(num_ftrs,num_classes)    input_size = 224  elif model_name == "vgg":    """ VGG11_bn    """    model_ft = models.vgg11_bn(pretrained=use_pretrained)    set_parameter_requires_grad(model_ft, feature_extract)    num_ftrs = model_ft.classifier[6].in_features    model_ft.classifier[6] = nn.Linear(num_ftrs,num_classes)    input_size = 224  elif model_name == "squeezenet":    """ Squeezenet    """    model_ft = models.squeezenet1_0(pretrained=use_pretrained)    set_parameter_requires_grad(model_ft, feature_extract)    model_ft.classifier[1] = nn.Conv2d(512, num_classes, kernel_size=(1,1), stride=(1,1))    model_ft.num_classes = num_classes    input_size = 224  elif model_name == "densenet":    """ Densenet    """    model_ft = models.densenet121(pretrained=use_pretrained)    set_parameter_requires_grad(model_ft, feature_extract)    num_ftrs = model_ft.classifier.in_features    model_ft.classifier = nn.Linear(num_ftrs, num_classes)     input_size = 224  elif model_name == "inception":    """ Inception v3     Be careful, expects (299,299) sized images and has auxiliary output    """    model_ft = models.inception_v3(pretrained=use_pretrained)    set_parameter_requires_grad(model_ft, feature_extract)    # Handle the auxilary net    num_ftrs = model_ft.AuxLogits.fc.in_features    model_ft.AuxLogits.fc = nn.Linear(num_ftrs, num_classes)    # Handle the primary net    num_ftrs = model_ft.fc.in_features    model_ft.fc = nn.Linear(num_ftrs,num_classes)    input_size = 299  else:    print("Invalid model name, exiting...")    exit()    return model_ft, input_size# Initialize the model for this runmodel_ft, input_size = initialize_model(model_name, num_classes, feature_extract, use_pretrained=True)# Print the model we just instantiated#print(model_ft) #準備數據data_transforms = {  'train': transforms.Compose([    transforms.RandomResizedCrop(input_size),    transforms.RandomHorizontalFlip(),    transforms.ToTensor(),    transforms.Normalize([0.485, 0.456, 0.406], [0.229, 0.224, 0.225])  ]),  'val': transforms.Compose([    transforms.Resize(input_size),    transforms.CenterCrop(input_size),    transforms.ToTensor(),    transforms.Normalize([0.485, 0.456, 0.406], [0.229, 0.224, 0.225])  ]),}print("Initializing Datasets and Dataloaders...")# Create training and validation datasetsimage_datasets = {x: datasets.ImageFolder(os.path.join(data_dir, x), data_transforms[x]) for x in ['train', 'val']}# Create training and validation dataloadersdataloaders_dict = {x: torch.utils.data.DataLoader(image_datasets[x], batch_size=batch_size, shuffle=True, num_workers=0) for x in ['train', 'val']}# Detect if we have a GPU availabledevice = torch.device("cuda:0" if torch.cuda.is_available() else "cpu")'''是否加載之前訓練過的模型we='/home/dell/Desktop/dj/inception_050.pth'model_ft.load_state_dict(torch.load(we))'''# Send the model to GPUmodel_ft = model_ft.to(device)params_to_update = model_ft.parameters()print("Params to learn:")if feature_extract:  params_to_update = []  for name,param in model_ft.named_parameters():    if param.requires_grad == True:      params_to_update.append(param)      print("/t",name)else:  for name,param in model_ft.named_parameters():    if param.requires_grad == True:      print("/t",name)# Observe that all parameters are being optimizedoptimizer_ft = optim.SGD(params_to_update, lr=0.001, momentum=0.9)# Decay LR by a factor of 0.1 every 7 epochs#exp_lr_scheduler = lr_scheduler.StepLR(optimizer_ft, step_size=30, gamma=0.95)# Setup the loss fxncriterion = nn.CrossEntropyLoss()# Train and evaluatemodel_ft, hist = train_model(model_ft, dataloaders_dict, criterion, optimizer_ft, num_epochs=num_epochs, is_inception=(model_name=="inception"))'''#隨機初始化時的訓練程序# Initialize the non-pretrained version of the model used for this runscratch_model,_ = initialize_model(model_name, num_classes, feature_extract=False, use_pretrained=False)scratch_model = scratch_model.to(device)scratch_optimizer = optim.SGD(scratch_model.parameters(), lr=0.001, momentum=0.9)scratch_criterion = nn.CrossEntropyLoss()_,scratch_hist = train_model(scratch_model, dataloaders_dict, scratch_criterion, scratch_optimizer, num_epochs=num_epochs, is_inception=(model_name=="inception"))# Plot the training curves of validation accuracy vs. number # of training epochs for the transfer learning method and# the model trained from scratchohist = []shist = []ohist = [h.cpu().numpy() for h in hist]shist = [h.cpu().numpy() for h in scratch_hist]plt.title("Validation Accuracy vs. Number of Training Epochs")plt.xlabel("Training Epochs")plt.ylabel("Validation Accuracy")plt.plot(range(1,num_epochs+1),ohist,label="Pretrained")plt.plot(range(1,num_epochs+1),shist,label="Scratch")plt.ylim((0,1.))plt.xticks(np.arange(1, num_epochs+1, 1.0))plt.legend()plt.show()'''
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产日韩中文字幕在线| 97香蕉久久夜色精品国产| 97精品国产91久久久久久| 成人激情视频小说免费下载| 国产精品亚洲аv天堂网| 国产精品免费网站| 久久精品一偷一偷国产| 日韩美女免费观看| 亚洲一区二区在线播放| 成人羞羞国产免费| …久久精品99久久香蕉国产| 国产精品男人爽免费视频1| 亚洲性xxxx| 热re91久久精品国99热蜜臀| 欧美激情亚洲视频| 成人欧美一区二区三区在线| 国产精品专区第二| 欧美一级片一区| 亚洲自拍在线观看| 欧美在线亚洲在线| 中日韩美女免费视频网址在线观看| 成人字幕网zmw| 在线视频欧美性高潮| 亚洲欧美日韩国产中文| 九九精品在线观看| 精品亚洲夜色av98在线观看| 日韩中文字幕国产精品| 国产精品久久久久久久久久小说| 欧美高清视频一区二区| 91免费在线视频| 日韩在线观看免费网站| 国产精品高潮呻吟久久av黑人| 国产97在线观看| 日韩国产欧美区| 日韩高清免费在线| 国产精品福利片| 欧美性生交大片免费| 国产亚洲精品高潮| 成人精品视频99在线观看免费| 欧美大秀在线观看| 欧美激情中文字幕乱码免费| 91在线网站视频| 国产精品久久久久久久久免费看| 国产精品高清网站| 欧美丰满片xxx777| 色老头一区二区三区| 亚洲国产精品久久精品怡红院| 国产日韩欧美在线视频观看| 欧美亚洲国产视频| 国产精品视频地址| 一区二区三欧美| 亚洲精品98久久久久久中文字幕| 青草青草久热精品视频在线观看| 欧美激情一区二区三区久久久| 91日本在线观看| 91视频国产高清| 国产精品视频区1| 久久久久久久久久久久av| 国产91在线播放| 亚洲激情免费观看| 九九热精品在线| 国产91精品久久久| 国产欧美日韩视频| 国产在线播放不卡| 亚洲欧美福利视频| 神马国产精品影院av| 国产在线播放91| 人人澡人人澡人人看欧美| 亚洲欧美自拍一区| 国产精品老女人精品视频| 亚洲第一中文字幕在线观看| 欧美另类老女人| 2019亚洲男人天堂| 8090成年在线看片午夜| 国产在线高清精品| 在线观看免费高清视频97| 亚洲欧美制服第一页| 国产成人综合久久| 亚洲精品久久7777777| 91九色视频在线| 久久久噜噜噜久久久| 欧美成人一区二区三区电影| 亚洲自拍另类欧美丝袜| 最近2019中文字幕大全第二页| 日韩中文字幕亚洲| 尤物九九久久国产精品的特点| 亚洲国产日韩精品在线| 亚洲精品一区久久久久久| 韩国视频理论视频久久| 欧美另类暴力丝袜| 亚洲精品自产拍| 久久久久99精品久久久久| 国语自产精品视频在线看抢先版图片| 一本色道久久综合狠狠躁篇怎么玩| 日韩国产精品视频| 亚洲白虎美女被爆操| 欧美日韩国产91| www欧美xxxx| 精品亚洲精品福利线在观看| 国内精品久久久久影院 日本资源| 亚洲第一视频网| www.久久草.com| 久久躁狠狠躁夜夜爽| 亚洲最大的av网站| 色妞久久福利网| 成人在线播放av| 亚洲综合在线小说| 亚洲成人免费在线视频| 狠狠干狠狠久久| 欧美三级欧美成人高清www| 九色91av视频| 成人精品一区二区三区电影黑人| 青青草原一区二区| 亚洲伊人久久大香线蕉av| 日韩精品视频在线观看免费| 欧美在线视频导航| 亚洲永久在线观看| 欧美美女15p| 中文字幕日韩免费视频| 久久91亚洲精品中文字幕奶水| 国产精品久久久久久久久久新婚| 国语自产精品视频在免费| 国产一区二区日韩精品欧美精品| 久久韩国免费视频| 欧美在线影院在线视频| 2019av中文字幕| 欧美精品激情在线观看| 久久久久久久久久av| 在线丨暗呦小u女国产精品| 欧美另类xxx| 亚洲毛茸茸少妇高潮呻吟| 国产精品wwww| 日韩中文字幕在线观看| 国产亚洲欧洲高清| 欧美壮男野外gaytube| 奇米成人av国产一区二区三区| 国产精品老女人视频| 欧美孕妇孕交黑巨大网站| 久久男人av资源网站| 成人国内精品久久久久一区| 97人人模人人爽人人喊中文字| 欧美激情亚洲视频| 国产91热爆ts人妖在线| 亚洲欧美日韩视频一区| 欧美日韩一区二区在线| 91免费在线视频网站| 亚洲系列中文字幕| 成人精品视频在线| 国产成人综合精品在线| 亚洲香蕉av在线一区二区三区| 美女精品视频一区| 欧美成人高清视频| 91美女高潮出水| 日韩美女福利视频| 欧美夫妻性视频| 亚洲2020天天堂在线观看| 国产视频久久网| 97在线观看免费| 欧美精品在线看| 亚洲性xxxx| 一区二区三区视频免费| 欧美在线精品免播放器视频| 亚洲精品av在线| 亚洲成人性视频|