AI实战营第二期 笔记5——MMPretrain代码课

举报
AI浩 发表于 2023/08/06 07:49:52 2023/08/06
【摘要】 @[toc] 摘要MMPretrain 是一个全新升级的预训练开源算法框架,旨在提供各种强大的预训练主干网络, 并支持了不同的预训练策略。MMPretrain 源自著名的开源项目 MMClassification 和 MMSelfSup,并开发了许多令人兴奋的新功能。 目前,预训练阶段对于视觉识别至关重要,凭借丰富而强大的预训练模型,我们能够改进各种下游视觉任务。【课程链接】https://...

@[toc]

摘要

MMPretrain 是一个全新升级的预训练开源算法框架,旨在提供各种强大的预训练主干网络, 并支持了不同的预训练策略。MMPretrain 源自著名的开源项目 MMClassification 和 MMSelfSup,并开发了许多令人兴奋的新功能。 目前,预训练阶段对于视觉识别至关重要,凭借丰富而强大的预训练模型,我们能够改进各种下游视觉任务。
在这里插入图片描述

【课程链接】https://www.bilibili.com/video/BV1Ju4y1Z7ZE
【讲师介绍】马泽润 OpenMMLab算法工程师
在这里插入图片描述

MMPreTrain实战

安装

git clone https://github.com/open-mmlab/mmpretrain.git
cd mmpretrain
pip install -U openmim
mim install -e ".[multimodal]"

在这里插入图片描述
multimodal:代表安装额外安装多模态的模型
在这里插入图片描述

推理

调用脚本实现推理,代码如下:

python demo/image_demo.py ${IMAGE_FILE} ${CONFIG_FILE} ${CHECKPOINT_FILE}

OR 使用API

get_model 通过模型名称或模型配置文件获取模型
list_models 列举 MMPretrain 中所有可用模型名称
inference_model 使用与模型相对应任务的推理器进行推理
调用ResNet实例代码:

import mmpretrain
print(mmpretrain.__version__)

from mmpretrain import get_model, list_models, inference_model
print(list_models(task='Image Classification', pattern  = 'resnet18'))

print(list_models(task='Image Caption', pattern='blip'))
model = get_model('resnet18_8xb16_cifar10')
print(type(model))

model  =  get_model( 'resnet18_8xb32_in1k')
print(type(model.backbone))

在这里插入图片描述
加载预训练模型推理

inference_model('blip-base_3rdparty_caption','demo/cat-dog.png',show=True)

在这里插入图片描述

数据集

CustomDataset OR ImageNet

子文件夹方式
标注文件方式
#配置文件
举例:resnet18_8xb32_in1k.py

_base_ = [
    '../_base_/models/resnet18.py',           # 模型配置
    '../_base_/datasets/imagenet_bs32.py',    # 数据配置
    '../_base_/schedules/imagenet_bs256.py',  # 训练策略配置
    '../_base_/default_runtime.py'            # 默认运行设置
]

训练与测试

训练

python tools/train.py ${CONFIG_FILE} [ARGS]

测试

python tools/test.py ${CONFIG_FILE} ${CHECKPOINT_FILE} [ARGS]

微调

数据集地址:https://download.openmmlab.com/mmclassification/dataset/cats_dogs_dataset.tar
在MMpretrain下面新建data文件夹,然后将数据集解压后,放进去。
查看模型,输入命令:

ls configs

在这里插入图片描述
查看具体模型的配置文件,ResNet为例:

ls configs/resnet

在这里插入图片描述
打开文件resnet18_8xb32_in1k.py,查看具体的内容:

_base_ = [
    '../_base_/models/resnet18.py', '../_base_/datasets/imagenet_bs32.py',
    '../_base_/schedules/imagenet_bs256.py', '../_base_/default_runtime.py'
]

../_base_/models/resnet18.py:模型文件,通过配置的方式,实现模型。
../_base_/datasets/imagenet_bs32.py:数据集配置。
../_base_/schedules/imagenet_bs256.py:规划配置
../_base_/default_runtime.py:运行配置
default_runtime的配置修改:

   # save checkpoint per epoch.
    checkpoint=dict(type='CheckpointHook', interval=1,max_keep_ckpts=5,sava_best="auto"),

保存最好的5个模型,自动保存最好的模型。

设置类别,和预训练权重路径。
在这里插入图片描述
设置成自定义数据集格式
在这里插入图片描述
配置数据集路径
在这里插入图片描述
训练

mim train mmpretrain configs/resnet/resnet50.py --work-dir=./exp

在这里插入图片描述
测试

mim test mmpretrain configs/resnet/resnet50.py --checkpoint exp/epoch_41.pth

在这里插入图片描述

分析结果:
在这里插入图片描述

【版权声明】本文为华为云社区用户原创内容,转载时必须标注文章的来源(华为云社区)、文章链接、文章作者等基本信息, 否则作者和本社区有权追究责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。