module.py 4.4 KB
Newer Older
D
dyning 已提交
1 2 3 4 5 6
# -*- coding:utf-8 -*-
from __future__ import absolute_import
from __future__ import division
from __future__ import print_function

import os
W
WenmuZhou 已提交
7 8
import sys
sys.path.insert(0, ".")
L
littletomatodonkey 已提交
9
import copy
W
WenmuZhou 已提交
10

D
dyning 已提交
11 12 13 14 15 16 17 18
import time

from paddlehub.common.logger import logger
from paddlehub.module.module import moduleinfo, runnable, serving
import cv2
import numpy as np
import paddlehub as hub

D
dyning 已提交
19
from tools.infer.utility import base64_to_cv2
D
dyning 已提交
20
from tools.infer.predict_system import TextSystem
L
littletomatodonkey 已提交
21
from tools.infer.utility import parse_args
D
dyning 已提交
22 23 24 25 26 27 28 29 30 31


@moduleinfo(
    name="ocr_system",
    version="1.0.0",
    summary="ocr system service",
    author="paddle-dev",
    author_email="paddle-dev@baidu.com",
    type="cv/text_recognition")
class OCRSystem(hub.Module):
32
    def _initialize(self, use_gpu=False, enable_mkldnn=False):
D
dyning 已提交
33 34 35
        """
        initialize with the necessary elements
        """
L
littletomatodonkey 已提交
36
        cfg = self.merge_configs()
D
dyning 已提交
37 38

        cfg.use_gpu = use_gpu
D
dyning 已提交
39 40 41 42 43 44
        if use_gpu:
            try:
                _places = os.environ["CUDA_VISIBLE_DEVICES"]
                int(_places[0])
                print("use gpu: ", use_gpu)
                print("CUDA_VISIBLE_DEVICES: ", _places)
D
dyning 已提交
45
                cfg.gpu_mem = 8000
D
dyning 已提交
46 47 48 49
            except:
                raise RuntimeError(
                    "Environment Variable CUDA_VISIBLE_DEVICES is not set correctly. If you wanna use gpu, please set CUDA_VISIBLE_DEVICES via export CUDA_VISIBLE_DEVICES=cuda_device_id."
                )
D
dyning 已提交
50
        cfg.ir_optim = True
51
        cfg.enable_mkldnn = enable_mkldnn
W
WenmuZhou 已提交
52

D
dyning 已提交
53
        self.text_sys = TextSystem(cfg)
D
dyning 已提交
54

L
littletomatodonkey 已提交
55 56 57 58 59 60 61 62 63 64 65 66 67 68 69
    def merge_configs(self, ):
        # deafult cfg
        backup_argv = copy.deepcopy(sys.argv)
        sys.argv = sys.argv[:1]
        cfg = parse_args()

        from ocr_det.params import read_params
        update_cfg_map = vars(read_params())

        for key in update_cfg_map:
            cfg.__setattr__(key, update_cfg_map[key])

        sys.argv = copy.deepcopy(backup_argv)
        return cfg

D
dyning 已提交
70 71 72 73 74 75 76 77 78 79 80 81
    def read_images(self, paths=[]):
        images = []
        for img_path in paths:
            assert os.path.isfile(
                img_path), "The {} isn't a valid file.".format(img_path)
            img = cv2.imread(img_path)
            if img is None:
                logger.info("error in loading image:{}".format(img_path))
                continue
            images.append(img)
        return images

W
WenmuZhou 已提交
82
    def predict(self, images=[], paths=[]):
D
dyning 已提交
83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104
        """
        Get the chinese texts in the predicted images.
        Args:
            images (list(numpy.ndarray)): images data, shape of each is [H, W, C]. If images not paths
            paths (list[str]): The paths of images. If paths not images
        Returns:
            res (list): The result of chinese texts and save path of images.
        """

        if images != [] and isinstance(images, list) and paths == []:
            predicted_data = images
        elif images == [] and isinstance(paths, list) and paths != []:
            predicted_data = self.read_images(paths)
        else:
            raise TypeError("The input data is inconsistent with expectations.")

        assert predicted_data != [], "There is not any image to be predicted. Please check the input data."

        all_results = []
        for img in predicted_data:
            if img is None:
                logger.info("error in loading image")
D
dyning 已提交
105
                all_results.append([])
D
dyning 已提交
106 107
                continue
            starttime = time.time()
D
dyning 已提交
108
            dt_boxes, rec_res = self.text_sys(img)
D
dyning 已提交
109
            elapse = time.time() - starttime
D
dyning 已提交
110 111
            logger.info("Predict time: {}".format(elapse))

D
dyning 已提交
112 113
            dt_num = len(dt_boxes)
            rec_res_final = []
D
dyning 已提交
114

D
dyning 已提交
115 116
            for dno in range(dt_num):
                text, score = rec_res[dno]
W
WenmuZhou 已提交
117 118 119 120 121
                rec_res_final.append({
                    'text': text,
                    'confidence': float(score),
                    'text_region': dt_boxes[dno].astype(np.int).tolist()
                })
D
dyning 已提交
122
            all_results.append(rec_res_final)
D
dyning 已提交
123 124 125 126 127 128 129 130
        return all_results

    @serving
    def serving_method(self, images, **kwargs):
        """
        Run as a service.
        """
        images_decode = [base64_to_cv2(image) for image in images]
D
dyning 已提交
131
        results = self.predict(images_decode, **kwargs)
D
dyning 已提交
132 133
        return results

W
WenmuZhou 已提交
134

D
dyning 已提交
135 136 137 138 139 140
if __name__ == '__main__':
    ocr = OCRSystem()
    image_path = [
        './doc/imgs/11.jpg',
        './doc/imgs/12.jpg',
    ]
D
dyning 已提交
141
    res = ocr.predict(paths=image_path)
W
WenmuZhou 已提交
142
    print(res)