README.md 3.9 KB
Newer Older
S
Steffy-zxf 已提交
1 2
## 概述

S
Steffy-zxf 已提交
3
Differentiable Binarization(简称DB)是一种基于分割的文本检测算法。在各种文本检测算法中,基于分割的检测算法可以更好地处理弯曲等不规则形状文本,因此往往能取得更好的检测效果。但分割法后处理步骤中将分割结果转化为检测框的流程复杂,耗时严重。DB将二值化阈值加入训练中学习,可以获得更准确的检测边界,从而简化后处理流程。该Module是一个通用的文本检测模型,支持直接预测。
S
Steffy-zxf 已提交
4 5 6 7 8 9 10 11 12 13 14

<p align="center">
<img src="https://bj.bcebos.com/paddlehub/model/image/ocr/db_algo.png" hspace='10'/> <br />
</p>

更多详情参考[Real-time Scene Text Detection with Differentiable Binarization](https://arxiv.org/pdf/1911.08947.pdf)


## 命令行预测

```shell
S
Steffy-zxf 已提交
15
$ hub run chinese_text_detection_db_server --input_path "/PATH/TO/IMAGE"
S
Steffy-zxf 已提交
16 17 18 19 20 21
```

**该Module依赖于第三方库shapely和pyclipper,使用该Module之前,请先安装shapely和pyclipper。**

## API

S
Steffy-zxf 已提交
22 23 24 25 26 27 28 29
### \_\_init\_\_(enable_mkldnn=False)

构造ChineseTextDetectionDBServer对象

**参数**

* enable_mkldnn(bool): 是否开启mkldnn加速CPU计算。该参数仅在CPU运行下设置有效。默认为False。

S
Steffy-zxf 已提交
30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52
```python
def detect_text(paths=[],
                images=[],
                use_gpu=False,
                output_dir='detection_result',
                box_thresh=0.5,
                visualization=False)
```

预测API,检测输入图片中的所有中文文本的位置。

**参数**

* paths (list\[str\]): 图片的路径;
* images (list\[numpy.ndarray\]): 图片数据,ndarray.shape 为 \[H, W, C\],BGR格式;
* use\_gpu (bool): 是否使用 GPU;**若使用GPU,请先设置CUDA_VISIBLE_DEVICES环境变量**
* box\_thresh (float): 检测文本框置信度的阈值;
* visualization (bool): 是否将识别结果保存为图片文件;
* output\_dir (str): 图片的保存路径,默认设为 detection\_result;

**返回**

* res (list\[dict\]): 识别结果的列表,列表中每一个元素为 dict,各字段为:
S
Steffy-zxf 已提交
53
    * data (list): 检测文本框结果,文本框在原图中的像素坐标,4*2的矩阵,依次表示文本框左下、右下、右上、左上顶点的坐标
S
Steffy-zxf 已提交
54 55 56 57 58 59 60 61
    * save_path (str): 识别结果的保存路径, 如不保存图片则save_path为''

### 代码示例

```python
import paddlehub as hub
import cv2

S
Steffy-zxf 已提交
62
text_detector = hub.Module(name="chinese_text_detection_db_server")
S
Steffy-zxf 已提交
63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
result = text_detector.detect_text(images=[cv2.imread('/PATH/TO/IMAGE')])

# or
# result =text_detector.detect_text(paths=['/PATH/TO/IMAGE'])
```


## 服务部署

PaddleHub Serving 可以部署一个目标检测的在线服务。

### 第一步:启动PaddleHub Serving

运行启动命令:
```shell
S
Steffy-zxf 已提交
78
$ hub serving start -m chinese_text_detection_db_server
S
Steffy-zxf 已提交
79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101
```

这样就完成了一个目标检测的服务化API的部署,默认端口号为8866。

**NOTE:** 如使用GPU预测,则需要在启动服务之前,请设置CUDA\_VISIBLE\_DEVICES环境变量,否则不用设置。

### 第二步:发送预测请求

配置好服务端,以下数行代码即可实现发送预测请求,获取预测结果

```python
import requests
import json
import cv2
import base64

def cv2_to_base64(image):
    data = cv2.imencode('.jpg', image)[1]
    return base64.b64encode(data.tostring()).decode('utf8')

# 发送HTTP请求
data = {'images':[cv2_to_base64(cv2.imread("/PATH/TO/IMAGE"))]}
headers = {"Content-type": "application/json"}
S
Steffy-zxf 已提交
102
url = "http://127.0.0.1:8866/predict/chinese_text_detection_db_server"
S
Steffy-zxf 已提交
103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127
r = requests.post(url=url, headers=headers, data=json.dumps(data))

# 打印预测结果
print(r.json()["results"])
```

## 查看代码

https://github.com/PaddlePaddle/PaddleOCR

## 依赖

paddlepaddle >= 1.7.2

paddlehub >= 1.6.0

shapely

pyclipper

## 更新历史

* 1.0.0

  初始发布
S
Steffy-zxf 已提交
128 129 130 131

* 1.0.2

  支持mkldnn加速CPU计算
S
Steffy-zxf 已提交
132 133 134 135

* 1.0.3

  增加更多预训练数据,更新预训练参数