欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python 如何給圖像分類(圖像識別模型構建)

 更新時間:2022年06月14日 09:33:04   作者:編程學習網  
這篇文章主要介紹了Python 教你如何給圖像分類,今天的文章主要是講圖像識別模型如何構建,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下

在日常生活中總是有給圖像分類的場景,比如垃圾分類、不同場景的圖像分類等;今天的文章主要是基于圖像識別場景進行模型構建。圖像識別是通過 Python深度學習來進行模型訓練,再使用模型對上傳的電子表單進行自動審核與比對后反饋相應的結果。主要是利用 Python Torchvision 來構造模型,Torchvision 服務于Pytorch 深度學習框架,主要是用來生成圖片、視頻數據集以及訓練模型。

模型構建

構建模型為了直觀,需要使用 Jupyter notebook 進行模型的構建,

導入所需包

圖像識別需要用到深度學習相關模塊,所以需要導入相應的包,具體導入的包如下:

%reload_ext autoreload
%autoreload 2
import torch
from torch.utils.data import DataLoader
from torchvision.datasets import ImageFolder
from torchvision import transforms as tfs
from torchvision import models
from torch import nn
import matplotlib.pyplot as plt
%matplotlib inline
import os
os.environ["KMP_DUPLICATE_LIB_OK"]="TRUE"

是否使用 GPU

模型的訓練主要方式是基于 GPU 或者 CPU 訓練,在沒有 GPU 的條件下就在 CPU 下進行訓練,模型的訓練需要花費一定的時間,訓練時長根據訓練集的數據和硬件性能而定,訓練結果精確性根據數據的多少和準確性而且,深度學習需要大量的素材才能判斷出精確的結果,所以需要申明使用 CPU 進行訓練:

# 是否使用GPU
use_gpu = False

數據增強

將拿到的數據進行訓練集的數據預處理并設置訓練分層數,再將拿到的圖片進行水平翻轉后對圖片進行剪裁, 剪裁后將圖片進行隨機翻轉,增強隨機對比度以及圖片顏色變化

# 數據增強
train_transform = tfs.Compose([
    # 訓練集的數據預處理
    tfs.Resize([224, 224]),
    tfs.RandomHorizontalFlip(),
    tfs.RandomCrop(128),
    tfs.ToTensor(),
    tfs.Normalize([0.5,0.5,0.5], [0.5,0.5,0.5])
])
test_transform = tfs.Compose([
    tfs.Resize([224,224]),
#     tfs.RandomCrop(128),
    tfs.ToTensor(),
    tfs.Normalize([0.5,0.5,0.5], [0.5,0.5,0.5])
])
# 每一個batch的數據集數目
batch_size = 10

數據集和驗證集準備

模型訓練需要準備數據集和驗證集,只有足夠的照片才能得到更精準的答案。訓練集和驗證集部分代碼如下:

# 構建訓練集和驗證集
# 
train_set = ImageFolder('./dataset1/train', train_transform)
train_data = DataLoader(train_set, batch_size, shuffle=True, num_workers=0)
valid_set = ImageFolder('./dataset1/valid', test_transform)
valid_data = DataLoader(valid_set, 2*batch_size, shuffle=False, num_workers=0)
train_set.class_to_idx
len(valid_data)
# 數據集準備
try:
    if iter(train_data).next()[0].shape[0] == batch_size and \
    iter(valid_data).next()[0].shape[0] == 2*batch_size:
        print('Dataset is ready!')
    else:
        print('Not success, maybe the batch size is wrong')
except:
    print('not success, image transform is wrong!')

模型構建并準備模型

# 構建模型
def get_model():
    model = models.resnet50(pretrained=True)
    model.fc = nn.Linear(2048, 3)
    return model
try:
    model = get_model()
    with torch.no_grad():
        scorce = model(iter(train_data).next()[0])
        print(scorce.shape[0], scorce.shape[1])
    if scorce.shape[0] == batch_size and scorce.shape[1] == 3:
        print('Model is ready!')
    else:
        print('Model is failed!')
except:
    print('model is wrong')
if use_gpu:
    model = model.cuda()

構建模型優(yōu)化器

# 構建loss函數和優(yōu)化器
criterion = nn.CrossEntropyLoss()
optimizer = torch.optim.Adam(model.parameters(), lr = 1e-4)
# 訓練的epoches數目
max_epoch = 20

模型訓練和訓練結果可視化

數據集和訓練集準備好后進行模型訓練和訓練結果可視化,部分代碼如下:

