news 2026/4/3 3:55:40

幽冥大陆(七十九)Python 水果识别训练视频识别 —东方仙盟练气期

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
幽冥大陆(七十九)Python 水果识别训练视频识别 —东方仙盟练气期

第一步:Win7 配置 Python 虚拟环境

1. 安装 Python 3.8.10

  • 下载地址:https://www.python.org/downloads/release/python-3810/
  • 选择Windows x86-64 executable installer,安装时必须勾选Add Python 3.8 to PATH

2. 创建并激活虚拟环境

  1. 打开 cmd 命令行,执行以下命令创建项目文件夹和虚拟环境:

    bash

    运行

    # 新建项目根目录 mkdir fruit_ncnn_project && cd fruit_ncnn_project # 创建虚拟环境(venv_fruit 为环境名) python -m venv venv_fruit
  2. 激活虚拟环境:

    bash

    运行

    # Win7 cmd 命令 venv_fruit\Scripts\activate.bat
    激活后命令行前缀会出现(venv_fruit),表示进入隔离环境。

3. 安装 Win7 兼容的依赖库

激活虚拟环境后,执行以下命令安装指定版本依赖,避免兼容性问题:

bash

运行

# 升级 pip 到兼容版本 python -m pip install --upgrade pip==21.3.1 # 安装 PyTorch + TorchVision CPU 版(Win7 最高兼容版本) pip install torch==1.12.1+cpu torchvision==0.13.1+cpu -f https://download.pytorch.org/whl/cpu/torch_stable.html # 安装其他必备库 pip install pillow==9.5.0 numpy==1.23.5 opencv-python==4.5.5.64

4. 退出虚拟环境(训练完成后执行)

bash

运行

deactivate

第二步:训练模型并生成 .pth 文件

注意:运行前需将 Fruits-360 数据集放在./datasets目录下,确保TrainingTest子文件夹存在。全程在激活的虚拟环境中执行。

训练代码(fruit_train.py)

python

运行

import torch import torch.nn as nn import torch.optim as optim from torchvision import transforms from torchvision.datasets import ImageFolder from torch.utils.data import DataLoader # ==================== 配置项 ==================== TRAIN_DIR = "./datasets/Training" # 数据集训练集路径 TEST_DIR = "./datasets/Test" # 数据集测试集路径 MODEL_SAVE_PATH = "fruit_mobilenetv2.pth" # 模型保存路径 NUM_EPOCHS = 15 # 训练轮数 BATCH_SIZE = 32 # 批次大小 # ================================================ # 1. 数据预处理(适配 Fruits-360 图像尺寸) transform = transforms.Compose([ transforms.Resize((100, 100)), transforms.ToTensor(), transforms.Normalize(mean=[0.485, 0.456, 0.406], std=[0.229, 0.224, 0.225]) ]) # 2. 加载数据集(Win7 必须设 num_workers=0) train_dataset = ImageFolder(TRAIN_DIR, transform=transform) test_dataset = ImageFolder(TEST_DIR, transform=transform) num_classes = len(train_dataset.classes) # 自动适配 208 类 train_loader = DataLoader(train_dataset, batch_size=BATCH_SIZE, shuffle=True, num_workers=0) test_loader = DataLoader(test_dataset, batch_size=BATCH_SIZE, shuffle=False, num_workers=0) # 3. 加载预训练 MobileNetV2 并修改分类头(迁移学习) from torchvision import models model = models.mobilenet_v2(pretrained=True) model.classifier[1] = nn.Linear(model.last_channel, num_classes) model = model.to("cpu") # 强制 CPU 训练 # 4. 训练配置 criterion = nn.CrossEntropyLoss() optimizer = optim.Adam(model.parameters(), lr=0.001) # 5. 训练+验证循环 print(f"开始训练 {num_classes} 类水果分类模型...") for epoch in range(NUM_EPOCHS): # 训练阶段 model.train() train_loss = 0.0 for imgs, labels in train_loader: optimizer.zero_grad() outputs = model(imgs) loss = criterion(outputs, labels) loss.backward() optimizer.step() train_loss += loss.item() * imgs.size(0) # 验证阶段 model.eval() test_acc = 0.0 with torch.no_grad(): for imgs, labels in test_loader: outputs = model(imgs) _, preds = torch.max(outputs, 1) test_acc += torch.sum(preds == labels.data) # 打印日志 avg_loss = train_loss / len(train_dataset) avg_acc = test_acc.double() / len(test_dataset) print(f"Epoch [{epoch+1}/{NUM_EPOCHS}] | Loss: {avg_loss:.4f} | Test Acc: {avg_acc:.4f}") # 6. 保存训练好的模型 torch.save(model.state_dict(), MODEL_SAVE_PATH) print(f"\n模型训练完成,已保存至 {MODEL_SAVE_PATH}")

阿雪技术观


在科技发展浪潮中,我们不妨积极投身技术共享。不满足于做受益者,更要主动担当贡献者。无论是分享代码、撰写技术博客,还是参与开源项目维护改进,每一个微小举动都可能蕴含推动技术进步的巨大能量。东方仙盟是汇聚力量的天地,我们携手在此探索硅基生命,为科技进步添砖加瓦。

Hey folks, in this wild tech - driven world, why not dive headfirst into the whole tech - sharing scene? Don't just be the one reaping all the benefits; step up and be a contributor too. Whether you're tossing out your code snippets, hammering out some tech blogs, or getting your hands dirty with maintaining and sprucing up open - source projects, every little thing you do might just end up being a massive force that pushes tech forward. And guess what? The Eastern FairyAlliance is this awesome place where we all come together. We're gonna team up and explore the whole silicon - based life thing, and in the process, we'll be fueling the growth of technology

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/2 20:02:49

DeepSeek-VL2视觉语言模型完整实践指南

DeepSeek-VL2视觉语言模型完整实践指南 【免费下载链接】deepseek-vl2 探索视觉与语言融合新境界的DeepSeek-VL2,以其先进的Mixture-of-Experts架构,实现图像理解与文本生成的飞跃,适用于视觉问答、文档解析等多场景。三种规模模型&#xff0…

作者头像 李华
网站建设 2026/3/27 23:10:47

Docker安装TensorFlow 2.9镜像全过程截图详解(附常见错误解决)

Docker部署TensorFlow 2.9全指南:从零搭建AI开发环境 在深度学习项目中,最让人头疼的往往不是模型设计,而是“在我机器上明明能跑”的环境问题。Python依赖冲突、CUDA版本不匹配、库缺失……这些问题反复消耗着开发者的时间和耐心。幸运的是&…

作者头像 李华
网站建设 2026/3/30 18:59:15

NeverSink过滤器完全配置手册:打造高效PoE2游戏体验的7个关键步骤

你是否曾经在Path of Exile 2的冒险旅程中,面对满地物品感到手足无措?珍贵的装备被普通物品淹没,稀有货币在杂乱的战利品中难以发现?NeverSink过滤器正是为解决这些困扰而设计的智能筛选工具,通过专业的视觉提示和声音…

作者头像 李华
网站建设 2026/3/13 12:12:24

农业信息网站的设计与实现开题报告

附表1 本科毕业论文(设计)开题报告 论文题目: 农业信息网站的设计与实现 学生姓名: 学 号: 2131053224 专 业: 网络工程 班 级&#xff…

作者头像 李华