【T寶客戶項目解決過程】01-模型訓練

1 項目需求描述

博主自己開了一家T寶店,有一個客戶有這個需求:有一大堆圖像,大概有10多萬張圖,都是比較小尺寸的圖。各種類型都有,我們想要通過將不同類型發圖像進行分開,如何實現呢?

2 思路

可以通過訓練模型,將圖像通過模型預測,來進行篩選圖像。比如:我們先訓練第一個圖像分類模型:卡通/貓。將每一個圖像都使用模型預測下,如果預測為卡通或者貓的得分比較大,那么,我們就認為這個圖像就是卡通或者貓,就把它從原始文件夾中拿出來,放到預測結果的這個類別的文件夾中。

3 步驟

3.1 圖像準備

先從這么多圖像中,篩選出卡通圖,貓圖各自100多張。用于訓練。整理數據格式為:

3.2 環境準備

要進行模型訓練,我們就需要在windows上配置訓練的環境。這里,我們仍使用yolo11進行訓練。環境準備過程如下:

3.2.1?環境創建

之前,我們都是使用conda創建環境,這次我們換一種方案,uv。

首先,在桌面上新建一個文件夾TB_Pro-Clas-Cat-Cartoon,然后打開Pycharm選擇項目路徑。配置環境如下(如果不會配置,可以參考Pycharm配置uv環境):

然后點擊創建,進入如下界面:

3.2.2 安裝ultralytics

使用如下命令安裝ultralytics:

uv pip install ultralytics

3.2.3 克隆倉庫

使用如下命令,注意,最好提前打開科學上網,這樣下載速度會更快!

git clone https://github.com/ultralytics/ultralytics.git

現在,我們查看一下目錄,就會看到如下結果:

3.3 劃分數據集

然后,為了訓練模型,我們需要將數據集整理為下面的格式:

包含訓練集、測試集和驗證集,按類別分文件夾存儲。

📁 data-train/
├── 📁 train/
│ ├── 📁 catroon/
│ └── 📁 cat/
├── 📁 test/
│ ├── 📁 catroon/
│ └── 📁 cat/
└── 📁 val/ (可選,本次項目,我們不劃分)

3.4 開始訓練

3.4.1 下載模型

從官網直接下載到的模型:

模型尺寸
(像素)
acc
top1
acc
top5
速度
CPU ONNX
(毫秒)
速度
T4TensorRT10
(ms)
params
(M)
FLOPs
(B) at 224
YOLO11n-cls22470.089.45.0 ± 0.31.1 ± 0.01.60.5
YOLO11s-cls22475.492.77.9 ± 0.21.3 ± 0.05.51.6
YOLO11m-cls22477.393.917.2 ± 0.42.0 ± 0.010.45.0
YOLO11l-cls22478.394.323.2 ± 0.32.8 ± 0.012.96.2
YOLO11x-cls22479.594.941.4 ± 0.93.8 ± 0.028.413.7

為了得到更高的準確率,我們使用YOLO11x-cls。下載后就會得到:

我們可以將這個文件挪到ultralytics文件夾內!

3.4.2 編寫訓練代碼

新建一個train-code.py文件。

并編寫訓練代碼如下:

from ultralytics import YOLO# Load a model
## yolo11x-cls.pt這個模型是從官網直接下載到的模型
model = YOLO("yolo11x-cls.pt") # Train the model
results = model.train(data="data-train", epochs=100, imgsz=224)

然后,在pycharm終端,cd到ultralytics文件夾,運行py文件,就開始訓練模型啦!

經過漫長的等待(等待時間取決于你的電腦顯卡配置),終于訓練完成啦!

然后,我們在路徑下,就會看到模型文件:

至此,模型訓練就結束啦!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/910582.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/910582.shtml
英文地址,請注明出處:http://en.pswp.cn/news/910582.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

如何在中將網絡改為橋接模式并配置固定IP地址

在使用服務器搭建虛擬機的過程中,我們發現有許多場景需要將虛擬機的網絡配置為橋接模式,并為其設置固定的IP地址。為了幫助大家更高效地進行網絡配置,提升虛擬機的連接穩定性和管理便捷性,我們總結了這篇指南,介紹如何…

強化學習 - 基于策略的Reinforce算法