def train(model, train_data, valid_data, max_epoch, criterion, optimizer):
    freq_print = int(len(train_data) / 3)
    metric_log = dict()
    metric_log['train_loss'] = list()
    metric_log['train_acc'] = list()
    if valid_data is not None:
        metric_log['valid_loss'] = list()
        metric_log['valid_acc'] = list()
    for e in range(max_epoch):
        model.train()
        running_loss = 0
        running_acc = 0
        for i, data in enumerate(train_data, 1):
            img, label = data
            if use_gpu:
                img = img.cuda()
                label = label.cuda()
            # forward前向傳播
            out = model(img)
            # 計算誤差
            loss = criterion(out, label.long())
            # 反向傳播,更新參數
            optimizer.zero_grad()
            loss.backward()
            optimizer.step()
            # 計算準確率
            _, pred = out.max(1)
            num_correct = (pred == label.long()).sum().item()
            acc = num_correct/img.shape[0]
            running_loss += loss.item()
            running_acc +=acc
            if i % freq_print == 0:
                print('[{}]/[{}], train loss: {:.3f}, train acc: {:.3f}' \
                .format(i, len(train_data), running_loss / i, running_acc / i))
        metric_log['train_loss'].append(running_loss / len(train_data))
        metric_log['train_acc'].append(running_acc / len(train_data))
        if valid_data is not None:
            model.eval()
            running_loss = 0
            running_acc = 0
            for data in valid_data:
                img, label = data
                if use_gpu:
                    img = img.cuda()
                    label = label.cuda()
                # forward前向傳播
                out = model(img)
                # 計算誤差
                loss = criterion(out, label.long())
                # 計算準確度
                _, pred = out.max(1)
                num_correct = (pred==label.long()).sum().item()
                acc = num_correct/img.shape[0]

                running_loss += loss.item()
                running_acc += acc
            metric_log['valid_loss'].append(running_loss/len(valid_data))
            metric_log['valid_acc'].append(running_acc/len(valid_data))
            print_str = 'epoch: {}, train loss: {:.3f}, train acc: {:.3f}, \
            valid loss: {:.3f}, valid accuracy: {:.3f}'.format(
                        e+1, metric_log['train_loss'][-1], metric_log['train_acc'][-1],
                        metric_log['valid_loss'][-1], metric_log['valid_acc'][-1])
        else:
            print_str = 'epoch: {}, train loss: {:.3f}, train acc: {:.3f}'.format(
                e+1,
                metric_log['train_loss'][-1],
                metric_log['train_acc'][-1])
        print(print_str)
    # 可視化
    nrows = 1
    ncols = 2
    figsize= (10, 5)
    _, figs = plt.subplots(nrows, ncols, figsize=figsize)
    if valid_data is not None:
        figs[0].plot(metric_log['train_loss'], label='train loss')
        figs[0].plot(metric_log['valid_loss'], label='valid loss')
        figs[0].axes.set_xlabel('loss')
        figs[0].legend(loc='best')
        figs[1].plot(metric_log['train_acc'], label='train acc')
        figs[1].plot(metric_log['valid_acc'], label='valid acc')
        figs[1].axes.set_xlabel('acc')
        figs[1].legend(loc='best')
    else:
        figs[0].plot(metric_log['train_loss'], label='train loss')
        figs[0].axes.set_xlabel('loss')
        figs[0].legend(loc='best')
        figs[1].plot(metric_log['train_acc'], label='train acc')
        figs[1].axes.set_xlabel('acc')
        figs[1].legend(loc='best')

調參進行模型訓練

# 用作調參
train(model, train_data, valid_data, max_epoch, criterion, optimizer)

保存模型

# 保存模型
torch.save(model.state_dict(), './model/save_model2.pth')

總結

今天的文章主要是講圖像識別模型如何構建。希望對大家有所幫助。

到此這篇關于Python 教你如何給圖像分類的文章就介紹到這了,更多相關Python 圖像分類內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • Python異步通信模塊asyncore解讀

    Python異步通信模塊asyncore解讀

    這篇文章主要介紹了Python異步通信模塊asyncore的使用,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • windows下Python實現(xiàn)將pdf文件轉化為png格式圖片的方法

    windows下Python實現(xiàn)將pdf文件轉化為png格式圖片的方法

    這篇文章主要介紹了windows下Python實現(xiàn)將pdf文件轉化為png格式圖片的方法,結合實例形式較為詳細的分析了Python實現(xiàn)將pdf轉換為png格式的相關模塊、使用方法與相關注意事項,需要的朋友可以參考下
    2017-07-07
  • python文件路徑操作方法總結

    python文件路徑操作方法總結

    在本篇文章里小編給大家整理的是一篇關于python文件路徑操作方法總結內容,有需要的朋友們可以學習下。
    2020-12-12
  • python中的round()函數用法詳解

    python中的round()函數用法詳解

    這篇文章主要給大家介紹了關于python中round()函數用法的相關資料,round()函數是Python內置函數之一,用于對數字進行四舍五入操作,需要的朋友可以參考下
    2023-08-08
  • python添加菜單圖文講解

    python添加菜單圖文講解

    在本篇文章中小編給大家整理的是關于python添加菜單圖文講解以及步驟分析,需要的朋友們學習下吧。
    2019-06-06
  • python for循環(huán)如何實現(xiàn)控制步長

    python for循環(huán)如何實現(xiàn)控制步長

    這篇文章主要介紹了python for循環(huán)如何實現(xiàn)控制步長,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • 打開電腦上的QQ的python代碼

    打開電腦上的QQ的python代碼

    使用python打開電腦上的QQ,方法很簡單,調用os模塊,然后os.startfile即可
    2013-02-02
  • Python實現(xiàn)為PDF大文件批量去除水印

    Python實現(xiàn)為PDF大文件批量去除水印

    在閱讀過程中如果遇到一些帶有水印的資料是比較煩心的,而市面上去水印的功能有多要收費且很不方便,那么,如何通過Python來對這類圖片水印進行去除呢,本文就來和大家分享一下實現(xiàn)方法吧
    2023-05-05
  • python中文件變化監(jiān)控示例(watchdog)

    python中文件變化監(jiān)控示例(watchdog)

    這篇文章主要介紹了python中文件變化監(jiān)控示例(watchdog),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • python中sort sorted reverse reversed函數的區(qū)別說明

    python中sort sorted reverse reversed函數的區(qū)別說明

    這篇文章主要介紹了python中sort sorted reverse reversed函數的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-05-05

最新評論