diff --git a/fluid/ocr_recognition/README.md b/fluid/ocr_recognition/README.md index bc81a2c536e818250d6929c353ee1b641d67e6a6..96543ac831fdbe3fc105074faec0498eb5ea93d0 100644 --- a/fluid/ocr_recognition/README.md +++ b/fluid/ocr_recognition/README.md @@ -8,7 +8,9 @@ 这里将介绍如何在PaddlePaddle fluid下使用CRNN-CTC 和 CRNN-Attention模型对图片中的文字内容进行识别。 ## 1. CRNN-CTC + 本章的任务是识别含有单行汉语字符图片,首先采用卷积将图片转为`features map`, 然后使用`im2sequence op`将`features map`转为`sequence`,经过`双向GRU RNN`得到每个step的汉语字符的概率分布。训练过程选用的损失函数为CTC loss,最终的评估指标为`instance error rate`。 + 本路径下各个文件的作用如下: - **ctc_reader.py : ** 下载、读取、处理数据。提供方法`train()` 和 `test()` 分别产生训练集和测试集的数据迭代器。 @@ -16,10 +18,11 @@ - **ctc_train.py : ** 用于模型的训练,可通过命令`python train.py --help` 获得使用方法。 - **inference.py : ** 加载训练好的模型文件,对新数据进行预测。可通过命令`python inference.py --help` 获得使用方法。 - **eval.py : ** 评估模型在指定数据集上的效果。可通过命令`python inference.py --help` 获得使用方法。 -- **utility.py : ** 实现的一些通用方法,包括参数配置、tensor的构造等。 +- **utility.py : ** 实现的一些通用方法,包括参数配置、tensor的构造等。 ### 1.1 数据 + 数据的下载和简单预处理都在`ctc_reader.py`中实现。 #### 1.1.1 数据格式 @@ -39,7 +42,9 @@ #### 1.1.2 数据准备 + **A. 训练集** + 我们需要把所有参与训练的图片放入同一个文件夹,暂且记为`train_images`。然后用一个list文件存放每张图片的信息,包括图片大小、图片名称和对应的label,这里暂记该list文件为`train_list`,其格式如下所示: ``` @@ -50,9 +55,12 @@ ... 157 48 00387_0622.jpg 2397,1707,5919,1278 ``` +
文件train_list
+ 上述文件中的每一行表示一张图片,每行被空格分为四列,前两列分别表示图片的宽和高,第三列表示图片的名称,第四列表示该图片对应的sequence label。 最终我们应有以下类似文件结构: + ``` |-train_data |- train_list @@ -62,16 +70,21 @@ |- 00007_0219.jpg | ... ``` + 在训练时,我们通过选项`--train_images` 和 `--train_list` 分别设置准备好的`train_images` 和`train_list`。 + >**注:** 如果`--train_images` 和 `--train_list`都未设置或设置为None, ctc_reader.py会自动下载使用[示例数据](http://cloud.dlnel.org/filepub/?uuid=df937251-3c0b-480d-9a7b-0080dfeee65c),并将其缓存到`$HOME/.cache/paddle/dataset/ctc_data/data/` 路径下。 + **B. 测试集和评估集** + 测试集、评估集的准备方式与训练集相同。 在训练阶段,测试集的路径通过train.py的选项`--test_images` 和 `--test_list` 来设置。 在评估时,评估集的路径通过eval.py的选项`--input_images_dir` 和`--input_images_list` 来设置。 **C. 待预测数据集** + 待预测数据集的格式与训练集也类似,只不过list文件中的最后一列可以放任意占位字符或字符串,如下所示: ``` @@ -80,66 +93,70 @@ 338 48 00007_0219.jpg s ... ``` + 在做inference时,通过inference.py的选项`--input_images_dir`和`--input_images_list` 来设置输入数据的路径。 + #### 1.2 训练 通过以下命令调用训练脚本进行训练: + ``` python ctc_train.py [options] ``` 其中,options支持配置以下训练相关的参数: - **- -batch_size : ** Minibatch 大小,默认为32. +**- -batch_size : ** Minibatch 大小,默认为32. **- -pass_num : ** 训练多少个pass。默认为100。 - **- -log_period : ** 每隔多少个minibatch打印一次训练日志, 默认为1000. +**- -log_period : ** 每隔多少个minibatch打印一次训练日志, 默认为1000. **- -save_model_period : ** 每隔多少个minibatch保存一次模型。默认为15000。 如果设置为-1,则永不保存模型。 - **- -eval_period : ** 每隔多少个minibatch用测试集测试一次模型。默认为15000。如果设置为-1,则永不进行测试。 +**- -eval_period : ** 每隔多少个minibatch用测试集测试一次模型。默认为15000。如果设置为-1,则永不进行测试。 - **- -save_model_dir : ** 保存模型文件的路径,默认为“./models”,如果指定路径不存在,则会自动创建路径。 +**- -save_model_dir : ** 保存模型文件的路径,默认为“./models”,如果指定路径不存在,则会自动创建路径。 - **- -init_model : ** 初始化模型的路径。如果模型是以单个文件存储的,这里需要指定具体文件的路径;如果模型是以多个文件存储的,这里只需指定多个文件所在文件夹的路径。该选项默认为 None,意思是不用预训练模型做初始化。 +**- -init_model : ** 初始化模型的路径。如果模型是以单个文件存储的,这里需要指定具体文件的路径;如果模型是以多个文件存储的,这里只需指定多个文件所在文件夹的路径。该选项默认为 None,意思是不用预训练模型做初始化。 - **- -learning_rate : ** 全局learning rate. 默认为 0.001. +**- -learning_rate : ** 全局learning rate. 默认为 0.001. - **- -l2 : ** L2 regularizer. 默认为0.0004. +**- -l2 : ** L2 regularizer. 默认为0.0004. - **- -max_clip : ** Max gradient clipping threshold. 默认为10.0. +**- -max_clip : ** Max gradient clipping threshold. 默认为10.0. - **- -momentum : ** Momentum. 默认为0.9. +**- -momentum : ** Momentum. 默认为0.9. **- -rnn_hidden_size: ** RNN 隐藏层大小。 默认为200。 **- -device DEVICE : ** 设备ID。设置为-1,训练在CPU执行;设置为0,训练在GPU上执行。默认为0。 - **- -min_average_window : ** Min average window. 默认为10000. +**- -min_average_window : ** Min average window. 默认为10000. - **- -max_average_window : ** Max average window. 建议大小设置为一个pass内minibatch的数量。默认为15625. +**- -max_average_window : ** Max average window. 建议大小设置为一个pass内minibatch的数量。默认为15625. - **- -average_window : ** Average window. 默认为0.15. +**- -average_window : ** Average window. 默认为0.15. - **- -parallel : ** 是否使用多卡进行训练。默认为True. +**- -parallel : ** 是否使用多卡进行训练。默认为True. - **- -train_images : ** 存放训练集图片的路径,如果设置为None,ctc_reader会自动下载使用默认数据集。如果使用自己的数据进行训练,需要修改该选项。默认为None。 +**- -train_images : ** 存放训练集图片的路径,如果设置为None,ctc_reader会自动下载使用默认数据集。如果使用自己的数据进行训练,需要修改该选项。默认为None。 **- -train_list : ** 存放训练集图片信息的list文件,如果设置为None,ctc_reader会自动下载使用默认数据集。如果使用自己的数据进行训练,需要修改该选项。默认为None。 - **- -test_images : ** 存放测试集图片的路径,如果设置为None,ctc_reader会自动下载使用默认数据集。如果使用自己的数据进行测试,需要修改该选项。默认为None。 +**- -test_images : ** 存放测试集图片的路径,如果设置为None,ctc_reader会自动下载使用默认数据集。如果使用自己的数据进行测试,需要修改该选项。默认为None。 - **- -test_list : ** 存放测试集图片信息的list文件,如果设置为None,ctc_reader会自动下载使用默认数据集。如果使用自己的数据进行测试,需要修改该选项。默认为None。 +**- -test_list : ** 存放测试集图片信息的list文件,如果设置为None,ctc_reader会自动下载使用默认数据集。如果使用自己的数据进行测试,需要修改该选项。默认为None。 - **- -num_classes : ** 字符集的大小。如果设置为None, 则使用ctc_reader提供的字符集大小。如果使用自己的数据进行训练,需要修改该选项。默认为None. +**- -num_classes : ** 字符集的大小。如果设置为None, 则使用ctc_reader提供的字符集大小。如果使用自己的数据进行训练,需要修改该选项。默认为None. ### 1.3 Inference 通过以下命令调用预测脚本进行预测: + ``` python inference.py [options] ``` @@ -148,17 +165,18 @@ python inference.py [options] **--model_path : ** 用来做预测的模型文件。如果模型是以单个文件存储的,这里需要指定具体文件的路径;如果模型是以多个文件存储的,这里只需指定多个文件所在文件夹的路径。为必设置选项。 - **--input_images_dir : ** 存放待预测图片的文件夹路径。如果设置为None, 则使用ctc_reader提供的默认数据。默认为None. +**--input_images_dir : ** 存放待预测图片的文件夹路径。如果设置为None, 则使用ctc_reader提供的默认数据。默认为None. - **--input_images_list : ** 存放待预测图片信息的list文件的路径。如果设置为None, 则使用ctc_reader提供的默认数据。默认为None. +**--input_images_list : ** 存放待预测图片信息的list文件的路径。如果设置为None, 则使用ctc_reader提供的默认数据。默认为None. - **--device DEVICE :** 设备ID。设置为-1,运行在CPU上;设置为0,运行在GPU上。默认为0。 +**--device DEVICE :** 设备ID。设置为-1,运行在CPU上;设置为0,运行在GPU上。默认为0。 预测结果会print到标准输出。 ### 1.4 Evaluate 通过以下命令调用评估脚本用指定数据集对模型进行评估: + ``` python eval.py [options] ``` @@ -167,8 +185,8 @@ python eval.py [options] **--model_path : ** 待评估模型的文件路径。如果模型是以单个文件存储的,这里需要指定具体文件的路径;如果模型是以多个文件存储的,这里只需指定多个文件所在文件夹的路径。为必设置选项。 - **--input_images_dir : ** 存放待评估图片的文件夹路径。如果设置为None, 则使用ctc_reader提供的默认数据。默认为None. +**--input_images_dir : ** 存放待评估图片的文件夹路径。如果设置为None, 则使用ctc_reader提供的默认数据。默认为None. - **--input_images_list : ** 存放待评估图片信息的list文件的路径。如果设置为None, 则使用ctc_reader提供的默认数据。默认为None. +**--input_images_list : ** 存放待评估图片信息的list文件的路径。如果设置为None, 则使用ctc_reader提供的默认数据。默认为None. - **--device DEVICE :** 设备ID。设置为-1,运行在CPU上;设置为0,运行在GPU上。默认为0。 +**--device DEVICE :** 设备ID。设置为-1,运行在CPU上;设置为0,运行在GPU上。默认为0。