400 128 6709

行业新闻

【PaddleHub模型贡献】一行代码实现蛇种识别

发布时间:2025-07-31点击次数:
该内容围绕蛇类识别模型展开,先安装PaddleX,解压数据集并划分,设置GPU后进行图像预处理与增强,定义数据迭代器,用ResNet50_vd_ssld模型训练,接着导出并转换模型为PaddleHub模块,测试单张和多张图片识别效果,最后介绍在GitHub提pr的步骤。

☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜

【paddlehub模型贡献】一行代码实现蛇种识别 -

一、模型开发

1.安装必要的资源库

原项目使用PaddleX开发,因此这里先安装PaddleX:

In [5]
!pip install paddlex
   

2.数据预处理

2.1解压数据集

In [2]
!unzip data/data44587/snake_data.zip -d /home/aistudio/
   

2.2划分训练集

In [ ]
!paddlex --split_dataset --format ImageNet --dataset_dir '/home/aistudio/snake_data' --val_value 0.2 --test_value 0.1
   

3.模型训练

3.1设置使用0号GPU卡

In [ ]
import matplotlib
matplotlib.use('Agg') 
import os
os.environ['CUDA_VISIBLE_DEVICES'] = '0'import paddlex as pdx
   

3.2图像预处理+数据增强

In [ ]
from paddlex.cls import transforms
train_transforms = transforms.Compose([
    transforms.RandomCrop(crop_size=224),
    transforms.RandomHorizontalFlip(),
    transforms.Normalize()
])
eval_transforms = transforms.Compose([
    transforms.ResizeByShort(short_size=256),
    transforms.CenterCrop(crop_size=224),
    transforms.Normalize()
])
   

3.3数据迭代器的定义

In [ ]
train_dataset = pdx.datasets.ImageNet(
    data_dir='snake_data',
    file_list='snake_data/train_list.txt',
    label_list='snake_data/labels.txt',
    transforms=train_transforms,
    shuffle=True)
eval_dataset = pdx.datasets.ImageNet(
    data_dir='snake_data',
    file_list='snake_data/val_list.txt',
    label_list='snake_data/labels.txt',
    transforms=eval_transforms)
       
2025-07-19 11:49:17 [INFO]	Starting to read file list from dataset...
2025-07-19 11:49:17 [INFO]	17364 samples in file snake_data/train_list.txt
2025-07-19 11:49:17 [INFO]	Starting to read file list from dataset...
2025-07-19 11:49:17 [INFO]	25 samples in file snake_data/val_list.txt
       

3.4开始炼丹

In [ ]
num_classes = len(train_dataset.labels)
model = pdx.cls.ResNet50_vd_ssld(num_classes=num_classes)
model.train(num_epochs = 60,
            s*e_interval_epochs = 10,
            train_dataset = train_dataset,
            train_batch_size = 64,
            eval_dataset = eval_dataset,
            learning_rate = 0.025,
            warmup_steps = 1084,
            warmup_start_lr = 0.0001,
            lr_decay_epochs=[20, 40],
            lr_decay_gamma = 0.025,    
            s*e_dir='/home/aistudio',
            use_vdl=True)
   

4.查看模型预测效果

In [ ]
import cv2import matplotlib.pyplot as plt# 加载模型print('**************************************加载模型*****************************************')
model = pdx.load_model('best_model')# 显示图片img = cv2.imread('test.jpg')
b,g,r = cv2.split(img)
img = cv2.merge([r,g,b])
%matplotlib inline
plt.imshow(img)# 预测result = model.predict('test.jpg', topk=3)print('**************************************预测*****************************************')print(result[0])
       
**************************************加载模型*****************************************
2025-07-19 14:21:06 [INFO]	Model[ResNet50_vd_ssld] loaded.
**************************************预测*****************************************
{'category_id': 4, 'category': '西部菱斑响尾蛇', 'score': 0.9999999}
       
<Figure size 432x288 with 1 Axes>
               

二、封装Module

1.导出inference模型

参数 说明
--model_dir inference模型所在的文件地址,文件包括:.pdparams、.pdopt、.pdmodel、.json和.yml
--s*e_dir 导出inference模型,文件将包括:__model__、__params__和model.yml
In [ ]
!paddlex --export_inference --model_dir=best_model --s*e_dir=./inference_model/ResNet50_vd_ssld
       
W0717 23:24:19.157521 13809 device_context.cc:252] Please NOTE: device: 0, CUDA Capability: 70, Driver API Version: 9.2, Runtime API Version: 9.0
W0717 23:24:19.161340 13809 device_context.cc:260] device: 0, cuDNN Version: 7.3.
2025-07-17 23:24:22 [INFO]	Model[ResNet50_vd_ssld] loaded.
2025-07-17 23:24:22 [INFO]	Model for inference deploy s*ed in ./inference_model/ResNet50_vd_ssld.
       

2.模型转换

PaddleX模型可以快速转换成PaddleHub模型,只需要用下面这一句命令即可:

