编程语言   发布时间:2022-06-26  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了计算机视觉-街景符号识别3构建模型大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
import os, sys, glob, shutil, json
import cv2

from PIL import Image
import numpy as np

import torch
from torch.utils.data.dataset import Dataset
import torchvision.transforms as transforms

class SVHNDataset(Dataset):
    def __init__(self, img_path, img_label, transform=NonE):
        self.img_path = img_path
        self.img_label = img_label 
        if transform is not None:
            self.transform = transform
        else:
            self.transform = None

    def __getitem__(self, indeX):
        img = Image.open(self.img_path[index]).convert('RGB')

        if self.transform is not None:
            img = self.transform(img)
        
        # 原始SVHN中类别10为数字0
        lbl = np.array(self.img_label[index], dtype=np.int)
        lbl = list(lbl)  + (5 - len(lbl)) * [10]
        
        return img, torch.from_numpy(np.array(lbl[:5]))

    def __len__(self):
        return len(self.img_path)

@R_197_9829@n_path = glob.glob('./mchar_@R_197_9829@n/*.png')
@R_197_9829@n_path.sort()
@R_197_9829@n_json = json.load(open('@R_197_9829@n.json'))
@R_197_9829@n_label = [@R_197_9829@n_json[x]['label'] for x in @R_197_9829@n_json]

@R_197_9829@n_loader = torch.utils.data.DataLoader(
        SVHNDataset(@R_197_9829@n_path, @R_197_9829@n_label,
                   transforms.Compose([
                       transforms.Resize((64, 128)),
                       transforms.ColorJitter(0.3, 0.3, 0.2),
                       transforms.RandomRotation(5),
                       transforms.ToTensor(),
                       transforms.Normalize([0.485, 0.456, 0.406], [0.229, 0.224, 0.225])
            ])), 
    batch_size=10, # 每批样本个数
    shuffle=false, # 是否打乱顺序
    num_workers=0, # 读取的线程个数
)

torch.manual_seed(0)
torch.BACkends.cudnn.deterministic = false
torch.BACkends.cudnn.benchmark = True

import torchvision.models as models
import torchvision.transforms as transforms
import torchvision.datasets as datasets
import torch.nn as nn
import torch.nn.functional as F
import torch.optim as optim
from torch.autograd import Variable
from torch.utils.data.dataset import Dataset

# 定义模型
class SVHN_Model1(nn.ModulE):
    def __init__(self):
        super(SVHN_Model1, self).__init__()
        # CNN提取特征模块
        self.cnn = nn.Sequential(
            nn.Co@R_696_11356@d(3, 16, kernel_size=(3, 3), Stride=(2, 2)),
            nn.ReLU(),  
            nn.MaxPool2d(2),
            nn.Co@R_696_11356@d(16, 32, kernel_size=(3, 3), Stride=(2, 2)),
            nn.ReLU(), 
            nn.MaxPool2d(2),
        )
        # 
        self.fc1 = nn.Linear(32*3*7, 11)
        self.fc2 = nn.Linear(32*3*7, 11)
        self.fc3 = nn.Linear(32*3*7, 11)
        self.fc4 = nn.Linear(32*3*7, 11)
        self.fc5 = nn.Linear(32*3*7, 11)
        self.fc6 = nn.Linear(32*3*7, 11)
    
    def forWARD(self, img):        
        feat = self.cnn(img)
        feat = feat.view(feat.shape[0], -1)
        c1 = self.fc1(feat)
        c2 = self.fc2(feat)
        c3 = self.fc3(feat)
        c4 = self.fc4(feat)
        c5 = self.fc5(feat)
        c6 = self.fc6(feat)
        return c1, c2, c3, c4, c5, c6
    
model = SVHN_Model1()
device=torch.device("cuda")#设置GPU
# 损失函数
criterion = nn.CrossEntropyLoss()
criterion = criterion.to(devicE)#损失函数在GPU上运行
model= model.to(devicE)#模型放在GPU上
# 优化器
optimizer = torch.optim.Adam(model.parameters(), 0.005)
optimizer
loss_plot, c0_plot = [], []
# 迭代10个Epoch
for epoch in range(10):
    for data in @R_197_9829@n_loader:
        img,target=data
        img=img.to(devicE)#输入图片放在GPU上
        target=target.to(devicE)#输入的标签放在GPU上
        c0, c1, c2, c3, c4, c5 = model(img)
        loss = criterion(c0, target[:, 0].long()) + 
                criterion(c1, target[:, 1].long()) + 
                criterion(c2, target[:, 2].long()) + 
                criterion(c3, target[:, 3].long()) + 
                criterion(c4, target[:, 4].long()) 
        loss /= 5
       
        optimizer.zero_grad()
        loss.BACkWARD()
        optimizer.step()
        
        loss_plot.append(loss.item())
        c0_plot.append((c0.argmax(1) == target[:, 0]).sum().item()*1.0 / c0.shape[0])
        
    print(epoch)

torch.save(model,"@H_785_70@moxing")

 

大佬总结

以上是大佬教程为你收集整理的计算机视觉-街景符号识别3构建模型全部内容,希望文章能够帮你解决计算机视觉-街景符号识别3构建模型所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。