🎯 REINFORCE 策略梯度算法推導(完整) 1. 目標函數定義 我們希望最大化策略的期望回報: J ( θ ) E τ ~ π θ [ R ( τ ) ] J(\theta) \mathbb{E}_{\tau \sim \pi_\theta} \left[ R(\tau) \right] J(θ)Eτ~πθ??[R(τ…

Windows Sever Core安裝及常用命令

一、Windows Sever Core 在安裝 Windows Server 的過程中,可以選擇“Server Core”(核心安裝)這種沒有圖形用戶界面(GUI)的安裝方式。這種模式下,Windows Server 主要通過命令行或遠程管理進行配置和維護&…

Java 單元測試實戰:以“兩數之和”為例,講透測試思維

🌟Java 單元測試實戰:以“兩數之和”為例,講透測試思維 在 Java 開發中,單元測試不僅是驗證功能正確的手段,更是衡量開發者是否具備“測試思維”的標志。今天我們通過一個最簡單的功能——“兩數之和”來系統講解如何…

Bootstrap 5學習教程,從入門到精通,Bootstrap 5 提示框(Tooltips) 語法知識點及案例(21)

Bootstrap 5 提示框(Tooltips) 語法知識點及案例 一、提示框語法知識點 1. 基本概念 提示框(Tooltips)是當用戶懸停在元素上時顯示的小浮動標簽,用于提供額外信息。 2. 核心屬性 data-bs-toggle"tooltip" - 標識元素為提示框觸發器title - 提示框顯示…

設計模式實戰指南:從源碼解析到Java后端架構的藝術

🎯 設計模式實戰指南:從源碼解析到Java后端架構的藝術 概述 本文檔基于設計模式分類,詳細介紹Java后端開發中各種設計模式的實際應用場景,結合Spring、MyBatis、Redis等主流框架的源碼分析,幫助開發者深入理解設計模…

Python Arrow 庫詳解:更智能的日期時間處理

1. 安裝與基本用法 安裝 Arrow pip install arrow基本使用示例 import arrow# 獲取當前時間 now arrow.now() print(now) # 輸出: 2023-07-15T14:30:45.12345608:00# 創建特定時間 dt arrow.get(2023-07-15 14:30:00, YYYY-MM-DD HH:mm:ss) print(dt) # 輸出: 2023-07-15T…

大家電破渠道困局,小家電攻用戶體驗,云徙有何解法?

中國家電行業正經歷深刻轉型。 自2018年市場規模觸及8400億頂峰后,行業從增量競爭轉向存量博弈。與此同時,線上渠道在2023年首次以58%的占比超越線下,其中掃地機器人等小家電品類線上滲透率突破90%。消費需求也在同步重構——從家庭場景向個…

DMDPC多副本數據分布測試

需求:測試建表和插入數據是否會根據分布列進行自動分發。 驗證方法:1)準備基礎環境:創建用戶和表空間。2)創建數據分布測試表,并插入數據。3)查詢指定分區數據,驗證數據分布情況。 …

Qt/C++開發監控GB28181系統/rtp解包/jrtplib庫的使用/同時支持udp和tcp被動和主動三種方式解包

一、前言說明 通過sip協議僅僅是交互,音視頻數據的收發最終并不是通過sip傳輸的,而是通過將數據打包成rtp的格式再通過udp或者tcp通信的,sip協議僅僅是告知對方待會要往哪里發數據,是udp還是tcp。由于數據都是rtp包格式&#xff…

集群聊天服務器---muduo庫的使用

使用 C 和 muduo 網絡庫來實現一個簡單的聊天服務器和客戶端。 服務器端: class chatServer { public:// 初始化TcpServerchatServer(muduo::net::EventLoop *loop,const muduo::net::InetAddress &listenAddr): _server(loop, listenAddr, "chatServer&…

關于Net Core Web API 項目測試 數據庫模擬的兩種不同方法 DC_week 6

1.關系型數據庫 插件:Microsoft.EntityFrameworkCore.InMemory Microsoft.EntityFrameworkCore.InMemory 是一個用于測試的“臨時內存數據庫”,讓你在不連接真實數據庫的情況下,測試 EF Core 的功能。 使用時就是用具體這個框架里面已經…

如何獲取 vscode 的 vsix 離線插件安裝包

1、搜索所需要的插件 Extensions for Visual Studio family of products | Visual Studio Marketplace網址 2、點擊 Repository 跳轉到對應的 git 倉庫 3、在 git 倉庫依次選擇 main , Tags, View all tags 4、選擇你想下載的版本,并點擊 downloads 5、往下滑動&…

ULS23 挑戰:用于計算機斷層掃描中 3D 通用病變分割的基準模型及基準數據集|文獻速遞-深度學習醫療AI最新文獻

Title 題目 The ULS23 challenge: A baseline model and benchmark dataset for 3D universal lesion segmentation in computed tomography ULS23 挑戰:用于計算機斷層掃描中 3D 通用病變分割的基準模型及基準數據集 01 文獻速遞介紹 每年進行的CT檢查數量持續…

WebSocket 端點 vs Spring Bean

在websocket端點中注入業務service時,不能像普通的springbean一樣通過Autowired或Resource注解進行注入。主要原因是websocket端點與spring容器中的bean的生命周期管理容器不同。 WebSocket 端點(ServerEndpoint)和 Spring Bean 的生命周期存…

MySQL8:jdbc插入數據后獲取自增ID

pom文件&#xff1a; <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation"http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd"&…

MyBatis(Web后端開發第二期)

p.s.這是萌新自己自學總結的筆記&#xff0c;如果想學習得更透徹的話還是請去看大佬的講解 目錄 JDBC、數據庫連接池、lombok日志輸出SQL注入數據封裝XML映射文件動態SQL<if><where><set><foreach><sql><include> 配置文件 Mybatis是是一…

Angular1--Hello

最近有個小錯誤&#xff0c;因為最近還是在看thingsboard&#xff0c;最近終于看到前端的代碼&#xff0c;突然發現怎么全是ts的文件&#xff0c;仔細一看原來并不是之前認為的AngularJS&#xff0c;而是Angular。。。我tm真的無語了&#xff0c;又要去重新學。。。 Angular的…

什么是redission看門狗機制

Redisson 的看門狗機制(Watchdog Mechanism)是其實現可重入分布式鎖時的一個核心特性,主要用于解決業務邏輯執行時間超過鎖的過期時間(leaseTime)而導致鎖提前釋放,進而引發數據不一致的問題。它是一個自動的鎖續期機制。 ?? 核心問題:為什么需要看門狗? 分布式鎖的…

黑馬程序員蒼穹外賣DAY1

1. 前端頁面能正常顯示但無法登錄&#xff08;一直轉圈圈&#xff09; 找到下面路徑的dev.yml port一定要跟自己本機的保持一致&#xff0c;&#xff0c;username和password也一定是自己主機的用戶名和密碼&#xff0c;不然連不上。 登錄界面的密碼為數據庫表的密碼&#xff0…