In [1]
!hub convert --model_dir inference_model/ResNet50_vd_ssld \
              --module_name SnakeIdentification \
              --module_version 1.0.0 \
              --output_dir outputs
   

转换成功后的模型保存在outputs文件夹下,我们解压一下:

In [3]
!gzip -dfq /home/aistudio/outputs/SnakeIdentification.tar.gz
!tar -xf /home/aistudio/outputs/SnakeIdentification.tar
   

3.模型安装

安装我们刚刚转换的模型:

In [6]
!hub install SnakeIdentification
       
/opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages/setuptools/depends.py:2: DeprecationWarning: the imp module is deprecated in f*our of importlib; see the module's documentation for alternative uses
  import imp
/opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages/matplotlib/__init__.py:107: DeprecationWarning: Using or importing the ABCs from 'collections' instead of from 'collections.abc' is deprecated, and in 3.8 it will stop working
  from collections import MutableMapping
/opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages/matplotlib/rcsetup.py:20: DeprecationWarning: Using or importing the ABCs from 'collections' instead of from 'collections.abc' is deprecated, and in 3.8 it will stop working
  from collections import Iterable, Mapping
/opt/conda/envs/python35-paddle120-env/lib/python3.7/site-packages/matplotlib/colors.py:53: DeprecationWarning: Using or importing the ABCs from 'collections' instead of from 'collections.abc' is deprecated, and in 3.8 it will stop working
  from collections import Sized[2025-03-12 10:45:54,828] [    INFO] - Successfully uninstalled SnakeIdentification[2025-03-12 10:45:55,105] [    INFO] - Successfully installed SnakeIdentification-1.0.0
       

4.模型预测

预测单张图片

【PaddleHub模型贡献】一行代码实现蛇种识别 -     In [12]
import cv2import paddlehub as hub

module = hub.Module(name="SnakeIdentification")

images = [cv2.imread('snake_data/class_1/2421.jpg')]# execute predict and print the resultresults = module.predict(images=images)for result in results:    print(result)
       
[2025-03-12 10:55:05,972] [ WARNING] - The _initialize method in HubModule will soon be deprecated, you can use the __init__() to handle the initialization of the object
       
[{'category_id': 0, 'category': '水蛇', 'score': 0.9999205}]
       

预测多张图片

选取5张图片,每张图片对应一个类别:

【PaddleHub模型贡献】一行代码实现蛇种识别 -     In [13]
import cv2import paddlehub as hub

module = hub.Module(name="SnakeIdentification")

images = [cv2.imread('snake_data/class_1/2421.jpg'), cv2.imread('snake_data/class_2/113.jpg'), cv2.imread('snake_data/class_3/757.jpg'),
          cv2.imread('snake_data/class_4/1101.jpg'), cv2.imread('snake_data/class_5/2566.jpg')]# execute predict and print the resultresults = module.predict(images=images)for result in results:    print(result)
       
[2025-03-12 11:00:07,036] [ WARNING] - The _initialize method in HubModule will soon be deprecated, you can use the __init__() to handle the initialization of the object
       
[{'category_id': 0, 'category': '水蛇', 'score': 0.9999205}]
[{'category_id': 1, 'category': '剑纹带蛇', 'score': 0.9988399}]
[{'category_id': 2, 'category': '德凯斯氏蛇', 'score': 0.9867851}]
[{'category_id': 3, 'category': '黑鼠蛇', 'score': 0.9468411}]
[{'category_id': 4, 'category': '西部菱斑响尾蛇', 'score': 1.0}]
       

三、在GitHub上提pr

pr就是Pull Request(翻译过来就是:拉取请求)的简称

1.Fork PaddleHub

进入PaddleHub的源码仓库https://github.com/PaddlePaddle/PaddleHub

【PaddleHub模型贡献】一行代码实现蛇种识别 -        

看到这个箭头指向的按钮了吗?点它!!!

Openflow Openflow

一键极速绘图,赋能行业工作流

Openflow 88 查看详情 Openflow

如果可以的话,可以顺手把它旁边的Star给点了(手动狗头)

点击以后,你的账号下面就有一个叫PaddleHub的代码仓库了,就像这样:

【PaddleHub模型贡献】一行代码实现蛇种识别 -        

2.上传Module

本项目是图像分类的项目,所以进入到图像分类的目录下:

PaddleHub/modules/image/classification/

【PaddleHub模型贡献】一行代码实现蛇种识别 -        

点击Add file:

【PaddleHub模型贡献】一行代码实现蛇种识别 -        

先输入您上传的Module名称,这里我的Module名称命名为SnakeIdentification,将它变成一个文件夹,只需要在后面加一个‘/’,创建好文件夹以后,把Module里的文件上传上去即可:

【PaddleHub模型贡献】一行代码实现蛇种识别 -        

上传成功后,点击Commit,文件就会自动上传到你自己的代码仓库里

3.Pull Request

最后一步,拉取请求:【PaddleHub模型贡献】一行代码实现蛇种识别 -        

