深度学习工程模板,简化加载数据、构建网络、训练模型和预测样本的流程。
By C. L. Wang @ 美图云事业部
下载工程
git clone https://github.com/SpikeKing/DL-Project-Template
创建和激活虚拟环境
virtualenv venv
source venv/bin/activate
安装Python依赖库
pip install -r requirements.txt
开发流程
- 定义自己的数据加载类,继承DataLoaderBase;
- 定义自己的网络结构类,继承ModelBase;
- 定义自己的模型训练类,继承TrainerBase;
- 定义自己的样本预测类,继承InferBase;
- 定义自己的配置文件,写入实验的相关参数;
执行训练模型和预测样本操作。
识别MNIST库中手写数字,工程simple_mnist
训练:
python main_train.py -c configs/simple_mnist_config.json
预测:
python main_test.py -c configs/simple_mnist_config.json -m simple_mnist.weights.10-0.24.hdf5
网络结构
TensorBoard
├── bases
│ ├── data_loader_base.py - 数据加载基类
│ ├── infer_base.py - 预测样本(推断)基类
│ ├── model_base.py - 网络结构(模型)基类
│ ├── trainer_base.py - 训练模型基类
├── configs - 配置文件夹
│ └── simple_mnist_config.json
├── data_loaders - 数据加载文件夹
│ ├── __init__.py
│ ├── simple_mnist_dl.py
├── experiments - 实验数据文件夹
│ └── simple_mnist - 实验名称
│ ├── checkpoints - 存储的模型和参数
│ │ └── simple_mnist.weights.10-0.24.hdf5
│ ├── images - 图片
│ │ └── model.png
│ └── logs - 日志,如TensorBoard
│ └── events.out.tfevents.1524034653.wang
├── infers - 推断文件夹
│ ├── __init__.py
│ ├── simple_mnist_infer.py
├── main_test.py - 预测样本入口
├── main_train.py - 训练模型入口
├── models - 网络结构文件夹
│ ├── __init__.py
│ ├── simple_mnist_model.py
├── requirements.txt - 依赖库
├── trainers - 训练模型文件夹
│ ├── __init__.py
│ ├── simple_mnist_trainer.py
└── utils - 工具文件夹
├── __init__.py
├── config_utils.py - 配置工具类
├── np_utils.py - NumPy工具类
├── utils.py - 其他工具类
操作步骤:
- 创建自己的加载数据类,继承DataLoaderBase基类;
- 覆写
get_train_data()
和get_test_data()
,返回训练和测试数据;
操作步骤:
- 创建自己的网络结构类,继承ModelBase基类;
- 覆写
build_model()
,创建网络结构; - 在构造器中,调用
build_model()
;
注意:plot_model()
支持绘制网络结构;
操作步骤:
- 创建自己的训练类,继承TrainerBase基类;
- 参数:网络结构model、训练数据data;
- 覆写
train()
,fit数据,训练网络结构;
注意:支持在训练中调用callbacks,额外添加模型存储、TensorBoard、FPR度量等。
操作步骤:
- 创建自己的预测类,继承InferBase基类;
- 覆写
load_model()
,提供模型加载功能; - 覆写
predict()
,提供样本预测功能;
定义在模型训练过程中所需的参数,JSON格式,支持:学习率、Epoch、Batch等参数。
训练:
- 创建配置文件config;
- 创建数据加载类dataloader;
- 创建网络结构类model;
- 创建训练类trainer,参数是训练和测试数据、模型;
- 执行训练类trainer的train();
预测:
- 创建配置文件config;
- 处理预测样本test;
- 创建预测类infer;
- 执行预测类infer的predict();