• Stars
    star
    186
  • Rank 207,316 (Top 5 %)
  • Language
    Python
  • Created over 9 years ago
  • Updated over 4 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Use caffe to train your own data in just one click

caffe一键式训练评估集成开发环境

Last Update 2020.07.08

概述

本项目提供一个集成式开发环境,在配好caffe环境的前提下,只需将准备好的图片放入data目录下,便可以一键生成lmdb数据文件、均值文件、标注文件和测试评估模型、找出错误样本、部署模型等所有的操作,更难能可贵的是它是跨平台的,可以无缝的在Windos和Linux间切换。

使用深度学习完成一个特定的任务比如说字符识别、人脸识别等大致可以分为数据准备、定义模型、训练模型、评估模型和部署模型等几个步骤。

配置caffe

现在配置caffe十分方便,仅需几行命令即可搞定,确保安装了所需的依赖,这里仅摘录最关键的部分,其余的详细内容可参见参考链接.

Windows

::为了减少日后不必要的麻烦,建议VS2015,Cuda8.0,cudnn5.1及以上,python2.7
git clone https://github.com/BVLC/caffe
cd caffe
git checkout windows
scripts\build_win.cmd

Linux

git clone https://github.com/BVLC/caffe
cd caffe
mkdir build
cd build
cmake ..
make -j8

1.数据准备

首先收集要任务相关的数据,这里准备了一个车牌字符数据(仅包含0-9共10个数字),直接解压data.zip到当前文件夹即可,格式如下图所示,每类图片对应一个文件夹,放到一个data文件夹下,注意格式一致型(都为.jpg或.png文件),仔细筛查,不要含有其他的非图片文件在里面,你也可以用自己的数据替换这些车牌字符数据。

structures

caffe使用了lmdb内存数据库等来加快训练时读取数据的速度,为此,caffe自带的tools里提供了一个工具(可由convert_imageset.cpp编译生成),它的输入是图片路径和标签对组成的文件,每次都手动生成这个文件不胜其烦。

我们希望是自动化的从文件夹读取的功能,因此,本项目通过preprocess/preprocess.py来获取如下图所示的文件夹下所有的文件路径以及对应的文件标签的功能,它输出训练和验证集preprocess/train.txt和preprocess/val.txt以及标签映射文件modef/labels.txt

你也可以直接下载已经转换好的lmdb.tar.gz文件直接使用

2.定义模型

训练定义文件位于models下的plate_train_test.prototxt,部署文件在deploy.prototxt,你可以通过网络结构可视化对这些网络进行可视化,以便更清晰的理解他们的含义

3.训练模型

./train.sh

4.评估模型

evaluation.py用来对data文件下下的数据进行评估,它会得出迭代次数为10000时模型的错误率,并且打印出误识别图片对应的真值和预测值,并把相应数据保存在error文件夹下,命名格式为字符文件夹/图片在文件夹内的序号_真值类别_预测类别(以0/190_0_4.jpg为例,代表0/190.jpg被误识为4),这些错误识别的样本需要仔细分析,不断调试参数,以获得期望的结果。

本项目提供了一个训练好的模型文件,其错误率低于0.1%,这就意味着其达到了99.9%以上的准确率。

5.部署模型

由于速度原因,实际中多使用C++而不是python进行部署,因此本项目在cpp文件夹下提供了evaluationcpp工程,它使用单例模式来防止每次预测都加载模型,只需使用如下代码即可在你的项目中一行代码使用CNN,此外,该项目也提供了对模型进行评估的功能。

 cv::Mat img=cv::imread("imagepath.jpg");
 string result=CnnPredictor::getInstance()->predict(img);

当然,你也可以运行calssification.bat来调用caffe自身进行分类识别

"../build/examples/cpp_classification/classification" "modeldef/deploy.prototxt" "trainedmodels/platerecognition_iter_1000.caffemodel" "modeldef/mean.binaryproto" "modeldef/labels.txt" "data/0/4-3.jpg"

其返回了最高的5个类别的相似度,不难看出训练的网络对于data/0/0.jpg有高达93%的概率认为其属于0这个字符,结果还是非常理想的

参考

More Repositories

1

MTCNN

Realtime Face Detection and Head pose estimation on Windows、Ubuntu、Mac、Android and iOS
Jupyter Notebook
462
star
2

EasyPR4Android

Andorid端实时车牌识别Realtime chinese plate recoginition on android
C++
176
star
3

MatConvNet-oneclick

Train your own data with MatConvNet
MATLAB
87
star
4

mxnet-oneclick

use mxnet to train your own data with just oneclick
Python
79
star
5

MRLabeler

极速检测标注工具An efficient tool for objection detection annotation
C++
72
star
6

ssd-models

caffe-ssd for face, head and vehicle detection
Python
70
star
7

yolo-face

use yolo v2 to train face detection model on CelebA dataset
Python
60
star
8

SeetaFace4Android

Realtime Face detection on android
Java
57
star
9

facemask

Realtime face and mask detection
Python
50
star
10

Way4CV

Best practice of computer vision learning
39
star
11

tensorflow-cpp-VS2015

tensorflow c++ example for VS2015
C++
32
star
12

fddb

Face Detection benchmark on Windows,Ubuntu and Mac
C++
28
star
13

PCN-Windows

C++
21
star
14

ncnn_face

MobileNet-SSD Face Detection by ncnn
C++
21
star
15

tf-car

Car Detection in tensorflow
Python
17
star
16

mrcv

useful tools for python
Python
16
star
17

DuiOCR

基于DUILib和Tesseract的OCR识别工具
C++
16
star
18

MRHead

efficient header for third-party libs
C
12
star
19

SSH-Windows

Windows version for Single Stage Headless Face Detector
Python
10
star
20

RepVGG-caffe

https://blog.csdn.net/WZZ18191171661/article/details/112691604
Python
8
star
21

ssd

跨平台编译版SSD,含有深度可分离卷积层,支持cuda10, Windows支持python3.6等,支持ssd训练预处理加速,支持MTCNN训练
C++
7
star
22

OpenWear

Virtual glasses wear on Windows、Ubuntu and Mac
C++
6
star
23

EasyPR-Swift

swift port of EasyPR
C++
3
star
24

portrait-matting-unet-flask

Python
1
star