2021-07-27 13:58:27 +08:00
{
"cells": [
{
"cell_type": "markdown",
"metadata": {
"id": "XjQxmm04iTx4"
},
"source": [
2021-07-27 07:57:21 -04:00
"<a href=\"https://colab.research.google.com/github/open-mmlab/mmclassification/blob/master/docs_zh-CN/tutorials/MMClassification_python_cn.ipynb\" target=\"_parent\"><img src=\"https://colab.research.google.com/assets/colab-badge.svg\" alt=\"Open In Colab\"/></a>"
2021-07-27 13:58:27 +08:00
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "UdMfIsMpiODD"
},
"source": [
"# 基于 Colab 的 MMClassification Python 教程\n",
"\n",
"在本教程中会介绍如下内容:\n",
"\n",
"* 如何安装 MMCls\n",
"* 如何基于预训练模型进行推理计算\n",
"* 如何基于预训练模型进行模型微调 "
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "iOl0X9UEiRvE"
},
"source": [
"## 安装 MMClassification\n",
"\n",
"在使用 MMClassification 之前,我们需要配置环境,步骤如下:\n",
"\n",
"- 安装 Python, CUDA, C/C++ compiler 和 git\n",
"- 安装 PyTorch (CUDA 版)\n",
"- 安装 mmcv\n",
"- 克隆 mmcls github 代码库然后安装\n",
"\n",
"因为我们在 Google Colab 进行实验, Colab 已经帮我们完成了基本的配置,我们可以直接跳过前面两个步骤 。"
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "XjQxmm04iTx4"
},
"source": [
"### 检查环境"
]
},
{
"cell_type": "code",
"execution_count": 1,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "c6MbAw10iUJI",
"outputId": "d2afec96-2fea-4dfc-bb44-79e49b979717"
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
2021-09-30 13:59:27 +08:00
"/home/PJLAB/mazerun/mmlab/cls-better-vis\n"
2021-07-27 13:58:27 +08:00
]
}
],
"source": [
2021-09-30 13:59:27 +08:00
"%cd ../../"
2021-07-27 13:58:27 +08:00
]
},
{
"cell_type": "code",
"execution_count": 2,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "4IyFL3MaiYRu",
"outputId": "a9b9015d-8ae7-4a5b-e935-909e78033028"
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
2021-09-30 13:59:27 +08:00
"/home/PJLAB/mazerun/mmlab/cls-better-vis\n"
2021-07-27 13:58:27 +08:00
]
}
],
"source": [
"!pwd"
]
},
{
"cell_type": "code",
"execution_count": 3,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "DMw7QwvpiiUO",
"outputId": "0ddc0277-47a9-4698-b6f2-d1e2a5e00f78"
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"nvcc: NVIDIA (R) Cuda compiler driver\n",
"Copyright (c) 2005-2020 NVIDIA Corporation\n",
2021-09-30 13:59:27 +08:00
"Built on Tue_Sep_15_19:10:02_PDT_2020\n",
"Cuda compilation tools, release 11.1, V11.1.74\n",
"Build cuda_11.1.TC455_06.29069683_0\n"
2021-07-27 13:58:27 +08:00
]
}
],
"source": [
"# 检查 nvcc 版本\n",
"!nvcc -V"
]
},
{
"cell_type": "code",
"execution_count": 4,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "4VIBU7Fain4D",
"outputId": "3201af41-2190-40fc-cfea-688d5a551998"
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
2021-09-30 13:59:27 +08:00
"gcc (Ubuntu 9.3.0-17ubuntu1~20.04) 9.3.0\n",
"Copyright (C) 2019 Free Software Foundation, Inc.\n",
2021-07-27 13:58:27 +08:00
"This is free software; see the source for copying conditions. There is NO\n",
"warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.\n",
"\n"
]
}
],
"source": [
"# 检查 GCC 版本\n",
"!gcc --version"
]
},
{
"cell_type": "code",
"execution_count": 5,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "24lDLCqFisZ9",
"outputId": "db2e6bf1-cefa-4aa9-c303-15d48477d03b"
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
2021-09-30 13:59:27 +08:00
"1.9.0\n",
2021-07-27 13:58:27 +08:00
"True\n"
]
}
],
"source": [
"# 检查 PyTorch 的安装情况\n",
"import torch, torchvision\n",
"print(torch.__version__)\n",
"print(torch.cuda.is_available())"
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "R2aZNLUwizBs"
},
"source": [
"### 安装 MMCV\n",
"\n",
"MMCV 是 OpenMMLab 代码库的基础库。Linux 环境的安装 whl 包已经提前打包好,大家可以直接下载安装。\n",
"\n",
"需要注意 PyTorch 和 CUDA 版本,确保能够正常安装。\n",
"\n",
"在前面的步骤中,我们输出了环境中 CUDA 和 PyTorch 的版本,分别是 11.0 和 1.9.0,我们需要选择相应的 MMCV 版本。\n",
"\n",
"另外,也可以安装完整版的 MMCV-full, 它包含所有的特性以及丰富的开箱即用的 CUDA 算子。需要注意的是完整版本可能需要更长时间来编译。"
]
},
{
"cell_type": "code",
"execution_count": 6,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "nla40LrLi7oo",
"outputId": "61e90f5e-023b-4a03-ddb8-760add09e868"
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Looking in links: https://download.openmmlab.com/mmcv/dist/cu110/torch1.9.0/index.html\n",
"Collecting mmcv\n",
" Downloading mmcv-1.3.9.tar.gz (313 kB)\n",
"\u001b[K |████████████████████████████████| 313 kB 7.8 MB/s \n",
"\u001b[?25hCollecting addict\n",
" Downloading addict-2.4.0-py3-none-any.whl (3.8 kB)\n",
"Requirement already satisfied: numpy in /usr/local/lib/python3.7/dist-packages (from mmcv) (1.19.5)\n",
"Requirement already satisfied: Pillow in /usr/local/lib/python3.7/dist-packages (from mmcv) (7.1.2)\n",
"Requirement already satisfied: pyyaml in /usr/local/lib/python3.7/dist-packages (from mmcv) (3.13)\n",
"Collecting yapf\n",
" Downloading yapf-0.31.0-py2.py3-none-any.whl (185 kB)\n",
"\u001b[K |████████████████████████████████| 185 kB 13.6 MB/s \n",
"\u001b[?25hBuilding wheels for collected packages: mmcv\n",
" Building wheel for mmcv (setup.py) ... \u001b[?25l\u001b[?25hdone\n",
" Created wheel for mmcv: filename=mmcv-1.3.9-py2.py3-none-any.whl size=451832 sha256=21838bb360585d5fb846ab545d87b70c262e22bcf79c680ab48bfc922ab5b5b3\n",
" Stored in directory: /root/.cache/pip/wheels/88/48/bf/655e136aea5534d7a9a85fe247fee7957178fc19cf79dda602\n",
"Successfully built mmcv\n",
"Installing collected packages: yapf, addict, mmcv\n",
"Successfully installed addict-2.4.0 mmcv-1.3.9 yapf-0.31.0\n"
]
}
],
"source": [
"# 安装 mmcv\n",
"!pip install mmcv -f https://download.openmmlab.com/mmcv/dist/cu110/torch1.9.0/index.html\n",
"# !pip install mmcv-full -f https://download.openmmlab.com/mmcv/dist/cu110/torch1.9.0/index.html"
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "GDTUrYvXjlRb"
},
"source": [
"### 克隆并安装 MMCls\n",
"\n",
"接着,我们从 github 上克隆下 mmcls 最新代码库并进行安装。"
]
},
{
"cell_type": "code",
"execution_count": 7,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "Bwme6tWHjl5s",
"outputId": "4094e1d1-0a3d-4a44-b0f4-7a75e953aa82"
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Cloning into 'mmclassification'...\n",
"remote: Enumerating objects: 3161, done.\u001b[K\n",
"remote: Counting objects: 100% (12/12), done.\u001b[K\n",
"remote: Compressing objects: 100% (12/12), done.\u001b[K\n",
"remote: Total 3161 (delta 2), reused 5 (delta 0), pack-reused 3149\u001b[K\n",
"Receiving objects: 100% (3161/3161), 2.81 MiB | 29.39 MiB/s, done.\n",
"Resolving deltas: 100% (2039/2039), done.\n"
]
}
],
"source": [
"# 下载 mmcls 代码库\n",
"!git clone https://github.com/open-mmlab/mmclassification.git"
]
},
{
"cell_type": "code",
"execution_count": 8,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "iJ45llP7jr5a",
"outputId": "c158c88c-5453-409a-aed9-1f6e219a6d17"
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"/content/mmclassification\n"
]
}
],
"source": [
"%cd mmclassification/"
]
},
{
"cell_type": "code",
"execution_count": 9,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "7c9K8ZVCjuFy",
"outputId": "d651cdbd-4457-4ffa-dc5f-f274570c0fd9"
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"configs docs_zh-CN model-index.yml requirements.txt tests\n",
"demo\t LICENSE README.md resources\t tools\n",
"docker\t MANIFEST.in README_zh-CN.md setup.cfg\n",
"docs\t mmcls\t requirements setup.py\n"
]
}
],
"source": [
"!ls"
]
},
{
"cell_type": "code",
"execution_count": 10,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "djjeq0I3jwOL",
"outputId": "0df874d1-4052-43b6-878c-0ea3c36fd7fc"
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Obtaining file:///content/mmclassification\n",
"Requirement already satisfied: matplotlib in /usr/local/lib/python3.7/dist-packages (from mmcls==0.13.0) (3.2.2)\n",
"Requirement already satisfied: numpy in /usr/local/lib/python3.7/dist-packages (from mmcls==0.13.0) (1.19.5)\n",
"Requirement already satisfied: pyparsing!=2.0.4,!=2.1.2,!=2.1.6,>=2.0.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib->mmcls==0.13.0) (2.4.7)\n",
"Requirement already satisfied: python-dateutil>=2.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib->mmcls==0.13.0) (2.8.1)\n",
"Requirement already satisfied: kiwisolver>=1.0.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib->mmcls==0.13.0) (1.3.1)\n",
"Requirement already satisfied: cycler>=0.10 in /usr/local/lib/python3.7/dist-packages (from matplotlib->mmcls==0.13.0) (0.10.0)\n",
"Requirement already satisfied: six in /usr/local/lib/python3.7/dist-packages (from cycler>=0.10->matplotlib->mmcls==0.13.0) (1.15.0)\n",
"Installing collected packages: mmcls\n",
" Running setup.py develop for mmcls\n",
"Successfully installed mmcls-0.13.0\n"
]
}
],
"source": [
"# 从源码安装 MMClassification\n",
"!pip install -e . "
]
},
{
"cell_type": "code",
2021-09-30 13:59:27 +08:00
"execution_count": 3,
2021-07-27 13:58:27 +08:00
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "hFg_oSG4j3zB",
"outputId": "3614ff26-ff64-45e9-ae30-b3d91dccea2c"
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
2021-09-30 13:59:27 +08:00
"0.15.0\n"
2021-07-27 13:58:27 +08:00
]
}
],
"source": [
"# 检查 MMClassification 的安装情况\n",
"import mmcls\n",
"print(mmcls.__version__)"
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "4Mi3g6yzj96L"
},
"source": [
"## 使用 MMCls 预训练模型\n",
"\n",
"MMCls 提供很多预训练好的模型,可以访问链接查看[模型库](https://github.com/open-mmlab/mmclassification/blob/master/docs/model_zoo.md).\n",
"这些模型都已经在 ImageNet 数据集上获得了 state-of-the-art 的结果。\n",
"我们能够直接使用这些模型进行推理计算。\n",
"\n",
"在使用预训练模型之前,我们需要进行如下操作:\n",
"\n",
"- 准备模型\n",
" - 准备 config 配置文件 \n",
" - 准备模型权重参数文件\n",
"- 构建模型\n",
"- 进行推理计算"
]
},
{
"cell_type": "code",
2021-09-30 13:59:27 +08:00
"execution_count": 4,
2021-07-27 13:58:27 +08:00
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "nDQchz8CkJaT",
"outputId": "8b7a96a8-2f8a-468e-98cf-9e5b27371f91"
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
2021-09-30 13:59:27 +08:00
"demo/banana.png: 没有那个文件或目录\n"
2021-07-27 13:58:27 +08:00
]
}
],
"source": [
"# 获取示例图片\n",
"!wget https://www.dropbox.com/s/k5fsqi6qha09l1v/banana.png?dl=0 -O demo/banana.png"
]
},
{
"cell_type": "code",
2021-09-30 13:59:27 +08:00
"execution_count": 3,
2021-07-27 13:58:27 +08:00
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/",
"height": 420
},
"id": "o2eiitWnkQq_",
"outputId": "9de00c3e-e70a-40f1-d68c-6a973ad964b8"
},
"outputs": [
{
"data": {
"image/png": "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
"text/plain": [
2021-09-30 13:59:27 +08:00
"<PIL.PngImagePlugin.PngImageFile image mode=RGBA size=393x403 at 0x7FE220329340>"
2021-07-27 13:58:27 +08:00
]
},
2021-09-30 13:59:27 +08:00
"execution_count": 3,
"metadata": {},
2021-07-27 13:58:27 +08:00
"output_type": "execute_result"
}
],
"source": [
"from PIL import Image\n",
"Image.open('demo/banana.png')"
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "sRfAui8EkTDX"
},
"source": [
"### 准备模型文件\n",
"\n",
"预训练模型通过配置文件和权重参数文件来定义。配置文件定义了模型结构,权重参数文件保存了训练好的模型参数。\n",
"\n",
"在 GitHub 上 MMCls 通过不同的页面来提供预训练模型。\n",
"比如, MobileNetV2 的配置文件和权重参数文件就在这个[链接](https://github.com/open-mmlab/mmclassification/tree/master/configs/mobilenet_v2)下。\n",
"\n",
"我们在安装 mmcls 时就已经将配置文件拿到了本地,但我们还需要手动下载模型权重参数文件。方便起见我们将权重参数文件统一保存到 `checkpoints` 文件夹下. "
]
},
{
"cell_type": "code",
"execution_count": 14,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "03RvRFuykb0C",
"outputId": "70385b7b-2cd9-4673-fbca-6637da435bb3"
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"--2021-07-27 03:22:19-- https://download.openmmlab.com/mmclassification/v0/mobilenet_v2/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"Resolving download.openmmlab.com (download.openmmlab.com)... 47.88.36.78\n",
"Connecting to download.openmmlab.com (download.openmmlab.com)|47.88.36.78|:443... connected.\n",
"HTTP request sent, awaiting response... 200 OK\n",
"Length: 14206911 (14M) [application/octet-stream]\n",
"Saving to: ‘ checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth’ \n",
"\n",
"mobilenet_v2_batch2 100%[===================>] 13.55M 11.0MB/s in 1.2s \n",
"\n",
"2021-07-27 03:22:21 (11.0 MB/s) - ‘ checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth’ saved [14206911/14206911]\n",
"\n"
]
}
],
"source": [
"!mkdir checkpoints\n",
"!wget https://download.openmmlab.com/mmclassification/v0/mobilenet_v2/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth -P checkpoints"
]
},
{
"cell_type": "code",
"execution_count": 15,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "VvRoZpBGkgpC",
"outputId": "1078d0df-e4d7-4947-e848-44c15b8ed444"
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"configs/mobilenet_v2/mobilenet_v2_b32x8_imagenet.py\n",
"checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n"
]
}
],
"source": [
"# 检查确保配置文件和参数文件都存在\n",
"!ls configs/mobilenet_v2/mobilenet_v2_b32x8_imagenet.py\n",
"!ls checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth"
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "eiYdsHoIkpD1"
},
"source": [
"### 图像分类\n",
"\n",
"MMCls 提供了 high level APIs 用来进行推理计算. \n",
"\n",
"首先,我们构建模型。"
]
},
{
"cell_type": "code",
2021-09-30 13:59:27 +08:00
"execution_count": 4,
2021-07-27 13:58:27 +08:00
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "KwJWlR2QkpiV",
"outputId": "4e897cde-f3f8-4c7e-de7b-4e04b5f22db8"
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Use load_from_local loader\n"
]
},
{
"name": "stderr",
"output_type": "stream",
"text": [
2021-09-30 13:59:27 +08:00
"/home/PJLAB/mazerun/mmlab/cls-better-vis/mmcls/apis/inference.py:44: UserWarning: Class names are not saved in the checkpoint's meta data, use imagenet by default.\n",
2021-07-27 13:58:27 +08:00
" warnings.warn('Class names are not saved in the checkpoint\\'s '\n"
]
}
],
"source": [
"from mmcls.apis import inference_model, init_model, show_result_pyplot\n",
"\n",
"# 指明配置文件和权重参数文件的路径\n",
"config_file = 'configs/mobilenet_v2/mobilenet_v2_b32x8_imagenet.py'\n",
"checkpoint_file = 'checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth'\n",
"# 指明设备,如果你没有开启 GPU, 可以使用 CPU, `device='cpu'`.\n",
"device = 'cuda:0'\n",
"# device = 'cpu'\n",
"# 通过配置文件和权重参数文件构建模型\n",
"model = init_model(config_file, checkpoint_file, device=device)"
]
},
{
"cell_type": "code",
2021-09-30 13:59:27 +08:00
"execution_count": 5,
2021-07-27 13:58:27 +08:00
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "GiSACYFgkvNE",
"outputId": "38445366-5bca-469a-a151-052510fe5d7d"
},
"outputs": [
{
"data": {
"text/plain": [
"(mmcls.models.classifiers.image.ImageClassifier,\n",
" mmcls.models.classifiers.base.BaseClassifier,\n",
" mmcv.runner.base_module.BaseModule,\n",
" torch.nn.modules.module.Module,\n",
" object)"
]
},
2021-09-30 13:59:27 +08:00
"execution_count": 5,
"metadata": {},
2021-07-27 13:58:27 +08:00
"output_type": "execute_result"
}
],
"source": [
"# 模型的继承关系\n",
"model.__class__.__mro__"
]
},
{
"cell_type": "code",
2021-09-30 13:59:27 +08:00
"execution_count": 6,
2021-07-27 13:58:27 +08:00
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "FyjY7hP9k0_D",
"outputId": "2f9c7e76-4350-44d4-a647-db5d26f8e2d7"
},
"outputs": [
{
"data": {
"text/plain": [
2021-09-30 13:59:27 +08:00
"{'pred_label': 954, 'pred_score': 0.9999284744262695, 'pred_class': 'banana'}"
2021-07-27 13:58:27 +08:00
]
},
2021-09-30 13:59:27 +08:00
"execution_count": 6,
"metadata": {},
2021-07-27 13:58:27 +08:00
"output_type": "execute_result"
}
],
"source": [
"# 在单张图片上展示模型的分类效果\n",
"img = 'demo/banana.png'\n",
"import mmcv\n",
"img_array = mmcv.imread(img)\n",
"result = inference_model(model, img_array)\n",
"result"
]
},
{
"cell_type": "code",
2021-09-30 13:59:27 +08:00
"execution_count": 7,
2021-07-27 13:58:27 +08:00
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/",
"height": 633
},
"id": "ndwdD8eUk96g",
"outputId": "abb722ef-4e71-4932-ed20-7876976bc378"
},
"outputs": [
{
"data": {
2021-09-30 13:59:27 +08:00
"image/png": "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
2021-07-27 13:58:27 +08:00
"text/plain": [
2021-09-30 13:59:27 +08:00
"<Figure size 393.01x403.01 with 1 Axes>"
2021-07-27 13:58:27 +08:00
]
},
"metadata": {
2021-09-30 13:59:27 +08:00
"needs_background": "light"
2021-07-27 13:58:27 +08:00
},
"output_type": "display_data"
}
],
"source": [
2021-09-30 13:59:27 +08:00
"%matplotlib inline\n",
2021-07-27 13:58:27 +08:00
"# 可视化分类结果\n",
"show_result_pyplot(model, img, result)"
]
},
2021-09-30 13:59:27 +08:00
{
"cell_type": "code",
"execution_count": 12,
"metadata": {},
"outputs": [
{
"data": {
"image/png": "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
"text/plain": [
"<Figure size 393.01x403.01 with 1 Axes>"
]
},
"metadata": {
"needs_background": "light"
},
"output_type": "display_data"
},
{
"data": {
"image/png": "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
"text/plain": [
"<Figure size 393.01x403.01 with 1 Axes>"
]
},
"metadata": {
"needs_background": "light"
},
"output_type": "display_data"
}
],
"source": [
"%matplotlib inline\n",
"from mmcls.core.visualization.image import ImshowInfosContextManager\n",
"import matplotlib.pyplot as plt\n",
"import numpy as np\n",
"\n",
"# fig1 = plt.figure()\n",
"# fig2 = plt.figure()\n",
"\n",
"# ax1 = fig1.add_subplot()\n",
"# ax1.plot([1,2,3], [2,3,4])\n",
"# ax2 = fig2.add_subplot()\n",
"# ax2.plot([1,2,3], [-2,-3,-4])\n",
"# print()\n",
"\n",
"result = {'res': 1}\n",
"result2 = {'res': 2}\n",
"\n",
"with ImshowInfosContextManager() as manager:\n",
" a = manager.put_img_infos(img, result, show=True)\n",
" b = manager.put_img_infos(img, result2, show=True)\n",
" \n",
"# fig = plt.figure()\n",
"# ax = fig.add_subplot()\n",
"# fig.subplots_adjust(left=0, right=1, bottom=0, top=1)\n",
"# ax.cla()\n",
"# ax.axis(False)\n",
"# img = mmcv.imread(img).astype(np.uint8)\n",
"# img = mmcv.bgr2rgb(img)\n",
"# ax.imshow(img)\n",
"# plt.close(fig)"
]
},
2021-07-27 13:58:27 +08:00
{
"cell_type": "markdown",
"metadata": {
"id": "oDMr3Bx_lESy"
},
"source": [
"## 模型微调\n",
"\n",
"模型微调是将预训练好的模型在特定的数据集上对模型参数进行非常精细调整的过程,最终让预训练的模型能够适配新的数据集及对应的任务。相比于模型的训练过程,模型微调大大降低了训练的时间,并减少了数据量很小的数据集在训练过程中会出现的过拟合问题。\n",
"\n",
"模型微调的基本步骤如下:\n",
"\n",
"1. 准备新数据集\n",
"2. 让数据集能够满足 MMCls 的要求\n",
"3. 根据数据集创建配置文件 \n",
"4. 进行训练和验证\n",
"\n",
"更多细节可以查看 [文档](https://github.com/open-mmlab/mmclassification/blob/master/docs/tutorials/new_dataset.md)."
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "TJtKKwAvlHX_"
},
"source": [
"### 准备数据集并满足 MMCls 的要求\n",
"\n",
"这里我们下载猫狗分类数据集,详细过程过程参考 MMClassification 教程"
]
},
{
"cell_type": "code",
"execution_count": 20,
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "3vBfU8GGlFPS",
"outputId": "431863a6-d7da-4642-a6a0-95167f696832"
},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"--2021-07-27 03:22:41-- https://www.dropbox.com/s/wml49yrtdo53mie/cats_dogs_dataset_reorg.zip?dl=0\n",
"Resolving www.dropbox.com (www.dropbox.com)... 162.125.1.18, 2620:100:6031:18::a27d:5112\n",
"Connecting to www.dropbox.com (www.dropbox.com)|162.125.1.18|:443... connected.\n",
"HTTP request sent, awaiting response... 301 Moved Permanently\n",
"Location: /s/raw/wml49yrtdo53mie/cats_dogs_dataset_reorg.zip [following]\n",
"--2021-07-27 03:22:41-- https://www.dropbox.com/s/raw/wml49yrtdo53mie/cats_dogs_dataset_reorg.zip\n",
"Reusing existing connection to www.dropbox.com:443.\n",
"HTTP request sent, awaiting response... 302 Found\n",
"Location: https://ucb4542ecde226f32d4315b1fbc8.dl.dropboxusercontent.com/cd/0/inline/BTGvHQfXo4i1Zuda0OfZIn3M0sLD9saAggO_ol8huDdBTN96R7KGhRMvQ1Qt7efcr-jQjKGu0jIht-yFUenpW8NxVNOfLZgAixsh7Of02gUkBZRBzOZkRTw9ZlePKnWLBFLX72WtD04FdxKOt4xG8Jp6/file# [following]\n",
"--2021-07-27 03:22:41-- https://ucb4542ecde226f32d4315b1fbc8.dl.dropboxusercontent.com/cd/0/inline/BTGvHQfXo4i1Zuda0OfZIn3M0sLD9saAggO_ol8huDdBTN96R7KGhRMvQ1Qt7efcr-jQjKGu0jIht-yFUenpW8NxVNOfLZgAixsh7Of02gUkBZRBzOZkRTw9ZlePKnWLBFLX72WtD04FdxKOt4xG8Jp6/file\n",
"Resolving ucb4542ecde226f32d4315b1fbc8.dl.dropboxusercontent.com (ucb4542ecde226f32d4315b1fbc8.dl.dropboxusercontent.com)... 162.125.1.15, 2620:100:6016:15::a27d:10f\n",
"Connecting to ucb4542ecde226f32d4315b1fbc8.dl.dropboxusercontent.com (ucb4542ecde226f32d4315b1fbc8.dl.dropboxusercontent.com)|162.125.1.15|:443... connected.\n",
"HTTP request sent, awaiting response... 302 Found\n",
"Location: /cd/0/inline2/BTG9WUVj6lUWIAp6GbSW-0BY6CLVIUaQD4UYVCKD2JSr0Ar8-dInWmMT3bXsc9xaHzLND2a2W3FrjDrM3aCBiRHIrpLSNqF9KdzroBiNmQF11eUUPszcj9GdSmTht-W9NMJfCYbBf5HOg9ldLUtex9mMEEV3LBMqT-qvGCNRYfXh9LWv8VOcrZM8JnebcmMFALgKdBl8FqbycGb0FkAhzHXshOhQvcWF1tdwE7VxyrVe2wT-B5RsuU8ClOuz0bY7nWyBIbyMFNNh1V28Qy3DSSTU3c74ULwTRMxlCHSN5dtZf3xvV99Kb57vkiTF8a888gyhO3C7F4TsGERtZxs9FXvMyKx990HfO0ORj-iTVw07akfIJN2jAyP6qmB3AyDPlSk/file [following]\n",
"--2021-07-27 03:22:42-- https://ucb4542ecde226f32d4315b1fbc8.dl.dropboxusercontent.com/cd/0/inline2/BTG9WUVj6lUWIAp6GbSW-0BY6CLVIUaQD4UYVCKD2JSr0Ar8-dInWmMT3bXsc9xaHzLND2a2W3FrjDrM3aCBiRHIrpLSNqF9KdzroBiNmQF11eUUPszcj9GdSmTht-W9NMJfCYbBf5HOg9ldLUtex9mMEEV3LBMqT-qvGCNRYfXh9LWv8VOcrZM8JnebcmMFALgKdBl8FqbycGb0FkAhzHXshOhQvcWF1tdwE7VxyrVe2wT-B5RsuU8ClOuz0bY7nWyBIbyMFNNh1V28Qy3DSSTU3c74ULwTRMxlCHSN5dtZf3xvV99Kb57vkiTF8a888gyhO3C7F4TsGERtZxs9FXvMyKx990HfO0ORj-iTVw07akfIJN2jAyP6qmB3AyDPlSk/file\n",
"Reusing existing connection to ucb4542ecde226f32d4315b1fbc8.dl.dropboxusercontent.com:443.\n",
"HTTP request sent, awaiting response... 200 OK\n",
"Length: 228802825 (218M) [application/zip]\n",
"Saving to: ‘ cats_dogs_dataset.zip’ \n",
"\n",
"cats_dogs_dataset.z 100%[===================>] 218.20M 122MB/s in 1.8s \n",
"\n",
"2021-07-27 03:22:45 (122 MB/s) - ‘ cats_dogs_dataset.zip’ saved [228802825/228802825]\n",
"\n"
]
}
],
"source": [
"# 下载分类数据集文件\n",
"!wget https://www.dropbox.com/s/wml49yrtdo53mie/cats_dogs_dataset_reorg.zip?dl=0 -O cats_dogs_dataset.zip\n",
"!mkdir data\n",
"!unzip -q cats_dogs_dataset.zip -d ./data/"
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "15iKNG0SlV9y"
},
"source": [
"### 根据数据集创建配置文件\n",
"\n",
"详细过程说明参考 MMClassification 教程,这里我们直接配置好微调的配置文件。"
]
},
{
"cell_type": "code",
2021-09-30 13:59:27 +08:00
"execution_count": 10,
2021-07-27 13:58:27 +08:00
"metadata": {
"id": "WCfnDavFlWrK"
},
"outputs": [],
"source": [
"# 载入已经存在的配置文件\n",
"from mmcv import Config\n",
"cfg = Config.fromfile('configs/mobilenet_v2/mobilenet_v2_b32x8_imagenet.py')\n",
"\n",
"# 修改模型分类头中的类别数目\n",
"cfg.model.head.num_classes = 2\n",
"cfg.model.head.topk = (1, )\n",
"\n",
"# 加载预训练权重\n",
"cfg.model.backbone.init_cfg = dict(type='Pretrained', checkpoint='checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth', prefix='backbone')\n",
"\n",
"# 根据你的电脑情况设置 sample size 和 workers \n",
"cfg.data.samples_per_gpu = 32\n",
"cfg.data.workers_per_gpu = 2\n",
"\n",
"# 指定训练集路径\n",
"cfg.data.train.data_prefix = 'data/cats_dogs_dataset/training_set/training_set'\n",
"cfg.data.train.classes = 'data/cats_dogs_dataset/classes.txt'\n",
"\n",
"# 指定验证集路径\n",
"cfg.data.val.data_prefix = 'data/cats_dogs_dataset/val_set/val_set'\n",
"cfg.data.val.ann_file = 'data/cats_dogs_dataset/val.txt'\n",
"cfg.data.val.classes = 'data/cats_dogs_dataset/classes.txt'\n",
"\n",
"# 指定测试集路径\n",
"cfg.data.test.data_prefix = 'data/cats_dogs_dataset/test_set/test_set'\n",
"cfg.data.test.ann_file = 'data/cats_dogs_dataset/test.txt'\n",
"cfg.data.test.classes = 'data/cats_dogs_dataset/classes.txt'\n",
"\n",
"# 设定数据集归一化参数\n",
"normalize_cfg = dict(type='Normalize', mean=[124.508, 116.050, 106.438], std=[58.577, 57.310, 57.437], to_rgb=True)\n",
"cfg.data.train.pipeline[3] = normalize_cfg\n",
"cfg.data.val.pipeline[3] = normalize_cfg\n",
"cfg.data.test.pipeline[3] = normalize_cfg\n",
"\n",
"# 修改评价指标选项\n",
"cfg.evaluation['metric_options']={'topk': (1, )}\n",
"\n",
"# 设置优化器\n",
"cfg.optimizer = dict(type='SGD', lr=0.01, momentum=0.9, weight_decay=0.0001)\n",
"cfg.optimizer_config = dict(grad_clip=None)\n",
"\n",
"# 设置学习率策略\n",
"cfg.lr_config = dict(policy='step', step=[1])\n",
"cfg.runner = dict(type='EpochBasedRunner', max_epochs=2)\n",
"\n",
"# 设置工作目录以保存模型和日志\n",
"cfg.work_dir = './work_dirs/cats_dogs_dataset'\n",
"\n",
"from mmcls.apis import set_random_seed\n",
"# 设置随机种子,并启用 cudnn 确定性选项以保证结果的可重复性\n",
"cfg.seed = 0\n",
"set_random_seed(0, deterministic=True)\n",
"\n",
"cfg.gpu_ids = range(1)"
]
},
{
"cell_type": "markdown",
"metadata": {
"id": "HDerVUPFmNR0"
},
"source": [
"### 模型微调\n",
"\n",
"基于我们修改的配置文件,开始对我们的数据集进行模型微调计算。 我们调用 `train_model` API 进行计算. "
]
},
{
"cell_type": "code",
2021-09-30 13:59:27 +08:00
"execution_count": null,
2021-07-27 13:58:27 +08:00
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/"
},
"id": "P7unq5cNmN8G",
"outputId": "0d7d9c26-842c-4e24-e958-4fdc8438c3e2"
},
"outputs": [
{
"name": "stderr",
"output_type": "stream",
"text": [
2021-09-30 13:59:27 +08:00
"2021-09-22 11:45:34,157 - mmcv - INFO - initialize MobileNetV2 with init_cfg {'type': 'Pretrained', 'checkpoint': 'checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth', 'prefix': 'backbone'}\n",
"2021-09-22 11:45:34,157 - mmcv - INFO - load backbone in model from: checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,185 - mmcv - INFO - initialize LinearClsHead with init_cfg {'type': 'Normal', 'layer': 'Linear', 'std': 0.01}\n",
"2021-09-22 11:45:34,186 - mmcv - INFO - backbone.conv1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,186 - mmcv - INFO - backbone.conv1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,186 - mmcv - INFO - backbone.conv1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,187 - mmcv - INFO - backbone.layer1.0.conv.0.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,187 - mmcv - INFO - backbone.layer1.0.conv.0.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,187 - mmcv - INFO - backbone.layer1.0.conv.0.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,188 - mmcv - INFO - backbone.layer1.0.conv.1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,188 - mmcv - INFO - backbone.layer1.0.conv.1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,188 - mmcv - INFO - backbone.layer1.0.conv.1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,189 - mmcv - INFO - backbone.layer2.0.conv.0.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,189 - mmcv - INFO - backbone.layer2.0.conv.0.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,189 - mmcv - INFO - backbone.layer2.0.conv.0.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,190 - mmcv - INFO - backbone.layer2.0.conv.1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,190 - mmcv - INFO - backbone.layer2.0.conv.1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,190 - mmcv - INFO - backbone.layer2.0.conv.1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,190 - mmcv - INFO - backbone.layer2.0.conv.2.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,191 - mmcv - INFO - backbone.layer2.0.conv.2.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,191 - mmcv - INFO - backbone.layer2.0.conv.2.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,191 - mmcv - INFO - backbone.layer2.1.conv.0.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,192 - mmcv - INFO - backbone.layer2.1.conv.0.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,192 - mmcv - INFO - backbone.layer2.1.conv.0.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,192 - mmcv - INFO - backbone.layer2.1.conv.1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,193 - mmcv - INFO - backbone.layer2.1.conv.1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,193 - mmcv - INFO - backbone.layer2.1.conv.1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,193 - mmcv - INFO - backbone.layer2.1.conv.2.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,194 - mmcv - INFO - backbone.layer2.1.conv.2.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,194 - mmcv - INFO - backbone.layer2.1.conv.2.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,194 - mmcv - INFO - backbone.layer3.0.conv.0.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,195 - mmcv - INFO - backbone.layer3.0.conv.0.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,195 - mmcv - INFO - backbone.layer3.0.conv.0.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,195 - mmcv - INFO - backbone.layer3.0.conv.1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,196 - mmcv - INFO - backbone.layer3.0.conv.1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,196 - mmcv - INFO - backbone.layer3.0.conv.1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,196 - mmcv - INFO - backbone.layer3.0.conv.2.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,197 - mmcv - INFO - backbone.layer3.0.conv.2.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,197 - mmcv - INFO - backbone.layer3.0.conv.2.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,199 - mmcv - INFO - backbone.layer3.1.conv.0.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,199 - mmcv - INFO - backbone.layer3.1.conv.0.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,200 - mmcv - INFO - backbone.layer3.1.conv.0.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,200 - mmcv - INFO - backbone.layer3.1.conv.1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,200 - mmcv - INFO - backbone.layer3.1.conv.1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,200 - mmcv - INFO - backbone.layer3.1.conv.1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,201 - mmcv - INFO - backbone.layer3.1.conv.2.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,201 - mmcv - INFO - backbone.layer3.1.conv.2.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,201 - mmcv - INFO - backbone.layer3.1.conv.2.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,201 - mmcv - INFO - backbone.layer3.2.conv.0.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,201 - mmcv - INFO - backbone.layer3.2.conv.0.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,202 - mmcv - INFO - backbone.layer3.2.conv.0.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,202 - mmcv - INFO - backbone.layer3.2.conv.1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,202 - mmcv - INFO - backbone.layer3.2.conv.1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,202 - mmcv - INFO - backbone.layer3.2.conv.1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,203 - mmcv - INFO - backbone.layer3.2.conv.2.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,203 - mmcv - INFO - backbone.layer3.2.conv.2.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,203 - mmcv - INFO - backbone.layer3.2.conv.2.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,203 - mmcv - INFO - backbone.layer4.0.conv.0.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,204 - mmcv - INFO - backbone.layer4.0.conv.0.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,204 - mmcv - INFO - backbone.layer4.0.conv.0.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,205 - mmcv - INFO - backbone.layer4.0.conv.1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,205 - mmcv - INFO - backbone.layer4.0.conv.1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,206 - mmcv - INFO - backbone.layer4.0.conv.1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,206 - mmcv - INFO - backbone.layer4.0.conv.2.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,206 - mmcv - INFO - backbone.layer4.0.conv.2.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,206 - mmcv - INFO - backbone.layer4.0.conv.2.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,207 - mmcv - INFO - backbone.layer4.1.conv.0.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,207 - mmcv - INFO - backbone.layer4.1.conv.0.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,207 - mmcv - INFO - backbone.layer4.1.conv.0.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,207 - mmcv - INFO - backbone.layer4.1.conv.1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,208 - mmcv - INFO - backbone.layer4.1.conv.1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,208 - mmcv - INFO - backbone.layer4.1.conv.1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,208 - mmcv - INFO - backbone.layer4.1.conv.2.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,208 - mmcv - INFO - backbone.layer4.1.conv.2.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,209 - mmcv - INFO - backbone.layer4.1.conv.2.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,209 - mmcv - INFO - backbone.layer4.2.conv.0.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,209 - mmcv - INFO - backbone.layer4.2.conv.0.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,209 - mmcv - INFO - backbone.layer4.2.conv.0.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,210 - mmcv - INFO - backbone.layer4.2.conv.1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,210 - mmcv - INFO - backbone.layer4.2.conv.1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,210 - mmcv - INFO - backbone.layer4.2.conv.1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,210 - mmcv - INFO - backbone.layer4.2.conv.2.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,211 - mmcv - INFO - backbone.layer4.2.conv.2.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,211 - mmcv - INFO - backbone.layer4.2.conv.2.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,211 - mmcv - INFO - backbone.layer4.3.conv.0.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,211 - mmcv - INFO - backbone.layer4.3.conv.0.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,211 - mmcv - INFO - backbone.layer4.3.conv.0.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,212 - mmcv - INFO - backbone.layer4.3.conv.1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,212 - mmcv - INFO - backbone.layer4.3.conv.1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,212 - mmcv - INFO - backbone.layer4.3.conv.1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,212 - mmcv - INFO - backbone.layer4.3.conv.2.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,213 - mmcv - INFO - backbone.layer4.3.conv.2.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,213 - mmcv - INFO - backbone.layer4.3.conv.2.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,213 - mmcv - INFO - backbone.layer5.0.conv.0.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,213 - mmcv - INFO - backbone.layer5.0.conv.0.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,213 - mmcv - INFO - backbone.layer5.0.conv.0.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,214 - mmcv - INFO - backbone.layer5.0.conv.1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,214 - mmcv - INFO - backbone.layer5.0.conv.1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,214 - mmcv - INFO - backbone.layer5.0.conv.1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,214 - mmcv - INFO - backbone.layer5.0.conv.2.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,215 - mmcv - INFO - backbone.layer5.0.conv.2.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,215 - mmcv - INFO - backbone.layer5.0.conv.2.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,215 - mmcv - INFO - backbone.layer5.1.conv.0.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,215 - mmcv - INFO - backbone.layer5.1.conv.0.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,216 - mmcv - INFO - backbone.layer5.1.conv.0.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,216 - mmcv - INFO - backbone.layer5.1.conv.1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,216 - mmcv - INFO - backbone.layer5.1.conv.1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,216 - mmcv - INFO - backbone.layer5.1.conv.1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,216 - mmcv - INFO - backbone.layer5.1.conv.2.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,217 - mmcv - INFO - backbone.layer5.1.conv.2.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,217 - mmcv - INFO - backbone.layer5.1.conv.2.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,217 - mmcv - INFO - backbone.layer5.2.conv.0.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,217 - mmcv - INFO - backbone.layer5.2.conv.0.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,218 - mmcv - INFO - backbone.layer5.2.conv.0.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,218 - mmcv - INFO - backbone.layer5.2.conv.1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,218 - mmcv - INFO - backbone.layer5.2.conv.1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,218 - mmcv - INFO - backbone.layer5.2.conv.1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,219 - mmcv - INFO - backbone.layer5.2.conv.2.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,219 - mmcv - INFO - backbone.layer5.2.conv.2.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,219 - mmcv - INFO - backbone.layer5.2.conv.2.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,223 - mmcv - INFO - backbone.layer6.0.conv.0.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,223 - mmcv - INFO - backbone.layer6.0.conv.0.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,223 - mmcv - INFO - backbone.layer6.0.conv.0.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,223 - mmcv - INFO - backbone.layer6.0.conv.1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,224 - mmcv - INFO - backbone.layer6.0.conv.1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,224 - mmcv - INFO - backbone.layer6.0.conv.1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,224 - mmcv - INFO - backbone.layer6.0.conv.2.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,224 - mmcv - INFO - backbone.layer6.0.conv.2.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,224 - mmcv - INFO - backbone.layer6.0.conv.2.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,225 - mmcv - INFO - backbone.layer6.1.conv.0.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,225 - mmcv - INFO - backbone.layer6.1.conv.0.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,225 - mmcv - INFO - backbone.layer6.1.conv.0.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,225 - mmcv - INFO - backbone.layer6.1.conv.1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,226 - mmcv - INFO - backbone.layer6.1.conv.1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,226 - mmcv - INFO - backbone.layer6.1.conv.1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,226 - mmcv - INFO - backbone.layer6.1.conv.2.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,226 - mmcv - INFO - backbone.layer6.1.conv.2.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,227 - mmcv - INFO - backbone.layer6.1.conv.2.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,227 - mmcv - INFO - backbone.layer6.2.conv.0.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,227 - mmcv - INFO - backbone.layer6.2.conv.0.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,227 - mmcv - INFO - backbone.layer6.2.conv.0.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,227 - mmcv - INFO - backbone.layer6.2.conv.1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,228 - mmcv - INFO - backbone.layer6.2.conv.1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,228 - mmcv - INFO - backbone.layer6.2.conv.1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,228 - mmcv - INFO - backbone.layer6.2.conv.2.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,228 - mmcv - INFO - backbone.layer6.2.conv.2.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,229 - mmcv - INFO - backbone.layer6.2.conv.2.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,229 - mmcv - INFO - backbone.layer7.0.conv.0.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,229 - mmcv - INFO - backbone.layer7.0.conv.0.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,229 - mmcv - INFO - backbone.layer7.0.conv.0.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,229 - mmcv - INFO - backbone.layer7.0.conv.1.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,230 - mmcv - INFO - backbone.layer7.0.conv.1.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,230 - mmcv - INFO - backbone.layer7.0.conv.1.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,230 - mmcv - INFO - backbone.layer7.0.conv.2.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,231 - mmcv - INFO - backbone.layer7.0.conv.2.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,231 - mmcv - INFO - backbone.layer7.0.conv.2.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,231 - mmcv - INFO - backbone.conv2.conv.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,233 - mmcv - INFO - backbone.conv2.bn.weight - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,234 - mmcv - INFO - backbone.conv2.bn.bias - PretrainedInit: load from checkpoints/mobilenet_v2_batch256_imagenet_20200708-3b2dc3af.pth\n",
"2021-09-22 11:45:34,234 - mmcv - INFO - head.fc.weight - NormalInit: mean=0, std=0.01, bias=0\n",
"2021-09-22 11:45:34,234 - mmcv - INFO - head.fc.bias - NormalInit: mean=0, std=0.01, bias=0\n",
"2021-09-22 11:45:34,273 - mmcls - INFO - Start running, host: PJLAB\\mazerun@shai14001059l, work_dir: /home/PJLAB/mazerun/mmlab/cls-better-vis/work_dirs/cats_dogs_dataset\n",
"2021-09-22 11:45:34,273 - mmcls - INFO - Hooks will be executed in the following order:\n",
2021-07-27 13:58:27 +08:00
"before_run:\n",
"(VERY_HIGH ) StepLrUpdaterHook \n",
"(NORMAL ) CheckpointHook \n",
"(NORMAL ) EvalHook \n",
"(VERY_LOW ) TextLoggerHook \n",
" -------------------- \n",
"before_train_epoch:\n",
"(VERY_HIGH ) StepLrUpdaterHook \n",
"(NORMAL ) EvalHook \n",
"(LOW ) IterTimerHook \n",
"(VERY_LOW ) TextLoggerHook \n",
" -------------------- \n",
"before_train_iter:\n",
"(VERY_HIGH ) StepLrUpdaterHook \n",
"(NORMAL ) EvalHook \n",
"(LOW ) IterTimerHook \n",
" -------------------- \n",
"after_train_iter:\n",
"(ABOVE_NORMAL) OptimizerHook \n",
"(NORMAL ) CheckpointHook \n",
"(NORMAL ) EvalHook \n",
"(LOW ) IterTimerHook \n",
"(VERY_LOW ) TextLoggerHook \n",
" -------------------- \n",
"after_train_epoch:\n",
"(NORMAL ) CheckpointHook \n",
"(NORMAL ) EvalHook \n",
"(VERY_LOW ) TextLoggerHook \n",
" -------------------- \n",
"before_val_epoch:\n",
"(LOW ) IterTimerHook \n",
"(VERY_LOW ) TextLoggerHook \n",
" -------------------- \n",
"before_val_iter:\n",
"(LOW ) IterTimerHook \n",
" -------------------- \n",
"after_val_iter:\n",
"(LOW ) IterTimerHook \n",
" -------------------- \n",
"after_val_epoch:\n",
"(VERY_LOW ) TextLoggerHook \n",
" -------------------- \n",
2021-09-30 13:59:27 +08:00
"2021-09-22 11:45:34,274 - mmcls - INFO - workflow: [('train', 1)], max: 2 epochs\n"
2021-07-27 13:58:27 +08:00
]
},
{
"name": "stdout",
"output_type": "stream",
"text": [
"Use load_from_local loader\n"
]
}
],
"source": [
"import time\n",
"import mmcv\n",
"import os.path as osp\n",
"\n",
"from mmcls.datasets import build_dataset\n",
"from mmcls.models import build_classifier\n",
"from mmcls.apis import train_model\n",
"\n",
"# 创建工作目录\n",
"mmcv.mkdir_or_exist(osp.abspath(cfg.work_dir))\n",
"# 创建分类器\n",
"model = build_classifier(cfg.model)\n",
"model.init_weights()\n",
"# 创建数据集\n",
"datasets = [build_dataset(cfg.data.train)]\n",
"# 添加类别属性以方便可视化\n",
"model.CLASSES = datasets[0].CLASSES\n",
"# 开始微调\n",
"train_model(\n",
" model,\n",
" datasets,\n",
" cfg,\n",
" distributed=False,\n",
" validate=True,\n",
" timestamp=time.strftime('%Y%m%d_%H%M%S', time.localtime()),\n",
" meta=dict())"
]
},
{
"cell_type": "code",
2021-09-30 13:59:27 +08:00
"execution_count": 5,
2021-07-27 13:58:27 +08:00
"metadata": {
"colab": {
"base_uri": "https://localhost:8080/",
"height": 652
},
"id": "HsoGBZA3miui",
"outputId": "c1a42eaa-588b-4431-fc02-bfedfed32c4f"
},
"outputs": [
{
2021-09-30 13:59:27 +08:00
"ename": "NameError",
"evalue": "name 'inference_model' is not defined",
"output_type": "error",
"traceback": [
"\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
"\u001b[0;31mNameError\u001b[0m Traceback (most recent call last)",
"\u001b[0;32m/tmp/ipykernel_1698183/2050782889.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m 7\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 8\u001b[0m \u001b[0mmodel\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcfg\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcfg\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 9\u001b[0;31m \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0minference_model\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mimg\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m 10\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m 11\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfigure\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfigsize\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m8\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m6\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
"\u001b[0;31mNameError\u001b[0m: name 'inference_model' is not defined"
2021-07-27 13:58:27 +08:00
]
}
],
"source": [
2021-09-30 13:59:27 +08:00
"%matplotlib inline\n",
2021-07-27 13:58:27 +08:00
"# 验证一下训练好的模型\n",
"import matplotlib.pyplot as plt\n",
"\n",
"\n",
"img = mmcv.imread('data/cats_dogs_dataset/training_set/training_set/cats/cat.1.jpg')\n",
"\n",
"model.cfg = cfg\n",
"result = inference_model(model, img)\n",
"\n",
"plt.figure(figsize=(8, 6))\n",
"show_result_pyplot(model, img, result)"
]
2021-09-30 13:59:27 +08:00
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": []
2021-07-27 13:58:27 +08:00
}
],
"metadata": {
"accelerator": "GPU",
"colab": {
"collapsed_sections": [],
"name": "MMClassification_python_cn.ipynb",
"provenance": []
},
"kernelspec": {
2021-09-30 13:59:27 +08:00
"display_name": "Python 3 (ipykernel)",
2021-07-27 13:58:27 +08:00
"language": "python",
"name": "python3"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 3
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
2021-09-30 13:59:27 +08:00
"version": "3.8.11"
2021-07-27 13:58:27 +08:00
}
},
"nbformat": 4,
"nbformat_minor": 4
}