确认无误后点击提交即可:【PaddleHub模型贡献】一行代码实现蛇种识别 -        

以上就是【PaddleHub模型贡献】一行代码实现蛇种识别的详细内容,更多请关注其它相关文章!


# git  # python  # 官网  # 加载  # 上传  # 一言  # 中文网  # fig  # udio  # red  # ai  # 合肥抖音seo免费咨询  # 云南品牌营销推广公司  # 青田建设委员会网站  # 胶州自适应网站建设  # 高端论坛推广网站  # 西丽怎样免费网站推广  # 烟台模版网站维护推广  # 哪个网站营销推广好点  # 学seo学会什么运营  # 抖音seo谁最牛  # 这一  # 迭代  # 先安装  # 自己的  # 多张 


相关栏目: 【 行业新闻62819 】 【 科技资讯67470


相关推荐: 谷歌借AI打破十年排序算法封印,每天被执行数万亿次,网友却说是最不切实际的研究?  人工智能:解决劳动力短缺的关键策略  先进技术在防止全球数据丢失方面的作用  自研4D激光雷达L1 + GPT大语言模型 宇树Unitree Go2四足机器人有啥黑科技?  “世界上最像人的机器人”接入 Stable Diffusion ,现场完成作画  农业产业升级:AI驱动的“崃·见田”开启农田未来展望  新闻传闻:迪士尼可能采用人工智能来控制电影制作成本  人工智能产业协同创新中心:全产业链资源在这里汇聚  DreamAvatar数字人使用教程  WAIC 2025|云深处科技绝影Lite3与X20四足机器人亮相  月薪6万,哪些AI岗位在抢人?  Moka发布AI原生HR SaaS产品“Moka Eva”,布局AGI时代  13条咒语挖掘GPT-4最大潜力,Github万星AI导师火了,网友:隔行再也不隔山了  用AI技术点亮老照片:Deep Nostalgia带给照片新生动感  联合国秘书长称支持建立全球人工智能监管机构  开创全新虚拟现实体验的Pimax Crystal VR头显  无人机自主巡检为高海拔输电线路运维添“新彩”  拓普龙7188ML:轻便壁挂式工控机箱,为人工智能应用场景提供有力保障  陈根:ChatGPT和人类合作开发机器人  利用AI探索抗体“钥匙”、加速药物研发——访百图生科团队  AI+游戏首度大范围公布实际应用成果,AI全面来临还有多远?  马斯克回应“人工智能让一切变得更好”:我们已经是半机器人了  人工智能助力林草行业高质量发展  云南首例达芬奇机器人微创心脏手术成功开展  聚焦WAIC|AI技术支撑大模型探索未来  讯飞听见会写“会议摘要”功能全面升级,AI更懂你的关注点  世界水下机器人大赛:9国青年携手逐梦深蓝  WHEE使用教程  英伟达首席执行官黄仁勋:生成式 AI 时代「人类」会是新的编程语言  广州团建公司方案 | 绝密飞行 → X-PLANE无人机团建主题团建  卫星通信牵引物联网竞争升维,模组厂商如何决胜百亿市场?  英伟达的AI领域垄断地位:一直无法撼动吗?  首部国内AI辅助动画片《魔游纪:人工智能辅助篇》预告发布  商业智能决策技术助力降本增效,世界人工智能大会举办商业AI高峰论坛  无人机协助盐城交通执法的协同训练  360°/180°双模式,佳能公布可折叠小体积的VR全景相机  “无人驾驶船”将首次亮相世界人工智能大会,下半年或开进上海迪士尼  业内领先 四川大学华西第四医院甲状腺乳腺外科成功进入手术机器人时代  闪电快讯|京东推出言犀AI大模型 面向零售、医疗、物流等产业场景  比尔盖茨:AI确实存在风险,但可控  吉林首例!机器人辅助下搭桥手术成功实施  中科院自研新一代 AI 大模型“紫东太初 2.0”问世  水路两栖艇、消防灭火机器人……这个展览“黑科技”抢眼  微软 GitHub Copilot 编程助手被投诉:换口吻改写公共代码来躲版权  国内首家,360智脑通过中国信通院可信AIGC大语言模型功能评估  Databricks推出人工智能模型共享机制,可令开发者与公司“双赢”  《共同的演化》展览启幕,重新思考人类与人工智能关系  陈根:AI工具为游戏软件实时3D内容助力  科技有狠活|时光修复师 :用AI让昨日重现  Dubbo负载均衡策略之 一致性哈希 

400 128 6709
E-mail

contact@tlftec.cn

扫一扫,添加微信

©  云南淘乐房科技有限公司 版权所有  滇ICP备2025071560号  

云南淘乐房科技有限公司 云南淘乐房科技有限公司 云南淘乐房科技有限公司 云南淘乐房科技有限公司 云南淘乐房科技有限公司 云南淘乐房科技有限公司 云南淘乐房科技有限公司 云南淘乐房科技有限公司 云南淘乐房科技有限公司 云南淘乐房科技有限公司