From 047fcb527a14ad3037767fd2934ecddbb8fd0053 Mon Sep 17 00:00:00 2001 From: littletomatodonkey Date: Fri, 21 Aug 2020 08:49:11 +0000 Subject: [PATCH 01/42] add warmup --- doc/doc_ch/config.md | 7 +++--- doc/doc_en/config_en.md | 7 +++--- ppocr/optimizer.py | 53 ++++++++++++++++++++++++++++++++++++++--- 3 files changed, 58 insertions(+), 9 deletions(-) diff --git a/doc/doc_ch/config.md b/doc/doc_ch/config.md index 03fe1b32..fe8db9c8 100644 --- a/doc/doc_ch/config.md +++ b/doc/doc_ch/config.md @@ -63,8 +63,9 @@ | beta1 | 设置一阶矩估计的指数衰减率 | 0.9 | \ | | beta2 | 设置二阶矩估计的指数衰减率 | 0.999 | \ | | decay | 是否使用decay | \ | \ | -| function(decay) | 设置decay方式 | - | 目前支持cosine_decay与piecewise_decay | -| step_each_epoch | 每个epoch包含多少次迭代, cosine_decay时有效 | 20 | 计算方式:total_image_num / (batch_size_per_card * card_size) | -| total_epoch | 总共迭代多少个epoch, cosine_decay时有效 | 1000 | 与Global.epoch_num 一致 | +| function(decay) | 设置decay方式 | - | 目前支持cosine_decay, cosine_decay_warmup与piecewise_decay | +| step_each_epoch | 每个epoch包含多少次迭代, cosine_decay/cosine_decay_warmup时有效 | 20 | 计算方式:total_image_num / (batch_size_per_card * card_size) | +| total_epoch | 总共迭代多少个epoch, cosine_decay/cosine_decay_warmup时有效 | 1000 | 与Global.epoch_num 一致 | +| warmup_minibatch | 线性warmup的迭代次数, cosine_decay_warmup时有效 | 1000 | \ | | boundaries | 学习率下降时的迭代次数间隔, piecewise_decay时有效 | - | 参数为列表形式 | | decay_rate | 学习率衰减系数, piecewise_decay时有效 | - | \ | diff --git a/doc/doc_en/config_en.md b/doc/doc_en/config_en.md index 66578424..b54def89 100644 --- a/doc/doc_en/config_en.md +++ b/doc/doc_en/config_en.md @@ -60,8 +60,9 @@ Take `rec_icdar15_train.yml` as an example: | beta1 | Set the exponential decay rate for the 1st moment estimates | 0.9 | \ | | beta2 | Set the exponential decay rate for the 2nd moment estimates | 0.999 | \ | | decay | Whether to use decay | \ | \ | -| function(decay) | Set the decay function | cosine_decay | Support cosine_decay and piecewise_decay | -| step_each_epoch | The number of steps in an epoch. Used in cosine_decay | 20 | Calculation :total_image_num / (batch_size_per_card * card_size) | -| total_epoch | The number of epochs. Used in cosine_decay | 1000 | Consistent with Global.epoch_num | +| function(decay) | Set the decay function | cosine_decay | Support cosine_decay, cosine_decay_warmup and piecewise_decay | +| step_each_epoch | The number of steps in an epoch. Used in cosine_decay/cosine_decay_warmup | 20 | Calculation: total_image_num / (batch_size_per_card * card_size) | +| total_epoch | The number of epochs. Used in cosine_decay/cosine_decay_warmup | 1000 | Consistent with Global.epoch_num | +| warmup_minibatch | Number of steps for linear warmup. Used in cosine_decay_warmup | 1000 | \ | | boundaries | The step intervals to reduce learning rate. Used in piecewise_decay | - | The format is list | | decay_rate | Learning rate decay rate. Used in piecewise_decay | - | \ | diff --git a/ppocr/optimizer.py b/ppocr/optimizer.py index 55f2eba1..fd315cd1 100644 --- a/ppocr/optimizer.py +++ b/ppocr/optimizer.py @@ -14,14 +14,50 @@ from __future__ import absolute_import from __future__ import division from __future__ import print_function +import math import paddle.fluid as fluid from paddle.fluid.regularizer import L2Decay +from paddle.fluid.layers.learning_rate_scheduler import _decay_step_counter +import paddle.fluid.layers.ops as ops from ppocr.utils.utility import initial_logger logger = initial_logger() +def cosine_decay_with_warmup(learning_rate, + step_each_epoch, + epochs=500, + warmup_minibatch=1000): + """Applies cosine decay to the learning rate. + lr = 0.05 * (math.cos(epoch * (math.pi / 120)) + 1) + decrease lr for every mini-batch and start with warmup. + """ + global_step = _decay_step_counter() + lr = fluid.layers.tensor.create_global_var( + shape=[1], + value=0.0, + dtype='float32', + persistable=True, + name="learning_rate") + + warmup_minibatch = fluid.layers.fill_constant( + shape=[1], + dtype='float32', + value=float(warmup_minibatch), + force_cpu=True) + + with fluid.layers.control_flow.Switch() as switch: + with switch.case(global_step < warmup_minibatch): + decayed_lr = learning_rate * (1.0 * global_step / warmup_minibatch) + fluid.layers.tensor.assign(input=decayed_lr, output=lr) + with switch.default(): + decayed_lr = learning_rate * \ + (ops.cos((global_step - warmup_minibatch) * (math.pi / (epochs * step_each_epoch))) + 1)/2 + fluid.layers.tensor.assign(input=decayed_lr, output=lr) + return lr + + def AdamDecay(params, parameter_list=None): """ define optimizer function @@ -36,7 +72,9 @@ def AdamDecay(params, parameter_list=None): l2_decay = params.get("l2_decay", 0.0) if 'decay' in params: - supported_decay_mode = ["cosine_decay", "piecewise_decay"] + supported_decay_mode = [ + "cosine_decay", "cosine_decay_warmup", "piecewise_decay" + ] params = params['decay'] decay_mode = params['function'] assert decay_mode in supported_decay_mode, "Supported decay mode is {}, but got {}".format( @@ -49,6 +87,15 @@ def AdamDecay(params, parameter_list=None): learning_rate=base_lr, step_each_epoch=step_each_epoch, epochs=total_epoch) + elif decay_mode == "cosine_decay_warmup": + step_each_epoch = params['step_each_epoch'] + total_epoch = params['total_epoch'] + warmup_minibatch = params.get("warmup_minibatch", 1000) + base_lr = cosine_decay_with_warmup( + learning_rate=base_lr, + step_each_epoch=step_each_epoch, + epochs=total_epoch, + warmup_minibatch=warmup_minibatch) elif decay_mode == "piecewise_decay": boundaries = params["boundaries"] decay_rate = params["decay_rate"] @@ -104,5 +151,5 @@ def RMSProp(params, parameter_list=None): optimizer = fluid.optimizer.RMSProp( learning_rate=base_lr, regularization=fluid.regularizer.L2Decay(regularization_coeff=l2_decay)) - - return optimizer \ No newline at end of file + + return optimizer From 3ebebae3e56e8989076a3b962d072a005ebb83a3 Mon Sep 17 00:00:00 2001 From: littletomatodonkey Date: Sat, 22 Aug 2020 07:13:06 +0000 Subject: [PATCH 02/42] replace zero_copy_run to run for memory leak --- deploy/cpp_infer/src/ocr_det.cpp | 16 +++++++++------- deploy/cpp_infer/src/ocr_rec.cpp | 18 +++++++++++------- tools/infer/predict_det.py | 23 +++++++++++++---------- tools/infer/predict_rec.py | 15 +++++++++------ tools/infer/utility.py | 3 +-- 5 files changed, 43 insertions(+), 32 deletions(-) diff --git a/deploy/cpp_infer/src/ocr_det.cpp b/deploy/cpp_infer/src/ocr_det.cpp index c87b653c..36ffc9af 100644 --- a/deploy/cpp_infer/src/ocr_det.cpp +++ b/deploy/cpp_infer/src/ocr_det.cpp @@ -31,7 +31,8 @@ void DBDetector::LoadModel(const std::string &model_dir) { } // false for zero copy tensor - config.SwitchUseFeedFetchOps(false); + // true for commom tensor + config.SwitchUseFeedFetchOps(true); // true for multiple input config.SwitchSpecifyInputNames(true); @@ -59,12 +60,13 @@ void DBDetector::Run(cv::Mat &img, std::vector input(1 * 3 * resize_img.rows * resize_img.cols, 0.0f); this->permute_op_.Run(&resize_img, input.data()); - auto input_names = this->predictor_->GetInputNames(); - auto input_t = this->predictor_->GetInputTensor(input_names[0]); - input_t->Reshape({1, 3, resize_img.rows, resize_img.cols}); - input_t->copy_from_cpu(input.data()); - - this->predictor_->ZeroCopyRun(); + // Inference. + paddle::PaddleTensor input_t; + input_t.shape = {1, 3, resize_img.rows, resize_img.cols}; + input_t.data = paddle::PaddleBuf(input.data(), input.size() * sizeof(float)); + input_t.dtype = PaddleDType::FLOAT32; + std::vector outputs; + this->predictor_->Run({input_t}, &outputs, 1); std::vector out_data; auto output_names = this->predictor_->GetOutputNames(); diff --git a/deploy/cpp_infer/src/ocr_rec.cpp b/deploy/cpp_infer/src/ocr_rec.cpp index bbd7b9b2..697f9e8e 100644 --- a/deploy/cpp_infer/src/ocr_rec.cpp +++ b/deploy/cpp_infer/src/ocr_rec.cpp @@ -39,18 +39,21 @@ void CRNNRecognizer::Run(std::vector>> boxes, this->permute_op_.Run(&resize_img, input.data()); - auto input_names = this->predictor_->GetInputNames(); - auto input_t = this->predictor_->GetInputTensor(input_names[0]); - input_t->Reshape({1, 3, resize_img.rows, resize_img.cols}); - input_t->copy_from_cpu(input.data()); - - this->predictor_->ZeroCopyRun(); + // Inference. + paddle::PaddleTensor input_t; + input_t.shape = {1, 3, resize_img.rows, resize_img.cols}; + input_t.data = + paddle::PaddleBuf(input.data(), input.size() * sizeof(float)); + input_t.dtype = PaddleDType::FLOAT32; + std::vector outputs; + this->predictor_->Run({input_t}, &outputs, 1); std::vector rec_idx; auto output_names = this->predictor_->GetOutputNames(); auto output_t = this->predictor_->GetOutputTensor(output_names[0]); auto rec_idx_lod = output_t->lod(); auto shape_out = output_t->shape(); + int out_num = std::accumulate(shape_out.begin(), shape_out.end(), 1, std::multiplies()); @@ -120,7 +123,8 @@ void CRNNRecognizer::LoadModel(const std::string &model_dir) { } // false for zero copy tensor - config.SwitchUseFeedFetchOps(false); + // true for commom tensor + config.SwitchUseFeedFetchOps(true); // true for multiple input config.SwitchSpecifyInputNames(true); diff --git a/tools/infer/predict_det.py b/tools/infer/predict_det.py index 82877c0e..234c41bf 100755 --- a/tools/infer/predict_det.py +++ b/tools/infer/predict_det.py @@ -17,22 +17,25 @@ __dir__ = os.path.dirname(os.path.abspath(__file__)) sys.path.append(__dir__) sys.path.append(os.path.abspath(os.path.join(__dir__, '../..'))) +import cv2 +import copy +import numpy as np +import math +import time +import sys + +import paddle.fluid as fluid + import tools.infer.utility as utility from ppocr.utils.utility import initial_logger logger = initial_logger() from ppocr.utils.utility import get_image_file_list, check_and_read_gif -import cv2 from ppocr.data.det.sast_process import SASTProcessTest from ppocr.data.det.east_process import EASTProcessTest from ppocr.data.det.db_process import DBProcessTest from ppocr.postprocess.db_postprocess import DBPostProcess from ppocr.postprocess.east_postprocess import EASTPostPocess from ppocr.postprocess.sast_postprocess import SASTPostProcess -import copy -import numpy as np -import math -import time -import sys class TextDetector(object): @@ -127,7 +130,7 @@ class TextDetector(object): dt_boxes_new.append(box) dt_boxes = np.array(dt_boxes_new) return dt_boxes - + def __call__(self, img): ori_im = img.copy() im, ratio_list = self.preprocess_op(img) @@ -135,8 +138,8 @@ class TextDetector(object): return None, 0 im = im.copy() starttime = time.time() - self.input_tensor.copy_from_cpu(im) - self.predictor.zero_copy_run() + im = fluid.core.PaddleTensor(im) + self.predictor.run([im]) outputs = [] for output_tensor in self.output_tensors: output = output_tensor.copy_to_cpu() @@ -152,7 +155,7 @@ class TextDetector(object): outs_dict['f_tvo'] = outputs[3] else: outs_dict['maps'] = outputs[0] - + dt_boxes_list = self.postprocess_op(outs_dict, [ratio_list]) dt_boxes = dt_boxes_list[0] if self.det_algorithm == "SAST" and self.det_sast_polygon: diff --git a/tools/infer/predict_rec.py b/tools/infer/predict_rec.py index c81b4eb2..92234415 100755 --- a/tools/infer/predict_rec.py +++ b/tools/infer/predict_rec.py @@ -17,15 +17,18 @@ __dir__ = os.path.dirname(os.path.abspath(__file__)) sys.path.append(__dir__) sys.path.append(os.path.abspath(os.path.join(__dir__, '../..'))) -import tools.infer.utility as utility -from ppocr.utils.utility import initial_logger -logger = initial_logger() -from ppocr.utils.utility import get_image_file_list, check_and_read_gif import cv2 import copy import numpy as np import math import time + +import paddle.fluid as fluid + +import tools.infer.utility as utility +from ppocr.utils.utility import initial_logger +logger = initial_logger() +from ppocr.utils.utility import get_image_file_list, check_and_read_gif from ppocr.utils.character import CharacterOps @@ -102,8 +105,8 @@ class TextRecognizer(object): norm_img_batch = np.concatenate(norm_img_batch) norm_img_batch = norm_img_batch.copy() starttime = time.time() - self.input_tensor.copy_from_cpu(norm_img_batch) - self.predictor.zero_copy_run() + norm_img_batch = fluid.core.PaddleTensor(norm_img_batch) + self.predictor.run([norm_img_batch]) if self.loss_type == "ctc": rec_idx_batch = self.output_tensors[0].copy_to_cpu() diff --git a/tools/infer/utility.py b/tools/infer/utility.py index 392bc4df..ec6705eb 100755 --- a/tools/infer/utility.py +++ b/tools/infer/utility.py @@ -106,8 +106,7 @@ def create_predictor(args, mode): config.disable_glog_info() # use zero copy - config.delete_pass("conv_transpose_eltwiseadd_bn_fuse_pass") - config.switch_use_feed_fetch_ops(False) + config.switch_use_feed_fetch_ops(True) predictor = create_paddle_predictor(config) input_names = predictor.get_input_names() input_tensor = predictor.get_input_tensor(input_names[0]) From 684676f61134873f277c10503026aaef13472ca2 Mon Sep 17 00:00:00 2001 From: WenmuZhou Date: Sat, 22 Aug 2020 19:42:14 +0800 Subject: [PATCH 03/42] init commit for build whl --- .gitignore | 4 + MANIFEST.in | 8 + __init__.py | 17 ++ doc/doc_ch/whl.md | 251 ++++++++++++++++++++++++++++ doc/doc_en/whl.md | 211 +++++++++++++++++++++++ doc/imgs_results/whl/11_det.jpg | Bin 0 -> 62863 bytes doc/imgs_results/whl/11_det_rec.jpg | Bin 0 -> 138201 bytes doc/imgs_results/whl/12_det.jpg | Bin 0 -> 170292 bytes doc/imgs_results/whl/12_det_rec.jpg | Bin 0 -> 86051 bytes paddleocr.py | 231 +++++++++++++++++++++++++ requirments.txt | 4 +- setup.py | 61 +++++++ tools/infer/utility.py | 39 +++-- 13 files changed, 814 insertions(+), 12 deletions(-) create mode 100644 MANIFEST.in create mode 100644 __init__.py create mode 100644 doc/doc_ch/whl.md create mode 100644 doc/doc_en/whl.md create mode 100644 doc/imgs_results/whl/11_det.jpg create mode 100644 doc/imgs_results/whl/11_det_rec.jpg create mode 100644 doc/imgs_results/whl/12_det.jpg create mode 100644 doc/imgs_results/whl/12_det_rec.jpg create mode 100644 paddleocr.py create mode 100644 setup.py diff --git a/.gitignore b/.gitignore index 1a2dd675..9eecb4f1 100644 --- a/.gitignore +++ b/.gitignore @@ -21,3 +21,7 @@ output/ *.log .clang-format .clang_format.hook + +build/ +dist/ +paddleocr.egg-info/ \ No newline at end of file diff --git a/MANIFEST.in b/MANIFEST.in new file mode 100644 index 00000000..388882df --- /dev/null +++ b/MANIFEST.in @@ -0,0 +1,8 @@ +include LICENSE.txt +include README.md + +recursive-include ppocr/utils *.txt utility.py character.py check.py +recursive-include ppocr/data/det *.py +recursive-include ppocr/postprocess *.py +recursive-include ppocr/postprocess/lanms *.* +recursive-include tools/infer *.py diff --git a/__init__.py b/__init__.py new file mode 100644 index 00000000..7d94f66b --- /dev/null +++ b/__init__.py @@ -0,0 +1,17 @@ +# Copyright (c) 2020 PaddlePaddle Authors. All Rights Reserved. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +__all__ = ['PaddleOCR', 'draw_ocr'] +from .paddleocr import PaddleOCR +from .tools.infer.utility import draw_ocr diff --git a/doc/doc_ch/whl.md b/doc/doc_ch/whl.md new file mode 100644 index 00000000..94243462 --- /dev/null +++ b/doc/doc_ch/whl.md @@ -0,0 +1,251 @@ +# paddleocr package使用说明 + +## 快速上手 + +### 安装whl包 + +pip安装 +```bash +pip install paddleocr +``` + +本地构建并安装 +```bash +python setup.py bdist_wheel +pip install dist/paddleocr-0.0.1-py3-none-any.whl +``` +### 1. 代码使用 + +* 检测+识别全流程 +```python +from paddleocr import PaddleOCR, draw_ocr +ocr = PaddleOCR(model_storage_directory='./model') # need to run only once to load model into memory +img_path = 'PaddleOCR/doc/imgs/11.jpg' +result = ocr.ocr(img_path) +for line in result: + print(line) + +# 显示结果 +from PIL import Image +image = Image.open(img_path).convert('RGB') +boxes = [line[0] for line in result] +txts = [line[1][0] for line in result] +scores = [line[1][1] for line in result] +im_show = draw_ocr(image, boxes, txts, scores, font_path='/path/to/PaddleOCR/doc/simfang.ttf') +im_show = Image.fromarray(im_show) +im_show.save('result.jpg') +``` +结果是一个list,每个item包含了文本框,文字和识别置信度 +```bash +[[[24.0, 36.0], [304.0, 34.0], [304.0, 72.0], [24.0, 74.0]], ['纯臻营养护发素', 0.964739]] +[[[24.0, 80.0], [172.0, 80.0], [172.0, 104.0], [24.0, 104.0]], ['产品信息/参数', 0.98069626]] +[[[24.0, 109.0], [333.0, 109.0], [333.0, 136.0], [24.0, 136.0]], ['(45元/每公斤,100公斤起订)', 0.9676722]] +[[[22.0, 140.0], [284.0, 140.0], [284.0, 167.0], [22.0, 167.0]], ['每瓶22元,1000瓶起订)', 0.97444016]] +[[[22.0, 174.0], [85.0, 174.0], [85.0, 198.0], [22.0, 198.0]], ['【品牌】', 0.8187138]] +[[[89.0, 176.0], [301.0, 176.0], [301.0, 196.0], [89.0, 196.0]], [':代加工方式/OEMODM', 0.9421848]] +[[[23.0, 205.0], [85.0, 205.0], [85.0, 229.0], [23.0, 229.0]], ['【品名】', 0.76008326]] +[[[88.0, 204.0], [235.0, 206.0], [235.0, 229.0], [88.0, 227.0]], [':纯臻营养护发素', 0.9633639]] +[[[23.0, 236.0], [121.0, 236.0], [121.0, 261.0], [23.0, 261.0]], ['【产品编号】', 0.84101385]] +[[[110.0, 239.0], [239.0, 239.0], [239.0, 256.0], [110.0, 256.0]], ['1:YM-X-3011', 0.8621878]] +[[[414.0, 233.0], [430.0, 233.0], [430.0, 304.0], [414.0, 304.0]], ['ODM OEM', 0.9084018]] +[[[23.0, 268.0], [183.0, 268.0], [183.0, 292.0], [23.0, 292.0]], ['【净含量】:220ml', 0.9278281]] +[[[24.0, 301.0], [118.0, 301.0], [118.0, 321.0], [24.0, 321.0]], ['【适用人群】', 0.90901047]] +[[[127.0, 300.0], [254.0, 300.0], [254.0, 323.0], [127.0, 323.0]], [':适合所有肤质', 0.95465785]] +[[[24.0, 332.0], [117.0, 332.0], [117.0, 353.0], [24.0, 353.0]], ['【主要成分】', 0.88936955]] +[[[139.0, 332.0], [236.0, 332.0], [236.0, 352.0], [139.0, 352.0]], ['鲸蜡硬脂醇', 0.9447544]] +[[[248.0, 332.0], [345.0, 332.0], [345.0, 352.0], [248.0, 352.0]], ['燕麦B-葡聚', 0.89748293]] +[[[54.0, 363.0], [232.0, 363.0], [232.0, 383.0], [54.0, 383.0]], [' 椰油酰胺丙基甜菜碱', 0.902023]] +[[[25.0, 364.0], [64.0, 364.0], [64.0, 383.0], [25.0, 383.0]], ['糖、', 0.985203]] +[[[244.0, 363.0], [281.0, 363.0], [281.0, 382.0], [244.0, 382.0]], ['泛服', 0.44537082]] +[[[367.0, 367.0], [475.0, 367.0], [475.0, 388.0], [367.0, 388.0]], ['(成品包材)', 0.9834532]] +[[[24.0, 395.0], [120.0, 395.0], [120.0, 416.0], [24.0, 416.0]], ['【主要功能】', 0.88684446]] +[[[128.0, 397.0], [273.0, 397.0], [273.0, 414.0], [128.0, 414.0]], [':可紧致头发磷层', 0.9342501]] +[[[265.0, 395.0], [361.0, 395.0], [361.0, 415.0], [265.0, 415.0]], ['琴,从而达到', 0.8253762]] +[[[25.0, 425.0], [372.0, 425.0], [372.0, 448.0], [25.0, 448.0]], ['即时持久改善头发光泽的效果,给干燥的头', 0.97785276]] +[[[26.0, 457.0], [137.0, 457.0], [137.0, 477.0], [26.0, 477.0]], ['发足够的滋养', 0.9577897]] +``` +结果可视化 + +
+ +
+ +* 单独执行检测 +```python +from paddleocr import PaddleOCR, draw_ocr +ocr = PaddleOCR(model_storage_directory='./model') # need to run only once to load model into memory +img_path = 'PaddleOCR/doc/imgs/11.jpg' +result = ocr.ocr(img_path,rec=False) +for line in result: + print(line) + +# 显示结果 +from PIL import Image + +image = Image.open(img_path).convert('RGB') +im_show = draw_ocr(image, result, txts=None, scores=None, font_path='/path/to/PaddleOCR/doc/simfang.ttf') +im_show = Image.fromarray(im_show) +im_show.save('result.jpg') +``` +结果是一个list,每个item只包含文本框 +```bash +[[26.0, 457.0], [137.0, 457.0], [137.0, 477.0], [26.0, 477.0]] +[[25.0, 425.0], [372.0, 425.0], [372.0, 448.0], [25.0, 448.0]] +[[128.0, 397.0], [273.0, 397.0], [273.0, 414.0], [128.0, 414.0]] +[[265.0, 395.0], [361.0, 395.0], [361.0, 415.0], [265.0, 415.0]] +[[24.0, 395.0], [120.0, 395.0], [120.0, 416.0], [24.0, 416.0]] +[[367.0, 367.0], [475.0, 367.0], [475.0, 388.0], [367.0, 388.0]] +[[54.0, 363.0], [232.0, 363.0], [232.0, 383.0], [54.0, 383.0]] +[[25.0, 364.0], [64.0, 364.0], [64.0, 383.0], [25.0, 383.0]] +[[244.0, 363.0], [281.0, 363.0], [281.0, 382.0], [244.0, 382.0]] +[[248.0, 332.0], [345.0, 332.0], [345.0, 352.0], [248.0, 352.0]] +[[139.0, 332.0], [236.0, 332.0], [236.0, 352.0], [139.0, 352.0]] +[[24.0, 332.0], [117.0, 332.0], [117.0, 353.0], [24.0, 353.0]] +[[127.0, 300.0], [254.0, 300.0], [254.0, 323.0], [127.0, 323.0]] +[[24.0, 301.0], [118.0, 301.0], [118.0, 321.0], [24.0, 321.0]] +[[23.0, 268.0], [183.0, 268.0], [183.0, 292.0], [23.0, 292.0]] +[[110.0, 239.0], [239.0, 239.0], [239.0, 256.0], [110.0, 256.0]] +[[23.0, 236.0], [121.0, 236.0], [121.0, 261.0], [23.0, 261.0]] +[[414.0, 233.0], [430.0, 233.0], [430.0, 304.0], [414.0, 304.0]] +[[88.0, 204.0], [235.0, 206.0], [235.0, 229.0], [88.0, 227.0]] +[[23.0, 205.0], [85.0, 205.0], [85.0, 229.0], [23.0, 229.0]] +[[89.0, 176.0], [301.0, 176.0], [301.0, 196.0], [89.0, 196.0]] +[[22.0, 174.0], [85.0, 174.0], [85.0, 198.0], [22.0, 198.0]] +[[22.0, 140.0], [284.0, 140.0], [284.0, 167.0], [22.0, 167.0]] +[[24.0, 109.0], [333.0, 109.0], [333.0, 136.0], [24.0, 136.0]] +[[24.0, 80.0], [172.0, 80.0], [172.0, 104.0], [24.0, 104.0]] +[[24.0, 36.0], [304.0, 34.0], [304.0, 72.0], [24.0, 74.0]] +``` +结果可视化 + + +
+ +
+ +* 单独执行识别 +```python +from paddleocr import PaddleOCR +ocr = PaddleOCR(model_storage_directory='./model') # need to run only once to load model into memory +img_path = 'PaddleOCR/doc/imgs_words/ch/word_1.jpg' +result = ocr.ocr(img_path,det=False) +for line in result: + print(line) +``` +结果是一个list,每个item只包含识别结果和识别置信度 +```bash +['韩国小馆', 0.9907421] +``` + +### 通过命令行使用 + +查看帮助信息 +```bash +paddleocr -h +``` + +* 检测+识别全流程 +```bash +paddleocr --image_dir PaddleOCR/doc/imgs/11.jpg +``` +结果是一个list,每个item包含了文本框,文字和识别置信度 +```bash +[[[24.0, 36.0], [304.0, 34.0], [304.0, 72.0], [24.0, 74.0]], ['纯臻营养护发素', 0.964739]] +[[[24.0, 80.0], [172.0, 80.0], [172.0, 104.0], [24.0, 104.0]], ['产品信息/参数', 0.98069626]] +[[[24.0, 109.0], [333.0, 109.0], [333.0, 136.0], [24.0, 136.0]], ['(45元/每公斤,100公斤起订)', 0.9676722]] +[[[22.0, 140.0], [284.0, 140.0], [284.0, 167.0], [22.0, 167.0]], ['每瓶22元,1000瓶起订)', 0.97444016]] +[[[22.0, 174.0], [85.0, 174.0], [85.0, 198.0], [22.0, 198.0]], ['【品牌】', 0.8187138]] +[[[89.0, 176.0], [301.0, 176.0], [301.0, 196.0], [89.0, 196.0]], [':代加工方式/OEMODM', 0.9421848]] +[[[23.0, 205.0], [85.0, 205.0], [85.0, 229.0], [23.0, 229.0]], ['【品名】', 0.76008326]] +[[[88.0, 204.0], [235.0, 206.0], [235.0, 229.0], [88.0, 227.0]], [':纯臻营养护发素', 0.9633639]] +[[[23.0, 236.0], [121.0, 236.0], [121.0, 261.0], [23.0, 261.0]], ['【产品编号】', 0.84101385]] +[[[110.0, 239.0], [239.0, 239.0], [239.0, 256.0], [110.0, 256.0]], ['1:YM-X-3011', 0.8621878]] +[[[414.0, 233.0], [430.0, 233.0], [430.0, 304.0], [414.0, 304.0]], ['ODM OEM', 0.9084018]] +[[[23.0, 268.0], [183.0, 268.0], [183.0, 292.0], [23.0, 292.0]], ['【净含量】:220ml', 0.9278281]] +[[[24.0, 301.0], [118.0, 301.0], [118.0, 321.0], [24.0, 321.0]], ['【适用人群】', 0.90901047]] +[[[127.0, 300.0], [254.0, 300.0], [254.0, 323.0], [127.0, 323.0]], [':适合所有肤质', 0.95465785]] +[[[24.0, 332.0], [117.0, 332.0], [117.0, 353.0], [24.0, 353.0]], ['【主要成分】', 0.88936955]] +[[[139.0, 332.0], [236.0, 332.0], [236.0, 352.0], [139.0, 352.0]], ['鲸蜡硬脂醇', 0.9447544]] +[[[248.0, 332.0], [345.0, 332.0], [345.0, 352.0], [248.0, 352.0]], ['燕麦B-葡聚', 0.89748293]] +[[[54.0, 363.0], [232.0, 363.0], [232.0, 383.0], [54.0, 383.0]], [' 椰油酰胺丙基甜菜碱', 0.902023]] +[[[25.0, 364.0], [64.0, 364.0], [64.0, 383.0], [25.0, 383.0]], ['糖、', 0.985203]] +[[[244.0, 363.0], [281.0, 363.0], [281.0, 382.0], [244.0, 382.0]], ['泛服', 0.44537082]] +[[[367.0, 367.0], [475.0, 367.0], [475.0, 388.0], [367.0, 388.0]], ['(成品包材)', 0.9834532]] +[[[24.0, 395.0], [120.0, 395.0], [120.0, 416.0], [24.0, 416.0]], ['【主要功能】', 0.88684446]] +[[[128.0, 397.0], [273.0, 397.0], [273.0, 414.0], [128.0, 414.0]], [':可紧致头发磷层', 0.9342501]] +[[[265.0, 395.0], [361.0, 395.0], [361.0, 415.0], [265.0, 415.0]], ['琴,从而达到', 0.8253762]] +[[[25.0, 425.0], [372.0, 425.0], [372.0, 448.0], [25.0, 448.0]], ['即时持久改善头发光泽的效果,给干燥的头', 0.97785276]] +[[[26.0, 457.0], [137.0, 457.0], [137.0, 477.0], [26.0, 477.0]], ['发足够的滋养', 0.9577897]] +``` + +* 单独执行检测 +```bash +paddleocr --image_dir PaddleOCR/doc/imgs/11.jpg --rec false +``` +结果是一个list,每个item只包含文本框 +```bash +[[26.0, 457.0], [137.0, 457.0], [137.0, 477.0], [26.0, 477.0]] +[[25.0, 425.0], [372.0, 425.0], [372.0, 448.0], [25.0, 448.0]] +[[128.0, 397.0], [273.0, 397.0], [273.0, 414.0], [128.0, 414.0]] +[[265.0, 395.0], [361.0, 395.0], [361.0, 415.0], [265.0, 415.0]] +[[24.0, 395.0], [120.0, 395.0], [120.0, 416.0], [24.0, 416.0]] +[[367.0, 367.0], [475.0, 367.0], [475.0, 388.0], [367.0, 388.0]] +[[54.0, 363.0], [232.0, 363.0], [232.0, 383.0], [54.0, 383.0]] +[[25.0, 364.0], [64.0, 364.0], [64.0, 383.0], [25.0, 383.0]] +[[244.0, 363.0], [281.0, 363.0], [281.0, 382.0], [244.0, 382.0]] +[[248.0, 332.0], [345.0, 332.0], [345.0, 352.0], [248.0, 352.0]] +[[139.0, 332.0], [236.0, 332.0], [236.0, 352.0], [139.0, 352.0]] +[[24.0, 332.0], [117.0, 332.0], [117.0, 353.0], [24.0, 353.0]] +[[127.0, 300.0], [254.0, 300.0], [254.0, 323.0], [127.0, 323.0]] +[[24.0, 301.0], [118.0, 301.0], [118.0, 321.0], [24.0, 321.0]] +[[23.0, 268.0], [183.0, 268.0], [183.0, 292.0], [23.0, 292.0]] +[[110.0, 239.0], [239.0, 239.0], [239.0, 256.0], [110.0, 256.0]] +[[23.0, 236.0], [121.0, 236.0], [121.0, 261.0], [23.0, 261.0]] +[[414.0, 233.0], [430.0, 233.0], [430.0, 304.0], [414.0, 304.0]] +[[88.0, 204.0], [235.0, 206.0], [235.0, 229.0], [88.0, 227.0]] +[[23.0, 205.0], [85.0, 205.0], [85.0, 229.0], [23.0, 229.0]] +[[89.0, 176.0], [301.0, 176.0], [301.0, 196.0], [89.0, 196.0]] +[[22.0, 174.0], [85.0, 174.0], [85.0, 198.0], [22.0, 198.0]] +[[22.0, 140.0], [284.0, 140.0], [284.0, 167.0], [22.0, 167.0]] +[[24.0, 109.0], [333.0, 109.0], [333.0, 136.0], [24.0, 136.0]] +[[24.0, 80.0], [172.0, 80.0], [172.0, 104.0], [24.0, 104.0]] +[[24.0, 36.0], [304.0, 34.0], [304.0, 72.0], [24.0, 74.0]] +``` + +* 单独执行识别 +```bash +paddleocr --image_dir PaddleOCR/doc/imgs_words/ch/word_1.jpg --det false +``` + +结果是一个list,每个item只包含识别结果和识别置信度 +```bash +['韩国小馆', 0.9907421] +``` + +## 参数说明 + +| 字段 | 说明 | 默认值 | +|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------| +| use_gpu | 是否使用GPU | TRUE | +| gpu_mem | 初始化占用的GPU内存大小 | 8000M | +| image_dir | 通过命令行调用时执行预测的图片或文件夹路径 | | +| det_algorithm | 使用的检测算法类型 | DB | +| det_model_name | 有两种使用方式: 1. 检测算法名称,此名称必须在支持列表内(目前只内置了ch_det_mv3_db),传入错误参数时会显示支持的列表 2. 自己转换好的inference模型路径,此时模型路径下必须包含model和params文件。选择此方式时,需要手动指定det_algorithm的值 | ch_det_mv3_db | +| det_max_side_len | 检测算法前向时图片长边的最大尺寸,当长边超出这个值时会将长边resize到这个大小,短边等比例缩放 | 960 | +| det_db_thresh | DB模型输出预测图的二值化阈值 | 0.3 | +| det_db_box_thresh | DB模型输出框的阈值,低于此值的预测框会被丢弃 | 0.5 | +| det_db_unclip_ratio | DB模型输出框扩大的比例 | 2 | +| det_east_score_thresh | EAST模型输出预测图的二值化阈值 | 0.8 | +| det_east_cover_thresh | EAST模型输出框的阈值,低于此值的预测框会被丢弃 | 0.1 | +| det_east_nms_thresh | EAST模型输出框NMS的阈值 | 0.2 | +| rec_algorithm | 使用的识别算法类型 | CRNN | +| rec_model_name | 有两种使用方式: 1. 识别算法名称,此名称必须在支持列表内(目前支持CRNN,Rosetta,STAR,RARE等算法,但是内置的只有ch_rec_mv3_crnn_enhance),传入错误参数时会显示支持的列表 2. 自己转换好的inference模型路径,此时模型路径下必须包含model和params文件。选择此方式时,需要手动指定rec_algorithm的值 | ch_rec_mv3_crnn_enhance | +| rec_image_shape | 识别算法的输入图片尺寸 | "3,32,320" | +| rec_char_type | 识别算法的字符类型,中文(ch)或英文(en) | ch | +| rec_batch_num | 进行识别时,同时前向的图片数 | 30 | +| rec_char_dict_path | 识别模型字典路径,当rec_model_name使用方式2传参时需要修改为自己的路径 | | +| use_space_char | 是否识别空格 | TRUE | +| enable_mkldnn | 是否启用mkldnn | FALSE | +| model_storage_directory | 下载模型保存路径 | ~/.paddleocr | +| det | 前向时使用启动检测 | TRUE | +| rec | 前向时是否启动识别 | TRUE | diff --git a/doc/doc_en/whl.md b/doc/doc_en/whl.md new file mode 100644 index 00000000..ad2125a4 --- /dev/null +++ b/doc/doc_en/whl.md @@ -0,0 +1,211 @@ +# paddleocr package + +## Get started quickly +### install package +install by pypi +```bash +pip install paddleocr +``` + +build own whl package and install +```bash +python setup.py bdist_wheel +pip install dist/paddleocr-0.0.1-py3-none-any.whl +``` +### 1. Use by code + +* detection and recognition +```python +from paddleocr import PaddleOCR,draw_ocr +ocr = PaddleOCR(model_storage_directory='./model') # need to run only once to load model into memory +img_path = 'PaddleOCR/doc/imgs_en/img_12.jpg' +result = ocr.ocr(img_path) +for line in result: + print(line) + +# draw result +from PIL import Image +image = Image.open(img_path).convert('RGB') +boxes = [line[0] for line in result] +txts = [line[1][0] for line in result] +scores = [line[1][1] for line in result] +im_show = draw_ocr(image, boxes, txts, scores, font_path='/path/to/PaddleOCR/doc/simfang.ttf') +im_show = Image.fromarray(im_show) +im_show.save('result.jpg') +``` + +Output will be a list, each item contains bounding box, text and recognition confidence +```bash +[[[442.0, 173.0], [1169.0, 173.0], [1169.0, 225.0], [442.0, 225.0]], ['ACKNOWLEDGEMENTS', 0.99283075]] +[[[393.0, 340.0], [1207.0, 342.0], [1207.0, 389.0], [393.0, 387.0]], ['We would like to thank all the designers and', 0.9357758]] +[[[399.0, 398.0], [1204.0, 398.0], [1204.0, 433.0], [399.0, 433.0]], ['contributors whohave been involved in the', 0.9592447]] +[[[395.0, 443.0], [1211.0, 443.0], [1211.0, 489.0], [395.0, 489.0]], ['production of this book;their contributions', 0.9713175]] +[[[395.0, 497.0], [1209.0, 495.0], [1209.0, 531.0], [395.0, 533.0]], ['have been indispensable to its creation.We', 0.96009934]] +[[[393.0, 545.0], [1212.0, 545.0], [1212.0, 591.0], [393.0, 591.0]], ['would also like to express our gratitude to al', 0.9371007]] +[[[393.0, 595.0], [1212.0, 593.0], [1212.0, 635.0], [393.0, 637.0]], ['the producers for their invaluable opinions', 0.96872145]] +[[[393.0, 645.0], [1209.0, 645.0], [1209.0, 685.0], [393.0, 685.0]], ['and assistance throughout this proiect.Andto', 0.94448787]] +[[[392.0, 697.0], [1212.0, 693.0], [1212.0, 735.0], [392.0, 739.0]], ['the many others whose names are not credited', 0.93633145]] +[[[397.0, 753.0], [689.0, 755.0], [689.0, 786.0], [397.0, 784.0]], ['buthavemades', 0.99324507]] +[[[813.0, 749.0], [1212.0, 747.0], [1212.0, 784.0], [813.0, 786.0]], ['inputin this book, we', 0.9166398]] +[[[675.0, 760.0], [799.0, 755.0], [799.0, 778.0], [675.0, 784.0]], ['speciti', 0.9063535]] +[[[393.0, 801.0], [715.0, 805.0], [715.0, 839.0], [393.0, 836.0]], ['thankyouforyoul', 0.92475533]] +[[[756.0, 812.0], [805.0, 812.0], [805.0, 830.0], [756.0, 830.0]], ['P', 0.14887337]] +[[[820.0, 803.0], [1085.0, 801.0], [1085.0, 836.0], [820.0, 838.0]], ['nuoussupport', 0.9898951]] +``` + +Visualization of results + +
+ +
+ +* only detection +```python +from paddleocr import PaddleOCR,draw_ocr +ocr = PaddleOCR(model_storage_directory='./model') # need to run only once to load model into memory +img_path = 'PaddleOCR/doc/imgs_en/img_12.jpg' +result = ocr.ocr(img_path,rec=False) +for line in result: + print(line) + +# draw result +from PIL import Image + +image = Image.open(img_path).convert('RGB') +im_show = draw_ocr(image, result, txts=None, scores=None, font_path='/path/to/PaddleOCR/doc/simfang.ttf') +im_show = Image.fromarray(im_show) +im_show.save('result.jpg') +``` + +Output will be a list, each item only contains bounding box +```bash +[[756.0, 812.0], [805.0, 812.0], [805.0, 830.0], [756.0, 830.0]] +[[820.0, 803.0], [1085.0, 801.0], [1085.0, 836.0], [820.0, 838.0]] +[[393.0, 801.0], [715.0, 805.0], [715.0, 839.0], [393.0, 836.0]] +[[675.0, 760.0], [799.0, 755.0], [799.0, 778.0], [675.0, 784.0]] +[[397.0, 753.0], [689.0, 755.0], [689.0, 786.0], [397.0, 784.0]] +[[813.0, 749.0], [1212.0, 747.0], [1212.0, 784.0], [813.0, 786.0]] +[[392.0, 697.0], [1212.0, 693.0], [1212.0, 735.0], [392.0, 739.0]] +[[393.0, 645.0], [1209.0, 645.0], [1209.0, 685.0], [393.0, 685.0]] +[[393.0, 595.0], [1212.0, 593.0], [1212.0, 635.0], [393.0, 637.0]] +[[393.0, 545.0], [1212.0, 545.0], [1212.0, 591.0], [393.0, 591.0]] +[[395.0, 497.0], [1209.0, 495.0], [1209.0, 531.0], [395.0, 533.0]] +[[395.0, 443.0], [1211.0, 443.0], [1211.0, 489.0], [395.0, 489.0]] +[[399.0, 398.0], [1204.0, 398.0], [1204.0, 433.0], [399.0, 433.0]] +[[393.0, 340.0], [1207.0, 342.0], [1207.0, 389.0], [393.0, 387.0]] +[[442.0, 173.0], [1169.0, 173.0], [1169.0, 225.0], [442.0, 225.0]] +``` + +Visualization of results + +
+ +
+ +* only recognition +```python +from paddleocr import PaddleOCR +ocr = PaddleOCR(model_storage_directory='./model') # need to run only once to load model into memory +img_path = 'PaddleOCR/doc/imgs_words_en/word_10.png' +result = ocr.ocr(img_path,det=False) +for line in result: + print(line) +``` + +Output will be a list, each item contains text and recognition confidence +```bash +['PAIN', 0.990372] +``` + +### Use by command line + +show help information +```bash +paddleocr -h +``` + +* detection and recognition +```bash +paddleocr --image_dir PaddleOCR/doc/imgs_en/img_12.jpg +``` + +Output will be a list, each item contains bounding box, text and recognition confidence +```bash +[[[442.0, 173.0], [1169.0, 173.0], [1169.0, 225.0], [442.0, 225.0]], ['ACKNOWLEDGEMENTS', 0.99283075]] +[[[393.0, 340.0], [1207.0, 342.0], [1207.0, 389.0], [393.0, 387.0]], ['We would like to thank all the designers and', 0.9357758]] +[[[399.0, 398.0], [1204.0, 398.0], [1204.0, 433.0], [399.0, 433.0]], ['contributors whohave been involved in the', 0.9592447]] +[[[395.0, 443.0], [1211.0, 443.0], [1211.0, 489.0], [395.0, 489.0]], ['production of this book;their contributions', 0.9713175]] +[[[395.0, 497.0], [1209.0, 495.0], [1209.0, 531.0], [395.0, 533.0]], ['have been indispensable to its creation.We', 0.96009934]] +[[[393.0, 545.0], [1212.0, 545.0], [1212.0, 591.0], [393.0, 591.0]], ['would also like to express our gratitude to al', 0.9371007]] +[[[393.0, 595.0], [1212.0, 593.0], [1212.0, 635.0], [393.0, 637.0]], ['the producers for their invaluable opinions', 0.96872145]] +[[[393.0, 645.0], [1209.0, 645.0], [1209.0, 685.0], [393.0, 685.0]], ['and assistance throughout this proiect.Andto', 0.94448787]] +[[[392.0, 697.0], [1212.0, 693.0], [1212.0, 735.0], [392.0, 739.0]], ['the many others whose names are not credited', 0.93633145]] +[[[397.0, 753.0], [689.0, 755.0], [689.0, 786.0], [397.0, 784.0]], ['buthavemades', 0.99324507]] +[[[813.0, 749.0], [1212.0, 747.0], [1212.0, 784.0], [813.0, 786.0]], ['inputin this book, we', 0.9166398]] +[[[675.0, 760.0], [799.0, 755.0], [799.0, 778.0], [675.0, 784.0]], ['speciti', 0.9063535]] +[[[393.0, 801.0], [715.0, 805.0], [715.0, 839.0], [393.0, 836.0]], ['thankyouforyoul', 0.92475533]] +[[[756.0, 812.0], [805.0, 812.0], [805.0, 830.0], [756.0, 830.0]], ['P', 0.14887337]] +[[[820.0, 803.0], [1085.0, 801.0], [1085.0, 836.0], [820.0, 838.0]], ['nuoussupport', 0.9898951]] +``` + +* only detection +```bash +paddleocr --image_dir PaddleOCR/doc/imgs_en/img_12.jpg --rec false +``` + +Output will be a list, each item only contains bounding box +```bash +[[756.0, 812.0], [805.0, 812.0], [805.0, 830.0], [756.0, 830.0]] +[[820.0, 803.0], [1085.0, 801.0], [1085.0, 836.0], [820.0, 838.0]] +[[393.0, 801.0], [715.0, 805.0], [715.0, 839.0], [393.0, 836.0]] +[[675.0, 760.0], [799.0, 755.0], [799.0, 778.0], [675.0, 784.0]] +[[397.0, 753.0], [689.0, 755.0], [689.0, 786.0], [397.0, 784.0]] +[[813.0, 749.0], [1212.0, 747.0], [1212.0, 784.0], [813.0, 786.0]] +[[392.0, 697.0], [1212.0, 693.0], [1212.0, 735.0], [392.0, 739.0]] +[[393.0, 645.0], [1209.0, 645.0], [1209.0, 685.0], [393.0, 685.0]] +[[393.0, 595.0], [1212.0, 593.0], [1212.0, 635.0], [393.0, 637.0]] +[[393.0, 545.0], [1212.0, 545.0], [1212.0, 591.0], [393.0, 591.0]] +[[395.0, 497.0], [1209.0, 495.0], [1209.0, 531.0], [395.0, 533.0]] +[[395.0, 443.0], [1211.0, 443.0], [1211.0, 489.0], [395.0, 489.0]] +[[399.0, 398.0], [1204.0, 398.0], [1204.0, 433.0], [399.0, 433.0]] +[[393.0, 340.0], [1207.0, 342.0], [1207.0, 389.0], [393.0, 387.0]] +[[442.0, 173.0], [1169.0, 173.0], [1169.0, 225.0], [442.0, 225.0]] +``` + +* only recognition +```bash +paddleocr --image_dir PaddleOCR/doc/imgs_words_en/word_10.png --det false +``` + +Output will be a list, each item contains text and recognition confidence +```bash +['PAIN', 0.990372] +``` + +## Parameter Description + +| Parameter | Description | Default value | +|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------| +| use_gpu | use GPU or not | TRUE | +| gpu_mem | GPU memory size used for initialization | 8000M | +| image_dir | The images path or folder path for predicting when used by the command line | | +| det_algorithm | Type of detection algorithm selected | DB | +| det_model_name | There are two ways to use: 1. The name of the detection algorithm which must be in the support list(only ch_det_mv3_db is built in currently), and the supported list will be displayed when the wrong parameter is passed in. 2. The path of the inference model that has been converted by yourself. At this time, the model path must contains model and params files. When choosing this method, you need to give the name of det_algorithm | ch_det_mv3_db | +| det_max_side_len | The maximum size of the long side of the image. When the long side exceeds this value, the long side will be resized to this size, and the short side will be scaled proportionally | 960 | +| det_db_thresh | Binarization threshold value of DB output map | 0.3 | +| det_db_box_thresh | The threshold value of the DB output box. Boxes score lower than this value will be discarded | 0.5 | +| det_db_unclip_ratio | The expanded ratio of DB output box | 2 | +| det_east_score_thresh | Binarization threshold value of EAST output map | 0.8 | +| det_east_cover_thresh | The threshold value of the EAST output box. Boxes score lower than this value will be discarded | 0.1 | +| det_east_nms_thresh | The NMS threshold value of EAST model output box | 0.2 | +| rec_algorithm | Type of recognition algorithm selected | CRNN | +| rec_model_name | There are two ways to use: 1. The name of the recognition algorithm which must be in the support list(only supports CRNN, Rosetta, STAR, RARE and other algorithms currently, but only ch_rec_mv3_crnn_enhance is built-in), and the supported list will be displayed when the wrong parameter is passed in. 2. The path of the inference model that has been converted by yourself. At this time, the model path must contains model and params files. When choosing this method, you need to give the name of rec_algorithm | ch_rec_mv3_crnn_enhance | +| rec_image_shape | image shape of recognition algorithm | "3,32,320" | +| rec_char_type | Character type of recognition algorithm, Chinese (ch) or English (en) | ch | +| rec_batch_num | When performing recognition, the batchsize of forward images | 30 | +| rec_char_dict_path | the alphabet path which needs to be modified to your own path when `rec_model_Name` use mode 2 | | +| use_space_char | Whether to recognize spaces | TRUE | +| enable_mkldnn | Whether to enable mkldnn | FALSE | +| model_storage_directory | Download model save path when det_model_name or rec_model_name use mode 1 | ~/.paddleocr | +| det | Enable detction when `ppocr.ocr` func exec | TRUE | +| rec | Enable detction when `ppocr.ocr` func exec | TRUE | diff --git a/doc/imgs_results/whl/11_det.jpg b/doc/imgs_results/whl/11_det.jpg new file mode 100644 index 0000000000000000000000000000000000000000..fe0cd23cc24457f5d7084fff0c63c239d09c9969 GIT binary patch literal 62863 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

8})=?RB>;j5)$gHOduj@nME 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 hknnK-llJ!;CHaFs@ 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 literal 0 HcmV?d00001 diff --git a/doc/imgs_results/whl/12_det.jpg b/doc/imgs_results/whl/12_det.jpg new file mode 100644 index 0000000000000000000000000000000000000000..1d5ccf2a6b5d3fa9516560e0cb2646ad6b917da6 GIT binary patch literal 170292 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%0AFNmcD2p+H&RgoPKyW`rJ}}IE;OiC8Hne! zZY*EaW-gL+WSuBaU~6)q@?IEh>N4%G9}5go220aHk6cga2u0O9P<9NMVE6ga5b8lS zr*tDr*yS}b$M)mq*7UEx)ZRE8$s)O)JgXfSRSh_IVh_mflwV+lD9w?|25-Ta&)6FU zqU=@x4hE>k5jSY|U{0K+Nl|G-21jLH^cRQ6(T?;SWQRh58pWc1sZrh9PcUNN(zo;HoI5@&(wtLbG<-O&{4ZXmV4+tT}*?T)>4uj zn5M6`zmn*Y5*miQ&KS*BWpi;pJ#WxS3Jldj2qcVj|4AW|EmTJ70v~qh_r8XM7+z9= z_Nx_|uYNONIK6)FQDox9{sS`aHc`HrW1x#XolY5R$g6?RZBLD_Ts5!upRrt83Vt)> z`o4Q|wi<}MRr+QY_dB!|dK2(z4EXZM!s>rQR*!oy*GbDB%JZFII2k3<_vz$tpsw&M zqd{lkQI>@a!2}0~G&o57BoWl`Y+%kL zJ|?2OiehOV_11niwo(>%N)cht|M9chP0$46TURt3-PH8uc=Q>+i?m#-SxE9m*>fm0 zI2k-)3wT7p1=Fk*uv7aZ*+Je|oqzfrO3ZD9o#}87dwFr#!6?PgS4yDHop5R^!Cd=U z`fRJzIG=&LA4HoWH||@?jmZ!st*{Yh=uB4_ofpI-N-yE+>wkN4f42t+JEvilOjpE% z({V4~1(7Oc)7y-jC_QHWwT@ zhUYpcm`^wjXtw6`j?Y07U~C;D$8}+yWn6Vky|+7ZgpRA2QnE9czULChB9Z_{TVQ{3 zkqj%-ijizVIfbX%tT{`@CkLF#Hrn>2B@p?AI!HQE!w9UEKZ;(khbVC>JY8hR0zrW=3$5gd3!-Tyyh-dik zG(LbX9r_nX>^ApLWTF?pv=^#MF088##Uf($8Y5W)$&`yT4dHH=^$HqQWtSV22RTbh zN>zO?Kz$UA-4W`TMtvDK7LT81!oAmsz;cqd>I$}UY`@J$A;jORz2#juYU)fVEQ0L< zZ}G#EDlL9}Zs#C6D()$+I;_>BM)2!x3nCpOnT@)o7oTvD-SuE1MM}b{W@GAolKLz% zM~p7sw2pQABDsJSW7gijlfVZ9?#pNUNnlaiE?k{v{#Y#=<-)1LqK;Et_7=<)9!iZh zxMrzKYUoT?Rf7$a`Mo9!Pp3qY5e`ZK<4FTu!(?w=f{(x}p=>9Ig zymcwsx4*WG$CpPswxrkOq1r-;1Z`8Vb3eQ_QH2FjL$^*{E4Hy_Q3)R`+>@jR(hbeB z*3rN6mcr_^U{X8e|Ar-(C(eAIjj=6@RV{fla78bNlsUvu_vqvd?!eONWPX?cDmi^f z{F&(M1(Uls9zr2@pam8|f)@Z16NtJE;O#+aaj>8ho(+U%T!QnRMtB5Q%Fh>fvIsMu z+a8zo8;pK$lcO|(f!C7jtW2_xiLW=fwEV*u@VS6{T)UbL;Q3SJt+C(mb%*YAB0B9K z1N0*gl1qjg!aY|&T%f=*rYQ3++Q@Jq?g^I$Jw1F@>)#1;1PO$Pj;Zb*{eJmdQ)AbR z>GOT?S`}3TwSp);!6S9|)$dil7X|jZH|Z1PT@mIYf}y1FHVV!YzY*F2>n`pq2{imd z?WjwZMa{X~%sk@nMEeFw#kBS_-0~yt4)|8RlO08n<`j?5?fNCQ@Y;^T!k=f;T>>w8 zuuOLs!35@X*V->E8-0EcFAGP#sR%L{!BsoiS){eRvN)eTan2ye`21qSJp^(uk-*pD zJ=o7|$eF6*YwLJ74kaKtQ0=I5!u2JnUryFa?x7jJ(tGVjTv5zRk>aV65W`ugK%e|I^F0?O665=D#`1z!|gaICD^X& zG=K!7?mtOVzY@T99o8xTw1ge+O{fHhodUY`9yHD=MKK*MS07IpN`7-u|)*AS%ynKT6&MYkSO?d|vdeYe7 z6Y-~e%^B=9R(;8w4$R)DF8JQlJbm8mp2MtLWT2SgHuFYG6cXmNt{$L^DL$Hp(R6JEp~zO-3x`GgQpH1DtRRVz3|6b|vsWo>-=}MGL(D*a z(aRS+G{o&MxakYjDfW5NwMT^oKr~d8+9Na}sWcHI7f7MJ#+a9$+(#;>Z7;m^3Y@-{ zlA1!K1mb!4dMEgR-#*P402L_&MN>d|6=iNn1I?WPcK#ypkycRt71Ws#ahe8MQ09s1 z``SQsQe*Jd?0sn%Wir3@r<1VHpFiJ|Bflq?!&Kuz)*%|SuMaosS{P;2|HwMY`Ih+S z1m$`M&a@<2r>Zp>enIjeW$IepSEJz??b3Y(Lk>MFE_?w0;q$B3F}@VDH@aJ%`1B0e z`L4EsPMC(P)uF(K(T6sR48SD>HGoco9b}jkFJHiukqNJ}C;7G-IC6T`f!k*RCyhN- zppPla*nEQ{v5?KGJ?{#x6yjkedx}bfdd{i@^@r_HIC+p!|Bfot6f|!Y!h-yg4UV@j zOF%v47=n7rAll($K~P6J*k$M=IQC(PR^5tm4^RDoJOnEer=xb^Kk8G1o|ikH%l!da z#8*iE^SSXqpUY4Cbn+6D631%=&wOF#{lpnu?InwQzi-io6>HPfz7w-1PeL7Za-=et zhV5fp3kWxX??PmAqd+a{4J2s8-7^I(Ua{Fc)Po#WMg|G3;Q-s^T&b`J)t0h`Fmm|v zxfd3(AzUDh27pKo2>Alk7z==Zg4q1%t4fc?MdUZ;=eplP5cJ(mP+f+Rt$*|U_Wn62 z`V_Q2dJC!0fc5$L0Lq-~2Tj(9k;~Ev*z0WQhZq~2*U$#58jkl#_gvLFPVQ4AQbr9+ z3L=@w+tta)R%396+oy#!#|^dRfkWReQHvNkX#%1YvFue$Ae+<)rx^YN67X_$OQ;eo zWA{zrEn1+tg&*KDkcG`u^$H!p0=|m??M0v?>}|*?AwaGd4^A`z%!&&?D=^B=tTMnY z_8&s&a(mquvEJdlIF|&>VNgOwaSJIAzE|moBT2`!ZCAepkfdEo5z@}bYLF|GV2xfz zfg$A4gd%1H{AYG+ef$2f5F1RzU z06SrO`T~GizV6-?h0Xsciam7UW&1}IalaJomndEVw%|Dm=Dx#G<7(6O>SfBSnHw|6 z;WHrq6vReI790AhIf0y;|M52R!$HvC4xDShJ%D0f3&G!R4Q-H}zK&gmqUk|IIt0tf z`1k3W?R^stG*A?n#n4Z)ke^+HyMkELx6jq_={RCgv8Z*gG{Ls&AnB7oW(C~9PZi!B z0I2Yeu>U{!W_c)q)?6&q|5TTizEc0=geGX%H=L*z?uZ&*O{8|!M0>4@61|$@d!?X6 zKVZH#==qb$3%#pumeg`Z`1ak%Lf(dyFgQ7!# zcRSDl)-f%S%73BpAA>;&xnS`R>HdSM|0@^S2t~i6IIb2yDN)>EBoSB% z0Euy#>u@{3$jQ&uVd=R2RJhA{OC{96J+cMn^T-wN8~^`g3;KEflr0yQ%LDIAqkndh z&K3f4gm04QA&1W)eL&GaJoE5Ng9+$KApkD}n^Qm8>)1#rnj5)%+6lbO_~&H+bEw8! z7+4C~l|U(0R0!e3@EY=a(*{5%2$dt}z199KK8lL7HPn-q z3Q5`~lb#@(wHs+66pcNyR%+;=owj`^dYtKn6PEug9nKwWs22N>O90%OZx7#Ctp?Xt z7GU}5w&)Ag{FaTK1s6{b+4LKcQ><{z*&mQ)E?N++KM!P;0KU8h8dMkw?HS0Sj~ph! zhm_o^9`-}sAKD~~#vMjt{p*k)n%a<)AlQn-7nPyA%0?|hdw=xv%GsIAfXj8dHuB7o z)p71a=u5KWxI`Sgc01LMFB7gm&GWTB@O7~BOvi(yOe`gJVIPT$1GVb^tLPF=c|C3Nc z!T&=rAPe~SYi9qL-~aSlD$W0in;{te7y_}(7Q75r9%`;y#GF_SEXH|_gF-88U?l)Z z$UW)^9K^vrNBVMQ?llMF?^|J1*~1*@k=$7cXxS%b_}+lW&%otwRN%kBHM74@^3!{M zkE+icjTPX~ecNHCba?&IwH$Y_rZb%BgYA3#liZVE}leXd8i-1!sM6Er5 zf*zd7MJg#+R3WF>lnpiA%^}lQ%#&whAlJaL^>jF>u0a1XP@UK!EiTw1Jr!~p8<27S zYi5Y{#PkK`<|1fYzi7rtO}Rp$jI5k~S?d=8m@!MknoJcHdh{6+Uwc%ji&kk0G_LN83X85}KOUi}xt4fwCAEotB3eB0)d(91MQj2Ax$h9uA1P;4f1&cK*56mfY9egu9q`wh9`Pd!tHE%PW%pPq);+K;QS_K^I5DECL) zIo{$R`px(RdLfr9_-=MTJmDC1n>ew(p*`);lq73%a-Db;D!tQbIqf>J4Qp5HJR)Ad z#Z5v%)xcP@)=L(`C7yeUg!R#})m%>WMEI+jL3Y%bw^mqlr;6`Us^=k{D;aJ|!?TNr zd&TmTXUn`>4h}4}@R;5l%v4yt*}3YXU<$AJT&)%Gp{QF7qaXtt4&0FHpEaCF7+J(z z6=+V+8dMwqjC3H;inwmv`~F*Je+jGSftyd|SQ94#zF&!g@5AIY*AFfug3f_OU6J4C zi_M(cUES1R1&czf3p|H-UkJb2j2XspDj`W+?0SqUD}wI(m#XC;CG7!pyCy@nmT?(LVFBB2PI6Bim@Q_zS!7jeXk*H; z^;I5P$4V9b0cDXjRhGTkNK6_gVJ4U(wVM7p7vU44gVXNdw7h3}!M#VvCc+_`T-3tk zNpm3e(u*@6=Mc|hNA3i+g>`Q}i!Ml8%1@~6obFU~>PH0zuCiV2j>oVfnuKc^{rv7! zhAj^c@YV492|T1CL3xx@rrRzlOYsR@L+GUzQjT0xAZGO*LS;r97&^*GH&GXL@Dfky z-APEWHAcR66X?hhNQseA)G&B={-A0jtA}qY#vSRJmZNe3-?iP$P1!3$%lh@S8 zz8Mes*D;s%P|kR(%J+D=^F=N-JQfsr!sm)$b}w2}X&jmtzg1#iiBN}m> z&f2Qd=f^ZF*v#X_zsTO~NqoaVj4BJEaz4#+d_=HAyVIKTopk90fASQM{(Z0KW@OPz zmgDb7vWcMUT}}$iT_(#-UruaV4GJ6EzMc-VtUh-6C|uQCwki6|3p%EX3hk)!Pbb=9G|cbV*Ed z!9?g^`XPd@sf>ed72X6#Z(_JfIN^h^t^-AYJwt2}cy z-QPggjyFy51}~K9nf)hw8QvMCo2?8L<$jck5VyqQZkjBh)xp~iMzV@M#VD|tmvJ&= zK3Fug3h~4;I6gJj>v^}uV00?rQYUk;Z}};DbuvqqvI7VeW)m_8O&4qNCdra&{}_k5 zA;10O&u#5)bH|B=2?xI{7HP8NOE_dOGgram@h8>7=cj5wHVL4NQ^$xKoyP1ffC z{m0<`!uV2J<134J@x1OF)6*S#j)56d-ehKzA*gaS))@+$5mbTagzLodrLnG(mf09< z$)uk2r3>=5!&2S4I_l>bt^p(HvraNg$9UA`3MLh6k>B_@?3jb7huybGIJ6)@CmsNi zm`qHcVuiE`+N(&ca;J2jc8)AIEWJ_6;wPu3;#QN?+c%^?bb8C+Svp*AfHChK^DvRI zj=i`W+Y*9$)=+TzmwsC1 z{2nuol{!2~xik<%-NZ3n9Qs_KtzTAO>m$Qv0Dt^D7tyZq><9&e^2fu04i-%NGGLgH z%T+Jr5U=}Gd8YiiIdQZfFjWg5*qHSjM$H?|>p8wflQc|BVyda&E;B3DRL(kz-Wu(5 z{3?lGnOnI@Ok6cg5pN_pITU!=m~V^~Ix<#+;0A@EdH0dD zaI0gF`%PYXo_pcY0&@&d%8R>oCD<#{n`cVyW0pY+J?8!gEm~Be8I9*~MuZ9DJB+Ta zEz~FV;fzjX_5$mXFAv^v>J)bSRh&q-DXGZoI3aky{c2{IM_Ra&)EQCxuXf5PnxZ)5 z{*Nqf#bmU%Ce`!vo!ciS#A7ZM5*M9klQX_9jImK$S_p^w3RlkgM)o?YH;0t!3Ax59ROJ|hE%6yXUrWjEpn+_VCzf*7j;O@K;jL-4* zc+k7}xTyj?mer6zti-Eh;hXuQSwP);rj|%46_F@3Gbr-^82iq!rk1X4nji?Gf^>)q2!eq0 zPC%rKNbjH`B_Ps^w5Uk$AfQO^9VwwhRH`7oNpDK;H9*Mu2K0FJJkR^S-w&?K#O&E? z&&-}#Yt4PHdt=WJ8UfE~qHD-EnR|#Ls!O*zG^)XVcegflnt%ZI4U%CiacK}uowcyp z0nZs$%IOpwYrpnAh+$GO<$6_GQDeb%V-kb37MC~cj6U+}LwHBKx!)GEb#}$2)r)%z zLYj{IwKhp-B8qkPyu>$}j@$J0mNpc46LP)tAeM9WS32nZ{P_~(G)mnIu3ee_VAvLF z=gYWVm?R(j>2OBQAu}Vm=~kO6{x`lzts2}Eyo-qg;7sOzSsw?((w^f>JZc!-6j2F2 z0Yd5-%*q8jbc^b{Uyd%m_GX8Cs0CVSBP@>W$c(`~cy_xmZg6X251YU2^UWtb^yg*l z-4gSr*frhts~kVrdDA36f@13+2@9{94{@wyn7I3%E*m||a5Zb!Lgf@NuNaw@$(KB15!DT| z7u`9w>gjx!X%W*mKCJT*H{YYo0-JFoeI=YbZYXfam=vhA?3zT>uP6!%qY3yKf@bN@ z8AqhPuOngG4e3wwlC9(-L=`nim<|>djI->eZwpTP7t4SAl)cv^HLG&bLU2FMbj^n; zEa#(brA6|?Xr{*uB9C&Uo=}Jf=2+?#ghp8J1sx2YbvZLO&f})}MyHmwB?qT+Jup1K z98X|UDQjPtAF-933j0)w zW}H6e>}x1jp%1>Ua8=92^vs)x{5VqOkdr|LM*TBrs_TNysrwbY7>&K(=>jJiE*YbrcbX?)ogsp8idXIQIO zW)Y!+d7ZLBZVh$cY|_~H#^dTfV>lN?26=BN+t)(*Soj<1Q%e;JR~H2v>V;>0t9xC% z)V>ptZ!Aehuwe&w>@ipzCMy4_p$LXHHOam0!PmpVg!_FvhP;a7d*`S)Dm>S3;LLC3 zee17ryr`l!kk99??vQOLXLA_1rK4xEWu(9 zIZ8RQrMiozCKWyh_va%Uy>to>ZgMcPsf{qRcfX=j?|I6TG3n1&Ln6z5F0U+f?!F?U z3vNz+8S2G!j+0MsN#7+cf6oo?%C zRkCSX;rrC6Nldz|B2J<+J<)h0--bp{8WL11ZeM&2nN;@P$c@IO(LXw?o4JMEt&(p@ zk`HZO^wlDfE{>~$xon-`E4kp8dqPbz(_EAmLo^ca%tmT2Es+rA$v!?ayxBE77)HP7 zENDblS((^-!z}b>TFJK}`VggQuJaZ>7H-xvFy}n`D_WQQo2TUG6U(CW*XYj&0`2Fr z-j#1PbqQBra>qCeH8}|Ug+*4&VQ2fk;9E}Z^y5eh4V#o}@5M|DhFL;)j_CDn^Nl)g z$KCSTM{ayOpN5>)b~2`MmA>DbS+-TkO#F(iAPVHM2v53HQsI)u`Cw|5+oFRMh*@P^ z$v4t)k38W;a!W&S;-(`(JWx2han8^nKV@2WbS?+)MLb#3!+R+ARDFc^ax819@njTx z+bpw`Fp>Bfic*(z)FShNWh$T&?j_hh2UDIs#6-4D5|lQtSwCRY<2rs;u@#drOG`z0 zzh^CyTvuyRcH@@a%NrFf7|s}woiZ{%Py$u1UqWY$-!6TJHiBHe(Gq--1-6^9EOWW) zTYxO<9H=w`BuPPv;Oa?AAdnT!inR}-W17>fiD$Un^OCSEbo_7HGL8{Pc+7nVp?{)0~qBZaP3kl|a~%jk}?W-~ikM3x&jX2OZi zh{T-{Qpd{JOJ7z3GOB!P&Kcy-^+1J7N(2W`R+aRb2{VygRtm&tJvmLs%UDd&o`Ekp|IQ=xvDs#{#4ZB6G-2xkPBR4eEP2>fX_DgPbq=rX%h0 zQ5b^SXLNl;g9HI@6cHZcd$xkt4B<0zrEU@ym(KY-{*j~WlQbQh((!9LE%;0H)s$r; z`j_9ixY}ngT{Eoqc{udkwMeper>Sqp)p5^;-$eOUM87tR=f>LHq-x|*gIoWIMkIaL z1;d`=-6q1dmvbS=h6MbHE%v%t9_5Q|e5Iwc+x!DBo}aN7QSn2op4n2#b&XwBW&I0F zBOH%l$=<54g&cZcD9r!Omg9$eyw4b*A}h&MWnsrXIvB={$vspV{`VA$?VAl)^o`C1 zWx?reZ@&?n#SXuxv+<=94CXHmjpTxETm<}?_r`>V-pv|;b?GQam>Xhue?(8(aXK&@ ze}emkx@*{N;|q&wI$|9}NG;V4fq`ygbr#Jb+6K%y-?hu*EHSxABenuRZzy7Awr&u? zKKj=D{wkeAiEPyh)~bF5h8EF}7C(+~RFWw*Tk~5s`0n>&_vi`-a+rqpE?ztvIdMu`PH>mI`@%oPN-mQP&-=OE3&GBl_r3E=43f- z(Nx#+tZ0tzPPi?S-}9NQ$NIupMeu*{h%$hka=E!ocmU4QMWNdOt#HhlA%rbne%9uM;m#{73U??30Z`g448dS1+ zW*WgD8~*nEJ)KB+g1KwZ2RCj1Lai;?xWNPbOLN0}l>kmrX!=Do5P81#dKUDnGt$3n zJAXakGd=S8nu!cHIaXR`_V=k?mo`%(T{}M zuQu4p?COo36CoT=))Bn>A>QjUXIiH2(xAPbv3`pf=dIRR;hZO{T5WB#8cgZ(7ZsLY z=p_unSxrRAVOaY#*0IY=!c6@=nw# z4yyC#+ef@?BfQ)?>LG%lRPD-H8i~pJe(Q1Ql0hGXi@lNvxM?{@+^>jgZ21EsGxTl4;_pmn5>wd z1WRa9@kb=PnyYM#7!lh*c3R@~e@}7BiJ~i1)!j5WD=!%@l;6gn{BkdwW|}WX%JiB62WDKHk%aF41qZ z7%WS_Mr_V^;9!7sIXHc!K`@rl+3+hh|HvfjX^ZM02fuD@SJ}v=M{Hkl840cxT8dZ~ z=9w@jd}HUk#5t%%FT=O`po)+3V%O8s=B1wZol~xbXUxJHp=7=Ky!G@v6uOV;1&gU5 z2DnuMnJr^n2PenpuVR)=t{NPgXIyk%A`snVYq1^-DeQX6Qd0Wb zGgrVM#4o1>;aF|-ZdzQeQ#6m3gn#zoN1dU-1x}9C>K9Xq{E;kYbaftIG|-qN5|bDr z;mDi#>MMN1N>~P+t*rOKsoYt_^WCk|iVFXvy6>#i=-laiD5Fb zq?=+9Z)$MC>-A{0wAlW%qmLMGZflhpW#oHwhx*3ln1q=(oK7Luv$gdwU5~e|*DjD^ z-B=u{S*4Zi+o6SV>@0X>r#mp-VEUGb@NwVhYlyAbGJ12}7k1vb^=%r-?#J9Y?S~Ge zjhhyO6Pz16&g|B7i?-4?ui)S}F9-IbLXVy}zE{!z3g5Y^*X>H$P(C-D+86P-+ za6C!PEv|QfkDcU^kV&227kL8_;#p#0{OEz9aDy5Gv^!9bFQokxR?~uEqT6@`oCRf< zz?2KDQ`j$b_w*=|9%dU%j()f_H;=E~HPND|u*OI_qi(&ynbM`xddyaylA%T-1+cmDj&hqx|Ue%6bZ!K5{~OA_IX4>>L!exNws@ThmzbhOyMxv>0LjLTua} zpaD%$K9cZ$YtHu$kqgmE_o7{E9(CCzvMrxxWz%JeGaGv~c6&jq;>7b9y=FzhId)!^ zjiQ$x{JDgYRu(p?i+e#|N*_ZCmN3 z?&chMrBn^QXy0D=&;%O!MIz7m062%wkz2w=B;{T=mm9=96L@z&7lK;JWy2i=`~86} z6|tXU;(|wBQI0$^{KCzYI?dBC8HfB66qUXtHLAIv47%fBp9_5kxS)WVHoyl?zsFUk zLrfpNbc{}o6(P1@{J4ZJg)@EFkNQV^;}wbLRb=_LFr$T4;OC7dE?AU@8wtVGV_6XMZi#z$Ns%B{HZoZu~-E(;(4RQO%ZU7haTPL)kCCL^gn0wH&5xk@NW}+|gopTtI zk_%_(t(4;$jhJ^Bqzs!Xg0WSV^A{*D@;O+>IiwL^wt961gJ_3;y0J0ewe64*6~A(% zx6*Y~Q+zw;oGuawZ7cx*{QMYlgAyYHCrMAdx_LbBZ=%MBVzhF1VPt@H-4vI@jjNdb zjGvUVFp{6nQCIh2+hFIulmX_kwgP_f^pOtOuEYg|x*uwCUciEiSkGllw;wrI)bu-k zPOX(jYMI4=AH>LmFE9Am|^X<*+KGKX?h$S0cx%&9bF*i$4i1k!C^K zYO-rpQj{-=SPlk5uqDGEM~#xVcPKTuY*0PjrRTBe(tI|{crZv`@3XNtxcW53klIW= z`k{!er(_2drVOwwg z#JPT!UJ{-Gs1X2ad=a+lehQn-SiNdx=(&t;+O_;OLl|Gx$3f4y4qD6ZT^jL9%`Fi4 z;y>&#)O`W2xRSOh=*Mu8b>PYEi}7#C?Nq7;JVf2k$v9*$mNdKNolLmGTO()=9-AZP zOizi9>rjre1WTnEt99A%4>P$QeCdB-tqx)2lxN;ip%tc%vTuIVR!IBuw2m~x1V!5v z!+0l5xxbLHte=CIuK4b#e2bSmO@GB^tPclA@5H%*Q1bh^K{i*g&QCg*II(y6xz%Dk z5A{{J_D2TqV%%YDJLPj)yL^~0&0slsd%B!3@NVKqKbxT^q80r*AI%wS7f_Ox{ZU+W zU_HRzA0R?mAd5MZW19X58?2Ays&_b4uZf0pq@lC=JrHKwO$_Jz@gA+s3BNM8Cnyh} zIy@ecD3;-0=c*&vGZVykw1dDA{>=jAJ5W^1Zii>WJUt6hYz0a)Ww9HpKJh~va?i-E z$Qsvu&*PtMDYTLVImD|tBzLTFskWE^uEvUL!b4Ofyk9`?IA360aHZsFSJ8Nic1Etf zu^Z){nZV@7AB%0l3@S-_(=;~FBT1w~y{+ogx7@@K6lC6zKQ>5=-_w%wYX8d1#FTg( z5^0tY500C%H@F7EgD(qgT?C+>Az?exhI4Pf^p5JiCH#DCL@El!K~%@C``L2=KKy3# zVEe}c_H_)ASeJS)M!kiP=f?fb<35Af7h+20CKe<3IXrqsx?~K)_r}|Vh{dI-3f^&1 zxXLLbl&nOvr(WP+zBD08fDzT;HX^J`Cc)l8ZUyrR{fzWy-JANt_QPM#4J(<1kLKPVrpiGc5NXo+!w!~0510lEXr z5hq?eCpD2<{!#Cdnp)rkPSz7~4Aw){-rz&k4qS>rZduj~)4i|NWkeBI$caFb#R-dr zyewhSf(qnP$knixSL!@1^(mKz_V#JL4?Vk$;EsPB`HXu$ zhktzTh3>szvpyGORPnga7q;n~YCBcCr+cq85Q;-Xt+PO^2OPHlOS&iThZxbyLiS-b z#(cjNzUr2=y_AGG7tjnp)o1!g+~zl3q!S$7z|c0d&Tp?y;N$)X3AnPXq{-!G9&4Gpzd_fREk3C3% zcIh9V3=_yb4dJ{;U*T3@79?o^q@%$-ULbsf+@S>smmi`(M=UM8UQ5=_J=fsTBYdZH`R~8-Q24>M+>kp5Mv@=BDC{7k?fXX!kJCC#vK+FK5l6@FTnm_4~4$LbS zz#WVp?vWeFIXGSiDpgk06HpW$Ky;o|uI2@9Knif1w%{0HIrP=Iq2u!avj-Ban{5CL zxYUov>;u&yMDRKUjRQf0e*Q!aY5`2c4}cR#myF`oYhk#BL?;2Xv9`I=f8OG`4c1bH z8vD3ws5$Gf?1N6JUFxSK`V8j=B|mKXpdcXcHXD61JpVQgWK;h)(*XSMznMn)k7;06 zdByeHvl(V^K(w;v_mSJAtNG?22QhU4bksdA%!N8Dj301?#a~?oTm1VrbYaIPJ!Ei^i5~;a|(?77u!H~{)cT1_fH2=6-*Ld$TW+36`UUI^0DPtLE){?&fbAMHb@bpSSZHyi$=`Lc|( zr80Ol!QPxH5RlD4!6SY?!Sa0oDh>cpYPBCv^y{;>Rp5C7HG)~W0gJz|*hp8uv}52( z8-UpWy4=Sk6}TgVfNuaN1GO_V{^J_}hm^>ZJGc*jYG%BBXzX_Y(4W6s5822Efab$~ z=n2W{@`x5`fCq>G&hCGm4Q*Cx52|3Nvlw+V`5I~8fXjdk?(}6i7pJNv&@lJ5{90;; zVt#y5-0o6v(w|)j2Jv5Z0kk+MMfqw~`lonO+~hIgh~L}^4YH)1@&JzSvTcss-Urhw z3j-FpKL-#H!ASn;ZpcQQ6;OV#guFYcF9n_E103*s{ZQ}@%sT3yLnFPr~fd26w%(`D=1ZF#7 zCYbHFol{OV!T)$*nfJ(c)UCNL`20FXMFrh}xf}{+F;vg*7_j-Sh5c)`@c;He@J}$X z5GDL5ow0D*Q*^`Y=wq-*ES|har&Irz5t?5mASh=lEnyC(1YZZHs9R?9^}Pg(8puC7 z>5n!Si*gInP|&UGR$_5wxj=tIo~up12fT!&fCfVX7J?J{7W@;zbkQ%mP$y<+b8NEC zPqI`#X-+1hc`7SeINTw$mNYpH$T9wfwS(IS!1Bdlae+;Qp^xAw!r0O;)ibde5^n2$?pM69u)8Zz|fs?xj=p7*hbPrY#`ZZ0(OBOAW-@j)*&`{&{M7CGNaSh&f1$n zcPJrf8o+pxMDzc{J_6*S-y6?gUxh-zMobEpxq4t0{lBfVsDm7U6#mAAZ(ooLoKO@$ z4RqrLp!>W)o>K9`{%lSRK>>kj(Gw|BK$RoN0?Wp!wQkVuRj?Oa{rnc* zZ2;e}y50$R;4mfvqpmmEZ?UYCTVJr zgbtEf0Bd0d$Y%Im2WzX89UwVm1D6QQW%#eTjQqVXOW|N3hK~MYik!GjCsQVM2R=Uv zc0}nYfQU^7+2g5xzzibzjXMVggZzuiX$Fcgp};=$+zo!b2Su$yeoUF4=CXs=DhceM z*yr!IV_t%(?X3!y>$4DF;D=I@O~xI084+qUj>lgX*do) zXYfyRAdfb8(mF&6lb%B6ww%4c&nF;lcNY7PmHFAMrZX|?+q?;M2FQ>gu*p<{EqqZ> zY_U`kTL1HMuf*G8KP#(v~MOmXp6cTAH*3cvr>#mBTXd67oP%bYQ6hqYoH* z$OTexi~quCng^_0v&%o}g70)3YP=piwvmjvDVUwiMwG|ykARfCA-pHI2MLtqiLC(TpA zcryaZUKctv=#(h;liH@P4|DT;ovEZmtHZHajbqWe7SV-1F$0 z$W;wl{I7!;w&~V|IN@a_g+x}YCT1Y5_*!*c25=8R=q7^$*a#=b={JDvB)CA55Tyq2 z{wHNePxuPyK%Mcm7r^?z0Tl!M00JTI9t=o1k}Tcez6US|t8vmwaUkr?jPKi2w!{i( zxvZx8G0&ziL*w0A9KORy{T&W(-b_LVdr<%$LMaHPS`1J{)6m$tFl{Dl6BFiY zb+{vw{T>5lY4xVhTm(}r&IF#8ww7TFV^uR$aS1xDXEC|G3nuufBbaX$qPTt!735m3 zMe4#Aah;s*%xn(7+jf)0tzKxa6DjG3L6g{9N|y|6HU~oT&d!{(B-WUOrDx)V@lF;H%X7Hcb74 z?O*rqjN^m_bG|mDOiN821e)~UyZ~MwJqqX644nI5Z?xuc zD0i=jYhd?=<7D8~snVDw*p-opmgOa7)@hj0XU~qJehQ~hIQc=HhVeYbQ?Q);765~- z;Eym>!v-xi+s-<%e?-(e!t$ku&_$u*z^ochj0z;Zw0O=Fhg{58x}U~|5U=PE3FN3d zd28VtX8})B@Xyd2I!z4xN!uTRwfgS4NxHhRoXo{)`_Y^OhG+NmH*j(mCpb6H#8jMr z2Q*8l@D6keuXyCxsLbE~1iX<3pvp+JPgYwbBo_dr)If= zwOO>9Hp^>*V2o3@G*1VPVwNxUWvFJB)iQ{hDfb3{+RAbjYykg}YWU{{(HR-8zMkqv z^(CQaC#7Oa2n?N{2k`r)xKPaY60atG;K1ZA8~5A?q5;& zj^B=2RCovjg)cxn@mp)gfA%QyM=bo)$ilR2^le1Q`lFIQnlXoO1dmXMI~~{G&O$D@ zzPktcdU)6N9`a_CK{+F_$kcgd?SZSuf*6y3ECsLepAmQ%>W?V?9c3U|HD!6QoPimE zaCgtT*kbqO9=5p1kX2rNb~&-5>y&${gt1U~+HxQRMI5LGdy*m$`X@y&wed%MAGQ)k zFMX8lv@94Pp#i)9)RdkO00E3t`UhZSGa78Bx;rqtuGg1+;WWb=eu1=&T9HBiVnOXL z++9=)R8CD0&6nEB=y#NR&CF=aOS`Y&cR*6w%&llnuMT0&%|*u{i_lYX``QFB7`gu?carBpsBN+J@%f z?vOo@hua51!I{SPje)LUr)7fb;=!x(F}M9zi3pkK?6w%#&4I500vWm!Kac-#-S9A7lCY=S~;Pz~-*x@sAV zxeP^9UV{911_yA*)3(x%c>icSSNkw5sP-z2B~8X^c}~{Ta{{fk6~U01<<`p+x??Tw z<|O@c+-)yjAJH&Sb399$XgV%X$9Sp(-_}mZDs$5_I8_vRd0}wtV&%<3fBD^yVOjXe zM=k;I1&40v`VJf|qv#k!Z$9HyV3RF1f2X{4+NET=ypcCtE+>~}$aj^~scXd=SEW4g zaoCqQ_W;ue&l7J6I&=@+glW9D&ha$b-?6oX}P9=Ns4V4r3>Ig1G0UD|xJa5yk7D6<(|oTvRj7T1NV^2y^ZeyXCn}QD7;1pvXICYwNd$X)UyEHw+Us$5Ozb)O<{NfK z?$hEXMkSjX7}_Co{gPtptCi`Od=w z)%MKb^Mirkp6)84>aXa*mW3(o^-IfKm!ymwP;pC7sbfZD)qRQN`4R(XnDc3qE(XCV z^et|Wl`0dyX-|B9fjg|ZRE##q(ycx!o4={Y%BM0?C_a=N|B5!HQ-*5+=Bo4)r?2&6 z9PI^NQO|Q~)>d{PLaN(LSTp?H|NwJ;}>=$6|O>kQFYDrpPfm%!<+vxy^yG{VdBar#k(_|IWx5HZnqLOnY_YXl4lw)r17-+ zgy9Uk)6Y-sbWW+Vy@4rhPA&a087k1Dj*}p*M@a*rZ2Ss z>jM8|AeSS&bd@4IWX^p3X%|Yf!&7iUJC_iz@hjt^(ZdW^c%uWVLgOVU6d`yKZ<|vr z{BFEmlN*zkc8mmdBFXKYiB3k*O!f*FhL^btdb7Osv=laYUn84BJJW~sjZ~*XNOguh zxNzF@J4_xSZ>s7&&zGy>=fEW8pw6im*Lv&L))iO2k-DkPQCYb53X+{0S(}(*Qn@Lc zlxwNSR6Zi}6;bm@pv~Q(Yf+mo$SO~qb7Eo(E-_6`$b{M4Ep(qD`96;H&ZsV}biGb{ z)=@|-BCgIo#{f2QF7i;Uc5^g_dd=3-tCgPQ^1PnPt4EvX6X=gy0-O}GUO#@r>CBc` ziKT6wzBoDTd~xJB)hfiB;c-XRyCn-4XDZha;jH{S%q1JrHo_53TRY5R;aa7!zpa76 z=L|U*G(yxMTLE5a`z%#7C9P5&p>c_T9`GigdC|+cT#T7F97wNW43PPFpR^>D4SIH| z+BczK3}vHTDR`+FFZ^ypjC6~{L27#%Zf)ke@~BIpCl7o0rcnW$GYggsQ-8)g_C50r z@#|m{q5Zk!q-jKuKJ`Onzxw@VnXVC?@^u48H1}=Ap$9JH+SF48_FK<5ca-m`2poRg z<9pM*yF@y}M(@1!7nb3s(8g{^`>38Am3x)RbSu-e)M|H+^%DwFyKCGZoLIVVr8KMh zWfxvLnr_M{D6Z@&vMJ!Y|5#zZbWLI^o~93gtiBEHWKuFxIw7#P8sMsmG7$(<;rV~c}P}2Mf8()cSnC% zvnZ5qaS`m*;e40TW>On}iC%?`KwYbrELR~L<*ED;YT*-X?>%HY)nm;`pd@vLI1+1@ zzr})gY-xh4f9*>Nt*Gt$#;OCQ$7|45O{Fp$YE+UUkxYywWx>D$Artlst>=e zX~|En$%kN;%_>)wFpBkIfDI9X&d5)2XmBlWaj(kJ>LKNuB&YC%Ts`?~j(WxWQR-!DLd&co@f1^^v+9k{juKSg(79vieA{WRKb6$4LwTS@J4&fvzSv@sFevbM1z;c@UKYD0njVjo4$Q%L$Sd>3pu(~r6F*bv znzAaY4Pofiv?YobM(2IGzR6~R5vuK{xaeZG@Vu6ck%8c0q9rD6lR{i;Jb&k%?!!pc zvJU4viqAI_RrpI^8|Dv9Aiqqz0uSmJEX`N42|o+Rd}Z^?C+JhyPTSKEipdFSI=2v?We}*#L>uHB;%cs5865y{rr$tg zayGLQ9uPR@yY5DJi%$W3IUJ+efbwg0aE+2ooM=~(za-_o7xY?=ao8bl*+V=Z7UAkP zaxOu!?Z%ylx_Z;t1Q5M@s;UD;b?`T09PS>MfWu~dK#nHFAa$WTsL57sn2`!;K-Vk& zqiH(A?62d@C-Re`QO^$V(8 zPX?s2N_nG&`+DuH2KW!so%Wy8-Y7k8K<9;_p5#$Pdq{mc&gpvpZOFtme^8z6rA`VK zsev}jlr`sJi%jjyLxPtI*PXG$?kmjslrpC9P28-nuZ`(zIJ6uulY0`Sc*Ll_m^fEe z=UJ=7S)3N~h@HuAl}&r4F_M;`5H`ZGS2|U-R(4P;?&3)vS=u80zV%AvvplyvRFGaj zUyXMvqAuOR?|}iO>Kc@$EWc0QTxG_Z$%=uhx(w=>dZ3cBMDozpypgyb->h1w8ZnNG z3sxWPr{1?%8FPn{AVf=yE%%o4`CJ-1ygx=|a-(q75Iq6(Tt0kh84HuO)Rk}EGTUhJ zH@JGDWuSphpUYxP$C$tVg=L8s@7&Bjh=px8QYmgDIp}C@hnOTu{n8t3pjQk4VRq}c zT^-vIYDs6kI-z5NdHKk(M zBrkhUC5UV*_dfRB!zB*kEgv7ADrP+B)#rBP^}2F~XJP6^QhAd%0MlOXUKUv`_s+Vx zjkESuXO`YDOcF}dyqOrCz2p+7P*Sn2Mw=d~UP+QmdOfyzgd!zpSa)nOx5&wq?MpHD z2YXSoxZ&&Eco?DnYugW%1yyeI$O2`H!S9IRK$~<1LTW|h;tv8gri~q#*or`xWedZDU4p@Uz^j; zaXNYMUxw)iBtS z;yrkv{cwteQLSg^-5Y-SXqHIlsP9i+5_Xs`)l-2<;H+%Zz@U$4L3@m}ekBck1<`Xc z`0{8ek#f_w!h|_w-~WkM2WvyVGjR0Q3TtHFTXV^l6~n|DY%Vn$Q;okEtkT?6369T~ z{+MAb#JSH#xolWaqqw(O)<&V0ToU@cH+nTY6nYon*NXGuLm&ggnlo`@!*dst!cd&D zbiG|IL?Dr;Bs3YaJ&~tBq4yQ7G4Q>n%6Ed-GM7gCEa506wK$5e!=Yur+I03fuw4aN ziuG_7seBBt`ON>>FD@`9&t0+lpJkt48d;e+Y*5z}d*jNv= z=EG{0vX){f80D*U*RE76cv+0!elhlqv^SVvPc;kgTh#8ZKqn8{@b0JlX+>qh>U*P% z{a1y3pyR*^>^D;hrcoI_aH_a|zy9qkGz4UbeNwWSV_#RB7AI(1M0HuGAI?6t%<`>O zHF@ankZW~qX<5Beh=W|IgrEMh{cww3&m)VbWhT28<}Z5HXJ`Yn>1K{=!|Uk@;=abe2_ErGkMkfs|pdqN0SCn5b~iaP-gl{<6- z_wKRZZfIiQK_KJ{9od6o?-RVSW>SMoD=j-#Il3GO9+DnW($%xt|AiIM4Ta>@QCGW zl`4=kB9p!A^LyOe zrd>N3ba&Kif{xxGODy4CBXATCi%a2!>dQS(Uos}O71z^U@*vGJKk_?>OY=;3o!h#R z7NyaL&fy`Juf$^b@MimPz?!`wk-v8bwX%XxqIGv|rVzj`M!o6UP8+S^2WM!c+h=0> zDvp|<^~UG`u0Tq_eio4BjqOxHn0siG(I&81NZi{WUrfllEI#jz*3MaqsSrF&sB*QZ zm?85GhDctvw;Y&k7{9%DtHOw-suDN6RQ3xt+9)$aG0Kn4d$`c=9vP`m!=oDmIRRnS zeI;t{qU(=Ciy9`kIAF%R^PrFqXgb3WdDX2WE1 zAv)Ga^5(4!HFiUr1;*!GA3@KLwAVXV)mFlJW}NA2;68-<_qm;P1w8KcZa=4)kc!&X zTYUr2v7g}CNSLeQNZ5;Zj;RhwiwPMs)w$TpZ$u*65?f5`DW}#~kkWi^q*W`%3yPLsRqb!8U@i?kuD%~PSIG$Y*v_fxau-uBBwau>GCeg7 zez96!U3Y)AcTMG(7ur^p0RKd}FS51l#*kSqIEo|WI2KBfU66N{_YR##7H&89Zhx-Q*~>q2@Lmoy1PwoLMZ)(C!Lc}&wA93|2CQnLOy>&3jv;T!{(5TD!~zsR+a{BNvqW$%{kH&tl@U`2HhV zf!8R$Sx;EYy&)J9>Ue^3Xwa&sD|1b8iPJUqC~dXxoXAWJx-Xm;5YsY~&SOBIBVH`u z&Ok^^h*PujysC?;Rkl9!Ft#MlMxdLVMmU44 zQWiHy^t=(z%uQk*xkb9iec6P(dN{att=@M=NnDn6SNq~FL!%2rzoGF4Zt~kfA^NfB zx#^Ks-Y6SfQOm>dR^O$?IOuHx>SGc;3Cc}@v<-2~to;vXghdFWiXnpq7K^Dcn!*$hF=^8qwNYPK&4cl#?1mDfDgB?+ z3KtpZkCQmJ4Q`EB$cedJTw@q_Q`-w4S!zzwDndt|#x(SXb1AT_hPep?ChmFK_$iH^ z*2rYX2W`)Y*}KGS9Sc-GWs>U-h!OB2~}t)gEvD?Sg7OnO0?5D3GQx6ep(#I0WRqQx_eQA4_=gLjsB z6-{5=?4UAb`5HWwUWiQ1eQ{irH3jc$gNHawFuvdD^7p8sH9#P0{O3g9aP}C&jpPtS z`CRT8Rtg&AmeMI@MA3`d_2CCn)0=_94V^2{1dXclz`hx;02`dufSYeM+=!KQZ5IW( zqeC#)+4XZETyH66#ChXt&C8Q!jDq&`E7u}8sEH$5AqgeBjL2)njfxzyz4dw9;x`L@ zbnfNF>lt-sE*6!}MNEPmfFlE|Y8=pNRqcJi6jM2MC?8>3P7 zK_vrlMX)val_^yQ(?Z2>51Z+9s?V`$4~0vi#r-mjQ=IE-r(n0+EpY`hjs85At79;idB_gV)_wYVap*?{x15grlTe#~#)ChjB+g}(O zDDK1c-Pjfmn}q`u_67^aT#)5?tPY|levMPXcAD()mSqPosIklECRApfBpu*Zhvos zy%gZG`~Spc1B6D&zoF&rGN79PBH#z~+fjAb658f{oD7zvGrcZQ+02!uSt_G;+gxDZ*=Q zv?=bD)^ejNy5&)*w;%3{1%lp_D-oQ56R{^yh|v~gV3uHR5PGKbCxwDu`X`0tgxm0w zfKa2T_dl={^#1t~z&9X%XDR#-Y!LR7qt%vwu@pj64xoUCQaJeE*bs^C(1sgpbFel3 zgX_`7Ro^OZw&2o5?n2OPMTg-053KIyMj>%*URiP#Gaa!P%@lM&sKgD@@9{li)ESF< z@Zq&9705SL&T;NeEDOBx#H8w-Rs<~~#3n}^js@4aF>fL9)>EqfM{6Gzjl5;7iEKk6 z1G~4EOp5uhFWpP4*|yqH=K4@%Vsp9R_5F{Rq-l!I29gtRxiaiN3KY?dFDPHz2MJ#C zv#iM=NedKdfOz*w85}@S!@B%p#)cS7Wa&L&#`?(4nVxpJYn*G9`*?KOAG?aCyH(YN znyq5=X&-K0zO{Q*%j|1_V*y|rVM|EV3H@i);y*byfNJsSGQhUaW_tl-L<>8m)`l7KIO7qS zdNtDUFD(9sNMbtA=@?=3*`oW&-S2mf{*yQY1vmMBrTuvz)a~~_j*nf4mLX)T$f$%& zWgn8An32?EY0prpkRlBUHL_$+i7=K#+ej(27)rNdY()}UEXfj*H23#hGqk<#&-?es z?~kWt=DA$Y>pIut?B{HTY~|mUa#JxRoXjj`YxI97oS^F<5~z{-GB`MS354G_ zHY*wbS9%I$Ysdn^PN%>8HJ0M6pQj_7hHRN@|L5tPq5oI1%uM>tpV=En?*2csYyKY> z{8x6({|^6WWMT`RI7a>hlA$>M-$@|b5wrN2G*i^@zt?~%@$ZZN%(N+L1a$ce$bTZ{ z&s%4)CBp&UXHq@xx%@Ab|L;ZFGr;@vHbt#*f8``C_&Z6)xqC<=VxID*>lBe-QO01> zR~@CjJtD?If7S*Y80-;Sk%Ch^XgfhD^0famH^NmO8z|ylQ~s9S0JiWKz0|k%Q_uf;4iWay z@1gDmnVB)$ZN53bR{ZTjP!#_6!4N>s`I$lC>-&F69sk`xrYHvc|GH@Puf&l}j6qS4 zQm2=tH*akIh{-$rsd8`8+WDb_V`GIh+{XM|KgqB24IVGhx%2#LYLIUFw=gV`EVm<& z>nY4YI4hl*BA}uXU|YxQmvIOrO%nL%W?5O!ghQi5SCq($B*|H3*t8xViW)@=q+GHZ z4uem~i9>m>P<<^T-r9WjnqUzxakX|zPVizR@7^9G9k|%QC*-JfneDeA%;#peD&hX> zH93SM2bW3A8d@319tF_=)0do!AGRe2DM8ycQiHT(*qUTKh5_ltyfpHL1V*r1qlh&T zyntQNY5@+s4Pi=5&L}PUAx0VFhGVK|NM}Hf?~_Rgmu5IXF-vp(dI((3j7#v%;7uOR z0H0v;8<1`1CD8=x;`Z|f@DC87c6GU~?F!XHbl9oUs8jG4qXJ(xiCs$!?sL#WoAmP zT|2=?=m+3Fo#UyXQsTbgRb}Z#8&94uM$}}(Tdpq7M^+^sfgw$fX@KKp_*y+g7PcHOhz0;A0whW3vorA#uCo#z^tAA8>> zS^w&2%j43h`rEe~yN(5E)4XSyPp((+pBBP)1Je@?^!{E*sB9T;F8I3W-N0B+jo!P_ zK`YoEe?-FGo242pZClj2lTYPV)$+9TE{U*=*sQ*KDIpQ1By>vWv zPsZdI3LmpHxmD6MKB5X@#JpfieoMB^c@)8x+V#(Zm|H9Dr-WOagYsWdZbaO_W9byl zv$L_`C^^6bUi`Np*Y_2jqQ3&15z71-jVt|b%TDo#Wyb`w?w6f>^r~p(u8}VH`_;u7 zTrMB^D~CCrT{&Es`+3EbsrL%euWp^IJ{nwnzj^G1PxX70a9z=(n+r6+2l05$TfL46 zjFq}>re^m~`YR3DBA47zRCdEJg^J^|~aBIsRXI;IaQ*-m;JK)Vye2(l|?Q3mX z_i6@X$VNr?Dt=F3pBddVPD=chKSy^@O?mUVwC9rMR##e&DlUT)Iyd9B<>=+QxHpGEd?PSmPU=>3ViliIDM$av2s?om zP9Yt|W}Kh5p}Ze(8Tr#O@zI$}f0)bzXlJx2jUCE9nut&5>bKV8str+^!GW zytMh&(aARXk!#Nm$^QXr|GQ}Wzp^(y{>uF8E%Ljt+-73M?%2pPKq z>lVV?f6Kc4mCoymYgw`3#*YMLg4e4L`>KaN$`r6_u2-@M?ZkMSR~y;>Ul#=h3c-xt z0Ha4PdoR>Im{kP&!@2|96y8D!iK92h3Q65|rK}Iv?}iiB?u&{)8=Vns@+~1+mmSc0 z;MU%PEoDtvw<@pJSV_N=Q+)3tdF>3N&0euzmcd%pw$NMsg!}pP$FCbJ+;wzRAn{f4U`Gn3p@zLY=p_F0f%?5(#dEl7K7 zQ)5$!ff7^tYLri9>zfp2 z-{kGxYQ8*b*gMj1_JU0(A3b{W>eX9q{pTCBlHMNH3eK(2of_UT{33Gc?X`1zuHSd{ zkEBp1t~_jUrYs$JrI2Qj!^p47N?4p-bPbmJ*kbe3_be9K;J>z~zDc-Q@P^^bFoY}AhG;WC^G2X*|a;kEbZ6rm@{hu|VZ|@^!0= z1Kh&8fWI!?ebXl7z1WSUrN$@D%QZdn%-rv8H+rKs@?ZqvogzZp?8 z!XH~Z((M}}7eDw=G0``2D1U*4DC zVV`}0{@_a>tELBfbe#OmF}@_RfEYV}7K zH}#T>b8c-*P9k}qsWK@z>b3kf`%CMFn<^iyKFKymtufO!UVYB}U{;+Upkw1%bKU9<7LACJb5!mm zu3aWy{kWg9?5QIGIK})`z2poUA0W?+vEipl;2GDhKqZPxm6g-cbzk75{=(%fU5N`8k!+4INVJ3HL34vooIrN7SWyVg?Kd}4Q zz|JJge>T*JF6zr=WyhJ()|`7TX`=j{H2Gh3HK>1>IsUkH;_`{d8_N=(hh-QJ+|+W^ zubI0!8p09V>WbA(i6!U8W@}wl-t@ryU|YmBEW1F|eT@2nFmUl_trJ@bu$ff+oI;Q_ zy{JF!Da{QAwy8-Kf!UGHQH91!*B#wAxheWuUet1%OQTi0<`fNNj8MRUw3m|!HuL7H z8h@=fn4EuEptiQU-C0c#UwTbWg|BMY-1u6bRBDXhY)={U#0(pQ;ky=ZI*Inp=}p^< zIc6#9Z%Invefr(Z1Qf@$+<=~njEoL3@_l5d(M@dS`f{dRwWqz@g$ARK#eSvHS>tv~ zZ6;!^=dKO8#4uQ~fLey?E$r+5S+~Roz4k9N(xHjt$>(rQW3}ev>v!IWe2de0E7<-* zq5M*!Wb)bKvcnJe)Q`%4vY34OzD*(MUaF0~T*s@vy5395EM~&3>znCOCFYgi8z!^Y zcnwoOXbfEReidh5qlF5bsQy*{;_5GJkK{|cL)ba^5uMFV{!-&bCI)t0@;<(oI786GTAl1s)j5AgHO+&H8K7)hvfUFOLfe4q3HcM`Kn!KsqPZpXxjkA zUb4}$VVR-!Q~ptN;ud$h{EP8b7!4x*URPxm^$(lLvZBjx6=zcb+>cSISevG^uxBba zRx?j1H{Q=5wG;a1);4XG$DdStmM^I;{cyE)^R2t}Tecs*m(!m3JYeTYR$oE@lj^SZ zFJ}J-Zsn4NT2uJC_hx>jjUv~d80~;^CGmL^hg%-KQ61{1d|j~qwX1;7lCy7DiHY$% z6f=RqyVlPofd)rfF3Bg=yjEI#Bz6u}q@dgVo6K>L8{E^s8#pB%H`Fm7j!J9!5It3b zujI+QEN6nnfe)J8${2jtCn4^zi^i218SH;SAohP*a^p&4-Ciz>ru( zOI}V-Hk1Wz%7X4}-kwI_VcO96z}5$Hf;qv%JhQ<=gc-E5hJJ1&63Y<<*z)M38;8>* zxbe2qDcOUN6TL1-O)J%fh+JnWwd(RXp6oprXvcE8@tBmHb8pft104A6So!}fYiqI! za1d0;CipfvKgu2~mFZO>H&UBY^E=(gTDE~D#=h5%r}b}l;-o7IaoNuyZ(2ZosRtI*=cdMBh#j0H8bdp^%=lEYF(-eyEDwv!0Qj_C zN-zU@(XHb#lh1=7;MRCK$B-^$6u@D!a+_&jJ0M!%#mLZ49x|-K!oVWdLYOclSJz*J z{^{Uw!|r?&5=pa0-&^1vF;MHBfjN>H6QG;1%}|Y^o0W>uw(!)lF&63uqlprH?Vwq- zyz@RqBYfq#s*UZ}m$baI9`HIlu@@=_wZHfgRKgBUd_m|ot!GE%M}RH(z>+CYk#uF8 zjU?+YR1@3Qq|Y~14m>aXM77toEIKN;XFSdR_|zm!s>=?jRsa(7JBbxUak>erKyvT?=P4& z6{zv@(i$R$zq&zpwFWI+L9KrN>vESX-u-&z;o`d!Q9k^6S96*U3lGF^^xko2 zNbvf~0jCQVcfH?KH?DtEv4L`}Qo;&@!-(;;7I;dX3EH`u5sdXy3bijTrH#K*4S8JE ztrY6GBf~=G?J@DR@mi5h`h~kxv|A|e90&GS6yNtgbfQme&FRJ9-79W{aJb7|-7CYc znH01w@-{qv9`iZSnb_I3ghJ0h^d02pkFT5D^InA(s*Zn*9PoXb@*|1=%dWGE|A;+w|dWk)Dem0 zGVS+Cfl7O2IyKf>4IiLqsu6aRcAeTACUiZY#y9M;mU?Srxzue4+N{(IzhAR{{_)sd ze#9yFXwT^4K!wQRrO(F)Dv#V+?-=MSSU5N$)7~L5I;;BX{;7h535rbQ<9&Bu41&nE zZuPbNi3?_-_K6pWCHh(VPA>C~j$WmPlV%yLdB1hZbMFrnjj+het*eAc&@9uzD`Z$9 zlCFAY)NiY(-xrnr56q3c6D|dLRTOD3=bajMJ9RJkpK4HfRxdwjVY%Weqri&JC=Qof zwDWz2%dksJ$aYua%Hn(Uc`kNZ8&|Ay;(064T>3rbME!2%E#G@AdRU&G z-}-vZ&E!*0AM7^NO7+U~T{E@+^45M?v3prWyyXl{5+7=nh%(L%4HcpC^yS_eHExZ`NQT||-WX+Vp{x=I9t0!OSQOlc}>zBV)c(?YTO4HTY zI|8oOv0i5;f|MtNs^}RmL(OpqBHP6+i$?B)eBEHz`D0VdW=4#UZ6SZKziMuO`tz{1 zJB!DY=l7NCmNhENlrT*B-9A~iPX$l)-3IG^o8p`S{M`#{Za@8qx5!d>#r9)O9Deeu zcg|7Yc32zM2Ke{BJA-PK&ZEmUDcj{&0NRhO}9f@^8x9koGov1S(N};K((<+fK z2pyu|^C-tRG4iaWqUY_}P_x0L`n{{wu=$zsB}Z24@08MJU*9`&RYTb1P+q@mbeVzr zJQqnzzO(Y725e=Pvont{Ul;BBs}lC9<%Q)k*Dq49dqoVZwDu^hz1j5n`LnfWE>k3o zt%N2wH4R1`H)>ub>?i$Md6!PKVp@#C$?yx7BJScAQ;zW`ec179+2LM_kEIS0D(%da zqg*T&KDjIN_`n9LBltzd_gFDRBW&~5&buxAZugn19kcFGPq$`))oX&eE>@zaW+ZL|PSen+F+J9H%QdhA-{HdY+rCzdcatmF% zwj}w7E4}{aDXzKverr}{v|+(N1A{6@^E7wp?9+YCGxkt1r7&?KJ##>&xZ=feb7;hT@KLdjZvH*5$t699 zbdP9Ano8(lU&oy!`+rD2Pik)R^*%FVv2Tr8AdkOE!=ebCDNk=KRELimoxj4fZ_9}E zuAqjP_nW2OXx#9Yw!8Yq^ze?k#~c}f?U_IXV&o1$T zJMS&KKNPY{EbNcTQC}X5nfeA*<@V-F$3NBjv{1N8i+Sjh*hzhe?6Yr&pX30MbH>PC=3+g`Gc-2Wh=$*zVgKDT23kD)> zo2o;Z(C}=+4D=#m18&BZPTJiym)k_Py7?xyWfn$MKWvWt1chwxyf8 zoynXiupH*QNhvY%x$=2CBdUU&I(vg-f}gYdxgyFsx|oq{q7wyI)6eeMo9;n8&DL-c z81z#ke0|sadVF{-bK+H(*oi7(WncYLcJaBaeD}zaxa>V$>kR+J9QN8{T;0vTKdE)a zp|f&9gX9K@;TKJ8%NMKI3X1HqYd@A*9P*iGvwyMPNxG#Ht&1(A6k$~swiz4UXXcPmS?;W+;+6OvSt>cLMT0>utKhAP|$PR zm+$c|8I6QaiQzX{K6z%E*UKMnaazSEu9g0%=;#IJZE{Qapt|pcz=Eo{RiYMiTPvd0 zT%cT2>htV%o=qA0pxd}TuI{=*y1K>Chi2S;4S<;jSFI#x!!1$vou`dD-Y(yIOfuo= z0b;1w+$#MRLTBObN`36%AA+a(CmAEOiA$JGz+;`22PSbG`6 zB0v9{F5VsIlH_Ifn#!{!b-Y9|a)5ecim+sZ%0Byp*i%vZUtWK4B{oQDNJQyr3U6M& zb4YS!->Y04BotPtXx6O$d1sQ)wzD^+ z#O^*>qDb~WQ%ostH#NWX%jkI$ttZ%l-&Nnf?)X!?evM{ZdA<~0Oz?^xQ2HshPoANpk8nJ=RH$Q&l{xRl@M zp1r`e;oS{J!=OfP?Dm~&u4>xnFQF03ZkO`=AFP%CM-9JHcJ0E%h;?cunvs!PwyP@a zNPN+J>-h5RMi)8@MD=6FZmhfV*ifgJoIGDx>6rB`eo~uroTpot!3WU+>Vqw}l5O{! zT8i2Fm^{lc%Dm?)Q7KD3y|27s`^qsnO~Z|ovX20bG-u0=r_!wIs+zA->8hdocC+gn zi?w!*Z)!0+e&^!;ozYh<_BE}}$=i3W^X-DJHMey?C=;HS60k+k%&Ylsmw(Uo^ zR>gTOWl=sA?HGAC;&6i`AtzB)=y_sAvMX!leny%sd(*Cm$FfEmPaIFRTN7{WK1BZ5 z`6Gky<-w2{X~I)vv*)4ox8<=Xim4B^UPy!tT)umzD{;y0<%{2*-COK)LTXq}Z^h(& z$5*eP%G}%YMd|Dvh1ZUO3?b+4K+(WKF<12m(i@fMzibM^K0P$VZhQW8r{~=ljw7@u zO=J2UvWt6D?V=i`_ED*R2g3=;^(OC9`&(;Q_)6T&c*LAToDfMWlsA4hBqbE4?kwFZ z+}-a~zL?C^2!C^g_~DUhmOsB7t!n66S`F=8Sm^pTT z&K7%0w%OwQ*A8AFyU4v2ztfe^{Ne)UuF^i=3F^Z|*-=h0Eqs$LTe7z@_tV>|MS?>F zwVcM%q|_bPU)Vrcc2m-^w_38MS3$LWXzWfy@sCwQ_uZG-d(S<$OEJQ}D(UNWU-jdr zr&ZFzTDRFtzTUdE?}6gS4a1E)yl0tySn0E3i{g+oTP3u&UjW~ZE zb-2^j@Z`-`>*VG#BAgj4LK?TbY*`|WcnXZC`bU=;EjV!RPeN#LU?3| zB_w7RPP>tLK3v$aG`5b964WyVswF<cTonh8lHN{^4k2hLiogO&$81;c=v zRk&QoLpGM{8p2d~gBO(Hpe9xXStr9UGh|jO8q*vS%byM{y5s4%3<10d6vg6JcxFW> zI6#Ca1VN?}K}Y=Ae2bGSiWT8Fi7_}jQ!scwp0NW3gC=phcnRT&Hnt`-0qLx7B=8|y z>o>sth{i%tR}2MUwg!v1fzKS{oaWK&raknY(Y%T5nmsIYeyTcFz8bUZcy~;KpUk!O z$|MbU&l>v5BWbN(H`-5C8{k##<5rz5^i!U6Yg_&LOZ%nqUea^C zHO8u8%K7qxp1q`c`~f@_bv<-r~{)nn%Sys|B}}@rA~G|4M>}+R6SzmltmXTT)ki@~K!p`lCHy zw$M3?Tlo-xqWC(r|0Q8kAcieK_@Z;GTYc{VLZ^5|brS?VwQnpLo;^mdy!G&HWMh)! zd1>!wiq!TNstwIB(f%Wpp1TINgdQov1QuexzKpdDlBPN|LI%wmX6Lx4D+f>u@(TeV5cZzNgVY{uM4uRF>{DYShF%Ave=8%sroy0|$ z2@DZN{86f~je46$Q=Z5y4}^!o5U`qtVlBqSKK+wmI|=KD2xgBOm&`=1vd z638E#V(;6atQoPQTBu=<7sX)b)l2~e@rno1;BT5bP%;X=#sd_-?DW3zI_`PpEyc<& zWOifwvb3dt4e62V(JaUNVVCa?*?qck{h_nC1v~Pp@P74ecfQ1T4vc^LNI51F^B`w= zGZVYaZ&TBsGkJQ-y`VB={=?*&E1H;&YPRW>)R;)dg*&saojI=SKfh$T*tzhUal)F0 zMuqm$mdiw&S4~^(hfK!)5o09DXjnZZfFbhS`*B%_q4lj&-<$DbzCstjD(HQM`UJ%Z z&xbPV`2Huv=&t;E82cYzT?gbE4i$Y(2mInUx|K|=GpHEa3DgF~r=^ZSoRLv!#Eyw6)PZj&|LLHLQba~PB=M_!M%cO}GD&8O6{io(kK8N5u;}LM`fUEbML5tn6 zbEt2)`p&HO%IX5)*z^}clnSWFQ-k>AT2`fA7%g$)0<n9Xa-y7#MY3B-S2{qm&D`nUsTPpfT@zbWpGtGu3(-VBP;qOw$#lyrTVAM3*x!nxyWWWA$u2y-Gj(ZI&pU^jgFa7;#%$Pg2O#xqlFH^&oghAQ4a#P_ z51F>Uk85J3j;2yC9yqM^=C}^6dtjDi=Cg~RrD9sx-wK(-9pP9^>1nl>0h98n4Jc^mHV7O26^}YI7RJQO@84%q!KE{@bZ`?y;R=DYln7L4k6#dFpenq0`Fq=uBW+K>02JL!2p?QACUJ&LZ;Fh# z9apz+8{H=crywkpx4H!k?S}A(U-!E~$=$Nq`@4KvS^3m~ksTY`qt8G1n4jI-ln{Sm z(}o{*QW|{biI#PzzU3;ox{%wA&KQNILX`qv1c=U~_JGon%VaE-=Jt5$P8nuB)kzy|+ms+Ts3rD+(UUpObLH{^5e#1jwmE#w z!B4c!P&09vHP~5qq~2IO&k3WN&sS(f!+2%hY3-8^m`h}Oc?;TVW*_S>HqOt>kT4v! z`$S$)DX+2d&Pm68N!jyd#crJ#nzPDS`GCupx~6LrTT;abI(C$|_rG6C9o74cE28cu zTHUE>Y4M&=y*4(bV!g4`Ei(S(`_eSVy}-leALm2g9>V%1Y{O|)ZuN>JbZe#!=PEG@b>Xn>%o$bAdz_xYlA1 zZ(?&RO1-ZbmC%@y{ulFY{%OVejMdUo$!`OZqPxodjDkYik!RZjy6ZE+LiVYt{kMJm zJJsuKE??r&S8f-5KA>UkGpxRR*oEft4Oy(UU6`A&3MI&T4{!9&R|X9SKRub zy7RGn^I>Y7h1eU-rkC&UOCGn+?*KzfZ^zJiFP-YCMadHYY^YB605CG-a#w^kMr zJ(zpRu%PJ)|D0oj=jG;_rZ29_$l&o~BbCN|_#3lJ!arZz zDPCP0b3|9U`_$@tFatu7*D|-@2gTG&3nUNutE%Q`&N7WT0WEmu;ku-wBrP(}I`)h^ z2G+7M!xOu&YSvd=xZv(r&!kc~zT}zk6-z%w#Y?49m#A-HL8DvtTfK<^Ng<7`_)f7E ztm8eh>FpY9%dQGWIXH`d7FnjV8<0nRCer2}+1fCa?f;jELu0dkKMBHdz)}9Qu(%gQ zOz-%QCsF^1;koiOccR3lg>h!gPOrIjp;{%qJ9eiG>F`=D)%TbnuR2`z(ASCVjBYC$l4aosUq2V7QWXG#@`^Z z9c2A^G_o2L#D###lkf>2#Cq0hidefpI_tno+L07$Jgb$a2N9vrW49Iq+CrKK500tf zX$_tvD5HWrEGmKtEC*g9Q!uuU$D$ZqO0xE3)C-2W#4!f@*m!R7#+0VpS8jd%Klwt=Gp)8NdnGOhIMF~_S44s#z z7VMixz%t^zp_SO%)d z%ROeHOfck|`s0{Z)sVWzIZ(11xi8LG@ z?xsivq8LJFL%W|46KKzj%ZyIoJO-}SL^t6a8%E1|z_$i;0ztonoTorcFbOkR4}(f@ z@W|n@4Ctb1p+I4vFw`YzHgs%W$L%8oc^&mEs9tOl04Kbmxg`LlSi>o%(2fTu9UhO( z4j?wr`0;fcAiy{j3KFMMUgliy^D&;g+9{b%K9IP{E#X0Bqq#%#-Y}3GRgY@D-jtMa z!nFD36!7;&kq<9Do~#QVSdft~fXK)&PdbaP0X32^;tWPw4-|5SnH1fikkINt5k3Ox zCDY}U<@8vi+0b0t8pl)v=O&9($792aOU6GC)F*YPS|cwa_&O;*wMw;ocuZzed^%*q zq4k8G%~l-6Qweq%qEbOltz;sUXhu(jiDkgNL(!t>#!77F1#6r%1Bx#l;lv#CPzW&B zO7vb>X6)Upe&c?a%pea?N+C{J1jm%`K^|5(^y_#>vk|QbsDOvl8drtRJHyQ@||NGz!2o36w z1MUiO(%IvnHv^Oay1*X`5utKgBcU`NEYZqV0BUI?1Y$g}#%0C=dD`;EvRFHi;Q(C{ z7b`;1;t)3EKB_>A?QL?C4V2d;4#^^Nl7)U#L=(sjnjR@^4R``~s{v4vQcZziXl|qD zUsz+TwNkasjk|(nDTS*+h-()1eO8_b&~P z(B{Zz`bsM0HH45vFbA`GAvM5_5qV_0N&5Tdp45n6H$B`;R zG(MF@=S?nNbOv4x<`!Gl8w@MI2-zewnHtz&2xR|?CT)(Vejur5h}(K2WCLvIRyh-6P3BrgJu1hyE(J@0nK=D zwQ2}uz^@OV3S={(;5nidPTOz}jf5eJ;xm&O%K*U9=(K9)z#clAdj&lk_V#oh=ubpK zga7~I;N`$CT0K;Zi<_$o|3IKUjMNyYn}Pa~Wix@kJzyBt?MHbjQ*&jkIh3c)ov1k|v3I$io zCx^)90c5xZkVqe5IY?eX#>wNrVkORi>ptPKp}Ra?quWxCL_^5So$YDF7e>A3Ax(}B zjnBBN#0Lqyh-4Cg>3XVBf{D#>$>@I$8HI3HUk?}>tb8yQ-W;H1df(C!*UAK@#yuGr z)AYB}{?n&G4_-hq5$=XmM=SRG$%w)bO`$}QpUX3|Oq|~^pAbFq8~Xh5Em}}S0-Wvs z7ccwmGXx*#_Osq3fy|=EIlUS15VBDaH`@c_MxEP$N}!${7t9dR8_#NvLsAO>j}nKS z!F*v*#W$d^lpG$WiW=l*BMv5>a3p(>!>iyEsPdl^UyKo?p{8(9gCAaCo{x-S=8R@fvRHGCXW8NVC>g@7S87>Ti#H{uNVi73*1c-S7c-}}dWcGHtN0!v z8F4utWL0eX*gtjQM|xZ714LENSkjz69ccZihsoHPmm#Zd%Ypj^@y4(sreV08=-GO) z;(+EMk=AP3*0?zdq+y!CqF|vR*pM6Kaj;uRP`}>{dnaSZhqz?A3?!;J1_Fg4;y`p^ zf-ngSkiuCOz)?P6{QxjXnBd3}h#e?K38exFCBC(T~e3TS|lz+HRJd%!(Jtxy@iY0CfWcP}ERUyqx)1pNju=*a*+ zQ*SIt;ZjJjSUubxBAB?l%iJR~1?1aVT#f`)2chi(fC@?k0u;rb?@AG6#eU$3%w>vU zTu!>wV*q7C0f~V0g5%LP!yd`t>$ePoU5?4_1$5!buF|i!D8np5D7%n#@+ckO&>YNT zr%H3=L_aybFPQB_&kwPKvD!Cf~~_M4}c6cFr5R1oP>Ie@an+f zLBbK_NFo43sPP0J4fg{PO$b*Ql!`CIGEVW*Fw?>%wj9{jj8qy7d@Kc6HUlI8craS7 z?b9%Zf!Hms@PH+CL&O#A@i(Xn0iZxLd;!P=RL&j2uix}q6`%-&^|CMo4iTsUApzKO zR)I0YLSTN-q6+~UPG1a^i$3}L5Q1m@CpGcc%D`j*b;Gyt2s;S=;-Tpi&2gAobQ_R4 zkSH7re_$V26Rm1FvehM!tJE4(5W4|AiUCw-)tW@xrXrn%zndXAirywWGZf@YEsIWA zvDt7J4(EctBtRaB{Td4_Rin&C0F`EkfsgU67zt}rCdj1w7v;{kHN^3*`Fe#F=#+DX zHKc93$B=y_^#P0UZV#X0NNok(cWsAn>PO#O|6(N9h5V>uCn)JB^pZr*=p6#iBus{3 zV#WLb!g)MEN=Xq#-9REl^k56{yrSpO96*=qWa1seFjyZmjbf#FpkT4_Kw?MefG$92 zyihL!tqfiSm7K`nr*n2PU=0f?PH5>EdjW$nq>r5KtuP7`B?pV8jy-|*L$i#1K*piU z5$H^iiUgosCmzEf1=goxTv!fJ74)Z6VZ*7*3457^mK{d+pSQ9xY9H~UO{9_Q)VO0`gh3e+E1XS0>K41NwD1KAd>(KbL~ zgfd)ed4yID20zWHfZjO3Vz%-a>`h?!+?KK8j1w?WB!T>-I}WuVI!d+X0tc7I5w}9) zM^J!35-lq_{)Q9o|I_%#6`|s27?*ma!E;xdOO#xd9=!)>da(9J2}orgl%LA2I3eb6Ded!rO9BYb;V}4dHnP?314b50xJ`afz1Q9LR z%~#FOU&O!cg@jV+7PV>jPwzL{keU zn#sYMs$)+fpa9C`gzu(N&{T7$5fK5%E?n)MyPDAqL?mKd={keEPF(O%!N6`b;}vfd zL52<}QVjQrt>?)1|3f%4a0C1f$PtOf2y!@y)IS*?kR$qLmN^)oc!5#@Ey!F6R)s^4 zu#OyZ<*0R>Pl%(xum|A`rzO<~*i9H>2S{*me}FyCI>YU@!x)s{pIRgkbG7DazyTWt z%HI|YqG;P#*>V-=aF_|O^rh;-93$cZNg7=JsmNWg0!nK(eZbOV4oOyxAPWW@q78HD zA!C6>qx76Qp5{0jG=au9ur5*}=oqaS@-?Ndt7|3QY`cP24Q{};toEutb6Mf?-Kpg{ z_d4w*YfTb|)ywrivp3es-w#?wbYRxdQVwxuQOhF(RA-o7OYn^|80lfy2M6()pjs~y z$CgnH^Fg4Y=(C~&9JCrqu-%c7Ln`6-33wuc|r6Nm!cqEdmGxLTxO$6Ca**4lDHZ?7)Xh; zRS`{)ps@5F8s|(PCIO6m589}3D!Bg{zletU^G+)2yz`RFK>ikiOmtom+>7EFvc>K} z*Zn#GQc*%Z$o330jD#6M7StPD=2;ko4EJPCnEFpb27CcJh7f)aPSGh2odEf$BN>8A zM@P`PSs?jgkbJ}us)=TTNc;r@3#ivK>(z0uqk=csW=p4QCP0q(oV5E2aZ9JFwTYE%(QhA{<9o2TkD z@d;og!9U)Be>`9;=6P~MqQ38yL0hr5ic%k!*Gm+Z+%_7RDxlx%G4nBvnbS76kD4fY zDD5i2cjKeW5ua(0r*B#z0vdZ)NF*?HNXq9F`~KLR6koPdCz~%!eNBQazy4)3dq(n0fYB8{ZwmxfD_P2EP0dSP@l9r*;wFlGC2)-Ali`}`0|kQ4Y&bR zV@(!>#TGzNZ;f$FK%$HcRQ-~o0YEYKAY=#KHWfow(>BxOe2BI!14&J%c#~p%fj-Y7 zVTEJGK*)sF3JER1yMehO2$;qMZpreWYdQ^5i1#3n;)h;tAwUtbILtU_vOy1>UQ8%j z28@oozSGnPR3e4UA6!CK!9uyNX(9sxLjcGnvdmBz8RS5qm-}@f5RGP#_P{%GSRDr? zp}51$DI z^FauZ2Z+Mx!SQ%7)pIb=wobF(%9^5G%L~eN?tCU5k|>y}o;dbKOafOWkJkZK#=kVh zj8H+|o+13Q>6lUC_9*9gx~6u~F~Pf4IxYL}5RS&MO7)Av@7|r|dZ4A{*vFyEJgvqj zh>lH1bxj<>m2 z*uz%{au3XZ05R3tZ4`3?HmGk7?6lbk5k$xs&>sP>jQcIYu16D4=LLf(Og*|M6sO}% zDKHAe*MZx^ZWjY0hE*ojX(9qZ>j^5$%z5139DS)GO1@`G4RTt5Vg*-vWYVDKg@q>u zHxBbpwylRhfhY%!MUlJ)Z~zj{3;b_dw2&tbScy7TL^~eQ6qi^yL*<~NY5>@!!3Tvn zS1|rcAj0dh}h7Crt zG|T|N6V4zyVNVJVM|e+wOH}||h42Y?a_YEu0$vLw)&-I_6TpghK8NNQERPpuiNlB=iT8pwM;|K>H3TIYj_$8yGUIB!@&kHg)jC3_P% zn?t8rWgwm4X9xgfWQ-#+^N@hqKvEg}bq5hK$3D)XFAn$NLL2&a2O3;-BjQjvfUN5L*aV`nAdC|1$zTzW2gwQ4GPU46@pvF8 zYea9hFiGev;CduXHlAq9XEb^q#%R|V#st#xt`1lWXW*Y&?t&3w8kVYworD)J-|VOk z7ni2S?(gdqs4>M@$E_hR$**J7jty)wYSe0`sbRw31+aqh0suPZw2L3hxlmyW3KZp@ z0;8ii^f`4IU~hZOptzdROF~&K)=~b{+R*0MH}Jqkv&IJlyxW3xY9SWVsJ#QFy4d7U>4*c7clyVG)A5q>&JikZ$R2DUnX;Mvz8&vAEOU z-uvu*_IuB{@4cV%$NRa9&s@xU#u{Th-zP@h&EBm5L~2T^N&pH90HA<>z}-CX7{JEF z#KOeD#=^qF!NJDGCndng!^5W}xlc$+OGQsdOGQJ&z{1PMz{Jf=L&Gk{!ObrqEG$gV zCLtp(D9tM*Eck~A3JwkqJ{~>=0Re>|BMqbA|Lf0P2SALC;*EukhQb7(5~H9IquhN3 z=s`X)Q2zP=fB&GMqM>78VqxRp;(;&J5&@_vXlSVDXc!pi=-}Id;Bx?-7=wgSKmqf< zwiOl=lvFSzE*qQqQDrBY&e#!)khOa#4lelv3QDSntZeKYoWdfaV&W2#kDn+iDXXZe z>FVhl7#bOy*x1_HJ2*Nydw6G`|SMU^6L7JTqpqA z-^2pH|0dYK$wdsxg^G@jhK}_|E)-NB@IWI*$6yq|BvH`DvVz`c5)8p6eH52n*@?p} zq;o`O?LLM}&LX_}@c55te@XVgCs^qJC&~Upuz$)m2jHWjfSrd%49EeoA=Al}1=euf z`=rFrP$O}HrvchUF`)^Xhe(^>dNlS=h%);stT4e|}M5|5*=37Uo(kJczxI6oryz98!ckZVkSy zG?z@8l7(G2R->2ZzZI#)#0}M8uGOeZH3(*8iVV&&4IlYLbMKdqMMSi=uPQ{KW5*_JiY^bE54(uWU6-5T-zFJn!r?}Wzwt+4`Igbcx4}X(%!P&DE6iKyE{!cl~ z?tth!U?amf8QE!Qam`VZRSxTeooGs{-vO2-6}P05D5Khnq`?1S2g=ChAyRew9c+)x z>kjyw3YYe|16WSKwx8oR-2r17ih!R1JL)I+OByXB5NqjJq}hsq*dHv3j-o-I;i-{- zxaWw{kk=!QYo^5*th4s1E}1e5lURx4aw{3~2X!F!w9tL?dQ_twdjNi1(aAI?0T63T zj(9qd98#cz1Nt}6?dMPytbt9G;pR06oqZ6NZi!(&leKYq(2sGqTk~? zD~t4>)_B`n?GgR6{rhyUkUV}LWmb%H0ywO4(S39KYE|o7DYCFDpI<#EtZR+mHVd7x zs2YD*-+1cwB!c5nMe+&n7W%dfVIHb|9;vo`D4dH+^B5x|uWZ*}k3(>z;L2Xf3&obO z!S0^Byse!CTB0yYiJ~2AE7{k%*WL!nViBD!ja0P3!VT!Xc`0_m%rcF=?$|_gzWLt{ z&c}aPHN@;o`kccD*!A^dII-Q*7$a8WBE7bPMSqqD-2pvysrK(7CC`66?{<+Mr2qb| zNkrmyJ$Qi?bA937=UQGbb{@7LvKx`|7X$*#)}L*>{YH+_#)EmajmCWAr}lq0zvDS5 zTbZ0?A$eL1*rR7zQY0>5QPKskr0W^9an&?8REI!Z;||JQA-cYrNh)|)ixG#FZ+qP( z*Mh|gOI_TE=NFw#yx{X@x%KB7fs~dhdOE=o-GPTod{3iWrlM?&-Y7=Q8Ly^lL%qm~ z--gE1DdFaBL<{<55m0eSZX1v%Jd2-Q+=Kr(cr{9t6W*&wyCB9K7I`jBqhEilm_D{c zGJrAEB3Z>{GRSV8_ff1A5+QEgcrM=S5h73RX~4b262fz4yuVk$yFQ_6{1o?10Q+FE zt5rkcufvW3bews!daB=4j~)vRiR3(Id0#&`TUzYLCNUU2iBh0wWqw&auPNGf(tC{t zEi6xOj^k&6ez1OQW3^&yyRj1N@hq)}{N-inp%RhV0My0i{0A+WH)L2e)QEQRosvVxSiO#!$f!GU-3H3$TBN1MJ0Ay%lbsjoz1p$6fTt_K?ayNK&>ehU1{IWNh5q z26RkZh|Hbq{jH*nT=(Nx95>OnqfTpQ&^PRi{6h=o8K_9LjojAKL?&uw6d(t=)f0BU z`H5sIvKH69+RZGC{n8Gb;+Vl=?4@I6b8TNz&G1-G)2uv)=oa5mitDH{9}>;>2JP(V zE5mEn^XHd{1+Qj4cRbR=ArIWd6%$7%@*CzCA6AkF+y9cWUOLrppFnr-@v>!hBA1u7 zed*m4`%HneyYgFxq(Kxws;&4xc98wscja#Y7j-X1{$u{(z zbX_NIbIL)lIK|;oxtZBxCkRi^*Y`96jDEB+xLLLd@+8{&!mUcnhT~--T#tqzKDa}~ zR-yV4O3JPTrdg=qy7*ro9L2jmpyEg4u!3m8H^} z`MW~%eQ4iE_5^A^u5%_c`biN6Nze+SFf*tA0BMi3O!MsXiR*ie!5fO4^cNMR=|-EtJOj7(`zzrHnf zZ2^a|u^!hx)G9*$$J}Bk7FMjvN_5tgI^q4DrpWW-j+58T_z+g#Z+ZRCpLH)sD?bfZ z=?5n#$G;f{;06kk*CR#R0B)p`De_R$$%84ug{g;^9VI1)6rr;g z%-q*XQD7ISysh2{Ymt)#TqSw{-Fmi*nbRD9l#ArkEc8B7NZvC2pBvv}Zg#FlQR*VK zw|edXnfs@tewDD1CwD+wIKXZqpmCZ_e=;R^n5~?74>sL*2L$2*W>EDS-B*`#+cmI@ z(VTrE*ofmDaF{KBuZJT4Hh&oz01^s>Yu3!eM!s5H%w}PM3o6XH_72E=3p=b-p4*3Q zZ_(devZFrLS))wzH$Syd<5cTnM488*Aa;Bhkq;3+iN@O| ztuy0x*?R*<1yXXEa(fs_vB6CMxZ&Law+pc$I%}zlXv|!ybs5UF)Zofrv!Iu&Lo82B zJR}THDHDSLkCa;(O+J)64!%A04xNXV+ zH6~whsUkFjl|k6^1+sl}XeKj#em#|74W{tdLDB4mDscecJ)WnP!}>2)HE&*lyQoJk zGi1N&muM!uXm#dw8ch>?T$%?wTT=PcBB*gov6$yV1R)wC$}W6+17+6wjgP&yvmr+w zjk;J7JE6WMXODHqO1-?RTxLHGC4Mtks8cep;(hrHdqlT$tzwihL4&r1M3W06T7-8m z01(u8>2JNXlfij(JGI%O^+{)Z4aZx}=;QmqTvXghn~Me8v+{YZFZENxzux23`qVW% zrYVjWB-fpE)xjRAEWVf{i^%1colKDU@7s3!nZCr3JyF zG8-aLxpR?sb^r4sXTK*0FOyDI+3=4wyU6X&0sy@hbg7vG zA(lVlCo?^;77$9%)d^*B5&wrA3iH)c z&{)D}UBN;@KWx^b*q$^JzvHg>QQyOWBoEc<@1AtWJ{RfU)p+%aV~r25e_XwAhe~mh zeLE@RM<_++!Uqh^82FVJ0FXurGA4lZ)O|M8Zj&4=be@4c<{0=8%uO(8G-aX*&R?mR;N6sAg5rK(c(~h zjG1M5N>)>5@hU)}oBHP?UfJkjIjY|`5HyXNB&-Nb)MeHs(YTL{{mdIWFIz}3v4B|q zdz{9eX*e56s*uDCC#IxFs#h7T1e6HeuuCmW(&Jo<`<{;LT7{`RbA`0QNporIb;h2z zg6v!KOur0(51s5!2cz%#9S*%%bfgO0DxoXlT)^vJbJS5e$cu3nK#$}?8PJ!J!YyNa z?db$Tykl&%6LaxbZB2uI^xn6gzo3Db;jdUi<%t$d&5U;Dc9)znHx~L>l2*?n^oWY% zf`OZkjLaUh>8yN9Ss5M~ zs}^p6Rvf)ph?ab;A2ottsH@{~uQ&Mwe}@+~s7Xr5l(3Ve1*6Jw@Sw|HE7{j!{?I;J z@QKhm!|@68?%RUn^6BO7RJ#%`W!g@=PvxosMP@aT%{Y+nKCfB;ci<<+qc)N;ohQEg z`H_9L+(gP=oZ-PX*uaZ>VHs_|QQ}s9sTWGitOi_piHfS`K8ZpPA;t21Z-ox{cG4tF z7w`TUU7GKSL)$c2SeVg!jCS+Nf*bwTpJjFrPndc=a`%CPUIgo~9iR+eqq0ZpI*^ z;Pq#>qJsvZ)8kvaE~a6!Hxes>Rmy@TG)0}1^X&|w*dt`T*;zYt`SGdd3xXo4FTOfS z$K7_}o|NKr0%!Z0?PGhj;yl^S(aNSy=wH5koEq!kq~K?)j*#AN1?(J?=X%N;MZ?N8 z2-eFQ8td93JsB5F|lZ(v1Ks1a*MtF&C4RkM~LDIK5({FtBp%&r{hjft-ahf)lXb}Ap()P213G>vPr|iI?|=s%6B6Gm;PFb4XL4lT zZ2rn?|57`-ms{NuZWk&q#@PSU9h*5;0SJ{qN9C+-dt>E7u;4@!>4wS667S&0LNOn@ zk+kBu4Q|VGp8J#}e zHM|eCAEHWxl4nH;y_Fa|`pUcv=g2b)mlXq~-FYUpg}H=?g9mxI8g+agRWc;n*a*$-`YKqWc`o?1?hGw%4&{nvLO97Htv;c@!1^W{ ztHOYPAVGlOm_%P-c%ZlxaC#7tD`RMQc`eA*YqI%(_r?cc{M6s9p z&xe)E8$H4V#b3dEYKItU|q#y%bN8< zi`}_jnIbI5xZ|-SFxMpS$E4UA>e^qB7|jp(;C8!@6{WHScGARrR5(ECAF?;{g$gg@ z^1azV<66b{Ubc_esKWVd-mF)`84@?UE>R{W<>6%G_QD~_1K))*)qdf`(#C^s<4hPu z=B3B3$%eo3`&zQ81(>adMD6?j7<}e;wsYHVTnW+qe$p8NO9p7ZI#}apLo&5^>*QZf zg!gY+#}2h3?{9Qa%hQC(5NhW|o)-Y|aY3m+T|0TNPRXfa z*>6}J7K<-Xv|1!l_ z6BfV{{=0~;tXz%l<9(%0V->ubn2*?3u-2JKu^U~j8@5n~8`H2twYbIdp0C+ub_r~e zVT~v&(Py=o?@$*6LU<9zt2CjeO>Nuj#8^ zJy#0L+-wH=3LPjs6+&rpj#uI`U-B5APClA8oKg_G-%dL6rIKW(3DB8r&_c!g-p8ek zXHBy>mq%JV>;9whxY~#%3Ve>+;i?SW$+NYDqK36!I zIdo`!p4Khu;iU9c14>O@QHS?|^WlBB<@SU9;Q&alc#lDHcf{Bkj~Z9=&CN{-vGWe| zSM)TW4;^#aDog%EGJYGucAX_IXYX4d?>lJ4k5i}MvlmL=7E|(zVd8&#ri$*m z0)5BhDl%XAN}1DzyR2YwkhYkDnX}VI8C5g+p*!?sUwniu()j2Oh{!d+|H$0Hbb>XL z)b7QW?+@lgT}KIpq(1RMy1qh+iu_CO^8*WF#aGu+;bpg{D$J@@OpYIkpJ6Wye9EOE z6YrJS3Vt|_Q1Dtaybx8R8F9!fytB`^1=tOY!4G3?Tp)*%IShp_`jN?l_wbDX;nRO)4(Xj$Gmub<& zXQcCEvqHFIpo3-x1L1h}{%?vhFRu3uRuZvG;^79I?~uY9g5A3f(o!~MfH>oxtC@|(EhYFxA9Lhwrkv1Ouwm;SrC&*_f%YdUa> zX1S$cjbFlIE>YaNns+uanP{lZZ_vyP3FSTU__< z(S9IfdOW&8JdwKbn@7&Dy(U2qj-KH{NVaGmn8*UC(#^c<60#(rTnK%MgO%^n-aZz! zl}CUuiQ3OS?m7xu{ZPV1q{{hCX+_U+efo29x3|ONx^akIV|B#blOzs?gnP86L8=mq z34;z214F>eAl9ZSwi$%Jq)BU0Oqbw(WK|7Zec(%_jvgIL2l|oFGMa_C-uvz)O!5>I z5h;u}ZWp3N&^rL&ximDj`8;pjx=}vj0rgj&W6ebG2Rh6EKuZunYm|;x&9hpSlEQf* zH||;x_6(mJvSr8N7OQ6ikUWadfr_KwI->diw+@c~&iV1*KfCvD-g@oz_A9oGhj+ji z{TU?OnH_DYQi)?Whm@3oGOw>z{GJn3o}h;pyaUE{Qu0tg+;i##{otT|uLa)d5YOw8 z17kPTaDiu_-A}Oq`o-Z|>?mNABuul1k)9)qkl|=1e4^)pWKH$1SnSnt5mjSKp z6S3<&*JU^uw}=)(l08d@ZE^ga%HgHHq%qB|NzCmzNXBo9%!tdx95sNHe*GD8O#BXr zp&q$8m+OsjqPqiT7U=cL=8r89alLmySK)a3PsT#nA6D9rihjpjA={a6&p;mc40RR+ zxy$>{6_CR3iz067d>rWB{x2l@3B#$x5J(G97|>0DE4Qlqv-RLG20;MpYQ~uC-iCad zw;98_92Ma=Dy(j1@uJ4M9NTAJzP<_DO>7S00$nyBcb9r|Y=~P6*k2@k5S)R8^vB2k zuzk=ef%_{{&nVe5$wwupnE~x;T)Bj$s7Xq_z(QY3`7~!vx&7<{?;n&T_%8LXA0RGT zLBB*8f&;dy=SXn}nEGX2|CH-$8Y?c5P;l@x@{-xrjPvQr&ZCZl8aU9u9mB|gb z11w$!>eRdSz)qCez~9Z0@4Frxxw(|<`tXVaoRKdML7xhEe|O&C$;%ig&(cK{Eu33N zs$$Bgf9Oce*EpOE(T&T^AoxKtC&)jdNmyL!%hDmwmTzzASLH8tR}T-(K}C%r$)-gM zYSl#&XSD=XBQ1k!vChxRVN)7^#iWk)0#xn*!#jZCI?rtr0iLjUz>bPv$wb$~E-vnX zGF6a^g6`#|W>C!bTjyO1!{~yB?#fp!spK?`lEoU7Yz#xh4keOZT-$yE}BBf^(5Bw+B+aa7q;Gx&nh{3&tci-T|1 zuj$v-M0mQn?7V}(k&p>8F@pFfjz=!_>%tCxNxr=ULSl|`kYwwO@J5{( zDg8(7AxL4EW9HRy3)p!!2&Vv*3&h_vQoq)I#T+R|aG-qMet(yFW=n2eLypkP>n4Mz zjb3LNq3_*3hlPCQCU-b{2T=X9uY~`N1e^~0nA<_%vTYlQPJIW!b2?|JYGiq*JOkBr zl8#KiVms`lN5f1GAqA!>=*6Wu9vp@g4511mYh2-@5wbj&!Jc=3vTn@Hg~6vYrTgz+ zr`t72wdfG*5Uaw`73+o5pgP1#?8KBNPGq7S4O!T4bNkkHh&8~Foh8*HPBUHaQ~Ca5 zjgBG}(1iym8II>L%M`z&vf<$u$O3#r+JC)6TGvfNjmGeO!|M4nx40n6q`Tj$%$^FnfyLR!m`N3a)U||oN>#km-za5Q zm}yO!NpHQoZ*;rok}@N2i>HmC$P?mQmyuT@#RDampC!yg>ZkT!@G@IUrf4tT0mnx< zM_GhApBsL)Q>f?~HB>cBBzg|mzBO48J9IS>NCqOP1>JKtU6lgXno6WTv{u$PM+)X1 zm%=G5gS(lTXHtO-c<)Rt^`c}T`+OSI4eDDrL%?kZ$JG5&P64CP-@aK|Sap&WY-}7I zuJ)bo8Xq6uTD!6i3FC-X*2ha0?~fXh*g5RLf+%{pyZ9%4x|irv)c1m+J%h`SDcne; zd9dr%*VuI^uJ7~4eRvUcO-6?v_p(Hr-d4=yNiq{n*F3Ftq&U9VHd|aelC}`-^W<3o z4;@+RwE>*fvKdiliNk=uLgOyKRX!uMZqK)pmLy}G#fC)YIl5do?}(niM_1=r+#feF zElFqh9^hU)A~XIXxlZFCjN;CtHV#n>l#~c*4k1@%np4oXew2~IkSG^dqW{h5y>C0Q zh)8QZ4hxk=IUOlG_NlAf>xAgrAumr9)w2NhGozZm#H15_`)DC*tI*(Q)D$bkOP`9I zy(MK{C(k8L8q`(B(ixjNm#d($?aG%1S|F8S1h7VMLCtz7*K24fDodZVg;5hnyiTI% zg%W2*NeVs1Cr&>h6we}XSyY;Mb|O0?mc0G_i;`MG3b$&{(p-e_v{Y`l;n!u_jlIwv!YLp;zwERQ)v z7UfdBpu8qJ#@CXZxF0lwKAJ86lY*;A=NUG4`u3;A%Hbh^%9K4h);+k@m+VJ!`_*t zwRO#9PNMhcd5iqY1fG0S=j>&8TTMhkvm%P=t|AjggtDxy(j3a}j%O2(i6W;qJbkz| zQL5t`^ga07JC+$ibQP`i2NKLaRiQYn!NSFf(G_+@njQqDr6==(rTt@7q}+nCN3_Z! znV((acd6R)3e?Dka$kO{=H?^vO7QKSW;wEv4hxIh(fZkbB7T{3d*gOX!j5MAU*WcV zMxq3q`wv$uE_m;N-{|Gh!MO0PH7<20UN%UaQr@R8&wyRuVw0OC#jIs@D=2O2*OyYI zF%LdQa!BJx!-fg$cdUOQi6~OH9P<|QIn3h{nJ>%-Y!a@tFmKDgi`B(0nl|{dM%hMn z^lmaUobEZBtVzoh?KTCyUqx>shd2}}k`+daxCt_!dwW@LtX6NXMCDL7rF)1hN3w8~ zni-opeQUC=Q8OEn?&u8Zsdnt8%rxo$}<*nl4 zehq2OocWAH_Q|o6Oq=I(Yw8Wfwf5tUn^!oiExmfhhaFKjOcHbFK3scxp!uM3$1B!^ z7Jm(w;aA{_i zBG2Pgnx6h{Vrsst7Vks5LPUxvnUSfKrw!Metd*jr>r&rW+vPGf>L=tbt2JanNjPIL zz|3A#PdPKa6~udwC-w7)+p=BBqAni(LwNyHj3fo+?VRc_ckIR^YS`nAu z@ne?XV^^L~*+&8)QH#$cq7QpXNT+$Z%Y`@11&x`=>j`e=lOpXp7$d%?7hajhWn5<6 z>xFNg$-s2rhuswgJ?M3FHQ~}9ZS3Ma(E2Ir_5jhysN8k&tupgns@}NIOXkZx5b3xD z&fe)b75R{lC~*@Hs~Wu-Rr{akNCR%#MssvUyd^9X$^iuyJ3aRY8mi>_l9o!vLA2E%XdX(d$FnvvhXB{I+q7A{v!>TSQV?U}v3>yppXQrv zXm_P}bOyEJ9rsq{J|O?4Db+4JOQH_mORlyqwM;J!%aPt({Ep4bN!`IVLg= z8xm4l^e*nt$q&-+AEDgy9Ne)v_L}}wIBTp}s9~RsW;uV|0g57k=l^6*#{U#852Vz8N)L#k1?>;%W4_za z^7h}l+VXTh(O^m@-EZsAi2Xd&3=9-SfR*E=5Zs%+2aO0CH2GYslT=^QNLi(8Ev(E}oRkx1-e;|H{e}+3RytGf zIvxmY%bBbP-3L4apWXozJ9ogSq9>i`jUj^By)0g8p&BESVPG*VQcv&Fc^G*VeAp{^^=k|`cV-Xi`BEkHzG!?H5rt0V;TDEl=u<{ zVwm)g4LlNsW8PTIUq7WPFDqWG-5ke>Ekb8-RklFZdLk)7|2Ola*6L~AoCZCDbDw+0 zp({tK`xA7D-*>LJqh3i_rV6*w2IPmlYGBi6fzaT`b)p@W=X70rx0Ao~zuuo1@^Gh& zNA0+h59UEmB9D6)lW~iiJN!%8MuHs|WZnD zx9(%8b2C%o@jG1#H0B~&nO=6{%^;#_SAPhR*f%ur&>eq6l+?Z%g@>*7h1UjReN7%J zG!cgSv5F)!l*D!ytZ;AC3;`ZzsU$=_?`2--=O=k?h)rW489Iwg#!-(J~feKLQc8xM_cA$h56GsNOA z_D&j7@#DG6w0gnLG^Ev1#%zN`U?v?uA)14Mz>xrJ?cgKqo9Qk)v&U>DwZPS$$bhp+ z?M8+`!?7*rh=WT|9F}gU7BuX%g+{LQgYw@>O;q66W<|>J5}BI4yd4P|Bd#XBTI4RhwvuV9@wdgXlQ~Od`9l11mc#xI)Betn}n;}+weKMNB74dk?D=?t@ z+GNg{k~d!d^hqgZmtjW1bhQ^AA+2w(`0xEk-A7mXh z)cWu;;Xz92#y!;AkMnI0DA<;x0~I|U)GhH(L#Dg6j%p+8t>svpg)pQHZ@M#DFA;@k zt{mu@cp{|8DUGK+PJ-00vC=ujw-bWphy1oeAS=!9@f^>LD`vFg;0(x_(^uCa>FyFuaV_=sht@vwC`^^e5!+ z>kzS?d7lrCqDN7~hfGY@314v2l#cysE^WLgBs3mt>N=v_bjDyq_vC)xH$jSxdC8a@ zc2}F2P-@inUY*B^;%6TOMp?SR2oDbszI50)W98fG@8c;jbc7m+GYYo)ZYG0=E{)wp zDk2Z8KdJS;NuUNV-jq4|O`S{IxTnmc`L&Fa zqShSNOr8dn&HhgDm`De?E*NKL%Y?LI{^hp86gNUL_4NbvV#?6OJ}l-;XUi9zkbF}F z*JN~z^r>-c%R!77{xfWuH&C}G9slgy$&SJqnKwtZUH5PJN^uvOqWgAJG1_m=vnfn24Rrn$~k&oT>@ z3ylX~j0k=p!FPy;Y95n+43PV}hD>0v2?C+La0_a|<5<2e=bhmO%RYPZX(M;LDT zL{T8Z*&T&O?*%*M+sqSwzFT*}HDN>FuTiISLYZaKo%dMT?Vln|MaK?6U>Yz$#jq4S+~ zpfnl`{x0)ISN`Lpb~7HnojgmRXUmrYUqqHAWktL!I}gIz8_;ory}1$^IL`pQ?--yZu-APv?LghE1fPaj&7L#`c5Opx zXaqVa89ZsIOk!TUx$%hX%Pt#6FLfKA;=>_6gVfSi)Gmi;PQ5P;r8E4ArzWV3rk_OR zY8`$m*5rw9p#6#Vz-)}qD++LW2Xn(C%CIeSwtyNKpz|KbH1GOP&Xq^;mf5_BUu5yA ztH<#`-yxo>;t>BvzCrd-WpOl}cwWVPJbNWRHZtaQfUwI7p1l)VhKxyH>lBBDY)ZRz;5sO`jw^(u$KQk$~)? z4B}ut_1DXIIL_;}$hgOI$XH84#(g4hcT-x*k5+L3GnxGyEFdyOerPhWw?B8XB*D-e zu`@fDYuk5mmJ8yP_QJdaN+;#h)9RoXN@0XeqTQxo3F}L@+ z91%y&h_ZF>Wl%NDnf^(^f@Pj>%pqq1KgLblt8Y^UXzWPDFI->P#;X$vdLWpib9X0f z99(p~|PO=wA+jWdq*?RZz-PF1let7|7$WMg>b~IMdLED&S`bMv^HG0mjF2D&r z)-NRXi>2Wfg{8vAhR1l!p3@z$$`NMx;H?#WpiDaAb@Gd*Pp%D7qA3Y4wJUst827u{#32)dg8+!~hI}=8n zO4-go2rMpHlxMrRC%qOaEiNpEwr{TrOxg;eb@q7Gl0M)!D-pi0%&s)sD@qXYTl{bc zkR;~p3iVO`z`oQUu9vZa`V6a1!|qoTm-BvsI$3{c0A8gR`6c43HCZx#BjxG<7Ra*+ z*s%|z-v>a}sLMY9k;9fzhWiO;KD;x$Ud`4FUpGjeD!ro zu=F9e{OcTl@8h!_Q%@~Sx||$~C6{xm50c?EsxEoISsiS_KubJcztZ?qaY zzzu&ZSxtiiCS$uo#t)`loIEzaMN!+7V|SJY@I26}8#UEP(~Zzc3Y~snYF(VgyZF6% zc&k^ENCqgIV@FG+qim*vMU*M!V0s!8{}?K|Mb4%&0Lv#YH^A&E@e(3OpQgaY;|VY9 z?Aq4!1!?#BWXBClu@8_A%XM*vm3TiIgMCr}-mJx|+R>{zAd*(LgJx7$ubt%aB6T+QN|sb)?CQbO~a8S|55hGHM~-uW-o}UA+A1*E?k7`76+$iWljf-wc+^^oB=th%luWLK<2riXX5_*0DY_1}RRkLrMX`xuL_U~-rylWhpg`T(+sw@A^J31& zXo1>CSk!(jD5D-Dv{8Z_HmL$EI^1s;DW54I9ML}gPv{@zO|fHr{ai+Z4`wzxM}gXS zvHFW~p@jRr?wvE$2@|yzlVxtaWuHx@#+;?}tOe|MuK9k5q_r9t1}`jpjT5hb^UYw+=)f)Iz%7kZ28*l$oRkJM zR_2pO&!VV!bcCxXa~l#rmieefSQ|yncf7dYN7;+@V)}y#&(C9?whGy7{7@;eI^Xb0 zot|{r$8O?ij)3LyLWYYg9N7GP6gikz+tL&X@uDkWEr7gC>Up9g9C@RbEcIsin;#`s z~m8m@6p`{p(n@8cp_b2nMuUF=fvsNlJEvy;uTxJ3MTF{znn!BSvS>Zs4~NS zbK`~H=)F|Sgw6%?S0JPUi}G{q{7OE0mh3#1#-ve+vwHlf{GMptL_)o|J>6^Lrm=Fl zdgiH8wqb7Zh0`lf|o-+3mr9?G}~!5>#+b>8q3}T2;-W86&Y~A@~_Ga(4)fsS79RB z-yAK#sCX{)L~L|2CBL6Asl%TNI30QYSn}TIrFziJ&nojdHSPAGPZn0?^qSkH2vTZ+ zbx}>XuWHDyjUb85A8ik%54I0_^#L{qnQA}Ze5EI%%fM|%WZnU9vrD1{p+3*P@81EH zzn8DE=3vW-U_4x|O89RV;o!v@Y*p@L5{9A!Of}Msg%WDlo&E(I`d)`))liC__y;-SXV>)<@u3q=EVZoyEqyfxHouk2L#ibR3J{k#Nf=UPX*_) zAcuc%rhNXdG#n5QGsHnZ7`6}c2}s0nz4UnH3=ECGK{#%_vAckE5SAGt{a`CPAS>1X zWaR;v-BI~_(nZ zudetIICsEDP*xkK_TTrwikNmhFbBtGC-ZL?Tu8EBSeNGd9;`p-!7Uh?-zx+oU1@#W z1+TNgcQbDj>4s^O!2mBH`;Wd)zWS8;uQGuG{$1LWzm&w%P9*nJ=M54GJJ*ACsUM>u z!`bEj@MWjWBE{E?1OlDg5r||Y2H&Za=3b!CKl&{8=N}A}{S8pi_M`Y$pqnIHjqv8` z4)~!1>ry>NkGUcRQ&RqLMH9Q%c6f<$R(uDXo>*LxwtwIIJGB4rpaiOmE(8lw_HdP={lAs+ z{C`E}$fcUJx8$Y5U+Q_DfFv2AiEg_`|N39i0M;Pt7){(~YiYYkSa^;Am zpR@;bK3Lyr2j`ERc$wsduzwjQb&^VdI{ilT2JCdz+nD@yqyi}5pW#+{{J&8$0qNDxI-spIzkZpP~nf|P&bCX{0HMsVeHuK~ljp{~Ep+cMU;=^MdD<{5XxC5!n zI$x^C%Y>mWELwx4hOGN(K0i9TN$007DMn~rOhSmw7P=i=M5emmu7p#m()`v(V?jQu z;;x-<&YxfjWVNlGR1oMdHP5ETD@uH{ih@S(yAmrkom5~&UX=IT=`^0HDP+aH)w?QD z96{jV#P5=H?rmUb-Otm+sp>%*ImE9WO;m{2OmhP5r`!dYU?gfs&W7Fw^iEY18@_ok zF_-?aJD`-f9Qy@L#Y1-my3L9;tB-;(N=ondG>N|{o<`3Ny-C_gVB&NM$Nc@ihe2=|iy z#h9*ANAJ1T=r}hQAKIiFQ`-m;xIGu67Ur57YO5sRpP>P0k4tM7{UV2&&Hpsk_B~G) zZvvF745B`Xu`dDUeFbLtvCbN**|OrJ)7xrwN#@CzJL&}65a3neov_3_eBwc ztH4?E*@tQW*WTG}V^G1`mhUT93DPMNioIwdm%3gua{3L&qREA(kL{!A+kY%_YRbqeIoGxE@|_8COIdPUD8_v; zA6;@$?9BgL{aTr7klC6#>=}E zu{FT-&PJ7~0S*&*xY*3_Dl3$qu)#{bxDUn?&jX)pX|uknG)veVpg%5ulrWLqos+xRAidJhW6eFK=pSHSN6bOqG=Fo~-@Z%zS>~NiI##$=d?~B*F%5DVXwn@sS0! zlaIg-^!`N*r7lY&QFr4vj_IC?=D7+0yo$0-Z`n zissQjrizjXe^h#iLeEkvh|&q1jt2|#iP-Q@{tozM8?k33(}j`nUDc*jM}dJRELeg5 zYpX}ETZGqOi8*0c-G%>4`1JJ>m!tjZg*X)DrLpJ=2XP&?wZAQXx<$j7+o2a%tASp< zdgk7CWo@vUTGWP+P~Fm|mL*zLLHSFrC@ceWzAn*D?#R?9m8~;}%jn#M5Bj}5E>4G+ zQvNUQ&N?c}fBW}CNJuD1=Kw>OAl-;`cZYNhogz|#Fu+g>(nxp1kOE3~cc*lNNO&K= z-*bMybIx7s-uvfoUDukmWai0FJkMwE{ob#gg+*2Y8;*1E^YgTK zEYV-PoU2fg^(K`fK763^BFRZ;>ASZb4Z<@ETuTbIxe&CHdq!JrSmY}(|m>VXpMD_A3pu#6u4cw>7g?bRIn zu|<%R?m*I@JRO@Z_>*R=36y;EiMh*n~vd7b?;EJK{QF*hSlcR!t5`KSz2pk(}l9RRen2vPsMVj9z zTIA0lCyvrXkB0aozY^1W6i674oC?U?tE!JN2;P&=f_iGzyeqT0Aka))pmNKwmRXCo zfbdps>uSDj*$~kdY=P9Lgr$31IoSA7mS;4%cf4`^JQ@rytNZ%;9GPqQD2HOG=;!M? z9HM0iVq&eazD03%Rqr>*Mc<8&pA=jKu78n`<_ZJV04<6=X1trHH+S6@HPSIT%uzC_VE9yoviJ&g{=6y-)!VN_<> zIPlIF074R&skdtk)CpcDZ8x_vAqIhCY%5?!fC#}LQn?0I|LfrZj_Mwxbh zcaF$sLMbhG?!m!0nf!LHP(N9!*v%O1tAJ~%hVdfd;=S!A&Ge-ngOXnCrUPZxmI?CW3=kS^QOF*th4u zf-HEHUECduao69eel9|i+t>!%P>i=l(EISRHnTpdowGX=(P&Gp+qC@+n#Pzx<-^sD zZv@A<9X^vtP?)My3`?e(x0_cK2;9bFpaQH)5+`c)SsKr`s<$zRCC#qns4abA-5B;Y7C%C+CFN5|H=m za&n9Xb|~PyzZB={5g1WJ%3L3^R@VF`#s=%}VyvmHZLCkRqn}p_rfW7o6b?=ZmZu1b zT5l#7|9Of4GI1U5N)lR6rpuf7!!P_rOQY*cogi@EO|#M3e(xf++~lSz~hfe*;eV!q%c=rKINV?O@)LxE? zhij2bhP}Cn31d%~45a*jpI$=to82KL97${BW{EP&w0g_?*T=y`=#iVkg10w2&Puxa z5)?bIOG=IJx9pB|2(Crb4s7^2cRiMkEs`oa=vl`5Q|&t&NMG*m3we90HC~68v=QGe zZ*l?$i7Se_?0r5cHB6Qse(g2Cl`dQ4m#ePQ_K%Lw1t=XO0wNo*qB6UtuLTwbp^BWf zQiW2Uv^;}_g>Z8F%9nbp-Y8`tWoSjyiapVrvRWNCeM9<<7WZU}=T)w0pENMI>SaU) zd9h6xKjLuswTd5H8RSM1wq$ti=yagzR9i_33+Q&GXtVv0>?Phss-`-??-bk}41O#*d zMTC{E%OGlA_C0U9!pgmWS=5AV&nXMOxVpimp<2}k%?YPc4y{^ZwH9uqCB3HsQW6xr zOF)9xxX3eiYve`t%evC)m{#uLJj>;PNcX2Z;+;x%#iF zgo&FxUdAPAWHB1|B%C9`Sp!ssiW=Li`)CZ299I|e$T^8Th~$Ws;|aFO?k~!` zR(O`qmGEy6VyS_Fx7o|f7cU&OIDYw#i2y0VZEV4giebFg7#WAU6EnYdv@Fe5(u-%|HwM| zlGBe4obPjG>9y)rv9w{I6U<0&aH7jzr7+F9%O8sRTFz0 zU5p}#k|DQ?h{a9$&(yER-=Kd}UFk|1{Rf4u5GCu6n(u$u2jxE{ZUjF64q*eW0sc%Q zjUdUF=70`NBS-=RaC`#as3AXoBn;%0;U`f{1ZF)3*;0&eq`3S|njvV&>jKDZ0GTFA z?T^267Wk7piQoW02?Dw@g+~B>2H4`y-lQhaKv>w}) z8QWFuVgS%L0G8!1cfsFKKagyUy+Q(o2EZ1iO@$>8Oh{k@zy5j&Y?vRXp@FA_0XtQC zeW;129?L{JGR##mm*(w!k2-w@``)x+TKya3+jjBHu%8L(?>hz4b#aIm0jI=vVx4j5 zb2a9KbC&1A=7j~9N!UFVA2oOga0@TK5^2lQ>HAf9Nq|2*4J+|0(zhFO1CYILr==! z>2;qe^|>Us3T(Y+! zR_X_QR{s?8`-~0i%8u7>Ip`P|KBDi4dy;2~z~HxCIz-HcN@FAJ?&#UyQ(;wS%pGl1=`BmloI8Kgb$`}c{l%diQ zgJ?no|2(YAutc(g5UEEcYDhqwP$nt}kgBBJoi|wZHm2x>yuNJiy48Behfg?4YH>NY zp5qh<7-a~e(20`J1cEoIBnd#Z+MOkv^Aa~+A}?d z=$t92N;|&*l^N=5%wc~tTa?o58lFRY;oJRG;@ZaAW<)f-trN0kPU7SCoaf+=uV?5e z;Gd)<{p{Y#u4Cd;z9g?c!3sah#|^m-V2;-Q%+#@yuMG0g(h=PWH?K3ig7u#r@;q=T zHx)50pd5lK*}SSVkoNbx9D+%ZaV0m^kjIP=(Oa$hcQW@@CDmUSvI0>>^9T6(Jy3cbj7M2V<-g?cC zaD%Gjv6#9QnZfw{NV_vI`8!2BjMg}_#*Fzc*pkt!tlU@FmHUnLAqlk<9(x#BI4P_j z8ygWJJ@wbi<~QiC8b0OXB3DPe25+W$h&njom=KM@OMJ2CJ)63%Tz%`vcu<5>Q8!{t zfB@}i_Ls0d)>NjWLp>uYHgmlcT8uckUY0j*LOPruJQs#cHZ%;Qh5S5%FIQg28#mE$Wa&-Rk-IJ&gg8$}DEocUqPSjX?sW0>+)Vi&2-l zDJ^^mH3Mnv8EZL+qfxdvvZApGhCn=OL2 zep<635CeRDje4pjLVH!TxJ49yO4@ujK_|E0{EbY1r&?)N*zTUusDlC(h z)egx|l}G0;nCsk%1WQqm)WwjJ(z^#r3JiI8fYkM`feT3*)njv8G*ODC?Z6-pW(HNU zNuWS*RUxMt_Dw#iDhV=?no=}y{pecPNB0{_6knonlNWP6dr)^MM$x(m6YkqU4!ybc z4Y0lGC$+pa2g|4DVH)Iiq#8mevI4zBeoqMJSIU#YHLbxoN>8eXxLHc7qWTczktlU~ zn^BZ4&*EZn_E^&sOj=Dzap*mo6P)UyVkcwoPHtdXQC}rc#CAjlN(>O;Wf#zw-P3#X zJJ5q@0!^@v@fzvXhSx!CE;e%?Z6F_0>4LHPF*`>tnem;5By)HNOR;boN+a%Jp39Py z7hPegGCf=FPfO{~t$fioFTkxygP;93&iPcqx2Iho&stsPwGlkS{Lr-@HoeoHYtP$bXuY@I%2aij0=H#@f( zfPiPs1AgMSCy(Y-9j{$yOP#?EH;Dd{#)#!PQNiOtmd^k4Q~=FpHzH0ymAdZ5rwgl{ zc{Cab_r0>K2N#ndmT$r)(l}Hpg5uI0$~0L0O8j2I3?q{_d^MQrH?u!s&zYkkc~ZKM zOb2oTEWiEB$N>%jX(^}0!T^$`3Hzc~k)sWtf5@4wOLB<+=+E2GwCmAazg=bpj zMcGRd^>CXT3ai3e8{G*(WQmec#DDoqwt%UhZcjum02M(n+8in{K$ zMaj>u7SZ+dF7T1n|5|CZY&fUPCStRr1)=cXsdFcuNqhr32^~)L7?&?Jk#eT<4INt4 zpn0^C`8kYfAx5g(#YIARkM+Y$3v+&w1=~!GeN)*Sob=H_FWs=-Cux@~h`p+c!ufRB z&oiQ$6ZVd}hQ^?>M2Hl@Ag1w;T&|I!xE`@ur0KDL!QcLW8=+QVmdNX3A|PP+d%=eE zHvs@C>kk2dO9J!H(hH#8{sja81pa^4Wz2s_0wB#Q01V9~Elil|_cT?j9wyJA*AkHy zzGZtRC4(d^H==nno>0w`r>vsmG|#_cAw^(b{k9ciXt+qedzTttf}QD{gimyvMY**1 z+REH1W!A`;bPA=~zuqwv68P@A>aNJdxQ+VfqcimfAbBzHH|VMx$WPFE=mTusjHJw; zr2K$fUG@rK?On9|p)a-lEav1`iMa!9=G-0s1|j_h9Y%gMFZvC#T=)$dQ5?C$Nd+|4 zc@MqyfA3HJXMgFfg;U_*6dwc9e}h)V@2i{%8cLf>46*nEmDx|ux9}J^w#B(nW7e;- z&!)e1L*jj%gIkL5*Uv1@Up%7j+LISQ zW*!16euGZHWB2g3^ZNiGqKyW(^SYCo1EMUMnK!JzLEKkNT{cqr-(5)(DHSe9FRU6M znn1|&zjpNf-?p|KaB#qD&@3{2vCvH)N3@#w*gYi1zu+vdx;pIP+wvLtp=^Icgq89{ ztjl*g@u2Lp!=E3j0cE?m_?hm5bvd)EmUvYU5E2HAv{lJMXSUZ>RSnIF*Xmpyf(7Gm)fQ;ONYi#utuz1omLdlb>r}%r zcfdjWOmC8^hDgfY*4O*z*SCqArW6eaP&w-@q9>kf_lR=)mH~-V>|gBiC!OPY_qtb4 z=l^}@6oDMHYUx}?4F~G_Ju&-E2F4MAd3owgLW^6PfSq5zL4e~32k5U((RAt?Ac7p< zcFt)YrA>X{n)&mg4H!Zp+Sc{KrR#|Q6KT=+Hw?|uNiLv!%oy;BjQ2+QV4 zFJKLLOX4Bsb?^=q?`DDnoHB=(sWnL=T#Q7)#nmT3+WGd0=BWA*$4YFvkTJ`L>9R@@vr(;Sm;KD`e(6f&(e3K%swfB5;~Hz;~y+rN#*k0s#z)PMXph<5qUSRVo2 z6IpdT_oo0MfIRp1QFp*5yYFw%TdCim?p=4WmDu}F;x|9P?gqpG|HQ;`%dxzm<}Ud*NS(MKF2aF1+yFhKmI!2ci?z?VYz2>--XJn zJg@TVB(-#%78J|VTZYm!09d7xc3KXXJj@p` z(dhmeLyeQu$&hAXLKe}07Hp&dpy}}3F1bHn(6(qfvUE^rDTx-6ju^-M%$Uu*0;Z-U zZ%cONvFx47LBNXmFU+zn3N>UPxC%Uz0Nc=_PMn}27lq51F|tMI%uY=*clY|5oAM=A z5s~nEG4di?HHAo^Wnia8Tb_HnZt*CC#U4A4x}73g_{{2(423fHQLPb0zv8oo3Kd)x zAKofy0*nGcAka&7`_KxA4M&w-=RM0Fn%7J*^#LbdpEFL|Z25Mh@6#f^;06p7BKmOk zUJ}%uG?c{=RQ~58#CVX(hWXRpFP}bqK`-N*o?h;sV+UAEh+wYwFbGDmXyB?E8g3@e zna_&$*CfRT`1JPlJjsqtcvSZUQ7^6`wa`_Ob#-Ia>D#73opEDHPb zY#FVa_Y`iA0Uw+*Ag&Vr>7Y*3qpl}q65teVdf+!B%;#&!Z{u{I$#3NJC$X^%UQp2XE<1}W^@X5kWHDZ3d4U>Np&8NwKMdb(6I zf{BV{XTJE^z0qy;JS56>hRi_uYhIRe@q9G5VZ)JgUNa(tneOqc0$1I|_97jK%M+4r zRl-Si2@(@XRcrG^DI}P>*2uu5!|hb&Wim2ikk}PP01_29QDz5Z+B*)O>C06=J6kBB zad`n(Icz+hIWO^0L#NEM^+vSe*qj{R*UtNQPP-ev5T;xGx)xUjca76r*0&d0Dv!3| z4Vg#S>BYx?5fm2{wVfT@zqj92U=%+uM-$vpMjO$8{3(5Eb`>8)PJo?}*M$9S zR2}d=hJN{4m!PdU#OL?gHGsF%nXa=v$Aa3k5521$&}pNru5}vZal4+-c?$t zo2=N>IBLU?aP`(+Lq!$uGU{fE<~j zgWu-vpa%~?#Wlt~$}ALvJIW2V*S8()uCtN&s(V1r zt~Z{ESgKVvZ$vB1N=X6RkDMHVFVgxw7zHZYuz+Zu&g{@tE#7s-(IEH5TTh?pYh=MC z-((MU%B7N#yDpE1feLcv*_znjClLh?+aRKI>rG;-)IU;7^{nX&@z#II-+PnStk)R4 zcV8aAKd8!S!EzeCfUv}ypgcDwBtYs^&bP1jvFV=9QA{(k=Qbjj8?1VFA^$i#)_c|M z$ub=*V@JN(_)U*KAAfxJyxZJ}v$GprA`wobDlQ7H9tGDAt_;^%bqP`f zXFnC6E=MWKQw-tH6ci^dR4(>cLSeZnI$7*qBLypwd9@tP=^}`zBEf|=d?JbsF!psh z9MHr%^X%{6TOaEYX>?cZYUoR%aQh~RM3H2+2BLMLFgAN^@P?%qbHuEE4ya+|-aUUc z1A|0f(?B=F6V6xfhQ*G2hP;3a77c*kU^Dmd?A@I&Jd`amj zSwy{XUP8UUPkhf;cBlL_FeDP!A}L`DQ9%)4+;*LBGGIa$wDMWyX2VzbPTl;nIc8hp z-r@7fWmwLWK$RrVf&r*c;WkA^(W)wS$_`Ah2&RX0(|4LL^ax?fqT- zUat}MMnbcb-{sxj5&=?=odMrCZ<0h7@kB#5%bC?G;r3BX*gU6>88}h4e z2?x2jKNy#r@RNt5z8!udxal`Zrk!81wnXIce*9sfaL*vs*l3|gC@a(|;FyZs{1G~( zoIrUs3}l(t$ziT-$CqB*1IlPmSuYb2Wytf+24J^kwc0fwO-)K)a&0f7T4`x~*j5`J zYS_rW?CWur2Dv9Ck^!%)r?n+xxE{@hSfSj`)NI3Js}_Q{#lAgd{5^??UmxBd9e6B> zIV>b!LFG21xjyI!a`X$K7_$=~QQ-4bmd0SmR_#*&k((Jix-(w-e<`zK^dAoP|8L5i zxB~uik^&%GJ4gjE-x{(||LBW>RTBdf;4`oNW3VOt<6GAuz?IGf{QSpm19nLQ%sFjl z**jIJ`2Kvr{bQCk*q0({GGFfsPgh5CwCAH)Zr;^VW+gVUt&fzh8o!bazipi`zBZBN zXyTd426E#(nJFVh>fP|#IlMb%Z$G%)F*7!{Cdod`0r`r)u4E%E+_le{=+K?P&ckv) zNHUVkR)pICEW~dRVEjBx$O5*OI;G8T(4*g=`}~5100Z)S8ROp|G%6C51Aa778S+^& zH*+o}E4-*D39gU~H~$(~PqVS5YN6fLgb^v!N+`7XNWAr>Hyh-a6F!G9lfmpWqzUzD z*?V9ed#lWu2^^mNpNEgJZ!1Bcv|2f_R=Rd4S0vwWw24%1YvESW`*`;HY$TE7QbM8J ze<7o`v(b;lV9UvgTs}riilFqM{iPbph$hvUuZYF0PHmFwtEh4NrY4rC_-PVQz)Ffw zn#IFQgJJOl>ffMwyIZS;vnPcEZL5QykEqUm*?r1Od2;xdUbCZ+xVff&Df>%9- z{1df3KTb(c3B!-nfd1fBD9szkx!@-%_YT?Tzd?KSWdW;z9a1~)`(6ADf4c3&6gaf) z6<{Gzt0x6?BslDKlT#KBMgG8?e-YH;eo?Nm&TcMWn$j!h6o0KgKOS<;Uk|dlc57i4 zq!cJm9r+C^OsxB7oB!1)4*zKLq&nk}J?`V5FCPDL7Z{h*Hye+xg?&3CHMMLn>})WT zvhczb81~&YR!MM_34uDZPZ+=3q{-aY*dQ5U6zqAsT?`l@m;ZHz|9b7C`y3sYq~3R= zBlFUfNgvq35uB*%%PjWxN}*GduQPn-4ef+|SmbvNGbqFJt_q>v(agC~^I^lI3-A1s zA1F2!1iM&Fx>yBbbfy-&7mU~gg;idJ+-5wXJ1@BTmvaIQJ}Z_3Fk?bqK&pbD5bksH z5L0<}rSRa2e1m)Sk_33u!9{=WYkLfdDRZxUcki%q-L6j?@CxxV3fBsKdm$W#_Qs9X z-mrHybURgNnl754rg_$kiBeun6*-Lqg^9Ij{}o=W4A5vm2P{kebw~ZshQt{)KVdsC zu@HNoE&HK$jN`0vv7-MDso8U+{hzibyUzB+2VN6F?%7N1-TeH?V7!B+y}Pe3`nC}w zzd^qu987<50&WSOe`~#~Wz%r~zlOi&Nz>B8@QJ-k|BNcKh&Pg+%$UV{lx*%DR8LXg zL)mV>9lu%HD%y2n_Ny7%X?f#K;ghOrm-kO`Rj)r#=*;}-VbOo~aE{>*6Yn5Tf4#xL z7u{?!Tj&B1UlEj$8!}OZ;X9hY?k6t5*^_=bdwt$|$u(cVneA@DN~815Dt4yA(y4a5 zsn44=D)clOeJ?OQd>VBXSH9aP|6jYn_Fubw{Oa#sm$Nf?S5We8$nw~njjx+tRvX=S zkGyRrr8jpp-lIvo^L=~ZQ_PyBPm<4Bu?P-9?>UsA{Q9}_pdH1?uY?5Pl}Xl z&~FgUf89!E{X_X*6CjcOOJn4Bye_EA`4W5nY<}|Nn);QGl_DW&HoSwoF48-@oHhU) zJv*^FZ*XFvLCj7vfi5nL{zK8#I)bhRZaXbkXZ(8O^(U*!Ub;zYhRmJcph-o8-=L0w z-ypl3`44}d5;nqL<^-b+*7qC~yK3Tv>tNklacO~AHStoF;8eO z)K#jjWw;7=teQ-BhF0m%d4^}?`boB=Z!p)S^TjR3@le}BL>9CjM-y064h3g5K z5m~EezI{dP7mGgDenrkl?B%%`5)(#?^0nE+UKPvaT7@XAa2)$+g|&R!u-tBKq-3-> zzExZox$BO*qIXMPdKC+si)gO*F}zfBUQZ5wWe&DcpRxORxw>adgF~~C(!G+&BwRY3 zbet42vNAe#*$Y-kFKMq3_^)aV7JVzpcNyau$i0qnIvoX9{VuyasG+TZr)xLhM3t9u zfs^Yuh#Cl@u4dSaRv%E$U5Y2a6W_FyxSqz-Gcs5-HdrPm+(1Z#i_ zO=yaXKB^`HS||H8{lYMZ?>72?{MuhvK*hZsCqb$}+=HCL3B)}UIfhp3Y2*L6LjZj^P{a<(1B;J^fx_Vef3)SU>XlizZ+=?nSBqba z{s#SE0956Ahz+u`rrc>Vju%|uZ9=dJE&I^w`lQz&{Ic`3@Pvt=#^ z-HbL5ca-3NMh+cty6v>#jeq21KSP{EMS04X?4FZZx5V2?6uV&9%-$~qjb1uMFp6_A zZlPp+d_Uad_A;)dZw3P^1Gq;`)p7^*y6XDMldbx)0;4^5NpGjvK5Q9P2A5pSRFe6e zw1hp@yew%^Lzl5*1-a9Pp#CNb?pRDzvaXZ12*(N!C_bjsX8hUuxQN{8*STE0Fc%1& z!}IU>NQ@yr92|5ZwlfW~?wbNwWW?rP86Z&nyHCBeN-5OeFK!8cIQXu;V5&`c9$FXw zq6K<`wvCeJnT4C}{M0U%r{hRvmUCS)x7BC*`H<1>{A=>jf@>62x+WdI0Y12mh0tqI`!9Nn<>@ug+u&v(v69G)bt8R ziv%29kdO@5ZrA-l+~9_L@=l$4oN|VOfEVobd9)uqeNpkCMowlJ(zlEC=;)&}uZ>tR z9WRcF=D#NSToYe=<2Xe)4sxK#6c)IUOF-}v=|DCGJV-Mp_KArM^eHl&d`hlejDKb|yEv^4^k*vV%% z0S4MLpYgb{X!1;yfIbyDZNaUkjg=FA9M;j%(E~ITPE15?wDh6Q^lqAQIdt*cUi@8i zxGtTY84|r@Z^uT6zA_Ybq{x1(zQ|qt%H7a8Wj22;zC-6ZY*3OhjjG|Y3spWr>IB&z zcEQ_na?{Ta8Ki+)MjeyClWYv!p|nM5F6AUPrvDmBTVLRvR|^kvW`_=zkuJATe+)`H z?7J+R-)`|5UM6Y?X7x+nj$3C*ygFtUwtD&QhroIu@1?T&cj;i}OU%3Q+)w7ZEDB*3 zLGftlldBrDd(#F{HPX&>HV0L4UEKZkDt5uRU%Zap zk|nYF1xsmQq7~LB5cXz})}^9wnN;TkZCyQlouO&eqCRZ(+d3z|#~ph2VhoomdMil2 z*x~B>O%IUKTjN|XCzfsD2HPj>e5X|E(g}5K)Y_82cTo7XOWrlFTse7kxTIn3IK6nI zD`mUct4qxx*)FO&T}ibrpLGIlF;K}Nt!jxmRB+tHa(dKKwVGxYJ&2}D_tlqla@vM< zLm9KHZleczF~Sl)uKQ{+62Vq1D{cT zite7)z?~9!eJ2`iu~)NP5ysQ#Dd0Vrveh<3*chEJDLz0GQ)n(oSMKKy1MMGp`mxK{ zy+(Yx`w?gZ)5~Dg7W@u%!3F+tbzBsdwMgbIElQ#CLuxm}NxJ(J%q$Pw_}W03A2X0d zAGyy=^S=Y1KDr-*sY0KQSy$@sM69pyL_J=8j{1IKhUDhwao8@Oe8B53^MJMC$ljeX z+6&D^;6d+59MF^|7Cl!G3=zKq7kSF0i86<>gjMB0P?rK6NQ zxvu8RZiasqn%H@W&^IYUFB&8PfkhQ`+to1X={q^I+R0_sA#Q>&{q>K> zR?m*Me!2DYoxF2G6U@Si!TkyA-;p27N;%9pTAzPTIaWUame50|bKu98L(O>dC3jM( z(q}~qZ*dW$+@kUP^||2yw6IxaInDCHGn%sYx{3OI?PoTptcJ>zal;_`W|>$v`E#63 zC?u}-5uV@c?n(}l9$M7e`4598kEcUBs}+4q-JCRAN0JC! zYvJvlG+Ou)y?xzivSniZR}1QOiY4-idZu9RUm?L5dl=y0C*WY#l&Qlb=vydS;n{MJ z6+;H}?SLF=z94GqSF71hH1tA}ez!L|h!3SSRW%K^k46nkk~#F2K;?ry2?!Khhz$ww zxX_-ZeGx0Co=}S)021Vl{NfW&>E!og9P4vv>%>AqGL+Vmr3e!L99OtlVAiQ}(?;h0UtM+-~M=E3geP7A@_T?sOT&{eV>+t`ph;$RbVQD!i9(`Lto zuK<-wt{r^An`dNP>bCoap)KEN4p_P@8Z8YxmD5k$vbMG)uc~$Fz?JJ>c6siQJ6c*W z@m4fnZ%J``(GXC9RNDy8sUZj8Ga+wv4xm0^jo>TX8Hj3r_ZW%stTYB|ux!mx5U?PR zJhhoduKK>rL2_J0vOvK?7Ni@~b=%3%H9I3g?L9owkyQeGhs+aFkCV{omip`G%J{Ln zu1=?Ti56plLm<7;7I|ER=!M;*!I#UshZBSKaomJj@$w|-kW~r_3s{|h#cq?^V%^{{ z{-pKVII(AB;0l-8%M;0+D)cXz<}O=dKPjVvmdaVZ0}jY2)gxK z<=d$?<3W`20!1_&W>LLC)V7N-H-e2=R+O$Q#IuE6-RDw})7d?>B~@&D{S@9s%*TS} zc_FKAUZ=o|Xfi~vx{)92S+8aN3J|`J19o_ru;gxdA1-T9kM8={nd)J|L~3r7zP>O2{!sf;mG)}Dk3|0%@Dy&UpSK1 zYREZW$B074j&@C5qoN(Xb%O^tMs{?rf8d7K6lzdH)J3@%7AAXUr;v3XLoxoZBRh3y z*{cXwf-E!ivtbNsnnz)LJ3%435SWAbQ^UC-!UG{oGDp`g(NY|?1OanWs#hBQ1gKz~ zMm7}{E(vmk(B-GEVZU0e4O6vcT(5jmWPs|Dpk6^#iVgH~=6R|@UVnz^`Y*{FAH_dDSqF0dR|oJXia;K+9G4Iv;KpP^kP>1 zaf>Ri(~ijmJAH~^xz~MKkZ|~1JVn&q5!&QxNFNC*RamtL^MFrtCoZ&t4!)MfCC{E) zm2()0j@^%r4l8h=XflbY*iGWo<>&V%=6CDFC$ehPPfkWVfKoh{iswS4VUvM=IEzT; z&+ai7jPL{>u5ec|DT2Wi2?Cq$_-QSXRD;YQ#*P39nWCvIEdk!J9dL0NQBR#ib#!j6vD^ff;} zC{5;0y)-o*VqvcZ#1x)5af$){9qtbZJ`imQ_E>a(~)EDfa5T)K^9?YXcZynLQXCxk~Oa)W$BtAfwK3eydcjf)u^^Lo@j!DG3?ut>lR|J zo7|^osP+4k*HLEY#)--PR7JUSdw9rnO+k!merRgnZ)WhW{0_-qovMTqMi0*D&hT^Z z4pFd;^>T2_7-4hFSmQKAfu6V;=f{~f=|sLRV0AK7^jXE(!+W`Nk%d+JFC}9CpGv#} zwVNOP5BpI3habN%=iiH!tD)1wnE=KH6O)o=A#&Oy5aS!8KbAC5>m(03N)1T{kT=1Z zkp8Hb0NjQO)8DFdg}>D4yzX7>@AFtP|RVRt6O?&E3FVGtf!8Sth*_tLU@ow@XWG zxt!2aA1byMdXD@t2`S!Ky*F_hNY}!&eg?Q%tkX!57RjkpkVZtja~1#*i@%KN&`)ke zxQ=$+47kyj;S-PJeb!6DVf~-`6G1)G<;(U4`3by(_(swm;x+lr5iRNYj4>1xR9Z(H zZRiP#t_}{~JO0_n+6lvveFANHS0qzqCHxtlOwnNlx@>V0?lDfW$NFvjt&2K)N zr{gh>&F=ueYXJZ1K)k)KyRn|36hwie_Qr;@#*4z&2W(R?>{Hqb)N)Y^`EEiMdW@Q2 zZ_Y!EL(TOB(zvIxeItkZ>!Qf9woF(h&ayUBGjvLUl_R;os9TGgF{pi`fB=V8g~-{K zVX~`P{Idm_3CMAW?plQ67vPz5?lo0QI)8`lk&;n{zocI_$;m_Zo^QZyG$tAHSY?ZZ zJnU$eQlNzR+8{C64|>%MxNd5Kv-}EQ%M6Bw)2c@m$7&(xz};bRVMVztIgMj&yqpNo z!@$Teu6IDu=1!Y|{6XnadE&NTnT~uCiP!j<46f{5)xjS}|0eZcXP%wmC}-n|aE1a3 za2}_y+UyOfh)iLb5^HWpN#mer{&^E05kL@V2)D~4c+aSVNKWh7y@tg48Um2DC z-%%-FfMagY)!2youKbfyvhP1bL&((bN4uZ5HEzHK{_fD1K!?5%ll@vPMnB2U+42SY zmg1Yaj(&hUuGF&;y3r`Vsa9FdHp`hK=yBqt9ktstvg*F@M5V7XF5YHPx;&*(LlO5J z6Z=pOa*uwGa)a*|4Yppfjm~;%Z|JL*hmfW-l%Z{xq%F7tZZF z(wqvx%npOJY8okqbXIQawLu%$F#PIRzNubuNO`L!RXJsAE?aVw?U{>#3|31T&dU02OPr~r(~PuRyxyELMTO+kY|J83aIBaM^{}BnEn2W$NZTs zT6Hbcn<-b*m`4V(RkzYPrV#LPA4)iYG&!BLPE^HT8p$?w;47)07od?F`)EaPF47HT zD7m|!K8q@`&aIv};MrcX;>&ULIvg~R(2P+57fo5f8A3TPts)|cB=c7Bdl>2Zj^szC zGwY4pXzu^CD)(^2eaX(Ee_fuRM);`6HXXx}cR*RddSCKU#ACL8=Aopl`h=@u<&e1n;ODkyNcJZp{*zw?!WL$V5T4C$ymJSpmpn3RN zAm3>Bm;WZ7;gVvZGBy}vBS99sXd%#S{qLEH3Czr%kkVy)96P@JX=kc*>~Z#5*UIw< zmsyU2t(!MG`7xe+d26ZUbFiBkq6pSlfyG|TjeY&oT&{qUuTz>BbT=NQZ$p4+V$lz7 zp8^`aFM1Y}o*ofeEZMuCLAdR{qD-E;{~RxwxkH8aI`h&kZxZx#n_hY2T-jPsi=%)E z!MJabZZs;wIS(%GxzEGy#h12*Ihp&UXLlo99en_18{53uU{+fWQ{2G}W35rQt4tDHp=E*y7p8NAE zmq96JB$DBjC}4-~Spe=su!;u$LwGjcfAeik7~jeUN+mvad<`^O8J#BJU=`>B_6;Eez(`WFn@9zN=lQxR9!>Yv7>nlpt+mzsvdxQ#d#F=@KS|%ZqMh z_Vnn)G`%?^d!4OzZ1eG#i75H5PehgFAw=gQG4$KThb+athKhYw8VW$@P6CqIo%CmJ z{QU|!%H%zGGqn}E)W4W5Nic>;#7lA)0B-~XS~Nn3moPs4(aR6MZQE!{YHTocbh3Ao-T>HG7%1({1@fN*371Ps7V1D0VK%^EQN7FDe$iwOsB32R;MtJQgwzgbv$<4|gTf#E z6+=KFk8OSud zM6qyoVX>@sCh>Im=fbo8FK`t!B*D#z(918a4m9qVOa)L3tSk@h_ z$lPk8Vk|B~y8&Spi;Rnb9_x#$6Y$>os80Oxtcl6M_G170-rJW)G~qu4D49^4VB44e zKC)%D^-b^coVJZ67L41Y;2m$1O*8hS!1oRSdJh)7eKp?8+|(2X=zYD1VmaO=e;JuS zKR@{H~ft09aoYt^F+b&BVPBec}} zs=`GcnLb%DUMR{&#BB6Y6H9GVbaZR~g0inO#c_0%NHNLgs@by)WqshRaGzy8eY)f? z?&H#+xSvm@Eq!Dj_BBt+LbndSLI(?#Vrn_oN#G$tWop&-qf1P`#m?<1I}_9phO_v(Rsux|6M2xvv?*2PYNj^A zgeT*sNp%2h{OQ`{mTJF@i@&`?+>gF_=SBchpgbx{UtkRir%!M!8dtq_PoD!cU9%B#gFbbCTRpHF=Z?NYt%0 zkS|j_zQ@OR%?jn+YH|O{*LhZGkq{K9;>&9t_?Wp`F1CAIZZ9s2Z4j^-Clk~p3ul)M z`&^y7qBEp{StGgWaO7 z&M#OFkFDP*Zqh<<11*q!Oq-)lS*-8Mcx8T}{zbk1CtOiqUMJwr;s+@3M5=qMxE;G&On!{J?igUk6LrwfFP(D6gdbLCbsX$rZMI zHE$;Y$#p9MT>U8ey4T+I%Ut8^@rTjr>nfIk-3^ZjBK4=B5d{{lVRwx{yjqrU=samv zUypO1yu_pbs2frq-1r|!>}u$e(*Gj3`ycXu^#3T+!t@_SS_qH^G}hr42Wo1g%(L0) z5*UDIKpN1={guZ)iVTS4YRv<&)nNt(ASHDmr5(Vp69BpGKu&tG&@ODJJhR zw^siZ8aHUHGTj0GU);TAR9sD${@qwe(1hTwA!vdG*Wh$;cXt|ST!KpyoJNBaJh(P4 z!QCOaTjLNQXx@|inP+C!%=)kOex7f@Vs&*@?Ng^}*S>z&Tl4@YC$C+S9)UM6PHHl* zz|X$beOX{IMd-?*rXd%hH|{A|SR)9>lpZIN?jG>J;w@>*^1!JbjN5sTHg9JJXr~w^ z7$%o5*<$GA8T9xia=!|7$P7e=^@=3;$a+xC00lvGk8KuR8)$W~V>bDjGQ*YCBYv$5 zg3SSRbd(+RAdV$x+Y;O4{W5yE=9r^H)5obBTI0LV=DnUB#?LOvFAIb;iQ){frSx7kJi6@HNATr&_aHZWwI{`wztGHT($Ku*K3836v{Sg_R1|%8727ms2tHOiIf=K zP+eZU)6)$SjF8QfR)N|v%$`fXP_q;VL@IsT>L+y>??rKp5Kx;94vHED$2Mi121eF~ zjy`?!85Xb}pCufIxK?k`^RcRvOjdHjg24F~iRtfyQ-`SWVXwW+QsU4>P(LJ@uE&zthaj^}oUoRei&=v7v(h!eN1=Qi-t=NsciywQ__Yp*a^C7neZ2h4+*$ zhr2aT@YBC%oWXwW zLl=Ac=Y9oMSl)K?%UwcE>D9~CwNq(K5)=&`#4#W&*S-pu)VasSn#b*vN6-j>gjI9< z&spYQ|86^%Njdo@KhO-QX}~L{=tccLzy28oB~wONaHhC!=nLCc*zrtRIpmVe&IYY+ zRQ<%9I*j=lu}NIulFy`GPhls7psH~uF9y#VX@U7Pt3@izWGy z;;>8vW&!f3{*wrYaS_EV>M_6w^^?sDAZz5kPoYr9Jq(z7cw^vz$Gc2 zy;b_T9?CGIy1_IuxE#U%q0Oe>ia*AtpWckPvloP%m_31_BVpX?=qpC~bb}x|-b+-)zRSO;juL-8shpnvvNvw&m?l zVV9UCXpu`jC{0B6XdQRUII;(kE=M}a9s(VJ83f+S;*qM(G6@Z@!Zwx=A7qhJ5%*d~ zZN$b9K?-?@yz+RlQp?pl(LkscSxhW+_h1%iA(O1udVdd)SN0GQ| zhSSWk$5a{>_c6COu~Y;c@M@)+9*XTD#nR}*{!H+pGe)`IPA?w`dL664G(4Hqe9VTM zvxP{}jI+Aj%)(GTuz`GA4ivbUDibXGREOa7ILymUZYPMJ7OyoSyYi#M=+BO^K>?)y787;Z2%?4Z41&w$Ji-ZmN!X97VRQSp zV8r^F75phV4lF%uv%2@`fep^GyP~R#Y!Zr7hir#y;FDJ? z@4oQrd{CSrCb<#*{#C#m;phv2mgsSpQ+j@@iOuT19&PZf&|o zy(E})yos@ae55(kE_9cmn6QnZcFO9GgUX@N&Z+sLvdASf{ST<*!A_)i>O+l>@SJYX zFpmz;_=x$PsXf8+dG|9udS@kFdmdd^-nV?Mv$~i*NsVDY=S8~Rmoq<>b$>kSWGthc zr0BZ@N=o|yC#RH3JAsf}Rya{*3bg1UgLJ_JCNj0XnYhP?-bk{qb^Pwe#A^qPed|`+ z_F<0F8Vg6vQoWBkZw)5CwnlmRK>!-PK~-zpZk4p|ph;CZ@Oep=UQj7HoeL{HetHvs zKD!d86VNoHI_V`jrCS!6MiKUmgkuX?S{6O4d+RFp_|5mZN12C@LoUC=WD8mr3uUja zJTOrwZ@%LW7de+KVQ&fx*Jzg2Sv1d-mzsXYt>Kv`$upQ|eo7;-nQnedI+kElEm73h zuA<`0IlQF|<7b1l?C1&-YMNX~s%{j`1|Mupw zEch(Cku~LiF#F~Kq;aUBK*}2jwE%#+o|F`+jBHx6XtTf;7PZMHs2zq< zB5v^)SN9ZL~|73L&y;ZM|V6R70Hj(*z+i8n-+nSkjzo3*G_?cL!=56Xdct$DlQ(d+bg&!?I&# zNhomh*+9;I&!*W#*QweYye41IX|}Uk2=X{I#YWBV$o~2LRwq^gY10zXJXAFl#au$-r(BAAwK9nKxp-n82J;Zmv46}5>bQ1`uBX9tdaS5!xre+x~qCf zFTIFgQ++A7Ti;%;8w;wvgg1n1M&X>1g|Q^tTT!q8Vk-VOxCl)mO71gOC&NYAl!ygiGQ~NGm4#xopcGRh?(~bQ%J-YUwa+`D2tXG{RBT9m z4>j>~!{l?_cbx@;zs`M>R-0VnH+^;oa&CE;}WvaX=G+~$1n+m(W*jNZrlZIb7o7UvuUf8E=a zd<)>?qpyXZ0>A^-%OnY3;h9A+rhn;I;y9ennHs93lE`z8X)T=`hC@TjDZ1&Dy4wXw zIIE(|Yw_mG5hLbjsDW|gx2oglZ#HxICV$&(AtmfQmDanFV0zi~O0YcYZ@CCoD4bOp0 zg2_669tajmvMpZ6;CDfBZbcmPGj8Uo7sQZQ+l#u(wQ zhh32XF1|FJB|#>RRm06jcTo+S=;-{v-W8j%$9tXe>b`;6aewI>@E|PBSq#x#i7z>*2#ymt+J4Ficczh70mT!o_$*&WBLeIO~B&D z6!l5pEJ%1%Mt2{m$zGc#eboC>?ht7xKfp6l#RUUtpu`9HoH9Rvyd2>E1brbwhQ&~v ztT$;M5l>I8;^tyFuFdZ|C8DxTWcg1Fl){h8wkLmOh`*AsA}ofmjAg|si}1dja**9E z;NLe;@_vn+=be~dZ+YfmMwq>(IE>88*Y6Nw6*-IBHPmdEg}OiF2*uBT5&U$CXEmc~ zGvAF{8J%gp`M^#=O@C@TQR*gjok%eKt_cN+9%dm}CDW&%QcS3z>r{o)gp;(DSj~ z8UL1acOwD3{(>QmR!4lpCchc`1q(TqO!Px}T8)JW1GkT-@dXxj~Q2*TBOs=qQu(Zad!EJN1+ z6K6w%L8inw8lAgZzJ5jY&hpyFc0mD^O%WE0_eua z(fQY=WAzY|uW5TBiZ-k=j<1gfjIKUpn&EUmmw8g#A`ZP$!bW&J899-3hc(tm#!i_i z^>d5~^OZ5bMj35ewIj?~n~$!t;f4Y<-m zq*qX2r2i_fkZ!D=FrH{(69zyVHZp|;{gsNBQ5qyQk#5&zOUU9K{d<6gB^e5}88=e! z#uo5TH4w|0SDEuBEuq;>!6)Jzkno#M(8q3yj>wm(9aC(PejKy+VEb#`Jf2k3h0;b% zpJEB_$f_eGCs33hK#X6$FgOE60;x|B7E&Pa?pg>f+o@Y0QG5UNo#2hKQ5RX5iLIIG zqcu8;83ees@QL2iOe*%Y`W=_OFC(JPlgzt2-mr-G_+Czw!$4N~88t}B$Xg!^plTug z&9&+OkHVP$GXhr^zQ2|^Q1SOjipT+gbq)waUv*+7;5iaFTvtWx88}?!FM#MTcJgm- zt|9jywJULcKA@SgL=2k8D}5SH!~+LW4JGE%Kh5JCjD^PHuIqZ1F6%@(+gx}#H_14G zZ=l>EDEPsA%1Wx}n`&z7ygybKN*pV;h9QI(a??kpn&6?3*2WOg1o#|?5QP;#sgte& zowi(ZffcS~4^Q5((DaRQa}G`PP8`DS@Ug5ZOZ--Ix}`ud`oMp|e}}*OsNM9jol&Ur z*G5hiFQoLRkx`fT7;=A&$WXEt>st(&?NF852OGb=)rXp~Q(oAje5_tVYm*6-1V;O2 zhh`k)ftywE^d2F|k-IuNuD85e8|V=*=fTwK-;!5})yhvo9zIxA6HR7!XEX9MDi^je zkXxDcwqu^!cl0SExw}-MHJN>3ICv3r9g6jeM&w|ibCj#jKt$O+_$bmv<~aCotE{#P zb_I6s?lr>K^Skg=X(oW(a4bO#LNn_nzdF+VTB~A$jaXR)quxuJHaEoOi3Dmy;JtO` z=*6*Z%k|~GI*QJ*vJ6w;(C0?(SU}U4(ws#erqc9e5)03olVkm8nVA2VH0mrel!`P z;#YG&4DdoFk2}#k!h7xbt2v~mp+5SjKFK%2YfjkYb7zv=A@d+P;W2MfSE{2-|G)|} zn*xMpgqw|c92nv^ASqA3{kg*pI8PRTlyLyoaK8fpf#C2dI#5 zGnz|nFPUS%KKaE6#Ugid{Ae?)l_*R9ut4@Mdg@5ntLXDyGlJPgU)7znfa)v;dY$)y z=WfHnqA}d<|7tjwe1W{ls}(#V_M@6u_D-QcRxaIsK4Y=9Ds`+5AVPqDylM*PyCg27 zy*Or{2(Omzey>JrX2F!OXw;)yikc+RE+sE?Wws-)SF zSeWXglM91LV^)8$b6VFRz>iGnRqBWKh%Td50lh9Ex{{nyB6mSVZ8@$|XC4fp;Si&b zPKx(;@UPvf^YH2t=0H*38rYhY(_K(=j=2#hLeq0hQJlm#YSul1wVRs3EDl`av)d9GpQI_{3*8bOX|+H>igFBRrb6tomUMcg$in^OIlcA%AU9MRXm@awo z=%TVFOV#ds3`LNfb`84T_$g^oB~mqEnhE^@p}b$R@sQ(=tuH_8&X4#~Ub*J)w7a|C z%au8kb3~cdt3ry)vV>%gJ{RF(pUS*2q!e>=m*|W$P0M(2O(@DWZgj>N5C(1jffI5j0B`$H!JnR1^eyp;19|nP5U4xr zM|JJpGW)f7?ex~;OvqA*M#$2#gO$bTG-^=SLpDc%l9-(?h3X`WWFX{?nUq){U1bV$ z07u}tYq=jR9l0vQg18tx%@Z(YPZhB5pW@S6VLOl z0`tbXhv5)$R?iiLdHdY=DIGzwuZvBgNZtwC!{DO61SpK8Jc7ne?c({a$I7S}#V6gy zd;^BMp39?Y-YlEeID<(Rl0j+>41BzR%&(*9hKaiCs?xKR9G(?EtZGsj0w3w5i=Lb$ z$0bmO{*8U0(@sE@qu2P4_C;LQBKn^-OUF`-ph~v$i_Df&U*_%63=Yw^R;8DgKQqb1@ccWNVStl^1jSO0`q!3^nxzqL zCuz<8)bV-CKHc+vUHaV}=wi-hac9TcltpvPGyqdgvymJ(km3AnzuO(?(rX~5>aw)v z@y$e6rqCOg&e7Q_|<7%kP)+LNd0{fG~mg^sMi2W ztZf*)0CAh3r8%*8{*da!;YjW*8wddogP-X;M`ajMjotQjzfP~u6|_c3H(9fn<%U^! zeCEVo5!dHO7d&-|G;1ZyUj$C10V4K}7wz}h{^yd))m z4ruJQ3paA#=ykooG_B-bwf#Ku6dtAn&hB8uz`g!tq?>Q%ShjbjEu0y});*yuWg(!z z3N4c*_XcHn%|b8oEKaJ}{a$np zorm{k_3=sj4V~(k{P-m%UwIh>CTn5PzxuZSmQqSwW%0rJ@3j#JXegSLs_l`9+nCahV{ZJTT4W-+zD<${Pz|IN=AVoynR=zs|=8nbyB!v+8jl@bz%a-v?V^ zm62n*xX_O9;LQ98p<`WoBedl`D@)K^vJw$Pu_y4#Pb$n;TI%skp(uFuE2gh9>3b^~ zq=dy@D|Maln71^8VSwQDYcUIpuBO!#v<#bzs0t>c^s5c`*w69A$EA;;L@cO8*JyE7 zcyh4~*zA8Wj*U+1Kn?u098>g8@UI#pCoYUc+x*3z9qcqJDa{O8#;L2@NsBn|Bauzi zwoncwCUc(wETBzI~6v-Zwt&&AXOw3WvlfLfeX+AK6+b z&1G9Y+pjl9%?UeFN`^`tXL+d5SpNFSpw&7&qzTx_7w^k1R7@(8Aayq3-_!(OJm*_IC9yiJyZsfJM zI;Et-4q8K z?G^_sI+ioAFAPQr2hDzK5N4mL9U6J&M#f^7&rUd{TOE%p$gMEkFYRZsB!|_-C#2;i zMzYXb{E+DAFhrF0Zlv3Nf(DXZlWv~r1RA(!RuF-_mt)Uuua*5+jNHZQ{6uHUS}*|7 zKwpk~?J_<~6nR+2&M=;rI!i*1sHCxq#M9c@WQ5m=cJFV=Hf$Ni1!a!Os&h3SkPn#IO|>e~O_3J#peGtI7L=5~tuH9n?TGL2u-t9h8GgZw=fh zo-PWFNmD+fVxBQw6^mZRr`+-Ke+eC36Wl)_eKpRqFF`F^)bw(EYs%~LL7pT0ZU$i}FU z3K8wn&G=dckF8Z5@`PiZujJCKRGedP*EGYNw1i94H0t0=pD8IDWodP`qW6SyK$b`^ zL74>s0^uxiXNGBxZX5m>jVk07zRW@s0oC|-+}#Do+2m$`2D@ONP~g21WtKywj8LzY zB%{MQh#n`Lj~ol!@gn9Bme-uAthKw;aO31jS?Aa2kE6S| z;91l2LQfo@<0h%k-WuO(fP76ET}8?(e>T|y5R&c2ocN7q*}yXqU@yUr1BXab(PN%t z=eKge+A;Q77n@OKyhTe0T+h0&-2alEzT_M}E&D>IHtIl(B9WkHbwO{R^i@njT{f?G zSayDPxH!J5qQu~aL~u&)>?XRPy80vKvehP=d*@cYY)@+%)%Lw2QM4I;+K z0KRN&HY&B&rdhWL%uWZtA7@Wj2rQN;cwJz2c66EEZsi_Q0A8f8hw5a}e=knIH-02vL?1n!U9J(=-caM;Y{MYM)*3|LjPQ#Bv#B$A0mQBJ%2Oqg^FCqUG?S zrAFsR!K`%|ck;}}RV-Ebe|%4o-W6fN4e~2*S1@+`zTLZS4(y`pn>;#WCz518CEwu5 zQtS3}zTdeIca9HuuTgTpwOq2XyG@^oH-?QJK@Am9wbYh4<$y}YLGvFJ0mxL;kuU`h zO%bQ5qtM|9`bX89=v<^UfQa6a`WMxm$>t?D!3HL%Zko;wI}MKPs~Rj8iK6W-oO2hP zg*>#luh37|E^5;O7wLF%<;EJ6y7E-^5O_AL&{##1@N1O1??h?{6~ygFo~ueZlh^S_ zYC_G1v_wpG&Fry-uwKYmI4#S5=Y2QOTJ+Dmx{Vr8&GjxG2`WZ&|Wu zAdsmI^iSogPm{dpns8r>kpxI~Fct%#jo@^0w{mGf*;&)}JKmPPY!VdG|}0&pA$nnDa%T7bQIO(uQP0-O9fYPb~EH|_?flHi{p5JdoG0#e1dv7)8@w+bb? zU3MQATYefR4@=#ACbq{q3)VXLH1Vpr^0$EHBl4c@Wz`tzj1Uwv5lnjl|_ZA zdk&A>*g3V8MVVcup=HU<>-;gT8(tAbFJ&KPbjSZcajzv+D&gkuQ7D{K)!Z01vlXw< z%Ajgtn$?1Z)WxKVwBUEMp9(@)mnvZh*I1{qm2TH)AHR}g%Qs$8&om>_pbKjL(kp0I zC=UNe?M9p$RwHn5bxWCnujIwhYyhV3J`AINAB|2Ac-{9Q#n_Yl!nSa0&ZWe8zj`V78`F?Q5D*8ZI z8Vuw|FI3Yyd4|fQie;|$Drh{Z&#yc22ss;<7Ms4E)mkcMyhWPQw`)qAL^xZ!a~NU^ zs6C6?TA1T3LW_IWp>IVN?S*O<`4xZ_Tb{kNZu$s)mQ$x!@}*!v9cQ>GN19WyZ&wIu z^kfwJ5iCff^oy*D1lIT0w`kOU1(hxDf~tRyNHdc4`D^Zp85hbx~~xI!h=q?qLN!Wb4a$tLA?|Z{9wR z0(-jbnUjaRPXMNR;vvlofHs$`-d*DYQ0j6BnP$++%0q4&Oo8dK`*bbdy(K4}qI1|W zb5Xajp*9TjH`}{@T|~Feo20RqvQZ)%=KY}cm?5~x@4~~)2c!G0gLgvhr^J6i=dZ4> zAiEDwPW(@nMDHC+h>xEX)T3)p3(bZMlMMzt0DiSD6|~i*Rt=NowFT3Jzj|jmW!i^e zs>A{bxV2PijxN)|%JkkjlN)w?4rnJ=tPx}a1SYSxI~baHDX=L=MW_6CsC0_AffHyS z@S@^bW~ZB>sTAnV*%^5`oG0~UiAmYz-0i0CKofW^Ig0M_`T&OC>i|gG?NhGaer~tB z2dQBeTN4>mk{9X31_NAD%z2P=)u&uZ*D;bN`rNWUULk5rPt%&+NC~zLProlxJAT{2 z&)Co>FP!cVREiFZ)Tj*sT>2OQ?rqZz$3rCZplDB{)}QsUaD-#$@f&lT`&atQ!-4T# z)dR>^?LdO!tZA2_Hfcxj52&832w+cjllTpuA3Kf8S0g2n00<0@QGqGim<6Ow zB}t1Im6^e3R$o%YkuXdx)#7Uc zlk41PCa};TeN(?h^lB9Mkyk%6*`jpO)6b5{_-h?gZ9bugIL09o=v=SX9@mf84S{X< z+i-MNu(1#x4fc3j>fHH|dKD3?_-qWTD=t>)ykNiY*73gwRLnd(_5l2Gx%J|`Bg?kL zwF^KQExF=8D>MkMwM+g=5#j{>1ByjN&1P9p0r`nE1w5s94cZP#(*xB~j3;l=t+4p{ z_QQv!SX;VsaS!*`XUhtfeO+e{1Mc%=KZJnR$Hbl?aGvlP{?FJF;3_ou4qG@{Ln-Fy z1kmbxq;B(|DCg7QscR?T)EkS42`?+RAayM!8?wRfy-V5rG%Dy`sX2e|X-|%o8G^&| zuC_j2y1ss*ZHi(_e@M7)X*P_;S`qv)@(Dq;Iy?VzW>Ab372*%*zXvq$!jJtYdWOv) zHwJ2|JH=o#*OJD%gG!F{gkY*$_QvAbPB&2;K!;|-35gy&BAqWwU61Q}|EvQQ&VN%i zdU%~*bvmAUA*1)eVO||^G(yfrZ4pQ*WgQ#baU+9L&#@3=@jqJ>5UtYxf@)>dywXME zE)EmPG(aBQ>Ng{On0MmTGAFrjY1(bCPC4LxVN`|?T+Q!(skeZxrD5?}s3R{M1fh=W z^&w3q!(~x#hlgW+v3Jm1FQ@mBjaxNiAFVET;yixrg{B2?t?@)!uQ#u%1gWlCT6` zfRM&e!iQ#DZ}LTG>tH{0D&F+pp>;%77riJ_O7}1Mxt^Bp)<3}Q!v~}%{(w?^Een$$ zQK%jzS0BfkcOMzy>2428`&+G-qhzmV6khSn+d@UUQ<~byoWz8$L822iUe$jx zU)!{ZyOG8R7#M@H6wQjhDG5*sh~kY-n3tcjoyEFmx_h6g-%C0W8PxF9@3`O54>8`p zO_wemh%CRP;}gDFoSJM)%-3Eq+?$fJbzm*EXQLyhD$UX+P5d`ezE% z;A0p<@fmsg-OR(Q6~Z~#u0kcOcT`Y1%+1FPpUP!xKMj0pVp#m`YqSc2I3BQ`DOeyo7jAs zN1G}2Pmb}0QXVZpS)}=^m;_lc05HbCb%Ck>PB{99hWr6dSp%{Q8aoCkV1kG*nahzKQ6;a*Cg9ah3 z0QV|&Wi;GFVYU=K2{DWb6H&=_;LU+;q0BsRM&9LuwT^HeS>6)p^*5})T*L2!Fr+hKDHB23J;5!HdKQ$04I^+p(WYdx2IN>Rf*L;aGn>fzZV*p zHLRh4t0^!N3CDJTEU*-peZ@S!$&HImzr|}T69Dy&f8@9NrmfSrr7P#&!C*sgR-{z`%351?{TEc^_D0{Rxnb$g1T8A&$S{t;j0;f)T zyQow&CZU@4Icb|MB8Gn=PyJX!7WL6yQ~(yhq;Gv|u?(Bnx0#LCef^`89%CYK4?j}< zbYXFE@gbAUGxt;6_BT+=@FU{Ayy3E59~1jxH*MBdHYTA z(sK*GWmA$8(pI7RITXDz1Y8Sxa@G*al~?sFl|TA1Aiox;2;QLva4LebF{*6p--^?} z(CLT+KUSfd;Vxzw^}_n(r)qmFfLd?}!53Dxb?wf9F+R$?RJn=?*H6=s1bvw;ud@L6 z6Mb`MZ*$dstuD1m);c7TNCR>5&S#^`gJdKpvjJ?=yqZaKvttksM}ltL>u-rDEH0Vi zYZrgNfBr;m<56~fnnDfiDX|cT5QZiX1;$@j`eGu*Dh2UNv}(BCoH*Ii=LFe70py

e_<`TI$0#Si|O-(eQ-_ByCPybR-CP>GRYI|R6$Pew z7G5P)onzLRosG!ao`O_6;+?7v>|6vK$t24NM-<9hk|0Oh%<92f3+rIN>)Ko~? z4Q4gPIMeyugy)(QAO5n38iYu^eFm+ufzV0l=(%rxqIy;5Wk<=A^VdhFnU*g~^YN|j zM#WTaVqYW68iy?qggu45PCm}FC6F1%fc?ux7`g5^%c7{e%5Xv4IeanEGLjFyK-y<5 zYcvg-Z*%P)yP&VV2!>$NNxkgGpfPF^>wO}q(KI&e=HrXkb);6(uPYh$+6>fEEr_PB zzh)l48aRFW8bvHX8hDc_4#`c`PWJZxSom3q@i8Tl6J5Mxe@woj(2n*(xoOIQ+D`Az zT#gd2Gg$g&0nt@7Sh@F<+4swIHij0dbefwhdpY-=jui;^-G-(EjtsrKP>j6Wabh8Y zHOj{f;@tmKf?IxD9Pva(A~0^1ApTAGrXEE4mWAJ9%5~q6B`wq>z3;K|o12A1tQYz= zA9`EQY!1Y#Q1~8Zx%|>^>m~xHQw*U5sM6!a2npU7X@Fi6gK$9k-$^NpDI2r*Z);U* zp(~5|KXS%E@D;#kQRBDn;Uhrux=hxf9^!obZvl7-svD6mAH@HXv}92M^NGKe zcBXbz3r34PRP+887ms5ielyJu%M(_|7wMaqWrHKlSZ<5TQFT!ny<{Yv%h*y&yH@|CYx;px;m0 zfg_i3E<0(n-^FB+$~;a_MDPxwr$4mvD#9ah{0O`n)+2ZGQx{0a+TwoPT)} zcKL5q{p*u+A6ckw1O2yb!v^ovXUV{{Cx>8YVcGByzWhi#%XlRpd1mfZz6^U|5!lM3 zM8eyQ5ME|qulGDRG})3kuGz(nnA*98^5iFA82teF|DhbL{z6dw26AooO57`~^?|#Y zO1M4vwmQoT%HPpd<@T61A7A2eidF)t3`mJ!x0*hpNh$of;SdBnX!DuKOJbM{h#)}+d0CQJ%jEk zq$S~X)<5*}Z0g|B&#=1jq`io#?=llsarKREt_hoJll>jlwajBBO{ihKk}Bd0vU`6( zZ#!-i58M9<0i?^5TQ}T$bRd1kykzjZVCI|7&gngb#Xd?djnx-)qPE#<^iQZwkEkwq zeT3#FOtaG{RWI=-MUbe~ee1tT$aD!FbKn@YtuOSu!Y*OBEB#WOrealxWg+>fIn{gA z<7dBH0mpxcxz1Ys0|NQ~w}?9y0`BaTsqUl10n}9AW47oGX~C4pyhkZQ629a8Apv9&0UL?%A)+trm!h@BAHQWP(gk_>+GaPp&50LFBChew8!OOn@WOO^Crtri=0AI8!5 z!SnwAL_FGm&DvY)hBJdV1&-7aYoyX0~^+3ME!C6w= z|2b_2|Fuxe-D?_M0;AhMgPLr}5{@9ViWk!sYaPQKgiUxz8@92OzD>P-ETx`x!&J zT>W=k5}wGPNp1gFl64LFs$THhs_}E;FTgvs-rFU*PPnWhg7s+j=}U3hIU!3^IYz*K zlpZF>2vf8bq;SwFYvGLgSO#?wlyPn}7^`REMHVzk@KawDR@4!aDokOgzhl_^P{4mI zQ3F8@qU#$Ny#2*TCyZCC zP*C`eR?Cc65HC~S2~JO2gx^k{3c~WYBj8(dwq2s;}C;WZ&c8WDELZTaT=y#L;dk|gEZ&@8*di`6} zFa1*npB9?JN_YMWJNp4M48SWxkv8%l9jDNg0*E`@2LE2wG=Nx2`bR!(%JOTJv@_g$ zpP1{poACLVW&r%eLOT7S}OGI!P@x(NEk%VGXPJ-vpD`gqQ?No#W@6QEGSF z$*)JSKA6C6?-VAEU3u%_^>OP-<_(`=knpYV0e+fWW|d{(W7DpB*jk68b|LVe4yuSH zmTI&(m)iS0b7xN>%}^TrOP_{PZo7kl^3YOcvGaGG1}n-KiiaM3`X1$)3%e?HGaos6 zwwzW5=(!%sw_1QlY-`DEh?$}v7d={|CEUozaxP=Qp6f>o;m+|r77U*rmMt++3)b1UVYl@t07+-$$j$|xNuX=-VH#t_25;f&t zUpcHy!>Es$W^!=NcCw#a>G}f$*JWjf$1K>Sx94^_cKFYQqMWom5|HDYDbD67_L~f2 zOuj7+Jjp@|BcZp^;jO_QcJ4M$H-|YfkIa-3)yL~DOUCOBhw;-v6W!=gU+e*HezS7| zQROA;(QoL&uHiv-jOQiD8q0$v})8`bqhUa80x>6Eh15!QRWC&_YOhP@eX4nXRi>=OK> zul`772a)Kyqib$Uk{k< zp~q`bMIu3|$d@BbvqOv5m8_O|$zjRF@`+V(1H9`lhj0-ip~T2o?Id-*=EXUrH9a4r zF?AXl;@}rmwPX3v&{99m9RYE?lb;11@+sHkCw79@9Q88#ue_Wv$}s}C40zIVe%c5? zrw%t0A@YgmTbXhobbe4Xoq*or8Y5ph~GX(0bau2J@WZ~1oyE2N;Y;s4|At%BnC`gP&KT|#gV65QQ_ zBzS<}u7ktiPLM#5AcF-6PH<0UfSSK0dOMPNNjJ~ffF<*TX3obY5bN8gq^-`Lu91!SN5ysMk zE9{6;Q$yLf1*P8XKAH=9D0(pvW?1BGa)u@oA2ZSux#wnx9@?WoMOx$c!Ug?lpLcNz zt78>1DbzP(eJ(6=6E4f>c*PFo?I%LqH=gu+H4z8?_qp-em!?Noen}D@-A1j%ZxGO+BOu zRb4V;R*hH2oUA5IINjyIpjX!1C^nto77aXT>dcZ~p!y7)r(ThL0OS6f(WU~FoA2_K zRb{9fFTnr8Hf)zJ)$kXZg6br1(fY;sGb;b&OV_36`-Q^f0m6U+Uj8W)ToDcF?6GcB z94ciV-=ir&w-gm`Uc;bgJw{)(GK8Np-#)Y$V%-sV(zTXCrSmH+2& zRO=Tq)bpvRde2CqjDtpMTn1lW+x-Jddz)|NCU#=b`cB&+K>t$>Lub2hJD>3~X9{2Z zmT;XYvUF=RYcoB{0MqtfRpa?-mYpS69N#F{cC?(%@^Bv*1xYv7MrJ~uAqya%&8Oc$ zxYvgBhNl;$zL9A?A4jnB``UDBDURi0<>M+jv$S1wwt=6DLujJwU@60@11C*r8OVADxsqZGk*PaRH5bQ6`dMuCTl zHqN?QM~c!Ou4fSt4OpdM8NQ!Pu8#WMvlZNvz2~AKR$aE2%R}Ror09kq10FUwQ;)AG z;uJ}g1t&2!8(i$Dn(vU}V7`<9d5&#YjYvv;97EimVfZ|)2_NrC?p8EK9B&vOG~DJc zXtp*8uR$D&QU_KS2LfsOREY%s0E389&g_WquaDm;%!2mCn_@;)Ci{~HUc@5{&(a&M zqCJ>)?y5n9E6rizn%P@-J5NucpOLomimF}~DsdP?D6i^x#l6R?)58iH+Gcj^X9Q1P zt2*fJU%Ol_lT$0OJfp}14V?%ECL zyq27wONeS%k@%4O3}=&HPU7TOWA05Bj44WLuBYjB5oJjfJ4;~Z`{&KEGFUV}OBo7?xpVk36BfxD&C?IUy) zhek#wCL{KoTs6AfEdDAI%KWvs+u4M%{q6%aYW6071J&9ZnqZk?nH>IUo02Aj)w?K( zec?7x|Lx2S!C2Aj3~z7cHwaD+l$MO)uUbk}fcz)fk7lA8WbOA+(2V7RrYX;ziBH*e zr)s7>OMs9GuXo)pThHhJxwe@y=Z0HamT3gJaLf1g&u~aB*U+KZ57)o=byFf8<+YFu z$ooF|^qszNDaLw5kCKW9l>uFhfgIi)F)1Bx%zY&U2n|MiA8qYOjqH|waC2D)slyqW zh)5)iWXNAkUMz-j6zO7r*8zckp};KtekiuhA3L9%XsvwK|GBL6I-~GTGu%?8Tx=`6 z9}r11s7h1jkZ`*c|7@M1-AOZ!@`-tuq|d&6N)?_fkdPARsq@HEvV17csZVCqU);K; z)pF@$(gbLo=&@co--Uh(Z)*hg^9L9Q5%tfVGR42Xsv+jAm+DP;rJ2p@fe57#1$`R2 z7IZM;N{dB#YgNzm{&>f_Ia#yiTm6d;DF3L&7LbA5&=k-aTXUGaW&&US?dePMQ(2|B zwR<#1C1`$pY`{%y1^TUM!PRaynA-4&xrU2-CvraM=lI1jzo5<6Pz6OMi``bL1cHMm z4Yz5z2N$RdgP|!nEAHbyKE4cS+XEe6Ub$kwQG70Mi6>bvJRwcfL-{iIPrWK7#zYrQ`e%%@sg)T8knv@4)z@V~;n`v6;+hU6#)ht! zk4uy?B)R^%dh}itR_bDsfs^P8DPWKJOztB1=;#UMknb*^b?ep3P~x2Ot5in&6X>i7EmkgR^9Oj6U7qSV%qq}n>9 zEhj%x9*~rJsH+DACg2}58Kw3Ya(X^hY%UrNA9=DzMia@M;DUA%=!tlZ{sl~>)@+(7ZCsbhZ=BE7KpvF!W7U2V{R_9g`mFQa_i)U@j3h=V6FYzY zMyy3GC&4OtKbpheihinCX}l3ebqa4PT`CqY5ba+r^q~9sxwD9dpm(c5C38zW3fxwP z+e*84K08SUY@#4L3cx@L=2^I8dQe_EMg?oP!4AIeDVM`eTt7u66dSik;pi0+Fsz9$ zSsLSX2rA>Mn(>dwc{$>bxvWgz_^ahm#63KQt2DExAE*((7!hprJlH*Qo)(N`Ba&CA z_#$fYg!PO9ErFRU)~0BX^2<$tEVjJjOhhHZUB^$B_Iy0g)Ej2FoJ-RDQsMq`m1CT7 zr^7A3Mu^<_{SJ~fJY~rKBl9Ea;uphJw@1@`^!4J$2^k|XUFCm3pXw6INfvYiA8<_7 zhgBs2S~e4k2Q@T`K1>Xi5R)-ch9OiezX~|FXQZUY%HnWKkmj-FJ?tD+R~-f6ch6Hb zPm7VS;+iNkjbAG9HK7f00o4MU3W$IjZ0b)NM0^O_2%*6E#c+hMu#_p;9wl;~)0>Cj zFGru=PYv+v?C#4A+bgQ^*s&Ex`JEH`#yxtPo--iC$GaNhjT6M8+|W96`Z}^lBbJ#~ zQgTB$JJK!K#IBUN{*eI&tefG1LJLdk2YbdD;4AZyWL*#jTTW4YC87+YY|MVeSkd44 z<}w2iJFS|;Q-!Rl$kKhv$LHy;GdKCjbG`!Wh#w!~gluI@EA?Qu=c{s?cs~?=rg0$v7;z<^O#vOlzrjM$x@%7k`Xv?=iw;NwUT2WzSR^YtV1JIMwM()36pCb} z1j5fKYgj?in07fmt(xAjZ42S|WS*_Va7N0OAjBt8P_&ex^!m@lj{mV~9q4%6Y!32h zpyGnGP;4VKVxY#WBK`ryW?$TgjLl}>2O=--BW}Qz1&FMygx{)y%-*6G+6n5vF?oJp z_VU=n#6=6tw1LTp%42S{RCO>!`>Oue&;#=T-MOeEJ4azD_H>qOK}gaU!b_4g<_MDF zt7uc?ZM?hjW0#{`Ppu)zdZq&od4};e8~sUcr9?2fg>h0$`ZEzM{%kW7&L~w}Z}PRN z)zG7IP6JfwwGMjdVn33!d9*1|EC+0Odn!@z+dUKoq#+lO>uBoQE4}E^KO^r9SqxP*{rq)% z{WvZmi|!0XV`&%|aM!m{^X315CW`-tBpH}3fBD?4Llm({_kh0lDqu^ZRfin?&#H6y z2~#9LU<51e*__CW@9RB4QEebp(lUSQ^>^blj_Y;XUhg6zafEhNXOF5*3}d>CC)!+V zvbf`&LBW+(eDH`Dr8O5rSRLDYM%=g`QUf#&fovhXoiNqsAfBGbm<2c45V71#`1Gb$ z7S71VNTgL~2G>lA{4($1OQxo@n{*)h08^cJqwa(^3FSC{^US4pRh zW7%#WJMz44oS#Y1(wfSeA}wcYs;df;Lakg}CChGdcfzP?7YDW!>(j47%>ADKeN_>6 z`4DQpRb#jb6XOfcPU>d2@KOpFas01lZ}AJ6Jj{WAw1Y8c{5&>>6J(S(s}X(`s{5RH zIdNJezDyScf4=Wj%4a8TsPBl10+AxLDSex4r7`5-TJsaO*O_$n4S(avp%hIgi#*SKVuLSMuX4Y037X#}L`&YgB`;HT)$ zSRw?|y6xw|4FfHn$-Mp)2mfj_#(a6me>`2oA1+2-ImK`Jk<0dET9)&-=xLTwKHXv0 zAlKx3BaxJKNV!OFP&Z!@kUt>mXJT5U=6|-1HOGvjH#>>&pse!u7KvZASu(Bv1M(?~ zHS25*B(L@w98D+Pb&x#Di6x!K9!V@pnV|NB&IXEwh+N;s9_e)b$2@?H2#ZA7D*NT1$96q>eSRjoSL-KbrUBd&I|`t+!y{lY<-pR zP1=9Qb*YJb?Rg$BA5?m#Un*7hfdud7H%ds3w`9w=0c=Yr(MN&R1RI{+=g#x{Ii9;e zT?Ch`u-VZRMnQR7KpIF8b?VMSe%I;Z2l8Ch(QlsB6Y7ka-&gPm3&A&eGjo!*S+)E( z@>KD%s<1)PY0DP1jx)2J zmo0tqMZAcCw;5<}!oS=5ZPg^XcZh;3w0ECOa;qfRWsc_tc+8JaAv@SdKzXH{Tj(MB z?lP*A`ZJs~ln4)pJ1~J|TGn$*&wPi9AA(lr&Bc5gRSAx%s;I9g z#`GF0SM;{bfuuvLCQ_fvigzP?oNweUFOO+_tsj?Z#i-|eI_7LH6soPJem~`rd{r+U zm-yP0DS}j=tP-kliX0}8%mzGC-hU6B=)Jb)7MXMc>IzJYI=|qZP{!{&tuql%(gXKs2oBtfHpSVk)`l*!6N#ncT=TC#2LCPy* z?4}yj@eGnG$B2ydo?H5qL-kWwb@`ep!qfm^B##4|X(dY?#QMyYjWnU29puE-E?brs zHZ36m4qo_S_xj+QLeV=LeEj7^9egQufz@o@L#k#ayD*uuCdhqhF_kOh?$&tSY;&MxZ)vmJ`R-(zPn&Wp97D7rUGI}Fs0ezZH0p}~ayhFo$w^DDa&^`U@;2?XoKLc_|MDc+y+?gOf3Lp4PsZ zpi_l{cn8Ed;s8Opchvw8Qv4l4DfTLLuct0dH_;le=$xv=f2eQ?c!?HPrE3Q6$TomN z6$P8^m$HdqS68E5J-sWccOJuX5$j*KKEbOqikZL6dLtWCu*e6y&paD0Xvb_h!}>x9 z<^6A#;PcORFeM7(kp$Nlb$M-9B*6iBe2R`zDM2C9R|Nn5a#AA)gIb8f<0-k=lz9?> zJ07xujbo!-UbnWT`Kena{SmfJc$x+eKC;h>-xM6tjHdaF*e{$}|F!|M5Pj=;TJ}as zc$cOs5Y=SsPIQ8r)XlJHR z&Qo*SsG-$6WL>0T#QsEZ@l}joD)K3Q4_cjPcCe5u30l-+I3(mKCghbKhthu1Z^I@n zwYIjdvG}4s@#L~m2s1z!q?CWnHv9PlibF}>YBEsHU>1#eD}&2WD8;V*-sLOO=->2b zNhYy=-Vh@=P}Uf@;Gy&?rKz-%Ze{z#9uvecQw|h0y4+ zT39Gaxr7<}EA}M4e>^NA?NraI`ZEfg-X#kp$uMY6VI0K*-l>EnXDOju@3l>rCx zhmBAve5Buxn9}k1#YtcJjJjQ_5pvT(@EO?FSikWSl(l#`Lz8ZMSH&HgC}y6=Fo}4@?iW=l_ZnmY1XLYi?h$#Z_kYmZL; z81HGpvV!In=^I$SVTp|Yl_C@OWNWXTJE4W0ltWYVs4mTs5WibE6 zL%t%#_N6^aWkEB7%iO?w%4O>G3~xJ{2Qn6`NX&YuzK^gF)kEB7)CsI*rilQZV_tQj z>3FH=KvLX(F*x;Z;$_P>ONHeZm&m@>7oQgBQK}1CI`nR}r@=F5BP(N$KY2Sle!}oK zHS3-H4Xg;C&vU*X&N`rQ-LDZI(VwUBGHwWL>+xs6L3mnC^+7awy}d)YaH((>gH64gU0(5gyB%>kYr3PBd<*oF$rfWU0^m)^OTHnJ6b61 zsbspn=o5FWHxTTnnSNh8x-Z%AK{l}hy7({vaOfl`Il|{8-&PtqnDHs?Hpf5&RE-ga zrBEJT0nSoXR(1s|8U_D1vxp9J*gEN?17Apxzo@*+ZjH zi9?PrDdw{<%EAZu2bl*$SWY6dYPo%gxyt3Ejj6sfjefQ(3q(7K^l8lTesN;#>Ur1y`5<`B|(X;qykkfd8 z#NixYTjpG?7C8S6H2I@&qpy2}i!o6HL64vlwwfdIk)I!wC|Ib0ZMs0rj>RlY z%~*9_NL6*BJ}7N-lgikW@~i8s46MYYwq0wN2sg~Lq4FA2*(}-6I z>qgcc8k7o^a%}SpH;h$+h1tjHFBmo5c!}_LYkQdsU^UV{8|8|-oIqJoilX$wATE2# zFNT{)&j%z(%~O*`K(Z5(g~2*TjyDUfCErWm)ngswT3KE2m#?-(&NJc-n0Qr5@ncm# zGdMa3EvG9!yq>Kbtf)>9-U@F30ULrp60!Xk_+2)hfn2kC6BsGG7090omlcN#CGRKE zFTC*yf3C{D@*F~;kS=>Xm>W`d@>nC1p)B6~KD{&tN^lIm_5iU>UQC!_2!VCyfg{f6 z5-w7<8c3nBG;Bl&){=qXsnz*d1={$+6ac24#8B0FHJ6`d+%o;nqq?u1Z@e#k$J*l; zq2~naTB;{x6VH~5VIHf1&)n2;ZE13O1WRq|SX^^& zNB5M#4JOxXyqdnRQCyG&Q6--yZHpf43#jIBg@)|6>ase;@f|&kVk3=*FT<7Bf zJ4ay%iMLlPdS4U~M2y8}rOiDD(P`Q|?$>WWbKPbtcYoMNYVdgjavOe~S^r z$#-x-^oLlQoheEWDW&7*=GfjJuKqWXs|D-+!o0~xvgZ4(#AGK4VqKvy*1T;!wfG-F0zcY6K$7bwAqdV9WTZKgw7eE_81?j}t zd@>;7Llq-basc@I6cxZH0|d>f0^Y4wX`fU9jrzzO7tia~NGF5ML>&KoZ~r)JS5^;9 zz2}W;qux1i7{qFcd)uo~Re1+eFK9tHb*Yjx`SNa7XYru>AJB^?Sk9l$v=i^U44jQ8 zYlP%W=C<$kfkIdwgzUm%A!qeyS4PF(n|&|mWD^!zpH z{Ov0trgm8ADaPHk`hj3nYC+Jb^bf$K#c1g9G5?G64`?TRcLr9OqqTbP6sRveK7kxm zg!j2z`^sOeAM5OTOva1L$dLPWb0n5+_Pc5pcq%?)(9x|0#oj{Gd)+1Qc?0Rs}D&Tp42N#DHU;$nccxDO4X+ zs~k;YvouQ1h^r_jC06~`W+RFEk_u168AL&_l(K_rO`E-~{X_5!-{4)HiGvS4A3P?_ za%Ef~LRZUR{bi^)iXxXfa1LIk1+Jd=udCa^?cv2mjdf3%6xL0d4&hQaB7!Yk*>Y0q zd@q0V0RjM#XKyE(r5!i0U1LZ z4$D*pvkC)l6c1j3l%%-n|N9085J0+%iM%@}p~(a_7eNNsDGu_l?TAp^a}1D{k;8pX z_M|FJM6JE0y}tK@2Sqsb^Ina-hAVgjk;TS6qtK)T9zT;%;}bz)*|EkAVJDsF!E<*) zUOXr8=YO;QdUC4Q{39~v2t6m z=e7%gdu378<}Pk#aEDi@N>=YwAcj2B73N$A(wO!22j3{18p<;Ih)*l?L~YD5D^7DU z)sr4D+2ZjPdmvT}5-Zf#zIrAMBwn~?<;x!!OuYsN7%rL{n@*u~VlocdBMnzS~rz0V|mjaENoDvKsYifTG z%rwn+<+HLQrHD7Jg{elsu?E+3w`TuKU!>-}o6X&{C7r6Sn*LH!Z~FFD{SJfWRw7af zHS`y)2fn)2-rLzz7w)1zB}H!#IuKplOwE3di9sFH65_g%!*6fdJPnDf zkF+n0(zr70-V((ueE@Lw*k?9R8hK1*9c2zRVGV!pfEBlgvGW$1Lm=4bx*>4@hSKoQVp$2uGi8RPCDZq- z)U#rgNvoKo{%cBb3v?E_45oW(o`QIST}zE&sh=Idbm=a1TJ&4CY*`M`c;* z2fP*`8NO6dr13vci#(HUX@vTDRgZ9>MW{h%L@0(MQ5b3N1E+@mH53RCmLVzU=8s8v zo-VigBK+TuUvU2-`%qH(IS<8k6xS>iCC(azFVB>u;mLK;9Q&ScS<>Z`H-G#K8IX-d z#<+rKpEJQRW6@Z7P$ZHo_TaSbtcz*JGWM1jng$7~z8P(@p5o6KT$zPeHJpz>r?^FU zmoeVQ?d8hD%CFDPu3s%4T{Fa0gVe#70+l?OnZP?a12cx{&IBzq2e26{b? zry8vS5jFJ@)*>Pk0wj2kXz&i@T?dI!Z&rTcBDEOtF0Nu&H>qwtvQS`JY0mcd-`-Bj zw%#M@s&P7UDse>rr7Sc`8vo|+jK@GKv#MQqwjBx!O$F5iQHWheY~^x9TiDu28v|%B_LwLfBjHB4ASLpyjegnL(vnSr6k7KRRy0 zl9W4BHej|*KmG>`@ybpu`|yxiS+R5RkO! z;l^H5T|=&0P-keQbebP&_|8y%jRBcIAg3B3Iw9zxb}%Zs>2~2zVH{#Q#(|f&bo0QZ ztfP=G328A#DU<3msG7hB&|!Rn|1GD7;hE5EW{gBfF*^*@hkS#pcr$B8!&Qt}ks7`p zs(>7*r>%07JK)f@QMP=|%v96aPgZv@4YR>Y{RY4pqz2V}{k0Dsq_F`Xx zzy8Vy(C!oTD%Bz{$VC&>jsS`3Z9kJVwq%}b1O@`e5Z%ifwwLJf-_WT1slsStRKmk2 ztmG|Yj?Fdep!XbPZJ$j?auQvs5WqTf6!+ov+wz0zGFX!F!-z(`N%3#eX|$`by<6Ac z!_=2j6;C>yv&Ri{aVyK53VI02OT%$~xw7qZtgWBrC#SF4nxLDjI++y2{K{15dKlkP zy@@|78|vNT>b0i!E$jQraeR56ylFA#7=@GhuBsV)fK%<{w; z^$gB5o!%;T$nk2VfFK|bJPnbkE&r<1g3i{koB5ZZ7PTxug_`Q7??3@MM<;l1y?YHU zbSSGDbKp&sWsB7K8ehYgG%>4N0ScQ(9RKtWcCP1R&Qw<7?7bBQ1%p8Bcup#@CR03K z=g}iEQaywU}9HROZKdd0Tw>aB?l!PBv>y&snR%WIusW%3xdrP6OXVII@?U^V} zh#|xGLDo__vSBDiBl1k&|8&&{s%)j8&5`DTPi#S?ESYsm)ztp`9z1Cq{}DiCp*UjO1vm3^d-gYi^1z)8pjbCKBO3{mYoF^qXle=dFBW z*Ua}iw3FnOt>l$;I4&0jno1bv7Wr>fs|I@(6hWl;ppDtCdRUmL+#jKiY16x5@ET*K z3sv1`Fufb-K#K+&eZd80$ddck+c7QKSoAGfT5r3M zi~z)n*7(~NR4H4&-jR$QosjO%e&xt41~lF}9p7I}^GE;IXSzs%q1Ku8P)VBCMiSZ! zF262sI1#7eU)lWJM#1b~9C>G>klEZ(4=BAv6?zuWyM;Qi3L2v1RVfT1p$gf3%vX zRmkb`ZIwEF5%%#LialV-JT#f8;p&aI)2pBOi)-|du%Q+zrgy_8ktnH*^B6;m7}<@V-~CgP3~|T?Rimk-(Qj{W)I7%rW0U@o-S)ORgXALW zKaAu+nzMFKp-huLnFznKui!b3uR|Dk1U08w7X`I;O#Qz2b3ni$oCl_xJPh9Up%Cz+(=>wsdB{%$}eXk8mi6 z(BmVa*dq1DiG#DZ7zK}hU>L8A_;P0E=F=WJ87}_-To!*?51c-vqCS7CfyRIa0FWk# zp}j44`uTENV&ICK{&UIvN00$gQ8_*C3FAWen3{W$f7AJ@Y>>C(MYrV=mK?MN)djaS z35q$OePjd}e5gsNN4;{{WJ%#C^Ho9|18KXW zTgfahoZ%6}pFU$e8;Jxg6od-!{4qEa!W6=Ev1{mv6pmKIpK0ZnW&QmL6yldjdFE|iLC$gO!9Q7MCnkrGPxk-IsZ+{;$S92`Mmt6HB~&4@{{ zDH<;TJ@LzwF|NiiE*PTPz)?SeYt(&!Nu6N{hLehdN$}X2hOe-C5qso5tlzyfh%HMcDWlx%4r+iO$0(V+KKC1E{gAg=uPrX zn0-EOARWPgUG-Qc>}jWO_U6EqC0pBxos^@y>^IfK`{0k$2lto&Og8q;Q9ni5@52an z0aujc2{}9zD)q0KWu$A0v19gomug$3arA~gMLx&F;9{80sWw!{BJRb6pqah9$tq&a zcv-{F7uA*|4e$TlAgX)P;-zP~Jjlj$U--7w!)QXPM=6D?+th{Dak%u=@BU@zw|>5U zzCQkeo{Oa;PsfuGe|K-GR^y>PV)$@G%y|W`!qp62o=~kkh!~)pktpg-SHrSU9K74P zuam_XMg5AjC`>i1Ffs170UrpI*9)>xxav`4TTABs4Igp3i;hxRegqCo<^v8NwKr4t zTnGP9!wNTisOFR#j@eBWo4&&I?R21}((3~{?*DUlVAwWk(LArOAL(E1jpPD(KZPby zu+rv$Tjb^ssL733Q852%s6F>SkD^CWPi$X z7sPqHdUs%_nbRx!xsf)hRY#-|#H;T@mg*8u_SoB63eM_Ix=s10Y2DJ5Cji^JV{i&|^7}(oX-_E2v?-_M^g}S+!k<(5=(?QY^XtOWaoccfQdgYE zEr~Dh!H6B{V(l0zhe9I74RTYe#E}~hf@dlDt{cc?%Fua=Nb0LE|A0K5d3(xs_HUA( ze>}_i8L3u2901Of3MN;mFts;o>b<><{fyKB-@>hz#Fq7U8OgU6w*yR?nrF7i+F(IE zw>K}0^B;_YcJwjctnpS4p4BkKgA-&s-hCj^H3A%QL9{j!4=P8`p@6#ecA4(cBd;N3 z+WG<0C*&`&^yqH;3Y+U6*z@d6Bb7DuPi(}i_5w;t>Km)z{LHQjM<0T6hx>?<%93Ho z$G&8;Hu=>W&~Wya8@>0j1_Mm~Y0#=it`qfIB7X?j)_*-a;pn2|Ck8r)qCc;*mOZWw8ANeLcrl1H2y(ZUq*X9Xjbl9q&J+ zYYs(I_5B)U&EvZ-f8@x2o^Au2A%Pd_=@#Q35Ow~c@7tQFvS7S_{ZR;)KHz&YqseH+MF!^ z<%cdwYVB_qB}v-Q`J&7}NhWVm_FJQqo$s6;^0H7^o{eu& zj=R!!uWo?9jm{!JS>tC>#o7ta(XPq4N5l`6fP3j-&XM}IDQDN)o=S&G$250ig)T>v z_=t{s3&0rilyT}ASYOJ&FRR{QLRgfAkSHq^naK%9V4kg$%7^4j1x*>E$J8_%9=4>am1v6Zc15h%4ob z(!&JKWPkUb8y3CbQbu}|Uo154@G99Ftke96hNHhk{*OYn^{FJF^5N*KtKC0Q>u9GcM<%h-=8#6(Yvc@1+avSgra4K%m75?k&)&LL$0nN zuP#3#&!K~uPuj{U%F|WcLMs9`uoU>X)`1725G!@>$dn?=h{hXFG6WF|Sf;`yUH^b+3Uh;i?`OC%aNT{>{|7|xaU-y3q%dWIhrVB2FW2-!ebjawN&iE9tugiE z*v$9JR{Ubi5`+eI(_}yNp`a0}%&deC>aJ%Moe=$nB1%#*QNeud6JNfFwH;q9|A3lZ zk&5fNyA^hHH$C>$^s>9)a9V@!COM7k^Ewb5c+f98!SrEAy9t0uQGeJ)0@C-Ckeetj zq$VD!6-QwRzwsD~iA&O|$NI-Tj?2q8`-2qg7kX#K)2Eybzj&N?a{J_to8#j=;@gxC zQui@MMF-xRlBHIqd@4Iw>UY0k0nBM(#1j?9?QGn|rIqT>Cg5Wt>PD=A`!#t%Po3xV zN5UIF7hoC{0d~eV@o$wv@RuD%xKgv!h@-(xxL~cjz0-X~>`a9cu>KsQQh%OQ z)&_ovfBi1C&ti!946J?5rRE3ZdBq~$Ni;OA-ZlH%)ZeGu!i3>ch51b7xzpnUrEdg$ z$Iyj!>NvHTY)_~>^_(<7lSGxurRsVH3^d^sgoi#0`fd~Dj-)Y=jbvidhlz|X7n2=@ zwYFRTquJT{*0fAG)(p=zCN();i=S@fHlj%qivI>yc2rfx#ePT`7+M_3nV0t%`(e?< zvFRppg0`>}Jy|Gm;6|9)7dJE{P*F(ZAmlf}zxy{*GV`-!ws&s0g|S zx4dU6Bes%>n}(4~NvrO2&B8fzNx`Mu&kUcYVMeX@_ylG%4(@x+4_8+eS^dFZa zV&Ep*$I3cf^D|S-z0JhwH^rSD8FdBZi+;X^Z0*u`8g967JJFD*t0%1&A`XR6HvG~{ zLi}MKn%$cAy%ez$;;j54Lj={yZ-}ngNSN{)g*XD~3_|x;b4>fb=`QLuS?j|NumDhB zk5w1Jvlo7p^!eUY$Mdf^=;MMdzANipjw^uf+{A_^gaqr9vts?;Z%#X#iAs`S(cjfSejfS{+-%uV3@mMxtx^qcLq#r#s*(YNTy0#7u1Vj*%u?5p$DS0N zm7q(&X9Mfwn*`b~$U{{9OP;XVO57Gk`b!R#a{C2sGY4KZF}<&+dKP@yd=vv4`tdq% zNWfVy$4>UfI@WfD6KBfVN6|A?yoE!N*??ULh(9sLy+{xQhy2R}fOm%6T}zv)806W> zKrvGS1l-K$)Q-N$yOFo^3$^Xmd>*RCVazf}s36#Rk0Y0ss2zbq48Ts>eXnrzuX|;; z&amIiEz7U3KttxR3png_Ct*M(?8QMq5oLVCi-TvEMYE|Qo({R}pNZhoVtN~5uyo(h zyqVt2ySQHjV5W)ogdb_)=M~RH?P&wb7aFM$pX*yGT=p}UK|>Zi-gBy?3XBR<^-UA*HFymT4LIh8imHj9={H36rTe^qe}&E3rH^Fu2_#Vx<%bD-^((n(sEaMlT;IWH zf~U#be;hxIv6}aNWsp&21!V*3=ll|pNLNxkGx(aW(#f@QQJU#Iq9`FC;uVz}N+_?A zQRBC1<&bHD@!fuL zLMc!_t~r5YKuuo3Us>*mEW^VW@{Wx0#-q_sIXMO`qRw}IjQ0JfrPPb_AN75U5RMBP zHyVG_(_HHq8m1*>0I?-LBd0+8$N-JwB>Ng{O;<{N>?xp6O z<<0#cfAiPum?CP!zE5bZ-)_b|Gq=n&{NHB@AMcFB2T z#@{^12*uj=&d2xEx`^M+v-!cPb#R+bN@;v3d`rkkp67Dhe@LC^M?;mkBDyp4H_xcP zt1ZTBW|c#Agq+UWg<^hZN|d>o)mUuLw_v`p^82CqLKIAm|4i!>?fu-z+dgMG1#-f% zhE9X4r*#b4yW*e?Dg+|-09xr1dAQrZMF$2qAjCVR=RKRt?g@-Qw)LBB9j_63ts!+G zz3ufuNhBpnn;@FeL3awvY!@@pBct?I*m5o-5b^%_^_$UCjsKq9VYIPh*@uy2B^M7~ zvQ8&qSM=r1s4Dv@$E4!iV&>keF{f4?0is@)RTPU{(Q#f0+Xm*zGijK`T=g}k_6O2k zxKHw8gGb3p4>mOkyYj%OAB&h|D1M0Y0@d5|(Mz>$oXYCp(>a_@27RXt{@%O|5Z`UT z#BP&dPJn8T&z4G>v2jP*h$qe5w{Aj%N=Ce~NDPc0uUc_EjR-K5X`%BTj<%|wXU(-5 zTQ5O;!_$I!{Cl`>Y_;R8U(QrR-a3^@YU7OT!xiHSf^r!tOCL;XnVu!Vhf3(&QJbpO zj!t|e{dv3Bvx2*N(A`mD7F5!qSB>QoGK@_6x&}BK4_UGC>|5IHjV;YHh=2)_@)&&y z?Ci#?P+#j$^G*Apf*4kmm;L&li++q|?J%n*LWip%Djr=+D#8$a*x2FZ03hZ0m1l*7 z*I8(TD<9Il54QZnJ|MJWg6Q*g5`uMOy~@D#c(p&QfcaRNTX$YGMZ-X~^3HV0e$Tro zSbf13Ta!{@`7MbaV<^9WK7MA4M7VJJ1^Sj&3#>JB_(&}V)3&L}zrCDDnc`~&vcmeI zXB_M^kRcl*yOJvQt{V`~jgb zJg;!JYi|VlZ#=xtvN|LA+^xYo#ukyNuzlI}dTZR5ggShozQ#ow*F;6o-WyMro69R* z+49}z$`OWF@^)5xqNv&Ur5I9`Mfu48Hvaqn^7sE-6TyLk7$a;X^&;X!RN{g}tx4o5 zdDeX7e*+Hy0--6>9Rqj@R%yJ3M!~GB zA*cVN`u+3Ej~tE_4(34}ba&aSUvH}2OX3+$ifx)~IyK$KE0Eo&m`;Kg2R_;s&3I$N z$p3J7x23K?RwZCWyf*ISXeQA3JhQ;L?pz8~lmd`(zPM!ezkIySIeJ3=07gy2f_aZF zrSSV;>223*gPZgfx@V=3&wAr{_@Wj$aD(%79H!A7CKS|vL$xok9u_lQB(lK4?+;4k>{?1Uv+Mkhp(S^CV4o zNl;NU{ZI%%HpImlF5Z84KD{F&T=UmrIiu85SJ?dxuTW&9hkm2~(+0)^Xca}ZNhN%X zBTTg_y`R{d-x#GVbMIn2%?WnuN4D+z-S1C_T(sH(?i_%v^_z)*KxljafT9cGcR!A{ zaj=34rCUNWRD0aiZ*NjGf>3>jsBlKy9S=CG6eSj0P|>$(n*aO~`cZC(v-Z+JQP4xG zbcyAPYA4LCv*n=0w zf;R6<{eUJSu`a%KUZ8wGFZ{o{`|6;$o;}~e2^z=*3j`a21PK}-5G;5I?(Pik?gR(~ zmm$G}yABQk0>OQdFlf-=8XWQtzk7G<-hEs3s`l-xw{`#Ms_t|8&`kF^U;lo-wQPrx zVot18FZ?z{F0H%$_7>a2!I`ABjil2Jq@|8SRUP-sI%h-yLCarYu&jcs zorj<}kZ+0WD$75`5^UN{6_1owGB{+ z?*iu%vgJxnL3Y2FVsiO_%%)Ovig(sS;FgodN7(+A7LKSnE~PmAQ>@t)5IPOf>30jQ zUrGiG^0)Z~UgObp!=!r;*B)S{HR8pPnY+xJX^fOZe_j-lQe@OsXSxLH2#;Jm4S_79 zTxs|(0S2ehbdd`jAl*(u8t#ZtZ2fh{(r`cwt4A`I6YDPZ4b=q?4hPz#+BPI+kc@E& zCyxB={oKN@T36$g_uioWd_-(K4lM@}_9K98Nv7X1g`b(}OZ{`{T^6&4Mnb zt?Ca40IFjm=a(k;DYh^F)xhD*EhymlBcQ@R$wjtv^xi~xsv`|u11{0oHx4kQOnA6yG=9K4hNQC{I8lVy4GiB?KAv=d@hOhYic zr+jHZ0hsUz@00-)xK&rLzec2gAKjMjxBmkLB0s;PX{P%H z(i0HAd#^Tw^t70QWU!ko1W+CdxtBYVzsGJe1MTYt6E-e~glM!@;s=ZYx)xInK!b$t z2f(2*-4i6?(&L+ezSku!^82v>_8xR=$;ys|1FoCL?d8eY)1u~W>|=>&klTc};CD&N z3kw1@r1@o}ts2(7;S- zq$1Bc61}*4)c8z|I$m==+hm!4gkVHh`JvsXDib&>kMTRHWxvpBpwwK~i*WorfdEC= z*-;Xzqvh#*rEL-}Q%C&fafUhKCI`(Diy)VNT_jl-aQFpC0$VB!V4^Z!s5AF(mtTAy z0cT&D4`t>20dW&b)HhG)TeL*%qsP6F=3jCM$>ONs%fx=2yTKT_pxH2eDz-rnc?tUi z;&C>5p=l7ll56{k#W%= z*dr#?p-|OSfB^G{|G_6=M=_@*0%!_S`);Zw#`3GY_K-LxJd#meT?sW|K>I~U`r&K) zreRl+!&s~KQ|u}L<`H-ea1{Sq0$uB`C0>mV9uc1TA7AI*nfX%!j0sGAAo~aOrOsMK znpgs;9l#P`6WGvW40Bj*^kgP z>!@^;ej(Rv$w(I5S4EY(b_X;IYoincX_LjsF2I68Kq#R)hDM<^{U$n3=^&#-ku9c? zYU}s#w!(v>p0EZ%b$HEgBVS5^>W0KI`%#1aYa^$O-oiGmwiyniBUT;Wiqu4SeYA5e zZ_juAvJwg3yx6uL?olHF(32!hj+YD2RR*hi)X>6>FtLDWV@IQ35$!p#q%(J<@V5D^%9{1k=-2 zWzn;l`_CQN%&@zBFwo76j(y^RfO+rdjEYm6jZ^!lEpsw^``N+IgVx`gOGghDt(C-y zMb~g{jTY2_9zSdfoWK2~K%Ge%klboNw-eL2=5nBSnhLA^1A2hm+QBG>>tcP@+{43t zL>E1L>;`fa9_2MuhHX%PI13vXW@q$!rhL-Bo)g6CTWgf=zWh|NKnAo^94}8f9zhpx zCiQE;nQ&D*)u5ccI=A2DaSp?P0$XdGEXM#OMk>1Ju#lcbhJVd8NWB$29o~s_(b_tK zo_!~WO_Q)z-werMp#heU1JNg^8kor|rFYK6dKHfPO=QNr#|82LG)La7q5pU-Ge)z{O|W5og$ zg*g-0q*s0!zSG7p{dnTXr;V;{-WUI597?IbN z@YOftq8H^N59$z55g^-dbLk@OR(;cKdwvx#Yv=ZWgeh%g{-`A?JKhnnC16x_6MBPY z!!~f^HXh`r4BEw316j+B{J*>?eJ1O=w{+5=GgrUsGFmlBX9VY1`Gz@CntVUWH}Ui1 z5XkmsZ;J|->@($e0ANr8pj#^xtDGVm%@e3M!~PeHN@QMrXu(5=A7(gQqWnV3lupxu z9OHWM*KC;^SKA|tJxJLvHVWDL>4GB<7S8!Q@ch1ICY$VZPe26or!oSYY9?kAHWXi( z*3yMJQS8xH5ePg_z&_6=2#btFt~_tivNv)(914D8ydcvjk}UsMxkaM3Zla;M*733$ zOA~I;F!1GV%boc6m`%4buPVG-vpCv6ASQ2*L9v&U09Y`=L|WLZ1fLm)pVwQwiuhaJ z?>ipYm#t(Rat_j%-uyxnTQHTnCl3q}9jKqt59hlXg0(ut4HXY)nv)aN0@!Y6kyPn+gIUdv@wdm z9TN!;B$#ndVIs2!5p(xp6&~{%C`k2?<2f(t=2ogh)rc-En%eQ_By3g#NTktCc!qQB zsJKi7ig=gsE_{cn;wQ=qCwbEfmz;R8kKeDa*>#&4V@{niFrn3IXetdzFq5NG1~WtB zB`G-}%5-^FU)0r%m?%LQuLE)JlXCv6ZS%$h;Jzo_?PoZETV-59ALBo`j z|E9l15YQWNtay(CY*bo#3!YS7ZNFs9WcUNBQlGhtv}Qu13!09^z#ss0OB@{#^JEen zq*}~u^-yI(Wei0gP&JJu*}xziz`u=J<8U)xu6xN^%=p9Jy|&nh;FouxRDj@giDs$? za^E*M7_D zSb({Wn=pJ3e_D<)S?ND?IOu|^pFb!{@k%p*2Sgx_*|&TwOCQPB$_mS&B`7aO!A<$V z{pK5&)KUtQ;|rONWpCw|p(_5mnv= zKYBTNQ8J;U+gWHO%f1>Ncx;{}p+X=1Bf=_f8T@ zOS5Bs4Lp=zpY>uc_cW3Cu2SDQ;490%U&_)^{YF!r)P9cFG3}by*+jFgW-Q9am+6JE z%Q{>_`}$AwN7sP(=ubXme?UV1=YYc~bp7`otf3D`=U+$O<_J)Mn4HD1$jDBC-}Cl} zcYddEdwN?<`Zj%pK%gH&J&_kKIcXfM1zS}x`|K{eft06pJ7p+<#3)h;6j66+Mq4`B zCT>-K{P328Znn=5dd`*kc~zMCo#sbbV3%#g(`hxhU7`~eJ;n=fzDku3cVB5lcz6kg z?aR=4RXu#>$PGuCi*-@kY-&TCRy&^$x-bk?Nrexp$I#Q4?CUv8563+a#^P-jr3dnW zrlhEzylV*4qN|NCPBLD>Jto>}$flN?*d$68Ud%N)pEkMB6H=DoaT%uA*FSzt8yt%6 z+iHY1v!iT-A3%^*KKDBNn5l|enl@VEna92|oZtoKt5{XtBj~ha_YnlQuFrDegoM68 zc5M~yxYz*sfP8jE3i@c!S@Ts&CSe2PNzN+&0g<9x;nG$O?Vwd>eAIknBi;`Ki78XIE6NJVzkue>4Zci5n( zkK)?HYxUJoe(PLc%D#G->|=Ap)tw( zd3T6gGQw2Q{QIn^$TXLixnsbx^hrU)!5%xCOEK@tq8NR$)fo0bkx@S!ts&jG!Og(W z&?b9+Rt8ch$ioiKwmR)m0k6g|Y;~+6GcZ5;S!p5Xp|JI^2jTB%;sW|OnU5M( z2iR)TTvl}^KE_G?%i-kN&@g(l-rJ5a=KMezVQE5@*E==63kD=k9Y?E2@g z&AXi&ks<$Y)PMgR-vD^eb$iP|lt1xQ{1}xfME*o;GR(P{(YvKJxtA`6yjfuN66lVA| zM#ChZ9;W|Z6J`(CZ~sT?Bc(f9B=Ic0R|U4YS6^{JSxk1^C)zn<9m6F`vsrYbYv~by z^Xnw-vJ(H4AwTR*l8^M5Aw?-OGn~Cjh&%nfe){0{|4yrgAaq*xWZWwcNaOh2N4)lh`O81~^4HH0 z>xmW3OY*euK;(VQEwAE96l7dwDSpgl=p1%vLZiAI8lHYSu8tJQa_BP{$-22QbZzfr zy;FR+(2XG1w=EBH@7d^5=m*LxNsD6fmQNQ!ujHTzS*Avqh35qA2CMaBRd*0}iO7e$ z|68#1du<#Godm; z0g{mUyK*=-8I}v+poCTg^roku6`#6fu#5q!;Nv^-FVldTVnQ)rJ|}&P#PaS_;W4;l z9GsH?3yRfo1W)ZKf&(4Pg-zd1v$v|}TJy#Is4EZ8Xdh{Ebw7E?0g{r&TCBxzKYc$E z(Bo~8Uw&b|s(>IK8-6`sH#AI9F{5z@wms!7c0|TcFxq&QYpNWl4M@kQa&TkWZ-A(p zdOU~qa)KUer{$X3JG>D;7&H_TmleIZtlvzx2Bj9b~$R~XDHQFIw zDR>ogQ_{f7=udysZ#4|BYPpHl1C||mta`}6qQ!=r?cQ9JZ{zjCj(sHPB*S3wMEvj; z?r{t~9DNxH zDI{D2@x3hTSF8=4BK@=Z=9;Q+84Co`R88ebCN$jdg7%k;PLM7GC$O11NH<3V*( z?V(R9@Sn98ZhPm$(yJt`YQ_BUhe{#4U{;65P}&EO)yBtdk{}a_f+fai2VN=NfNBL( z{2HR?jgL057dhYhRB{-2|CclW z-Y_$Q;}7U3SHtA!EOO)(R-FYG5v}{*wyS;dKsQMV6D$1mR#6tgVVe1zuMu{&vcVhk zGx9M^!x0yZ{_qJEp_~wRfpw~8Xb!^u>mbz-XH8z5+ypZufpF*}5XM}7#e|krf4GjY zo~FpF_x20>^2ENasrqyKMA!sQ&8|{MHP%Ky+3Iw2GgCI+^Wm4uhT!jI+8?3Hwy9HJ zU{d0;j&mUx_GwO0E}1_zUyD4L?{%R10ee(ZP;ynl<(sox!2Q%I-OH}QT`+33&JC`F z#p(Amd}jY(bIM&jg~BY=S`s&fC4sW<`v=POXPEqRlba|fTNIh41SvMfe#vw-O_3Yg z#_^v<#wiQHMMzu>)BYaL5obX;CbZDB&a1@N)kU3D?*)faBbT5vbe8-mkNITW&6rU- z(S!u{xpl85uTC|ZjS;kU*Kbp*%IEDVBp;?r;qcw zEZYp>qt`E)p8!ep5NE;FD2rw!6G~hUZ5V$NsOXERI>?Bi!?h4N>HCmarBx^Qvj{1Xb>q2W)S1AK5A8y>vH_W_9Vnw%4gm}*a91pug|C5o;2EO0Frb6?7Ch{U#8CEHL{Mi z>&XT|-rc)bh`KC3jw+oWidZn&MM(Ur02*1(BftgwfA84)*LC9c<%5&pV5WR9jt)9g zeqMgI$+#pKTSrGu2NNLmKqh}AGc-_Hl8pujxP<;!j5J(X6oUzvi3&@&NA#4_0bzgv z@1M%wUzq}NYFhF!UIY0{XkX}8_GP11Q^RbOHtriRp9BkXC!ctihF)R zDu}rtLxBf`cYfh2V$G8C4+moVbUCh8vielrvMzoHFxu|Un6hnS}*j^v#}*D8-V451CAI)_bdFsyOCX|eDLgz*yu*4F*fy;^T>Afc1%0ew7y`ealvp`)a{I{bLA011Z$k4WH<)T0wU=om0_bV9`N zm-3**daaO^Yux74w6-XSd`z@2k>l&Q7G=eyDk}{1zB-ciSm7^sD>_Z8Zfk6Y&Cg4& zl{|JsN9#9^GV|Ld^j+3qFU>PB(BCF?N1E@&l$B{r-}S5$F``Iyv7~f?JZUEn`HSrf zo9iz^jF!xOnnbGCiLuGmLN*e)&$hRF+{u>7a9iUZg=CC z$OJ|NitXG6z4rI*7$bF`mwLjy=$ep(FlV&jGPS5uv{AB6N=>$xp}(0=XDfAxIUqBb zXmfIAE7`vJCF1&|{uk0@mvd>`A;P0Y_j2b9z zqj=ABpLwW42WXpO*yKHa6vT^aSLI)j&vRv0&10c$ssARe51{x}JxY+Bf}Mi7_~sL? z$0ezw8$OJND5?^Rmp%G*NvdCHbWg(Bi3EkTP&pl0*m$t2jlDoGIU4yUS!akwZG^cj9onWk8cO=3KH(x%L*g9|Z!tu|bPx1y$_Edhr3UmREk4Xhmc|s3 zz8N_KUArbv*-cF8y$bB3uB_PmdTRry#hRKhcNHB`%Y=z5+(ew3Qo&N+4iXwm^h}v8 z9U{H?G;Sf73hVou`t3eFyw$`Od!OHcIqYR;7QltyODpnG+g)>NFrUr(_J?UDHq|)0 zWNtLrWF6|)?Zt-f?pE%a!!t2xVbamHFvj4h#i=nR6yQU|;#`&QUkR5+*li>{D%n=n zk%ic*PqUTN@6pG}ebI}N+Gi1dt(xyE+Bmk%%F50&)fPk7{UJ|Vs9`QMD1^56ZLm*j z(@NX3O_e&tzHO55Mw%bht}+Sk#@;}U+2I3eqX(<}!qJ?;xo?GLc$r85w0U znWjIZVr0=v_FsWrZXlU(6vRwg8a(UUQ|9Rd_C+?0k^LjO6t4yA@oFt)EF)2ghTQ#4 zfr|6DP0g(ndlekE(b1FfVX)aeVzRX6eM;(b=jM%gud-;9(L16YE&Kgi8_Y6vTgjGe zjkv6@WT?wbR8AugXi%TCNw#XQ*a;$ky{J|orjn9(Ga-?+fUqAZeR+abperoeW9pgX z!-fYV@x6ohOjmI4IU7Y=N~3+&0-E0FZ+soXFFBM1vhlMB zWecKRR3gVK_bMouG8JBL;jnNFp%-CqdeDAgOeXKFfHm#NKPeq0t8e0k!{WXhpYg9I z6?>8A5e$hZfS#xkxC}Z)JsKOkKgR#34X7~(0BNjc0+psZH4U$rOS1v_{-11jC}YY1 zvdjOlhBA6_a3{MN5wQE%?GGp?HB#uG?WB?*vx!JKB^NRANFA|v*%&!Nk{~uVntU)e zfK8okEH5iBiYtj4X~YJ`VFoS%7Fr!SCcu^sFg*;g5~o#8Bsv?wJV7cG%D}|`^BJJt z?~e)~QUMPofmA4%3Q&O&4RPGK3^Xt)ENMas)gvz-2$)Sm$U&J<3O+3`Z`^BB(PaU> zrMFCD?Q8hZKOnu7OO@@_Tk^Z41*|*K>Gt14s%R=ns*-|1G2o-O;3FBV5dAhMv~uWn zgU9qD-xynNtFfiWSuEd@$#PQEV}Ty;#2)B_42H)MrEK4pA}W9)k8qj2Pp!cL%-wTg z5A4&#H``VFgcHA|G|c#u);CW@Ji0sKlF8Ke?5dI_bAs1km?A3eld$J=;5_xcUL@9r2qdvifgoYF&j!E4jD2G5JpD_-}t6iS75Wz*B_(z^rD8ZIGQqNKmd zK2kq|QhY>~mm~OF^yZpErx-3h9#%+AbfC(G#E0}^*78K_vx@wrNmOob^rW4-8zoU+ zH^-;cRl-1Db)f`&Fxy2Xgk{>&CA!c`$VU&CNAkpEdiLr)tLa8ShGcqFtn%BBh6r;+ zUi+hFU1{3)tyRs$KkN5U0$DwL8$oMF(}6riWj`yRcarl3+E}v>Wrgg}B8X%leBWLg zEiVU+5Pr$M_E4mr&HCzV9ZnKHU@P#$tdsv+M#(z@K?=}#PLs`^)#%F91bRxdjuAc|+V~I66>aIR-_5fBDfwmP;iRmM}~? z^U8ljG^5+LpFqmr1I^k|Y%L0vP(qYKO`Wquhe~V9XKv4g8g6?$hrxv@VTzSFMmg!8 zQty41evBM`nPBGmk;zkEpR$y|u_H`H1P3&hQzi7sNq8m%K3id#;Pv^5YeKb!!>1V8 z9o^HvQ5wDTk9G2;xORLaJ%-N!B;c6-XP`&KaYOqktF%PbnOu_6g@$@s7ZaOZ6Z7&; z_Gip~wkLd>Zv|u@X69KMlW%U&7ra237?*T3Rc~)SZ2#aZdHaQ-?R(UDFp@P0EN?&b zMchWC!sS(Z>!W95@u9p;fyU2n}+gEihn0_D$%ag zz`&DXt$B)}LA96{u9Enn{wLex`!IBJ#iP2>Q<)NdKzNA;vnUyxcaxJG5<;4+d@DQ)Va>@D9P@NlKje zJrpZIMZo}qZy&<%N$$Na1JGYQ9bl74BL8jnJw=AA+>>txpmRU(AKSm*06Kt*ql7x~ z7x4xLv^fcZXtI(FAk4IPJb(&An?0d~azAF^O9FBoXnA_J-T_UNT(E&}^t1>LgdY<7 zIGkJStKJDOZ7E&&{sDDoF8v_7N(D{lgOSQ_O}`7>t1Q@Y>gE2+g)zQ-D-%~T<#&ip zdHnPmI{PS$L6-Rb^OE3}RM8>bTR9&;D;@o<9tApil|LY;Osa|nek^NFamU<A9Mv>y*{vfP13-Of9bC2qMYVR5fi3d0BS9TYya?InMcMRzWa>Vw=OXz@_U3Db$D zG(MME9V35Sc=T!8(@Z$f!+sLU3w@w><$ybPbBA}VEw3^@Zg9%|v0&|f6?K@>)SzFT zNN-2EnLIM#(g!hfFP%i`*PGR|dCJi8wJzpO9fc4~cU>xWIC-8ckPKBkROs|}lj1#{q`8rLTSs%!5GQ!1YF^9`wvr4UfM9fNiV$W1_TM`r zdEOuOD3H&?_6k0ug4F4?KcLZwRx?*4&X0t3_AYH=(Y4II4Ba!m7P6ycX;G$l7F9%P zY6B9zVevMrh8(u4pej$6f@J!Ho=Sq87by`1bpUd*h4L8{pEky4ERmhFfdOfg&q$G3 z>q;BSW`l^ztrR}ZmoGg?UpjXalbAPYfBuZQYe)G)B7w6Z9gkw$b%6^ZTO%*e6y;cH z;qJ~jSxYQ?&RA9Iiqbthr+49^K9+g+sx;~28xpR0-MM~|gQOmRqrmtUJTZDo^#g2q zwt`UabC?Hg^tRB4Ibv`A>nuCOjRxd_N=6wKxy_VKVAEl{^Yh6QFS~uCR50zt%EAgg z>(U~cNT}<*)dDa+P|ifbuhTy9WQb3bW-2^ajy%eVGG7$p;#ZyzbrwBnpxSOLk@Z-W zKOn}ni8r??z~z?^AA}6)^<66m@{@`3uWe2M)-u$B&;HE?DR#c~=OjBqCSv$QK9IL( z=DRi#Gp9RtQcK+=0BFJuMaECBVF56HKxzH+8#rXzfjr>ao_1o zHtAUwqh{)TOR)`n9H#HWcr+C1#y(U4G#MEF+o_`3#6`=fzmlsYU6w1UQF02B9r zt91Uanp02CgCnPdL&*%y$q>brmjSrQUrgmb3XvdYC=UMr13Gy*kszj=sC&&V2?PgdEd~Ri zJ^)^o`%V&wLJlAE6E?IU32?2*$?3>}zMWKH)CH zBAK!8YjWK;;P&6&r@twdG{7^M_X#S0VW|G&i6v10Sr@Z^7R)8+Np-WJiUupuhHD!MQk>~9Ws?E_ q(ffZAp8ipg`v1`XkL9$0Uy%(6gZJ53|C1Wpf5ajINC@?x+5ZK$^E$o& literal 0 HcmV?d00001 diff --git a/paddleocr.py b/paddleocr.py new file mode 100644 index 00000000..3c356bb3 --- /dev/null +++ b/paddleocr.py @@ -0,0 +1,231 @@ +# Copyright (c) 2020 PaddlePaddle Authors. All Rights Reserved. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +import os +import sys + +__dir__ = os.path.dirname(__file__) +sys.path.append(os.path.join(__dir__, '')) + +import cv2 +import numpy as np +from pathlib import Path +import tarfile +import requests +from tqdm import tqdm + +from tools.infer import predict_system +from ppocr.utils.utility import initial_logger + +logger = initial_logger() +from ppocr.utils.utility import check_and_read_gif + +__all__ = ['PaddleOCR'] + +model_params = { + 'ch_det_mv3_db': { + 'url': + 'https://paddleocr.bj.bcebos.com/ch_models/ch_det_mv3_db_infer.tar', + 'algorithm': 'DB', + }, + 'ch_rec_mv3_crnn_enhance': { + 'url': + 'https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_enhance_infer.tar', + 'algorithm': 'CRNN' + }, +} + +SUPPORT_DET_MODEL = ['DB'] +SUPPORT_REC_MODEL = ['Rosetta', 'CRNN', 'STARNet', 'RARE'] + + +def download_with_progressbar(url, save_path): + response = requests.get(url, stream=True) + total_size_in_bytes = int(response.headers.get('content-length', 0)) + block_size = 1024 # 1 Kibibyte + progress_bar = tqdm(total=total_size_in_bytes, unit='iB', unit_scale=True) + with open(save_path, 'wb') as file: + for data in response.iter_content(block_size): + progress_bar.update(len(data)) + file.write(data) + progress_bar.close() + if total_size_in_bytes != 0 and progress_bar.n != total_size_in_bytes: + logger.error("ERROR, something went wrong") + sys.exit(0) + + +def download_and_unzip(url, model_storage_directory): + tmp_path = os.path.join(model_storage_directory, url.split('/')[-1]) + print('download {} to {}'.format(url, tmp_path)) + os.makedirs(model_storage_directory, exist_ok=True) + download_with_progressbar(url, tmp_path) + with tarfile.open(tmp_path, 'r') as tarObj: + for filename in tarObj.getnames(): + tarObj.extract(filename, model_storage_directory) + os.remove(tmp_path) + + +def maybe_download(model_storage_directory, model_name, mode='det'): + algorithm = None + # using custom model + if os.path.exists(os.path.join(model_name, 'model')) and os.path.exists( + os.path.join(model_name, 'params')): + return model_name, algorithm + # using the model of paddleocr + model_path = os.path.join(model_storage_directory, model_name) + if not os.path.exists(os.path.join(model_path, + 'model')) or not os.path.exists( + os.path.join(model_path, 'params')): + assert model_name in model_params, 'model must in {}'.format( + model_params.keys()) + download_and_unzip(model_params[model_name]['url'], + model_storage_directory) + algorithm = model_params[model_name]['algorithm'] + return model_path, algorithm + + +def parse_args(): + import argparse + + def str2bool(v): + return v.lower() in ("true", "t", "1") + + parser = argparse.ArgumentParser() + # params for prediction engine + parser.add_argument("--use_gpu", type=str2bool, default=True) + parser.add_argument("--ir_optim", type=str2bool, default=True) + parser.add_argument("--use_tensorrt", type=str2bool, default=False) + parser.add_argument("--gpu_mem", type=int, default=8000) + + # params for text detector + parser.add_argument("--image_dir", type=str) + parser.add_argument("--det_algorithm", type=str, default='DB') + parser.add_argument("--det_model_name", type=str, default='ch_det_mv3_db') + parser.add_argument("--det_max_side_len", type=float, default=960) + + # DB parmas + parser.add_argument("--det_db_thresh", type=float, default=0.3) + parser.add_argument("--det_db_box_thresh", type=float, default=0.5) + parser.add_argument("--det_db_unclip_ratio", type=float, default=2.0) + + # EAST parmas + parser.add_argument("--det_east_score_thresh", type=float, default=0.8) + parser.add_argument("--det_east_cover_thresh", type=float, default=0.1) + parser.add_argument("--det_east_nms_thresh", type=float, default=0.2) + + # params for text recognizer + parser.add_argument("--rec_algorithm", type=str, default='CRNN') + parser.add_argument( + "--rec_model_name", type=str, default='ch_rec_mv3_crnn_enhance') + parser.add_argument("--rec_image_shape", type=str, default="3, 32, 320") + parser.add_argument("--rec_char_type", type=str, default='ch') + parser.add_argument("--rec_batch_num", type=int, default=30) + parser.add_argument( + "--rec_char_dict_path", + type=str, + default="./ppocr/utils/ppocr_keys_v1.txt") + parser.add_argument("--use_space_char", type=bool, default=True) + parser.add_argument("--enable_mkldnn", type=bool, default=False) + + parser.add_argument("--model_storage_directory", type=str, default=False) + parser.add_argument("--det", type=str2bool, default=True) + parser.add_argument("--rec", type=str2bool, default=True) + return parser.parse_args() + + +class PaddleOCR(predict_system.TextSystem): + def __init__(self, + det_model_name='ch_det_mv3_db', + rec_model_name='ch_rec_mv3_crnn_enhance', + model_storage_directory=None, + log_level=20, + **kwargs): + """ + paddleocr package + args: + det_model_name: det_model name, keep same with filename in paddleocr. default is ch_det_mv3_db + det_model_name: rec_model name, keep same with filename in paddleocr. default is ch_rec_mv3_crnn_enhance + model_storage_directory: model save path. default is ~/.paddleocr + det model will save to model_storage_directory/det_model + rec model will save to model_storage_directory/rec_model + log_level: + **kwargs: other params show in paddleocr --help + """ + logger.setLevel(log_level) + postprocess_params = parse_args() + # init model dir + if model_storage_directory: + self.model_storage_directory = model_storage_directory + else: + self.model_storage_directory = os.path.expanduser( + "~/.paddleocr/") + '/model' + Path(self.model_storage_directory).mkdir(parents=True, exist_ok=True) + + # download model + det_model_path, det_algorithm = maybe_download( + self.model_storage_directory, det_model_name, 'det') + rec_model_path, rec_algorithm = maybe_download( + self.model_storage_directory, rec_model_name, 'rec') + # update model and post_process params + postprocess_params.__dict__.update(**kwargs) + postprocess_params.det_model_dir = det_model_path + postprocess_params.rec_model_dir = rec_model_path + if det_algorithm is not None: + postprocess_params.det_algorithm = det_algorithm + if rec_algorithm is not None: + postprocess_params.rec_algorithm = rec_algorithm + + if postprocess_params.det_algorithm not in SUPPORT_DET_MODEL: + logger.error('det_algorithm must in {}'.format(SUPPORT_DET_MODEL)) + sys.exit(0) + if postprocess_params.rec_algorithm not in SUPPORT_REC_MODEL: + logger.error('rec_algorithm must in {}'.format(SUPPORT_REC_MODEL)) + sys.exit(0) + + postprocess_params.rec_char_dict_path = Path( + __file__).parent / postprocess_params.rec_char_dict_path + + # init det_model and rec_model + super().__init__(postprocess_params) + + def ocr(self, img, det=True, rec=True): + """ + ocr with paddleocr + args: + img: img for ocr, support ndarray, img_path and list or ndarray + det: use text detection or not, if false, only rec will be exec. default is True + rec: use text recognition or not, if false, only det will be exec. default is True + """ + assert isinstance(img, (np.ndarray, list, str)) + if isinstance(img, str): + image_file = img + img, flag = check_and_read_gif(image_file) + if not flag: + img = cv2.imread(image_file) + if img is None: + logger.error("error in loading image:{}".format(image_file)) + return None + if det and rec: + dt_boxes, rec_res = self.__call__(img) + return [[box.tolist(), res] for box, res in zip(dt_boxes, rec_res)] + elif det and not rec: + dt_boxes, elapse = self.text_detector(img) + if dt_boxes is None: + return None + return [box.tolist() for box in dt_boxes] + else: + if not isinstance(img, list): + img = [img] + rec_res, elapse = self.text_recognizer(img) + return rec_res diff --git a/requirments.txt b/requirments.txt index 94e8478f..ec538138 100644 --- a/requirments.txt +++ b/requirments.txt @@ -1,4 +1,6 @@ shapely imgaug pyclipper -lmdb \ No newline at end of file +lmdb +tqdm +numpy \ No newline at end of file diff --git a/setup.py b/setup.py new file mode 100644 index 00000000..70f748e6 --- /dev/null +++ b/setup.py @@ -0,0 +1,61 @@ +# Copyright (c) 2020 PaddlePaddle Authors. All Rights Reserved. +# +# Licensed under the Apache License, Version 2.0 (the "License"); +# you may not use this file except in compliance with the License. +# You may obtain a copy of the License at +# +# http://www.apache.org/licenses/LICENSE-2.0 +# +# Unless required by applicable law or agreed to in writing, software +# distributed under the License is distributed on an "AS IS" BASIS, +# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. +# See the License for the specific language governing permissions and +# limitations under the License. + +from setuptools import setup +from io import open + +with open('requirments.txt', encoding="utf-8-sig") as f: + requirements = f.readlines() + requirements.append('tqdm') + + +def readme(): + with open('doc/doc_en/whl.md', encoding="utf-8-sig") as f: + README = f.read() + return README + + +setup( + name='paddleocr', + packages=['paddleocr'], + package_dir={'paddleocr': ''}, + include_package_data=True, + entry_points={"console_scripts": ["paddleocr= paddleocr.paddleocr:main"]}, + version='0.0.3', + install_requires=requirements, + license='Apache License 2.0', + description='Awesome OCR toolkits based on PaddlePaddle (8.6M ultra-lightweight pre-trained model, support training and deployment among server, mobile, embeded and IoT devices', + long_description=readme(), + long_description_content_type='text/markdown', + author='Baidu PaddlePaddle', + url='https://github.com/PaddlePaddle/PaddleOCR', + download_url='https://github.com/PaddlePaddle/PaddleOCR.git', + keywords=[ + 'ocr textdetection textrecognition paddleocr crnn east star-net rosetta ocrlite db chineseocr chinesetextdetection chinesetextrecognition' + ], + classifiers=[ + 'Intended Audience :: Developers', 'Operating System :: OS Independent', + 'Natural Language :: Chinese (Simplified)', + 'Programming Language :: Python', 'Programming Language :: Python :: 2', + 'Programming Language :: Python :: 2.5', + 'Programming Language :: Python :: 2.6', + 'Programming Language :: Python :: 2.7', + 'Programming Language :: Python :: 3', + 'Programming Language :: Python :: 3.2', + 'Programming Language :: Python :: 3.3', + 'Programming Language :: Python :: 3.4', + 'Programming Language :: Python :: 3.5', + 'Programming Language :: Python :: 3.6', + 'Programming Language :: Python :: 3.7', 'Topic :: Utilities' + ], ) diff --git a/tools/infer/utility.py b/tools/infer/utility.py index b0a0ec1f..9e1e0946 100755 --- a/tools/infer/utility.py +++ b/tools/infer/utility.py @@ -134,7 +134,12 @@ def resize_img(img, input_size=600): return im -def draw_ocr(image, boxes, txts, scores, draw_txt=True, drop_score=0.5): +def draw_ocr(image, + boxes, + txts=None, + scores=None, + drop_score=0.5, + font_path="./doc/simfang.ttf"): """ Visualize the results of OCR detection and recognition args: @@ -142,23 +147,29 @@ def draw_ocr(image, boxes, txts, scores, draw_txt=True, drop_score=0.5): boxes(list): boxes with shape(N, 4, 2) txts(list): the texts scores(list): txxs corresponding scores - draw_txt(bool): whether draw text or not drop_score(float): only scores greater than drop_threshold will be visualized + font_path: the path of font which is used to draw text return(array): the visualized img """ if scores is None: scores = [1] * len(boxes) - for (box, score) in zip(boxes, scores): - if score < drop_score or math.isnan(score): + box_num = len(boxes) + for i in range(box_num): + if scores is not None and (scores[i] < drop_score or + math.isnan(scores[i])): continue - box = np.reshape(np.array(box), [-1, 1, 2]).astype(np.int64) + box = np.reshape(np.array(boxes[i]), [-1, 1, 2]).astype(np.int64) image = cv2.polylines(np.array(image), [box], True, (255, 0, 0), 2) - - if draw_txt: + if txts is not None: img = np.array(resize_img(image, input_size=600)) txt_img = text_visual( - txts, scores, img_h=img.shape[0], img_w=600, threshold=drop_score) + txts, + scores, + img_h=img.shape[0], + img_w=600, + threshold=drop_score, + font_path=font_path) img = np.concatenate([np.array(img), np.array(txt_img)], axis=1) return img return image @@ -236,7 +247,12 @@ def str_count(s): return s_len - math.ceil(en_dg_count / 2) -def text_visual(texts, scores, img_h=400, img_w=600, threshold=0.): +def text_visual(texts, + scores, + img_h=400, + img_w=600, + threshold=0., + font_path="./doc/simfang.ttf"): """ create new blank img and draw txt on it args: @@ -244,6 +260,7 @@ def text_visual(texts, scores, img_h=400, img_w=600, threshold=0.): scores(list|None): corresponding score of each txt img_h(int): the height of blank img img_w(int): the width of blank img + font_path: the path of font which is used to draw text return(array): """ @@ -262,7 +279,7 @@ def text_visual(texts, scores, img_h=400, img_w=600, threshold=0.): font_size = 20 txt_color = (0, 0, 0) - font = ImageFont.truetype("./doc/simfang.ttf", font_size, encoding="utf-8") + font = ImageFont.truetype(font_path, font_size, encoding="utf-8") gap = font_size + 5 txt_img_list = [] @@ -343,6 +360,6 @@ if __name__ == '__main__': txts.append(dic['transcription']) scores.append(round(dic['scores'], 3)) - new_img = draw_ocr(image, boxes, txts, scores, draw_txt=True) + new_img = draw_ocr(image, boxes, txts, scores) cv2.imwrite(img_name, new_img) From 3b1ecb13391a3fcc579b761ecfc7c482dcef8607 Mon Sep 17 00:00:00 2001 From: zhoujun <572459439@qq.com> Date: Sat, 22 Aug 2020 20:15:56 +0800 Subject: [PATCH 04/42] Update predict_system.py --- tools/infer/predict_system.py | 1 - 1 file changed, 1 deletion(-) diff --git a/tools/infer/predict_system.py b/tools/infer/predict_system.py index f8a62679..647a76b2 100755 --- a/tools/infer/predict_system.py +++ b/tools/infer/predict_system.py @@ -157,7 +157,6 @@ def main(args): boxes, txts, scores, - draw_txt=True, drop_score=drop_score) draw_img_save = "./inference_results/" if not os.path.exists(draw_img_save): From 32c2989b1b5c4f202bd47213133306d986b56394 Mon Sep 17 00:00:00 2001 From: Tangmq Date: Sat, 22 Aug 2020 23:38:18 +0800 Subject: [PATCH 05/42] add an english version readme file --- docker/hubserving/README.md | 58 ++++++++++++++++++++++++++++++++++ docker/hubserving/README_cn.md | 57 +++++++++++++++++++++++++++++++++ docker/hubserving/readme.md | 47 ++++++++++++++------------- 3 files changed, 140 insertions(+), 22 deletions(-) create mode 100644 docker/hubserving/README.md create mode 100644 docker/hubserving/README_cn.md diff --git a/docker/hubserving/README.md b/docker/hubserving/README.md new file mode 100644 index 00000000..71e2377d --- /dev/null +++ b/docker/hubserving/README.md @@ -0,0 +1,58 @@ +English | [简体中文](README_cn.md) + +## Introduction +Many user hopes package the PaddleOCR service into an docker image, so that it can be quickly released and used in the docker or k8s environment. + +This page provide some standardized code to achieve this goal. You can quickly publish the PaddleOCR project into a callable Restful API service through the following steps. (At present, the deployment based on the HubServing mode is implemented first, and author plans to increase the deployment of the PaddleServing mode in the futrue) + +## 1. Prerequisites + +You need to install the following basic components first: +a. Docker +b. Graphics driver and CUDA 10.0+(GPU) +c. NVIDIA Container Toolkit(GPU,Docker 19.03+ can skip this) +d. cuDNN 7.6+(GPU) + +## 2. Build Image +a. Download PaddleOCR sourcecode +``` +git clone https://github.com/PaddlePaddle/PaddleOCR.git +``` +b. Goto Dockerfile directory(ps:Need to distinguish between cpu and gpu version, the following takes cpu as an example, gpu version needs to replace the keyword) +``` +cd docker/cpu +``` +c. Build image +``` +docker build -t paddleocr:cpu . +``` + +## 3. Start container +a. CPU version +``` +sudo docker run -dp 8866:8866 --name paddle_ocr paddleocr:cpu +``` +b. GPU version (base on NVIDIA Container Toolkit) +``` +sudo nvidia-docker run -dp 8866:8866 --name paddle_ocr paddleocr:gpu +``` +c. GPU version (Docker 19.03++) +``` +sudo docker run -dp 8866:8866 --gpus all --name paddle_ocr paddleocr:gpu +``` +d. Check service status(If you can see the following statement then it means completed:Successfully installed ocr_system && Running on http://0.0.0.0:8866/) +``` +docker logs -f paddle_ocr +``` + +## 4. Test +a. Calculate the Base64 encoding of the picture to be recognized (if you just test, you can use a free online tool, like:https://freeonlinetools24.com/base64-image/) +b. Post a service request(sample request in sample_request.txt) + +``` +curl -H "Content-Type:application/json" -X POST --data "{\"images\": [\"Input image Base64 encode(need to delete the code 'data:image/jpg;base64,')\"]}" http://localhost:8866/predict/ocr_system +``` +c. Get resposne(If the call is successful, the following result will be returned) +``` +{"msg":"","results":[[{"confidence":0.8403433561325073,"text":"约定","text_region":[[345,377],[641,390],[634,540],[339,528]]},{"confidence":0.8131805658340454,"text":"最终相遇","text_region":[[356,532],[624,530],[624,596],[356,598]]}]],"status":"0"} +``` diff --git a/docker/hubserving/README_cn.md b/docker/hubserving/README_cn.md new file mode 100644 index 00000000..9b9e5f50 --- /dev/null +++ b/docker/hubserving/README_cn.md @@ -0,0 +1,57 @@ +[English](README.md) | 简体中文 + +## Docker化部署服务 +在日常项目应用中,相信大家一般都会希望能通过Docker技术,把PaddleOCR服务打包成一个镜像,以便在Docker或k8s环境里,快速发布上线使用。 + +本文将提供一些标准化的代码来实现这样的目标。大家通过如下步骤可以把PaddleOCR项目快速发布成可调用的Restful API服务。(目前暂时先实现了基于HubServing模式的部署,后续作者计划增加PaddleServing模式的部署) + +## 1.实施前提准备 + +需要先完成如下基本组件的安装: +a. Docker环境 +b. 显卡驱动和CUDA 10.0+(GPU) +c. NVIDIA Container Toolkit(GPU,Docker 19.03以上版本可以跳过此步) +d. cuDNN 7.6+(GPU) + +## 2.制作镜像 +a.下载PaddleOCR项目代码 +``` +git clone https://github.com/PaddlePaddle/PaddleOCR.git +``` +b.切换至Dockerfile目录(注:需要区分cpu或gpu版本,下文以cpu为例,gpu版本需要替换一下关键字即可) +``` +cd docker/cpu +``` +c.生成镜像 +``` +docker build -t paddleocr:cpu . +``` + +## 3.启动Docker容器 +a. CPU 版本 +``` +sudo docker run -dp 8866:8866 --name paddle_ocr paddleocr:cpu +``` +b. GPU 版本 (通过NVIDIA Container Toolkit) +``` +sudo nvidia-docker run -dp 8866:8866 --name paddle_ocr paddleocr:gpu +``` +c. GPU 版本 (Docker 19.03以上版本,可以直接用如下命令) +``` +sudo docker run -dp 8866:8866 --gpus all --name paddle_ocr paddleocr:gpu +``` +d. 检查服务运行情况(出现:Successfully installed ocr_system和Running on http://0.0.0.0:8866/等信息,表示运行成功) +``` +docker logs -f paddle_ocr +``` + +## 4.测试服务 +a. 计算待识别图片的Base64编码(如果只是测试一下效果,可以通过免费的在线工具实现,如:http://tool.chinaz.com/tools/imgtobase/) +b. 发送服务请求(可参见sample_request.txt中的值) +``` +curl -H "Content-Type:application/json" -X POST --data "{\"images\": [\"填入图片Base64编码(需要删除'data:image/jpg;base64,')\"]}" http://localhost:8866/predict/ocr_system +``` +c. 返回结果(如果调用成功,会返回如下结果) +``` +{"msg":"","results":[[{"confidence":0.8403433561325073,"text":"约定","text_region":[[345,377],[641,390],[634,540],[339,528]]},{"confidence":0.8131805658340454,"text":"最终相遇","text_region":[[356,532],[624,530],[624,596],[356,598]]}]],"status":"0"} +``` diff --git a/docker/hubserving/readme.md b/docker/hubserving/readme.md index 109e6aa6..71e2377d 100644 --- a/docker/hubserving/readme.md +++ b/docker/hubserving/readme.md @@ -1,55 +1,58 @@ -# Docker化部署服务 -在日常项目应用中,相信大家一般都会希望能通过Docker技术,把PaddleOCR服务打包成一个镜像,以便在Docker或k8s环境里,快速发布上线使用。 +English | [简体中文](README_cn.md) -本文将提供一些标准化的代码来实现这样的目标。大家通过如下步骤可以把PaddleOCR项目快速发布成可调用的Restful API服务。(目前暂时先实现了基于HubServing模式的部署,后续作者计划增加PaddleServing模式的部署) +## Introduction +Many user hopes package the PaddleOCR service into an docker image, so that it can be quickly released and used in the docker or k8s environment. -## 1.实施前提准备 +This page provide some standardized code to achieve this goal. You can quickly publish the PaddleOCR project into a callable Restful API service through the following steps. (At present, the deployment based on the HubServing mode is implemented first, and author plans to increase the deployment of the PaddleServing mode in the futrue) -需要先完成如下基本组件的安装: -a. Docker环境 -b. 显卡驱动和CUDA 10.0+(GPU) -c. NVIDIA Container Toolkit(GPU,Docker 19.03以上版本可以跳过此步) +## 1. Prerequisites + +You need to install the following basic components first: +a. Docker +b. Graphics driver and CUDA 10.0+(GPU) +c. NVIDIA Container Toolkit(GPU,Docker 19.03+ can skip this) d. cuDNN 7.6+(GPU) -## 2.制作镜像 -a.下载PaddleOCR项目代码 +## 2. Build Image +a. Download PaddleOCR sourcecode ``` git clone https://github.com/PaddlePaddle/PaddleOCR.git ``` -b.切换至Dockerfile目录(注:需要区分cpu或gpu版本,下文以cpu为例,gpu版本需要替换一下关键字即可) +b. Goto Dockerfile directory(ps:Need to distinguish between cpu and gpu version, the following takes cpu as an example, gpu version needs to replace the keyword) ``` cd docker/cpu ``` -c.生成镜像 +c. Build image ``` docker build -t paddleocr:cpu . ``` -## 3.启动Docker容器 -a. CPU 版本 +## 3. Start container +a. CPU version ``` sudo docker run -dp 8866:8866 --name paddle_ocr paddleocr:cpu ``` -b. GPU 版本 (通过NVIDIA Container Toolkit) +b. GPU version (base on NVIDIA Container Toolkit) ``` sudo nvidia-docker run -dp 8866:8866 --name paddle_ocr paddleocr:gpu ``` -c. GPU 版本 (Docker 19.03以上版本,可以直接用如下命令) +c. GPU version (Docker 19.03++) ``` sudo docker run -dp 8866:8866 --gpus all --name paddle_ocr paddleocr:gpu ``` -d. 检查服务运行情况(出现:Successfully installed ocr_system和Running on http://0.0.0.0:8866/等信息,表示运行成功) +d. Check service status(If you can see the following statement then it means completed:Successfully installed ocr_system && Running on http://0.0.0.0:8866/) ``` docker logs -f paddle_ocr ``` -## 4.测试服务 -a. 计算待识别图片的Base64编码(如果只是测试一下效果,可以通过免费的在线工具实现,如:http://tool.chinaz.com/tools/imgtobase/) -b. 发送服务请求(可参见sample_request.txt中的值) +## 4. Test +a. Calculate the Base64 encoding of the picture to be recognized (if you just test, you can use a free online tool, like:https://freeonlinetools24.com/base64-image/) +b. Post a service request(sample request in sample_request.txt) + ``` -curl -H "Content-Type:application/json" -X POST --data "{\"images\": [\"填入图片Base64编码(需要删除'data:image/jpg;base64,')\"]}" http://localhost:8866/predict/ocr_system +curl -H "Content-Type:application/json" -X POST --data "{\"images\": [\"Input image Base64 encode(need to delete the code 'data:image/jpg;base64,')\"]}" http://localhost:8866/predict/ocr_system ``` -c. 返回结果(如果调用成功,会返回如下结果) +c. Get resposne(If the call is successful, the following result will be returned) ``` {"msg":"","results":[[{"confidence":0.8403433561325073,"text":"约定","text_region":[[345,377],[641,390],[634,540],[339,528]]},{"confidence":0.8131805658340454,"text":"最终相遇","text_region":[[356,532],[624,530],[624,596],[356,598]]}]],"status":"0"} ``` From 186bf9f33a63a8b41b6aba2dbb6dc5f61425aeca Mon Sep 17 00:00:00 2001 From: WenmuZhou Date: Sun, 23 Aug 2020 16:38:01 +0800 Subject: [PATCH 06/42] =?UTF-8?q?=E5=88=A0=E6=8E=89py2=E7=9A=84=E6=94=AF?= =?UTF-8?q?=E6=8C=81,=E4=BF=AE=E6=AD=A3=E6=96=87=E6=A1=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- doc/doc_ch/whl.md | 2 +- doc/doc_en/whl.md | 2 +- setup.py | 5 ----- 3 files changed, 2 insertions(+), 7 deletions(-) diff --git a/doc/doc_ch/whl.md b/doc/doc_ch/whl.md index 94243462..8715276f 100644 --- a/doc/doc_ch/whl.md +++ b/doc/doc_ch/whl.md @@ -12,7 +12,7 @@ pip install paddleocr 本地构建并安装 ```bash python setup.py bdist_wheel -pip install dist/paddleocr-0.0.1-py3-none-any.whl +pip install dist/paddleocr-0.0.3-py3-none-any.whl ``` ### 1. 代码使用 diff --git a/doc/doc_en/whl.md b/doc/doc_en/whl.md index ad2125a4..e073e8e3 100644 --- a/doc/doc_en/whl.md +++ b/doc/doc_en/whl.md @@ -10,7 +10,7 @@ pip install paddleocr build own whl package and install ```bash python setup.py bdist_wheel -pip install dist/paddleocr-0.0.1-py3-none-any.whl +pip install dist/paddleocr-0.0.3-py3-none-any.whl ``` ### 1. Use by code diff --git a/setup.py b/setup.py index 70f748e6..28409139 100644 --- a/setup.py +++ b/setup.py @@ -38,7 +38,6 @@ setup( description='Awesome OCR toolkits based on PaddlePaddle (8.6M ultra-lightweight pre-trained model, support training and deployment among server, mobile, embeded and IoT devices', long_description=readme(), long_description_content_type='text/markdown', - author='Baidu PaddlePaddle', url='https://github.com/PaddlePaddle/PaddleOCR', download_url='https://github.com/PaddlePaddle/PaddleOCR.git', keywords=[ @@ -47,10 +46,6 @@ setup( classifiers=[ 'Intended Audience :: Developers', 'Operating System :: OS Independent', 'Natural Language :: Chinese (Simplified)', - 'Programming Language :: Python', 'Programming Language :: Python :: 2', - 'Programming Language :: Python :: 2.5', - 'Programming Language :: Python :: 2.6', - 'Programming Language :: Python :: 2.7', 'Programming Language :: Python :: 3', 'Programming Language :: Python :: 3.2', 'Programming Language :: Python :: 3.3', From 0a011e564a476502ba80d5c640a69919c0abd4c6 Mon Sep 17 00:00:00 2001 From: littletomatodonkey Date: Mon, 24 Aug 2020 02:11:17 +0000 Subject: [PATCH 07/42] add python interface --- tools/infer/predict_det.py | 9 +++++++-- tools/infer/predict_rec.py | 9 +++++++-- tools/infer/utility.py | 9 +++++++-- 3 files changed, 21 insertions(+), 6 deletions(-) diff --git a/tools/infer/predict_det.py b/tools/infer/predict_det.py index 234c41bf..625f87ab 100755 --- a/tools/infer/predict_det.py +++ b/tools/infer/predict_det.py @@ -42,6 +42,7 @@ class TextDetector(object): def __init__(self, args): max_side_len = args.det_max_side_len self.det_algorithm = args.det_algorithm + self.use_zero_copy_run = args.use_zero_copy_run preprocess_params = {'max_side_len': max_side_len} postprocess_params = {} if self.det_algorithm == "DB": @@ -138,8 +139,12 @@ class TextDetector(object): return None, 0 im = im.copy() starttime = time.time() - im = fluid.core.PaddleTensor(im) - self.predictor.run([im]) + if self.use_zero_copy_run: + self.input_tensor.copy_from_cpu(im) + self.predictor.zero_copy_run() + else: + im = fluid.core.PaddleTensor(im) + self.predictor.run([im]) outputs = [] for output_tensor in self.output_tensors: output = output_tensor.copy_to_cpu() diff --git a/tools/infer/predict_rec.py b/tools/infer/predict_rec.py index 92234415..6a379853 100755 --- a/tools/infer/predict_rec.py +++ b/tools/infer/predict_rec.py @@ -40,6 +40,7 @@ class TextRecognizer(object): self.character_type = args.rec_char_type self.rec_batch_num = args.rec_batch_num self.rec_algorithm = args.rec_algorithm + self.use_zero_copy_run = args.use_zero_copy_run char_ops_params = { "character_type": args.rec_char_type, "character_dict_path": args.rec_char_dict_path, @@ -105,8 +106,12 @@ class TextRecognizer(object): norm_img_batch = np.concatenate(norm_img_batch) norm_img_batch = norm_img_batch.copy() starttime = time.time() - norm_img_batch = fluid.core.PaddleTensor(norm_img_batch) - self.predictor.run([norm_img_batch]) + if self.use_zero_copy_run: + self.input_tensor.copy_from_cpu(norm_img_batch) + self.predictor.zero_copy_run() + else: + norm_img_batch = fluid.core.PaddleTensor(norm_img_batch) + self.predictor.run([norm_img_batch]) if self.loss_type == "ctc": rec_idx_batch = self.output_tensors[0].copy_to_cpu() diff --git a/tools/infer/utility.py b/tools/infer/utility.py index ec6705eb..4dcdfa67 100755 --- a/tools/infer/utility.py +++ b/tools/infer/utility.py @@ -71,6 +71,7 @@ def parse_args(): default="./ppocr/utils/ppocr_keys_v1.txt") parser.add_argument("--use_space_char", type=bool, default=True) parser.add_argument("--enable_mkldnn", type=bool, default=False) + parser.add_argument("--use_zero_copy_run", type=bool, default=False) return parser.parse_args() @@ -105,8 +106,12 @@ def create_predictor(args, mode): #config.enable_memory_optim() config.disable_glog_info() - # use zero copy - config.switch_use_feed_fetch_ops(True) + if args.use_zero_copy_run: + config.delete_pass("conv_transpose_eltwiseadd_bn_fuse_pass") + config.switch_use_feed_fetch_ops(False) + else: + config.switch_use_feed_fetch_ops(True) + predictor = create_paddle_predictor(config) input_names = predictor.get_input_names() input_tensor = predictor.get_input_tensor(input_names[0]) From ed52619f4b4791fda71ff4b22f517e04c78bd3b8 Mon Sep 17 00:00:00 2001 From: littletomatodonkey Date: Mon, 24 Aug 2020 02:37:41 +0000 Subject: [PATCH 08/42] add cpp zero copy run interface --- deploy/cpp_infer/include/config.h | 4 ++++ deploy/cpp_infer/include/ocr_det.h | 6 ++++-- deploy/cpp_infer/include/ocr_rec.h | 5 ++++- deploy/cpp_infer/src/main.cpp | 13 +++++++------ deploy/cpp_infer/src/ocr_det.cpp | 23 ++++++++++++++++------- deploy/cpp_infer/src/ocr_rec.cpp | 24 ++++++++++++++++-------- deploy/cpp_infer/tools/config.txt | 1 + 7 files changed, 52 insertions(+), 24 deletions(-) diff --git a/deploy/cpp_infer/include/config.h b/deploy/cpp_infer/include/config.h index c5257d8a..8db693b1 100644 --- a/deploy/cpp_infer/include/config.h +++ b/deploy/cpp_infer/include/config.h @@ -41,6 +41,8 @@ public: this->use_mkldnn = bool(stoi(config_map_["use_mkldnn"])); + this->use_zero_copy_run = bool(stoi(config_map_["use_zero_copy_run"])); + this->max_side_len = stoi(config_map_["max_side_len"]); this->det_db_thresh = stod(config_map_["det_db_thresh"]); @@ -68,6 +70,8 @@ public: bool use_mkldnn = false; + bool use_zero_copy_run = false; + int max_side_len = 960; double det_db_thresh = 0.3; diff --git a/deploy/cpp_infer/include/ocr_det.h b/deploy/cpp_infer/include/ocr_det.h index ed2667ee..0308d07f 100644 --- a/deploy/cpp_infer/include/ocr_det.h +++ b/deploy/cpp_infer/include/ocr_det.h @@ -39,8 +39,8 @@ public: explicit DBDetector(const std::string &model_dir, const bool &use_gpu, const int &gpu_id, const int &gpu_mem, const int &cpu_math_library_num_threads, - const bool &use_mkldnn, const int &max_side_len, - const double &det_db_thresh, + const bool &use_mkldnn, const bool &use_zero_copy_run, + const int &max_side_len, const double &det_db_thresh, const double &det_db_box_thresh, const double &det_db_unclip_ratio, const bool &visualize) { @@ -49,6 +49,7 @@ public: this->gpu_mem_ = gpu_mem; this->cpu_math_library_num_threads_ = cpu_math_library_num_threads; this->use_mkldnn_ = use_mkldnn; + this->use_zero_copy_run_ = use_zero_copy_run; this->max_side_len_ = max_side_len; @@ -75,6 +76,7 @@ private: int gpu_mem_ = 4000; int cpu_math_library_num_threads_ = 4; bool use_mkldnn_ = false; + bool use_zero_copy_run_ = false; int max_side_len_ = 960; diff --git a/deploy/cpp_infer/include/ocr_rec.h b/deploy/cpp_infer/include/ocr_rec.h index 471aeb58..520f0f28 100644 --- a/deploy/cpp_infer/include/ocr_rec.h +++ b/deploy/cpp_infer/include/ocr_rec.h @@ -38,12 +38,14 @@ public: explicit CRNNRecognizer(const std::string &model_dir, const bool &use_gpu, const int &gpu_id, const int &gpu_mem, const int &cpu_math_library_num_threads, - const bool &use_mkldnn, const string &label_path) { + const bool &use_mkldnn, const bool &use_zero_copy_run, + const string &label_path) { this->use_gpu_ = use_gpu; this->gpu_id_ = gpu_id; this->gpu_mem_ = gpu_mem; this->cpu_math_library_num_threads_ = cpu_math_library_num_threads; this->use_mkldnn_ = use_mkldnn; + this->use_zero_copy_run_ = use_zero_copy_run; this->label_list_ = Utility::ReadDict(label_path); this->label_list_.push_back(" "); @@ -64,6 +66,7 @@ private: int gpu_mem_ = 4000; int cpu_math_library_num_threads_ = 4; bool use_mkldnn_ = false; + bool use_zero_copy_run_ = false; std::vector label_list_; diff --git a/deploy/cpp_infer/src/main.cpp b/deploy/cpp_infer/src/main.cpp index 27c98e5b..1dd33b30 100644 --- a/deploy/cpp_infer/src/main.cpp +++ b/deploy/cpp_infer/src/main.cpp @@ -48,14 +48,15 @@ int main(int argc, char **argv) { cv::Mat srcimg = cv::imread(img_path, cv::IMREAD_COLOR); - DBDetector det(config.det_model_dir, config.use_gpu, config.gpu_id, - config.gpu_mem, config.cpu_math_library_num_threads, - config.use_mkldnn, config.max_side_len, config.det_db_thresh, - config.det_db_box_thresh, config.det_db_unclip_ratio, - config.visualize); + DBDetector det( + config.det_model_dir, config.use_gpu, config.gpu_id, config.gpu_mem, + config.cpu_math_library_num_threads, config.use_mkldnn, + config.use_zero_copy_run, config.max_side_len, config.det_db_thresh, + config.det_db_box_thresh, config.det_db_unclip_ratio, config.visualize); CRNNRecognizer rec(config.rec_model_dir, config.use_gpu, config.gpu_id, config.gpu_mem, config.cpu_math_library_num_threads, - config.use_mkldnn, config.char_list_file); + config.use_mkldnn, config.use_zero_copy_run, + config.char_list_file); auto start = std::chrono::system_clock::now(); std::vector>> boxes; diff --git a/deploy/cpp_infer/src/ocr_det.cpp b/deploy/cpp_infer/src/ocr_det.cpp index 36ffc9af..56fbace8 100644 --- a/deploy/cpp_infer/src/ocr_det.cpp +++ b/deploy/cpp_infer/src/ocr_det.cpp @@ -32,7 +32,7 @@ void DBDetector::LoadModel(const std::string &model_dir) { // false for zero copy tensor // true for commom tensor - config.SwitchUseFeedFetchOps(true); + config.SwitchUseFeedFetchOps(!this->use_zero_copy_run_); // true for multiple input config.SwitchSpecifyInputNames(true); @@ -61,12 +61,21 @@ void DBDetector::Run(cv::Mat &img, this->permute_op_.Run(&resize_img, input.data()); // Inference. - paddle::PaddleTensor input_t; - input_t.shape = {1, 3, resize_img.rows, resize_img.cols}; - input_t.data = paddle::PaddleBuf(input.data(), input.size() * sizeof(float)); - input_t.dtype = PaddleDType::FLOAT32; - std::vector outputs; - this->predictor_->Run({input_t}, &outputs, 1); + if (this->use_zero_copy_run_) { + auto input_names = this->predictor_->GetInputNames(); + auto input_t = this->predictor_->GetInputTensor(input_names[0]); + input_t->Reshape({1, 3, resize_img.rows, resize_img.cols}); + input_t->copy_from_cpu(input.data()); + this->predictor_->ZeroCopyRun(); + } else { + paddle::PaddleTensor input_t; + input_t.shape = {1, 3, resize_img.rows, resize_img.cols}; + input_t.data = + paddle::PaddleBuf(input.data(), input.size() * sizeof(float)); + input_t.dtype = PaddleDType::FLOAT32; + std::vector outputs; + this->predictor_->Run({input_t}, &outputs, 1); + } std::vector out_data; auto output_names = this->predictor_->GetOutputNames(); diff --git a/deploy/cpp_infer/src/ocr_rec.cpp b/deploy/cpp_infer/src/ocr_rec.cpp index 697f9e8e..a3486db4 100644 --- a/deploy/cpp_infer/src/ocr_rec.cpp +++ b/deploy/cpp_infer/src/ocr_rec.cpp @@ -40,13 +40,21 @@ void CRNNRecognizer::Run(std::vector>> boxes, this->permute_op_.Run(&resize_img, input.data()); // Inference. - paddle::PaddleTensor input_t; - input_t.shape = {1, 3, resize_img.rows, resize_img.cols}; - input_t.data = - paddle::PaddleBuf(input.data(), input.size() * sizeof(float)); - input_t.dtype = PaddleDType::FLOAT32; - std::vector outputs; - this->predictor_->Run({input_t}, &outputs, 1); + if (this->use_zero_copy_run_) { + auto input_names = this->predictor_->GetInputNames(); + auto input_t = this->predictor_->GetInputTensor(input_names[0]); + input_t->Reshape({1, 3, resize_img.rows, resize_img.cols}); + input_t->copy_from_cpu(input.data()); + this->predictor_->ZeroCopyRun(); + } else { + paddle::PaddleTensor input_t; + input_t.shape = {1, 3, resize_img.rows, resize_img.cols}; + input_t.data = + paddle::PaddleBuf(input.data(), input.size() * sizeof(float)); + input_t.dtype = PaddleDType::FLOAT32; + std::vector outputs; + this->predictor_->Run({input_t}, &outputs, 1); + } std::vector rec_idx; auto output_names = this->predictor_->GetOutputNames(); @@ -124,7 +132,7 @@ void CRNNRecognizer::LoadModel(const std::string &model_dir) { // false for zero copy tensor // true for commom tensor - config.SwitchUseFeedFetchOps(true); + config.SwitchUseFeedFetchOps(!this->use_zero_copy_run_); // true for multiple input config.SwitchSpecifyInputNames(true); diff --git a/deploy/cpp_infer/tools/config.txt b/deploy/cpp_infer/tools/config.txt index a049fc7d..40beea3a 100644 --- a/deploy/cpp_infer/tools/config.txt +++ b/deploy/cpp_infer/tools/config.txt @@ -4,6 +4,7 @@ gpu_id 0 gpu_mem 4000 cpu_math_library_num_threads 10 use_mkldnn 0 +use_zero_copy_run 1 # det config max_side_len 960 From 09e15a684a3662a41c28de3b7104fa6525d407da Mon Sep 17 00:00:00 2001 From: WenmuZhou Date: Mon, 24 Aug 2020 11:30:00 +0800 Subject: [PATCH 09/42] =?UTF-8?q?=E4=BF=AE=E6=AD=A3=E6=96=87=E6=A1=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- doc/doc_ch/whl.md | 110 +++++----------------------------------------- doc/doc_en/whl.md | 66 +++++----------------------- 2 files changed, 22 insertions(+), 154 deletions(-) diff --git a/doc/doc_ch/whl.md b/doc/doc_ch/whl.md index 8715276f..1328f8c5 100644 --- a/doc/doc_ch/whl.md +++ b/doc/doc_ch/whl.md @@ -19,7 +19,7 @@ pip install dist/paddleocr-0.0.3-py3-none-any.whl * 检测+识别全流程 ```python from paddleocr import PaddleOCR, draw_ocr -ocr = PaddleOCR(model_storage_directory='./model') # need to run only once to load model into memory +ocr = PaddleOCR() # need to run only once to download and load model into memory img_path = 'PaddleOCR/doc/imgs/11.jpg' result = ocr.ocr(img_path) for line in result: @@ -40,29 +40,7 @@ im_show.save('result.jpg') [[[24.0, 36.0], [304.0, 34.0], [304.0, 72.0], [24.0, 74.0]], ['纯臻营养护发素', 0.964739]] [[[24.0, 80.0], [172.0, 80.0], [172.0, 104.0], [24.0, 104.0]], ['产品信息/参数', 0.98069626]] [[[24.0, 109.0], [333.0, 109.0], [333.0, 136.0], [24.0, 136.0]], ['(45元/每公斤,100公斤起订)', 0.9676722]] -[[[22.0, 140.0], [284.0, 140.0], [284.0, 167.0], [22.0, 167.0]], ['每瓶22元,1000瓶起订)', 0.97444016]] -[[[22.0, 174.0], [85.0, 174.0], [85.0, 198.0], [22.0, 198.0]], ['【品牌】', 0.8187138]] -[[[89.0, 176.0], [301.0, 176.0], [301.0, 196.0], [89.0, 196.0]], [':代加工方式/OEMODM', 0.9421848]] -[[[23.0, 205.0], [85.0, 205.0], [85.0, 229.0], [23.0, 229.0]], ['【品名】', 0.76008326]] -[[[88.0, 204.0], [235.0, 206.0], [235.0, 229.0], [88.0, 227.0]], [':纯臻营养护发素', 0.9633639]] -[[[23.0, 236.0], [121.0, 236.0], [121.0, 261.0], [23.0, 261.0]], ['【产品编号】', 0.84101385]] -[[[110.0, 239.0], [239.0, 239.0], [239.0, 256.0], [110.0, 256.0]], ['1:YM-X-3011', 0.8621878]] -[[[414.0, 233.0], [430.0, 233.0], [430.0, 304.0], [414.0, 304.0]], ['ODM OEM', 0.9084018]] -[[[23.0, 268.0], [183.0, 268.0], [183.0, 292.0], [23.0, 292.0]], ['【净含量】:220ml', 0.9278281]] -[[[24.0, 301.0], [118.0, 301.0], [118.0, 321.0], [24.0, 321.0]], ['【适用人群】', 0.90901047]] -[[[127.0, 300.0], [254.0, 300.0], [254.0, 323.0], [127.0, 323.0]], [':适合所有肤质', 0.95465785]] -[[[24.0, 332.0], [117.0, 332.0], [117.0, 353.0], [24.0, 353.0]], ['【主要成分】', 0.88936955]] -[[[139.0, 332.0], [236.0, 332.0], [236.0, 352.0], [139.0, 352.0]], ['鲸蜡硬脂醇', 0.9447544]] -[[[248.0, 332.0], [345.0, 332.0], [345.0, 352.0], [248.0, 352.0]], ['燕麦B-葡聚', 0.89748293]] -[[[54.0, 363.0], [232.0, 363.0], [232.0, 383.0], [54.0, 383.0]], [' 椰油酰胺丙基甜菜碱', 0.902023]] -[[[25.0, 364.0], [64.0, 364.0], [64.0, 383.0], [25.0, 383.0]], ['糖、', 0.985203]] -[[[244.0, 363.0], [281.0, 363.0], [281.0, 382.0], [244.0, 382.0]], ['泛服', 0.44537082]] -[[[367.0, 367.0], [475.0, 367.0], [475.0, 388.0], [367.0, 388.0]], ['(成品包材)', 0.9834532]] -[[[24.0, 395.0], [120.0, 395.0], [120.0, 416.0], [24.0, 416.0]], ['【主要功能】', 0.88684446]] -[[[128.0, 397.0], [273.0, 397.0], [273.0, 414.0], [128.0, 414.0]], [':可紧致头发磷层', 0.9342501]] -[[[265.0, 395.0], [361.0, 395.0], [361.0, 415.0], [265.0, 415.0]], ['琴,从而达到', 0.8253762]] -[[[25.0, 425.0], [372.0, 425.0], [372.0, 448.0], [25.0, 448.0]], ['即时持久改善头发光泽的效果,给干燥的头', 0.97785276]] -[[[26.0, 457.0], [137.0, 457.0], [137.0, 477.0], [26.0, 477.0]], ['发足够的滋养', 0.9577897]] +...... ``` 结果可视化 @@ -73,7 +51,7 @@ im_show.save('result.jpg') * 单独执行检测 ```python from paddleocr import PaddleOCR, draw_ocr -ocr = PaddleOCR(model_storage_directory='./model') # need to run only once to load model into memory +ocr = PaddleOCR() # need to run only once to download and load model into memory img_path = 'PaddleOCR/doc/imgs/11.jpg' result = ocr.ocr(img_path,rec=False) for line in result: @@ -92,29 +70,7 @@ im_show.save('result.jpg') [[26.0, 457.0], [137.0, 457.0], [137.0, 477.0], [26.0, 477.0]] [[25.0, 425.0], [372.0, 425.0], [372.0, 448.0], [25.0, 448.0]] [[128.0, 397.0], [273.0, 397.0], [273.0, 414.0], [128.0, 414.0]] -[[265.0, 395.0], [361.0, 395.0], [361.0, 415.0], [265.0, 415.0]] -[[24.0, 395.0], [120.0, 395.0], [120.0, 416.0], [24.0, 416.0]] -[[367.0, 367.0], [475.0, 367.0], [475.0, 388.0], [367.0, 388.0]] -[[54.0, 363.0], [232.0, 363.0], [232.0, 383.0], [54.0, 383.0]] -[[25.0, 364.0], [64.0, 364.0], [64.0, 383.0], [25.0, 383.0]] -[[244.0, 363.0], [281.0, 363.0], [281.0, 382.0], [244.0, 382.0]] -[[248.0, 332.0], [345.0, 332.0], [345.0, 352.0], [248.0, 352.0]] -[[139.0, 332.0], [236.0, 332.0], [236.0, 352.0], [139.0, 352.0]] -[[24.0, 332.0], [117.0, 332.0], [117.0, 353.0], [24.0, 353.0]] -[[127.0, 300.0], [254.0, 300.0], [254.0, 323.0], [127.0, 323.0]] -[[24.0, 301.0], [118.0, 301.0], [118.0, 321.0], [24.0, 321.0]] -[[23.0, 268.0], [183.0, 268.0], [183.0, 292.0], [23.0, 292.0]] -[[110.0, 239.0], [239.0, 239.0], [239.0, 256.0], [110.0, 256.0]] -[[23.0, 236.0], [121.0, 236.0], [121.0, 261.0], [23.0, 261.0]] -[[414.0, 233.0], [430.0, 233.0], [430.0, 304.0], [414.0, 304.0]] -[[88.0, 204.0], [235.0, 206.0], [235.0, 229.0], [88.0, 227.0]] -[[23.0, 205.0], [85.0, 205.0], [85.0, 229.0], [23.0, 229.0]] -[[89.0, 176.0], [301.0, 176.0], [301.0, 196.0], [89.0, 196.0]] -[[22.0, 174.0], [85.0, 174.0], [85.0, 198.0], [22.0, 198.0]] -[[22.0, 140.0], [284.0, 140.0], [284.0, 167.0], [22.0, 167.0]] -[[24.0, 109.0], [333.0, 109.0], [333.0, 136.0], [24.0, 136.0]] -[[24.0, 80.0], [172.0, 80.0], [172.0, 104.0], [24.0, 104.0]] -[[24.0, 36.0], [304.0, 34.0], [304.0, 72.0], [24.0, 74.0]] +...... ``` 结果可视化 @@ -126,7 +82,7 @@ im_show.save('result.jpg') * 单独执行识别 ```python from paddleocr import PaddleOCR -ocr = PaddleOCR(model_storage_directory='./model') # need to run only once to load model into memory +ocr = PaddleOCR() # need to run only once to download and load model into memory img_path = 'PaddleOCR/doc/imgs_words/ch/word_1.jpg' result = ocr.ocr(img_path,det=False) for line in result: @@ -153,29 +109,7 @@ paddleocr --image_dir PaddleOCR/doc/imgs/11.jpg [[[24.0, 36.0], [304.0, 34.0], [304.0, 72.0], [24.0, 74.0]], ['纯臻营养护发素', 0.964739]] [[[24.0, 80.0], [172.0, 80.0], [172.0, 104.0], [24.0, 104.0]], ['产品信息/参数', 0.98069626]] [[[24.0, 109.0], [333.0, 109.0], [333.0, 136.0], [24.0, 136.0]], ['(45元/每公斤,100公斤起订)', 0.9676722]] -[[[22.0, 140.0], [284.0, 140.0], [284.0, 167.0], [22.0, 167.0]], ['每瓶22元,1000瓶起订)', 0.97444016]] -[[[22.0, 174.0], [85.0, 174.0], [85.0, 198.0], [22.0, 198.0]], ['【品牌】', 0.8187138]] -[[[89.0, 176.0], [301.0, 176.0], [301.0, 196.0], [89.0, 196.0]], [':代加工方式/OEMODM', 0.9421848]] -[[[23.0, 205.0], [85.0, 205.0], [85.0, 229.0], [23.0, 229.0]], ['【品名】', 0.76008326]] -[[[88.0, 204.0], [235.0, 206.0], [235.0, 229.0], [88.0, 227.0]], [':纯臻营养护发素', 0.9633639]] -[[[23.0, 236.0], [121.0, 236.0], [121.0, 261.0], [23.0, 261.0]], ['【产品编号】', 0.84101385]] -[[[110.0, 239.0], [239.0, 239.0], [239.0, 256.0], [110.0, 256.0]], ['1:YM-X-3011', 0.8621878]] -[[[414.0, 233.0], [430.0, 233.0], [430.0, 304.0], [414.0, 304.0]], ['ODM OEM', 0.9084018]] -[[[23.0, 268.0], [183.0, 268.0], [183.0, 292.0], [23.0, 292.0]], ['【净含量】:220ml', 0.9278281]] -[[[24.0, 301.0], [118.0, 301.0], [118.0, 321.0], [24.0, 321.0]], ['【适用人群】', 0.90901047]] -[[[127.0, 300.0], [254.0, 300.0], [254.0, 323.0], [127.0, 323.0]], [':适合所有肤质', 0.95465785]] -[[[24.0, 332.0], [117.0, 332.0], [117.0, 353.0], [24.0, 353.0]], ['【主要成分】', 0.88936955]] -[[[139.0, 332.0], [236.0, 332.0], [236.0, 352.0], [139.0, 352.0]], ['鲸蜡硬脂醇', 0.9447544]] -[[[248.0, 332.0], [345.0, 332.0], [345.0, 352.0], [248.0, 352.0]], ['燕麦B-葡聚', 0.89748293]] -[[[54.0, 363.0], [232.0, 363.0], [232.0, 383.0], [54.0, 383.0]], [' 椰油酰胺丙基甜菜碱', 0.902023]] -[[[25.0, 364.0], [64.0, 364.0], [64.0, 383.0], [25.0, 383.0]], ['糖、', 0.985203]] -[[[244.0, 363.0], [281.0, 363.0], [281.0, 382.0], [244.0, 382.0]], ['泛服', 0.44537082]] -[[[367.0, 367.0], [475.0, 367.0], [475.0, 388.0], [367.0, 388.0]], ['(成品包材)', 0.9834532]] -[[[24.0, 395.0], [120.0, 395.0], [120.0, 416.0], [24.0, 416.0]], ['【主要功能】', 0.88684446]] -[[[128.0, 397.0], [273.0, 397.0], [273.0, 414.0], [128.0, 414.0]], [':可紧致头发磷层', 0.9342501]] -[[[265.0, 395.0], [361.0, 395.0], [361.0, 415.0], [265.0, 415.0]], ['琴,从而达到', 0.8253762]] -[[[25.0, 425.0], [372.0, 425.0], [372.0, 448.0], [25.0, 448.0]], ['即时持久改善头发光泽的效果,给干燥的头', 0.97785276]] -[[[26.0, 457.0], [137.0, 457.0], [137.0, 477.0], [26.0, 477.0]], ['发足够的滋养', 0.9577897]] +...... ``` * 单独执行检测 @@ -187,29 +121,7 @@ paddleocr --image_dir PaddleOCR/doc/imgs/11.jpg --rec false [[26.0, 457.0], [137.0, 457.0], [137.0, 477.0], [26.0, 477.0]] [[25.0, 425.0], [372.0, 425.0], [372.0, 448.0], [25.0, 448.0]] [[128.0, 397.0], [273.0, 397.0], [273.0, 414.0], [128.0, 414.0]] -[[265.0, 395.0], [361.0, 395.0], [361.0, 415.0], [265.0, 415.0]] -[[24.0, 395.0], [120.0, 395.0], [120.0, 416.0], [24.0, 416.0]] -[[367.0, 367.0], [475.0, 367.0], [475.0, 388.0], [367.0, 388.0]] -[[54.0, 363.0], [232.0, 363.0], [232.0, 383.0], [54.0, 383.0]] -[[25.0, 364.0], [64.0, 364.0], [64.0, 383.0], [25.0, 383.0]] -[[244.0, 363.0], [281.0, 363.0], [281.0, 382.0], [244.0, 382.0]] -[[248.0, 332.0], [345.0, 332.0], [345.0, 352.0], [248.0, 352.0]] -[[139.0, 332.0], [236.0, 332.0], [236.0, 352.0], [139.0, 352.0]] -[[24.0, 332.0], [117.0, 332.0], [117.0, 353.0], [24.0, 353.0]] -[[127.0, 300.0], [254.0, 300.0], [254.0, 323.0], [127.0, 323.0]] -[[24.0, 301.0], [118.0, 301.0], [118.0, 321.0], [24.0, 321.0]] -[[23.0, 268.0], [183.0, 268.0], [183.0, 292.0], [23.0, 292.0]] -[[110.0, 239.0], [239.0, 239.0], [239.0, 256.0], [110.0, 256.0]] -[[23.0, 236.0], [121.0, 236.0], [121.0, 261.0], [23.0, 261.0]] -[[414.0, 233.0], [430.0, 233.0], [430.0, 304.0], [414.0, 304.0]] -[[88.0, 204.0], [235.0, 206.0], [235.0, 229.0], [88.0, 227.0]] -[[23.0, 205.0], [85.0, 205.0], [85.0, 229.0], [23.0, 229.0]] -[[89.0, 176.0], [301.0, 176.0], [301.0, 196.0], [89.0, 196.0]] -[[22.0, 174.0], [85.0, 174.0], [85.0, 198.0], [22.0, 198.0]] -[[22.0, 140.0], [284.0, 140.0], [284.0, 167.0], [22.0, 167.0]] -[[24.0, 109.0], [333.0, 109.0], [333.0, 136.0], [24.0, 136.0]] -[[24.0, 80.0], [172.0, 80.0], [172.0, 104.0], [24.0, 104.0]] -[[24.0, 36.0], [304.0, 34.0], [304.0, 72.0], [24.0, 74.0]] +...... ``` * 单独执行识别 @@ -230,7 +142,7 @@ paddleocr --image_dir PaddleOCR/doc/imgs_words/ch/word_1.jpg --det false | gpu_mem | 初始化占用的GPU内存大小 | 8000M | | image_dir | 通过命令行调用时执行预测的图片或文件夹路径 | | | det_algorithm | 使用的检测算法类型 | DB | -| det_model_name | 有两种使用方式: 1. 检测算法名称,此名称必须在支持列表内(目前只内置了ch_det_mv3_db),传入错误参数时会显示支持的列表 2. 自己转换好的inference模型路径,此时模型路径下必须包含model和params文件。选择此方式时,需要手动指定det_algorithm的值 | ch_det_mv3_db | +| det_model_dir | 检测模型所在文件夹。传参方式有两种,1. None: 自动下载内置模型到 `~/.paddleocr/det`;2.自己转换好的inference模型路径,模型路径下必须包含model和params文件 | None | | det_max_side_len | 检测算法前向时图片长边的最大尺寸,当长边超出这个值时会将长边resize到这个大小,短边等比例缩放 | 960 | | det_db_thresh | DB模型输出预测图的二值化阈值 | 0.3 | | det_db_box_thresh | DB模型输出框的阈值,低于此值的预测框会被丢弃 | 0.5 | @@ -239,13 +151,13 @@ paddleocr --image_dir PaddleOCR/doc/imgs_words/ch/word_1.jpg --det false | det_east_cover_thresh | EAST模型输出框的阈值,低于此值的预测框会被丢弃 | 0.1 | | det_east_nms_thresh | EAST模型输出框NMS的阈值 | 0.2 | | rec_algorithm | 使用的识别算法类型 | CRNN | -| rec_model_name | 有两种使用方式: 1. 识别算法名称,此名称必须在支持列表内(目前支持CRNN,Rosetta,STAR,RARE等算法,但是内置的只有ch_rec_mv3_crnn_enhance),传入错误参数时会显示支持的列表 2. 自己转换好的inference模型路径,此时模型路径下必须包含model和params文件。选择此方式时,需要手动指定rec_algorithm的值 | ch_rec_mv3_crnn_enhance | +| rec_model_dir | 识别模型所在文件夹。传承那方式有两种,1. None: 自动下载内置模型到 `~/.paddleocr/rec`;2.自己转换好的inference模型路径,模型路径下必须包含model和params文件 | None | | rec_image_shape | 识别算法的输入图片尺寸 | "3,32,320" | | rec_char_type | 识别算法的字符类型,中文(ch)或英文(en) | ch | | rec_batch_num | 进行识别时,同时前向的图片数 | 30 | -| rec_char_dict_path | 识别模型字典路径,当rec_model_name使用方式2传参时需要修改为自己的路径 | | +| max_text_length | 识别算法能识别的最大文字长度 | 25 | +| rec_char_dict_path | 识别模型字典路径,当rec_model_dir使用方式2传参时需要修改为自己的字典路径 | ./ppocr/utils/ppocr_keys_v1.txt | | use_space_char | 是否识别空格 | TRUE | | enable_mkldnn | 是否启用mkldnn | FALSE | -| model_storage_directory | 下载模型保存路径 | ~/.paddleocr | | det | 前向时使用启动检测 | TRUE | | rec | 前向时是否启动识别 | TRUE | diff --git a/doc/doc_en/whl.md b/doc/doc_en/whl.md index e073e8e3..2edf2037 100644 --- a/doc/doc_en/whl.md +++ b/doc/doc_en/whl.md @@ -17,7 +17,7 @@ pip install dist/paddleocr-0.0.3-py3-none-any.whl * detection and recognition ```python from paddleocr import PaddleOCR,draw_ocr -ocr = PaddleOCR(model_storage_directory='./model') # need to run only once to load model into memory +ocr = PaddleOCR() # need to run only once to download and load model into memory img_path = 'PaddleOCR/doc/imgs_en/img_12.jpg' result = ocr.ocr(img_path) for line in result: @@ -39,18 +39,7 @@ Output will be a list, each item contains bounding box, text and recognition con [[[442.0, 173.0], [1169.0, 173.0], [1169.0, 225.0], [442.0, 225.0]], ['ACKNOWLEDGEMENTS', 0.99283075]] [[[393.0, 340.0], [1207.0, 342.0], [1207.0, 389.0], [393.0, 387.0]], ['We would like to thank all the designers and', 0.9357758]] [[[399.0, 398.0], [1204.0, 398.0], [1204.0, 433.0], [399.0, 433.0]], ['contributors whohave been involved in the', 0.9592447]] -[[[395.0, 443.0], [1211.0, 443.0], [1211.0, 489.0], [395.0, 489.0]], ['production of this book;their contributions', 0.9713175]] -[[[395.0, 497.0], [1209.0, 495.0], [1209.0, 531.0], [395.0, 533.0]], ['have been indispensable to its creation.We', 0.96009934]] -[[[393.0, 545.0], [1212.0, 545.0], [1212.0, 591.0], [393.0, 591.0]], ['would also like to express our gratitude to al', 0.9371007]] -[[[393.0, 595.0], [1212.0, 593.0], [1212.0, 635.0], [393.0, 637.0]], ['the producers for their invaluable opinions', 0.96872145]] -[[[393.0, 645.0], [1209.0, 645.0], [1209.0, 685.0], [393.0, 685.0]], ['and assistance throughout this proiect.Andto', 0.94448787]] -[[[392.0, 697.0], [1212.0, 693.0], [1212.0, 735.0], [392.0, 739.0]], ['the many others whose names are not credited', 0.93633145]] -[[[397.0, 753.0], [689.0, 755.0], [689.0, 786.0], [397.0, 784.0]], ['buthavemades', 0.99324507]] -[[[813.0, 749.0], [1212.0, 747.0], [1212.0, 784.0], [813.0, 786.0]], ['inputin this book, we', 0.9166398]] -[[[675.0, 760.0], [799.0, 755.0], [799.0, 778.0], [675.0, 784.0]], ['speciti', 0.9063535]] -[[[393.0, 801.0], [715.0, 805.0], [715.0, 839.0], [393.0, 836.0]], ['thankyouforyoul', 0.92475533]] -[[[756.0, 812.0], [805.0, 812.0], [805.0, 830.0], [756.0, 830.0]], ['P', 0.14887337]] -[[[820.0, 803.0], [1085.0, 801.0], [1085.0, 836.0], [820.0, 838.0]], ['nuoussupport', 0.9898951]] +...... ``` Visualization of results @@ -62,7 +51,7 @@ Visualization of results * only detection ```python from paddleocr import PaddleOCR,draw_ocr -ocr = PaddleOCR(model_storage_directory='./model') # need to run only once to load model into memory +ocr = PaddleOCR() # need to run only once to download and load model into memory img_path = 'PaddleOCR/doc/imgs_en/img_12.jpg' result = ocr.ocr(img_path,rec=False) for line in result: @@ -82,18 +71,7 @@ Output will be a list, each item only contains bounding box [[756.0, 812.0], [805.0, 812.0], [805.0, 830.0], [756.0, 830.0]] [[820.0, 803.0], [1085.0, 801.0], [1085.0, 836.0], [820.0, 838.0]] [[393.0, 801.0], [715.0, 805.0], [715.0, 839.0], [393.0, 836.0]] -[[675.0, 760.0], [799.0, 755.0], [799.0, 778.0], [675.0, 784.0]] -[[397.0, 753.0], [689.0, 755.0], [689.0, 786.0], [397.0, 784.0]] -[[813.0, 749.0], [1212.0, 747.0], [1212.0, 784.0], [813.0, 786.0]] -[[392.0, 697.0], [1212.0, 693.0], [1212.0, 735.0], [392.0, 739.0]] -[[393.0, 645.0], [1209.0, 645.0], [1209.0, 685.0], [393.0, 685.0]] -[[393.0, 595.0], [1212.0, 593.0], [1212.0, 635.0], [393.0, 637.0]] -[[393.0, 545.0], [1212.0, 545.0], [1212.0, 591.0], [393.0, 591.0]] -[[395.0, 497.0], [1209.0, 495.0], [1209.0, 531.0], [395.0, 533.0]] -[[395.0, 443.0], [1211.0, 443.0], [1211.0, 489.0], [395.0, 489.0]] -[[399.0, 398.0], [1204.0, 398.0], [1204.0, 433.0], [399.0, 433.0]] -[[393.0, 340.0], [1207.0, 342.0], [1207.0, 389.0], [393.0, 387.0]] -[[442.0, 173.0], [1169.0, 173.0], [1169.0, 225.0], [442.0, 225.0]] +...... ``` Visualization of results @@ -105,7 +83,7 @@ Visualization of results * only recognition ```python from paddleocr import PaddleOCR -ocr = PaddleOCR(model_storage_directory='./model') # need to run only once to load model into memory +ocr = PaddleOCR() # need to run only once to load model into memory img_path = 'PaddleOCR/doc/imgs_words_en/word_10.png' result = ocr.ocr(img_path,det=False) for line in result: @@ -134,18 +112,7 @@ Output will be a list, each item contains bounding box, text and recognition con [[[442.0, 173.0], [1169.0, 173.0], [1169.0, 225.0], [442.0, 225.0]], ['ACKNOWLEDGEMENTS', 0.99283075]] [[[393.0, 340.0], [1207.0, 342.0], [1207.0, 389.0], [393.0, 387.0]], ['We would like to thank all the designers and', 0.9357758]] [[[399.0, 398.0], [1204.0, 398.0], [1204.0, 433.0], [399.0, 433.0]], ['contributors whohave been involved in the', 0.9592447]] -[[[395.0, 443.0], [1211.0, 443.0], [1211.0, 489.0], [395.0, 489.0]], ['production of this book;their contributions', 0.9713175]] -[[[395.0, 497.0], [1209.0, 495.0], [1209.0, 531.0], [395.0, 533.0]], ['have been indispensable to its creation.We', 0.96009934]] -[[[393.0, 545.0], [1212.0, 545.0], [1212.0, 591.0], [393.0, 591.0]], ['would also like to express our gratitude to al', 0.9371007]] -[[[393.0, 595.0], [1212.0, 593.0], [1212.0, 635.0], [393.0, 637.0]], ['the producers for their invaluable opinions', 0.96872145]] -[[[393.0, 645.0], [1209.0, 645.0], [1209.0, 685.0], [393.0, 685.0]], ['and assistance throughout this proiect.Andto', 0.94448787]] -[[[392.0, 697.0], [1212.0, 693.0], [1212.0, 735.0], [392.0, 739.0]], ['the many others whose names are not credited', 0.93633145]] -[[[397.0, 753.0], [689.0, 755.0], [689.0, 786.0], [397.0, 784.0]], ['buthavemades', 0.99324507]] -[[[813.0, 749.0], [1212.0, 747.0], [1212.0, 784.0], [813.0, 786.0]], ['inputin this book, we', 0.9166398]] -[[[675.0, 760.0], [799.0, 755.0], [799.0, 778.0], [675.0, 784.0]], ['speciti', 0.9063535]] -[[[393.0, 801.0], [715.0, 805.0], [715.0, 839.0], [393.0, 836.0]], ['thankyouforyoul', 0.92475533]] -[[[756.0, 812.0], [805.0, 812.0], [805.0, 830.0], [756.0, 830.0]], ['P', 0.14887337]] -[[[820.0, 803.0], [1085.0, 801.0], [1085.0, 836.0], [820.0, 838.0]], ['nuoussupport', 0.9898951]] +...... ``` * only detection @@ -158,18 +125,7 @@ Output will be a list, each item only contains bounding box [[756.0, 812.0], [805.0, 812.0], [805.0, 830.0], [756.0, 830.0]] [[820.0, 803.0], [1085.0, 801.0], [1085.0, 836.0], [820.0, 838.0]] [[393.0, 801.0], [715.0, 805.0], [715.0, 839.0], [393.0, 836.0]] -[[675.0, 760.0], [799.0, 755.0], [799.0, 778.0], [675.0, 784.0]] -[[397.0, 753.0], [689.0, 755.0], [689.0, 786.0], [397.0, 784.0]] -[[813.0, 749.0], [1212.0, 747.0], [1212.0, 784.0], [813.0, 786.0]] -[[392.0, 697.0], [1212.0, 693.0], [1212.0, 735.0], [392.0, 739.0]] -[[393.0, 645.0], [1209.0, 645.0], [1209.0, 685.0], [393.0, 685.0]] -[[393.0, 595.0], [1212.0, 593.0], [1212.0, 635.0], [393.0, 637.0]] -[[393.0, 545.0], [1212.0, 545.0], [1212.0, 591.0], [393.0, 591.0]] -[[395.0, 497.0], [1209.0, 495.0], [1209.0, 531.0], [395.0, 533.0]] -[[395.0, 443.0], [1211.0, 443.0], [1211.0, 489.0], [395.0, 489.0]] -[[399.0, 398.0], [1204.0, 398.0], [1204.0, 433.0], [399.0, 433.0]] -[[393.0, 340.0], [1207.0, 342.0], [1207.0, 389.0], [393.0, 387.0]] -[[442.0, 173.0], [1169.0, 173.0], [1169.0, 225.0], [442.0, 225.0]] +...... ``` * only recognition @@ -190,7 +146,7 @@ Output will be a list, each item contains text and recognition confidence | gpu_mem | GPU memory size used for initialization | 8000M | | image_dir | The images path or folder path for predicting when used by the command line | | | det_algorithm | Type of detection algorithm selected | DB | -| det_model_name | There are two ways to use: 1. The name of the detection algorithm which must be in the support list(only ch_det_mv3_db is built in currently), and the supported list will be displayed when the wrong parameter is passed in. 2. The path of the inference model that has been converted by yourself. At this time, the model path must contains model and params files. When choosing this method, you need to give the name of det_algorithm | ch_det_mv3_db | +| det_model_dir | the text detection inference model folder. There are two ways to transfer parameters, 1. None: Automatically download the built-in model to `~/.paddleocr/det`; 2. The path of the inference model converted by yourself, the model and params files must be included in the model path | None | | det_max_side_len | The maximum size of the long side of the image. When the long side exceeds this value, the long side will be resized to this size, and the short side will be scaled proportionally | 960 | | det_db_thresh | Binarization threshold value of DB output map | 0.3 | | det_db_box_thresh | The threshold value of the DB output box. Boxes score lower than this value will be discarded | 0.5 | @@ -199,13 +155,13 @@ Output will be a list, each item contains text and recognition confidence | det_east_cover_thresh | The threshold value of the EAST output box. Boxes score lower than this value will be discarded | 0.1 | | det_east_nms_thresh | The NMS threshold value of EAST model output box | 0.2 | | rec_algorithm | Type of recognition algorithm selected | CRNN | -| rec_model_name | There are two ways to use: 1. The name of the recognition algorithm which must be in the support list(only supports CRNN, Rosetta, STAR, RARE and other algorithms currently, but only ch_rec_mv3_crnn_enhance is built-in), and the supported list will be displayed when the wrong parameter is passed in. 2. The path of the inference model that has been converted by yourself. At this time, the model path must contains model and params files. When choosing this method, you need to give the name of rec_algorithm | ch_rec_mv3_crnn_enhance | +| rec_model_dir | the text recognition inference model folder. There are two ways to transfer parameters, 1. None: Automatically download the built-in model to `~/.paddleocr/rec`; 2. The path of the inference model converted by yourself, the model and params files must be included in the model path | None | | rec_image_shape | image shape of recognition algorithm | "3,32,320" | | rec_char_type | Character type of recognition algorithm, Chinese (ch) or English (en) | ch | | rec_batch_num | When performing recognition, the batchsize of forward images | 30 | -| rec_char_dict_path | the alphabet path which needs to be modified to your own path when `rec_model_Name` use mode 2 | | +| max_text_length | The maximum text length that the recognition algorithm can recognize | 25 | +| rec_char_dict_path | the alphabet path which needs to be modified to your own path when `rec_model_Name` use mode 2 | ./ppocr/utils/ppocr_keys_v1.txt | | use_space_char | Whether to recognize spaces | TRUE | | enable_mkldnn | Whether to enable mkldnn | FALSE | -| model_storage_directory | Download model save path when det_model_name or rec_model_name use mode 1 | ~/.paddleocr | | det | Enable detction when `ppocr.ocr` func exec | TRUE | | rec | Enable detction when `ppocr.ocr` func exec | TRUE | From c581ff51a8c22c10ae7e98abff318ea09613f6a0 Mon Sep 17 00:00:00 2001 From: WenmuZhou Date: Mon, 24 Aug 2020 11:30:56 +0800 Subject: [PATCH 10/42] =?UTF-8?q?model=5Fstorage=5Fdirectory=E5=8F=82?= =?UTF-8?q?=E6=95=B0=E5=8F=96=E6=B6=88=EF=BC=8C=E6=94=B9=E4=B8=BAdet=5Fmod?= =?UTF-8?q?el=5Fdir=E5=92=8Crec=5Fmodel=5Fdir?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- paddleocr.py | 133 ++++++++++++++++++++++----------------------------- 1 file changed, 57 insertions(+), 76 deletions(-) diff --git a/paddleocr.py b/paddleocr.py index 3c356bb3..65bca7ae 100644 --- a/paddleocr.py +++ b/paddleocr.py @@ -29,25 +29,19 @@ from tools.infer import predict_system from ppocr.utils.utility import initial_logger logger = initial_logger() -from ppocr.utils.utility import check_and_read_gif +from ppocr.utils.utility import check_and_read_gif, get_image_file_list __all__ = ['PaddleOCR'] model_params = { - 'ch_det_mv3_db': { - 'url': - 'https://paddleocr.bj.bcebos.com/ch_models/ch_det_mv3_db_infer.tar', - 'algorithm': 'DB', - }, - 'ch_rec_mv3_crnn_enhance': { - 'url': - 'https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_enhance_infer.tar', - 'algorithm': 'CRNN' - }, + 'det': 'https://paddleocr.bj.bcebos.com/ch_models/ch_det_mv3_db_infer.tar', + 'rec': + 'https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_enhance_infer.tar', } SUPPORT_DET_MODEL = ['DB'] -SUPPORT_REC_MODEL = ['Rosetta', 'CRNN', 'STARNet', 'RARE'] +SUPPORT_REC_MODEL = ['CRNN'] +BASE_DIR = os.path.expanduser("~/.paddleocr/") def download_with_progressbar(url, save_path): @@ -65,34 +59,29 @@ def download_with_progressbar(url, save_path): sys.exit(0) -def download_and_unzip(url, model_storage_directory): - tmp_path = os.path.join(model_storage_directory, url.split('/')[-1]) - print('download {} to {}'.format(url, tmp_path)) - os.makedirs(model_storage_directory, exist_ok=True) - download_with_progressbar(url, tmp_path) - with tarfile.open(tmp_path, 'r') as tarObj: - for filename in tarObj.getnames(): - tarObj.extract(filename, model_storage_directory) - os.remove(tmp_path) - - -def maybe_download(model_storage_directory, model_name, mode='det'): - algorithm = None +def maybe_download(model_storage_directory, url): # using custom model - if os.path.exists(os.path.join(model_name, 'model')) and os.path.exists( - os.path.join(model_name, 'params')): - return model_name, algorithm - # using the model of paddleocr - model_path = os.path.join(model_storage_directory, model_name) - if not os.path.exists(os.path.join(model_path, - 'model')) or not os.path.exists( - os.path.join(model_path, 'params')): - assert model_name in model_params, 'model must in {}'.format( - model_params.keys()) - download_and_unzip(model_params[model_name]['url'], - model_storage_directory) - algorithm = model_params[model_name]['algorithm'] - return model_path, algorithm + if not os.path.exists(os.path.join( + model_storage_directory, 'model')) or not os.path.exists( + os.path.join(model_storage_directory, 'params')): + tmp_path = os.path.join(model_storage_directory, url.split('/')[-1]) + print('download {} to {}'.format(url, tmp_path)) + os.makedirs(model_storage_directory, exist_ok=True) + download_with_progressbar(url, tmp_path) + with tarfile.open(tmp_path, 'r') as tarObj: + for member in tarObj.getmembers(): + if "model" in member.name: + filename = 'model' + elif "params" in member.name: + filename = 'params' + else: + continue + file = tarObj.extractfile(member) + with open( + os.path.join(model_storage_directory, filename), + 'wb') as f: + f.write(file.read()) + os.remove(tmp_path) def parse_args(): @@ -111,7 +100,7 @@ def parse_args(): # params for text detector parser.add_argument("--image_dir", type=str) parser.add_argument("--det_algorithm", type=str, default='DB') - parser.add_argument("--det_model_name", type=str, default='ch_det_mv3_db') + parser.add_argument("--det_model_dir", type=str, default=None) parser.add_argument("--det_max_side_len", type=float, default=960) # DB parmas @@ -126,11 +115,11 @@ def parse_args(): # params for text recognizer parser.add_argument("--rec_algorithm", type=str, default='CRNN') - parser.add_argument( - "--rec_model_name", type=str, default='ch_rec_mv3_crnn_enhance') + parser.add_argument("--rec_model_dir", type=str, default=None) parser.add_argument("--rec_image_shape", type=str, default="3, 32, 320") parser.add_argument("--rec_char_type", type=str, default='ch') parser.add_argument("--rec_batch_num", type=int, default=30) + parser.add_argument("--max_text_length", type=int, default=25) parser.add_argument( "--rec_char_dict_path", type=str, @@ -138,53 +127,30 @@ def parse_args(): parser.add_argument("--use_space_char", type=bool, default=True) parser.add_argument("--enable_mkldnn", type=bool, default=False) - parser.add_argument("--model_storage_directory", type=str, default=False) parser.add_argument("--det", type=str2bool, default=True) parser.add_argument("--rec", type=str2bool, default=True) return parser.parse_args() class PaddleOCR(predict_system.TextSystem): - def __init__(self, - det_model_name='ch_det_mv3_db', - rec_model_name='ch_rec_mv3_crnn_enhance', - model_storage_directory=None, - log_level=20, - **kwargs): + def __init__(self, **kwargs): """ paddleocr package args: - det_model_name: det_model name, keep same with filename in paddleocr. default is ch_det_mv3_db - det_model_name: rec_model name, keep same with filename in paddleocr. default is ch_rec_mv3_crnn_enhance - model_storage_directory: model save path. default is ~/.paddleocr - det model will save to model_storage_directory/det_model - rec model will save to model_storage_directory/rec_model - log_level: **kwargs: other params show in paddleocr --help """ - logger.setLevel(log_level) postprocess_params = parse_args() - # init model dir - if model_storage_directory: - self.model_storage_directory = model_storage_directory - else: - self.model_storage_directory = os.path.expanduser( - "~/.paddleocr/") + '/model' - Path(self.model_storage_directory).mkdir(parents=True, exist_ok=True) - - # download model - det_model_path, det_algorithm = maybe_download( - self.model_storage_directory, det_model_name, 'det') - rec_model_path, rec_algorithm = maybe_download( - self.model_storage_directory, rec_model_name, 'rec') - # update model and post_process params postprocess_params.__dict__.update(**kwargs) - postprocess_params.det_model_dir = det_model_path - postprocess_params.rec_model_dir = rec_model_path - if det_algorithm is not None: - postprocess_params.det_algorithm = det_algorithm - if rec_algorithm is not None: - postprocess_params.rec_algorithm = rec_algorithm + + # init model dir + if postprocess_params.det_model_dir is None: + postprocess_params.det_model_dir = os.path.join(BASE_DIR, 'det') + if postprocess_params.rec_model_dir is None: + postprocess_params.rec_model_dir = os.path.join(BASE_DIR, 'rec') + print(postprocess_params) + # download model + maybe_download(postprocess_params.det_model_dir, model_params['det']) + maybe_download(postprocess_params.rec_model_dir, model_params['rec']) if postprocess_params.det_algorithm not in SUPPORT_DET_MODEL: logger.error('det_algorithm must in {}'.format(SUPPORT_DET_MODEL)) @@ -229,3 +195,18 @@ class PaddleOCR(predict_system.TextSystem): img = [img] rec_res, elapse = self.text_recognizer(img) return rec_res + + +def main(): + # for com + args = parse_args() + image_file_list = get_image_file_list(args.image_dir) + if len(image_file_list) == 0: + logger.error('no images find in {}'.format(args.image_dir)) + return + ocr_engine = PaddleOCR() + for img_path in image_file_list: + print(img_path) + result = ocr_engine.ocr(img_path, det=args.det, rec=args.rec) + for line in result: + print(line) From 8346621bcf73a659f9aa4b6dadcc3796758f1629 Mon Sep 17 00:00:00 2001 From: WenmuZhou Date: Mon, 24 Aug 2020 16:25:36 +0800 Subject: [PATCH 11/42] =?UTF-8?q?=E6=B7=BB=E5=8A=A0=E4=BD=BF=E7=94=A8?= =?UTF-8?q?=E8=87=AA=E5=AE=9A=E4=B9=89=E6=A8=A1=E5=9E=8B=E6=96=87=E6=A1=A3?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- doc/doc_ch/whl.md | 31 +++++++++++++++++++++++++++++++ doc/doc_en/{whl.md => whl_en.md} | 32 ++++++++++++++++++++++++++++++++ setup.py | 2 +- 3 files changed, 64 insertions(+), 1 deletion(-) rename doc/doc_en/{whl.md => whl_en.md} (91%) diff --git a/doc/doc_ch/whl.md b/doc/doc_ch/whl.md index 1328f8c5..9df1791d 100644 --- a/doc/doc_ch/whl.md +++ b/doc/doc_ch/whl.md @@ -134,6 +134,37 @@ paddleocr --image_dir PaddleOCR/doc/imgs_words/ch/word_1.jpg --det false ['韩国小馆', 0.9907421] ``` +## 自定义模型 +当内置模型无法满足需求时,需要使用到自己训练的模型。 +首先,参照[inference.md](./inference.md) 第一节转换将检测和识别模型转换为inference模型,然后按照如下方式使用 + +### 代码使用 +```python +from paddleocr import PaddleOCR, draw_ocr +# 检测模型和识别模型路径下必须含有model和params文件 +ocr = PaddleOCR(det_model_dir='your_det_model_dir',rec_model_dir='your_rec_model_dir') +img_path = 'PaddleOCR/doc/imgs/11.jpg' +result = ocr.ocr(img_path) +for line in result: + print(line) + +# 显示结果 +from PIL import Image +image = Image.open(img_path).convert('RGB') +boxes = [line[0] for line in result] +txts = [line[1][0] for line in result] +scores = [line[1][1] for line in result] +im_show = draw_ocr(image, boxes, txts, scores, font_path='/path/to/PaddleOCR/doc/simfang.ttf') +im_show = Image.fromarray(im_show) +im_show.save('result.jpg') +``` + +### 通过命令行使用 + +```bash +paddleocr --image_dir PaddleOCR/doc/imgs/11.jpg --det_model_dir your_det_model_dir --rec_model_dir your_rec_model_dir +``` + ## 参数说明 | 字段 | 说明 | 默认值 | diff --git a/doc/doc_en/whl.md b/doc/doc_en/whl_en.md similarity index 91% rename from doc/doc_en/whl.md rename to doc/doc_en/whl_en.md index 2edf2037..3e12a9b5 100644 --- a/doc/doc_en/whl.md +++ b/doc/doc_en/whl_en.md @@ -138,6 +138,38 @@ Output will be a list, each item contains text and recognition confidence ['PAIN', 0.990372] ``` +## Use custom model +When the built-in model cannot meet the needs, you need to use your own trained model. +First, refer to the first section of [inference_en.md](./inference_en.md) to convert your det and rec model to inference model, and then use it as follows + +### 1. Use by code + +```python +from paddleocr import PaddleOCR,draw_ocr +# The path of detection and recognition model must contain model and params files +ocr = PaddleOCR(det_model_dir='your_det_model_dir',rec_model_dir='your_rec_model_dir') +img_path = 'PaddleOCR/doc/imgs_en/img_12.jpg' +result = ocr.ocr(img_path) +for line in result: + print(line) + +# draw result +from PIL import Image +image = Image.open(img_path).convert('RGB') +boxes = [line[0] for line in result] +txts = [line[1][0] for line in result] +scores = [line[1][1] for line in result] +im_show = draw_ocr(image, boxes, txts, scores, font_path='/path/to/PaddleOCR/doc/simfang.ttf') +im_show = Image.fromarray(im_show) +im_show.save('result.jpg') +``` + +### Use by command line + +```bash +paddleocr --image_dir PaddleOCR/doc/imgs/11.jpg --det_model_dir your_det_model_dir --rec_model_dir your_rec_model_dir +``` + ## Parameter Description | Parameter | Description | Default value | diff --git a/setup.py b/setup.py index 28409139..7141f170 100644 --- a/setup.py +++ b/setup.py @@ -21,7 +21,7 @@ with open('requirments.txt', encoding="utf-8-sig") as f: def readme(): - with open('doc/doc_en/whl.md', encoding="utf-8-sig") as f: + with open('doc/doc_en/whl_en.md', encoding="utf-8-sig") as f: README = f.read() return README From bd32a9002128e65443c6834e205b7d9b13be0f97 Mon Sep 17 00:00:00 2001 From: WenmuZhou Date: Mon, 24 Aug 2020 16:59:43 +0800 Subject: [PATCH 12/42] =?UTF-8?q?=E8=B7=AF=E5=BE=84=E6=B7=BB=E5=8A=A0{}?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- doc/doc_ch/whl.md | 4 ++-- doc/doc_en/whl_en.md | 4 ++-- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/doc/doc_ch/whl.md b/doc/doc_ch/whl.md index 9df1791d..280cc2f6 100644 --- a/doc/doc_ch/whl.md +++ b/doc/doc_ch/whl.md @@ -142,7 +142,7 @@ paddleocr --image_dir PaddleOCR/doc/imgs_words/ch/word_1.jpg --det false ```python from paddleocr import PaddleOCR, draw_ocr # 检测模型和识别模型路径下必须含有model和params文件 -ocr = PaddleOCR(det_model_dir='your_det_model_dir',rec_model_dir='your_rec_model_dir') +ocr = PaddleOCR(det_model_dir='{your_det_model_dir}',rec_model_dir='{your_rec_model_dir}') img_path = 'PaddleOCR/doc/imgs/11.jpg' result = ocr.ocr(img_path) for line in result: @@ -162,7 +162,7 @@ im_show.save('result.jpg') ### 通过命令行使用 ```bash -paddleocr --image_dir PaddleOCR/doc/imgs/11.jpg --det_model_dir your_det_model_dir --rec_model_dir your_rec_model_dir +paddleocr --image_dir PaddleOCR/doc/imgs/11.jpg --det_model_dir {your_det_model_dir} --rec_model_dir {your_rec_model_dir} ``` ## 参数说明 diff --git a/doc/doc_en/whl_en.md b/doc/doc_en/whl_en.md index 3e12a9b5..73ab78c1 100644 --- a/doc/doc_en/whl_en.md +++ b/doc/doc_en/whl_en.md @@ -147,7 +147,7 @@ First, refer to the first section of [inference_en.md](./inference_en.md) to con ```python from paddleocr import PaddleOCR,draw_ocr # The path of detection and recognition model must contain model and params files -ocr = PaddleOCR(det_model_dir='your_det_model_dir',rec_model_dir='your_rec_model_dir') +ocr = PaddleOCR(det_model_dir='{your_det_model_dir}',rec_model_dir='{your_rec_model_dir}å') img_path = 'PaddleOCR/doc/imgs_en/img_12.jpg' result = ocr.ocr(img_path) for line in result: @@ -167,7 +167,7 @@ im_show.save('result.jpg') ### Use by command line ```bash -paddleocr --image_dir PaddleOCR/doc/imgs/11.jpg --det_model_dir your_det_model_dir --rec_model_dir your_rec_model_dir +paddleocr --image_dir PaddleOCR/doc/imgs/11.jpg --det_model_dir {your_det_model_dir} --rec_model_dir {your_rec_model_dir} ``` ## Parameter Description From 9fea2df2cf5f48e2e9826ea3629c8fb2b62d7a9b Mon Sep 17 00:00:00 2001 From: dyning Date: Mon, 24 Aug 2020 20:53:20 +0800 Subject: [PATCH 13/42] Update update.md --- doc/doc_ch/update.md | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/doc/doc_ch/update.md b/doc/doc_ch/update.md index 1cd77885..23a47df5 100644 --- a/doc/doc_ch/update.md +++ b/doc/doc_ch/update.md @@ -1,6 +1,8 @@ # 更新 +- 2020.8.24 支持通过whl包安装使用PaddleOCR,具体参考[Paddleocr Package使用说明](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/whl.md) +- 2020.8.21 更新8月18日B站直播课回放和PPT,课节2,易学易用的OCR工具大礼包,[获取地址](https://aistudio.baidu.com/aistudio/education/group/info/1519) - 2020.8.16 开源文本检测算法[SAST](https://arxiv.org/abs/1908.05498)和文本识别算法[SRN](https://arxiv.org/abs/2003.12294) -- 2020.7.23 发布7月21日B站直播课回放和PPT,PaddleOCR开源大礼包全面解读,[获取地址](https://aistudio.baidu.com/aistudio/course/introduce/1519) +- 2020.7.23 发布7月21日B站直播课回放和PPT,课节1,PaddleOCR开源大礼包全面解读,[获取地址](https://aistudio.baidu.com/aistudio/course/introduce/1519) - 2020.7.15 添加基于EasyEdge和Paddle-Lite的移动端DEMO,支持iOS和Android系统 - 2020.7.15 完善预测部署,添加基于C++预测引擎推理、服务化部署和端侧部署方案,以及超轻量级中文OCR模型预测耗时Benchmark - 2020.7.15 整理OCR相关数据集、常用数据标注以及合成工具 From 2783a688fafb743e1d7e5e0d71a1030aa0148285 Mon Sep 17 00:00:00 2001 From: dyning Date: Mon, 24 Aug 2020 20:54:18 +0800 Subject: [PATCH 14/42] Update README_cn.md --- README_cn.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/README_cn.md b/README_cn.md index 10bcbc50..8bdcce62 100644 --- a/README_cn.md +++ b/README_cn.md @@ -4,11 +4,11 @@ PaddleOCR旨在打造一套丰富、领先、且实用的OCR工具库,助力使用者训练出更好的模型,并应用落地。 **近期更新** +- 2020.8.24 支持通过whl包安装使用PaddleOCR,具体参考[Paddleocr Package使用说明](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/whl.md) +- 2020.8.21 更新8月18日B站直播课回放和PPT,课节2,易学易用的OCR工具大礼包,[获取地址](https://aistudio.baidu.com/aistudio/education/group/info/1519) - 2020.8.16 开源文本检测算法[SAST](https://arxiv.org/abs/1908.05498)和文本识别算法[SRN](https://arxiv.org/abs/2003.12294) -- 2020.7.23 发布7月21日B站直播课回放和PPT,PaddleOCR开源大礼包全面解读,[获取地址](https://aistudio.baidu.com/aistudio/course/introduce/1519) +- 2020.7.23 发布7月21日B站直播课回放和PPT,课节1,PaddleOCR开源大礼包全面解读,[获取地址](https://aistudio.baidu.com/aistudio/course/introduce/1519) - 2020.7.15 添加基于EasyEdge和Paddle-Lite的移动端DEMO,支持iOS和Android系统 -- 2020.7.15 完善预测部署,添加基于C++预测引擎推理、服务化部署和端侧部署方案,以及超轻量级中文OCR模型预测耗时Benchmark -- 2020.7.15 整理OCR相关数据集、常用数据标注以及合成工具 - [more](./doc/doc_ch/update.md) From 219cfe2251f4d5fc23f437cd3bb1c4fa7e8537e7 Mon Sep 17 00:00:00 2001 From: dyning Date: Mon, 24 Aug 2020 20:57:46 +0800 Subject: [PATCH 15/42] Update update_en.md --- doc/doc_en/update_en.md | 1 + 1 file changed, 1 insertion(+) diff --git a/doc/doc_en/update_en.md b/doc/doc_en/update_en.md index dc839d89..5d858558 100644 --- a/doc/doc_en/update_en.md +++ b/doc/doc_en/update_en.md @@ -1,4 +1,5 @@ # RECENT UPDATES +- 2020.8.24 Support the use of PaddleOCR through whl package installation,pelease refer [Paddleocr Package](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_en/whl_en.md) - 2020.8.16 Release text detection algorithm [SAST](https://arxiv.org/abs/1908.05498) and text recognition algorithm [SRN](https://arxiv.org/abs/2003.12294) - 2020.7.23, Release the playback and PPT of live class on BiliBili station, PaddleOCR Introduction, [address](https://aistudio.baidu.com/aistudio/course/introduce/1519) - 2020.7.15, Add mobile App demo , support both iOS and Android ( based on easyedge and Paddle Lite) From d424243a5d11396634967782169a5a7b7b0b46fc Mon Sep 17 00:00:00 2001 From: dyning Date: Mon, 24 Aug 2020 20:58:40 +0800 Subject: [PATCH 16/42] Update README.md --- README.md | 1 + 1 file changed, 1 insertion(+) diff --git a/README.md b/README.md index 08a27d8e..cbc091c4 100644 --- a/README.md +++ b/README.md @@ -4,6 +4,7 @@ English | [简体中文](README_cn.md) PaddleOCR aims to create rich, leading, and practical OCR tools that help users train better models and apply them into practice. **Recent updates** +- 2020.8.24 Support the use of PaddleOCR through whl package installation,pelease refer [Paddleocr Package](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_en/whl_en.md) - 2020.8.16, Release text detection algorithm [SAST](https://arxiv.org/abs/1908.05498) and text recognition algorithm [SRN](https://arxiv.org/abs/2003.12294) - 2020.7.23, Release the playback and PPT of live class on BiliBili station, PaddleOCR Introduction, [address](https://aistudio.baidu.com/aistudio/course/introduce/1519) - 2020.7.15, Add mobile App demo , support both iOS and Android ( based on easyedge and Paddle Lite) From c41a7b5477dd01d6d1048812b80c8c348de1c01e Mon Sep 17 00:00:00 2001 From: dyning Date: Mon, 24 Aug 2020 20:59:52 +0800 Subject: [PATCH 17/42] Update README.md --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index cbc091c4..a9210072 100644 --- a/README.md +++ b/README.md @@ -4,7 +4,7 @@ English | [简体中文](README_cn.md) PaddleOCR aims to create rich, leading, and practical OCR tools that help users train better models and apply them into practice. **Recent updates** -- 2020.8.24 Support the use of PaddleOCR through whl package installation,pelease refer [Paddleocr Package](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_en/whl_en.md) +- 2020.8.24 Support the use of PaddleOCR through whl package installation,pelease refer [PaddleOCR Package](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_en/whl_en.md) - 2020.8.16, Release text detection algorithm [SAST](https://arxiv.org/abs/1908.05498) and text recognition algorithm [SRN](https://arxiv.org/abs/2003.12294) - 2020.7.23, Release the playback and PPT of live class on BiliBili station, PaddleOCR Introduction, [address](https://aistudio.baidu.com/aistudio/course/introduce/1519) - 2020.7.15, Add mobile App demo , support both iOS and Android ( based on easyedge and Paddle Lite) From 46c3c752d95da5aa8298c8b8be0b0224c6ada580 Mon Sep 17 00:00:00 2001 From: dyning Date: Mon, 24 Aug 2020 21:00:11 +0800 Subject: [PATCH 18/42] Update update_en.md --- doc/doc_en/update_en.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/doc/doc_en/update_en.md b/doc/doc_en/update_en.md index 5d858558..ca050370 100644 --- a/doc/doc_en/update_en.md +++ b/doc/doc_en/update_en.md @@ -1,5 +1,5 @@ # RECENT UPDATES -- 2020.8.24 Support the use of PaddleOCR through whl package installation,pelease refer [Paddleocr Package](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_en/whl_en.md) +- 2020.8.24 Support the use of PaddleOCR through whl package installation,pelease refer [PaddleOCR Package](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_en/whl_en.md) - 2020.8.16 Release text detection algorithm [SAST](https://arxiv.org/abs/1908.05498) and text recognition algorithm [SRN](https://arxiv.org/abs/2003.12294) - 2020.7.23, Release the playback and PPT of live class on BiliBili station, PaddleOCR Introduction, [address](https://aistudio.baidu.com/aistudio/course/introduce/1519) - 2020.7.15, Add mobile App demo , support both iOS and Android ( based on easyedge and Paddle Lite) From 5ffe0988660513f2c35eb39e36fe95568ce70334 Mon Sep 17 00:00:00 2001 From: dyning Date: Tue, 25 Aug 2020 10:07:19 +0800 Subject: [PATCH 19/42] Update quickstart.md --- doc/doc_ch/quickstart.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/doc/doc_ch/quickstart.md b/doc/doc_ch/quickstart.md index fead57f3..a85babce 100644 --- a/doc/doc_ch/quickstart.md +++ b/doc/doc_ch/quickstart.md @@ -5,6 +5,8 @@ 请先参考[快速安装](./installation.md)配置PaddleOCR运行环境。 +*注意:也可以通过 whl 包安装使用PaddleOCR,具体参考[Paddleocr Package使用说明](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/whl.md)* + ## 2.inference模型下载 |模型名称|模型简介|检测模型地址|识别模型地址|支持空格的识别模型地址| From 1252aee48d564c84922289fd7af85c45e788e6d9 Mon Sep 17 00:00:00 2001 From: dyning Date: Tue, 25 Aug 2020 10:07:50 +0800 Subject: [PATCH 20/42] Update quickstart.md --- doc/doc_ch/quickstart.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/doc/doc_ch/quickstart.md b/doc/doc_ch/quickstart.md index a85babce..701b50ed 100644 --- a/doc/doc_ch/quickstart.md +++ b/doc/doc_ch/quickstart.md @@ -5,7 +5,7 @@ 请先参考[快速安装](./installation.md)配置PaddleOCR运行环境。 -*注意:也可以通过 whl 包安装使用PaddleOCR,具体参考[Paddleocr Package使用说明](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/whl.md)* +*注意:也可以通过 whl 包安装使用PaddleOCR,具体参考[Paddleocr Package使用说明](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/whl.md)。* ## 2.inference模型下载 From 3d1b3980c9b1201618ef182c530fcb0be6bffc17 Mon Sep 17 00:00:00 2001 From: dyning Date: Tue, 25 Aug 2020 10:22:36 +0800 Subject: [PATCH 21/42] Update quickstart_en.md --- doc/doc_en/quickstart_en.md | 1 + 1 file changed, 1 insertion(+) diff --git a/doc/doc_en/quickstart_en.md b/doc/doc_en/quickstart_en.md index bf22f22f..730bf369 100644 --- a/doc/doc_en/quickstart_en.md +++ b/doc/doc_en/quickstart_en.md @@ -5,6 +5,7 @@ Please refer to [quick installation](./installation_en.md) to configure the PaddleOCR operating environment. +* Note: Support the use of PaddleOCR through whl package installation,pelease refer [PaddleOCR Package](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_en/whl_en.md) * ## 2.inference models From fb9e47b262529386983edc21b33abfa16bbf06ac Mon Sep 17 00:00:00 2001 From: dyning Date: Tue, 25 Aug 2020 10:22:57 +0800 Subject: [PATCH 22/42] Update quickstart_en.md --- doc/doc_en/quickstart_en.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/doc/doc_en/quickstart_en.md b/doc/doc_en/quickstart_en.md index 730bf369..d1fa1683 100644 --- a/doc/doc_en/quickstart_en.md +++ b/doc/doc_en/quickstart_en.md @@ -5,7 +5,7 @@ Please refer to [quick installation](./installation_en.md) to configure the PaddleOCR operating environment. -* Note: Support the use of PaddleOCR through whl package installation,pelease refer [PaddleOCR Package](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_en/whl_en.md) * +*Note: Support the use of PaddleOCR through whl package installation,pelease refer [PaddleOCR Package](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_en/whl_en.md)。* ## 2.inference models From 8a78af26df0dd8f15b734cc8db13e25d2a3656a2 Mon Sep 17 00:00:00 2001 From: MissPenguin Date: Wed, 26 Aug 2020 05:01:51 +0000 Subject: [PATCH 23/42] fix hub serving parmas bug --- deploy/hubserving/ocr_det/params.py | 4 +++- deploy/hubserving/ocr_rec/params.py | 4 +++- deploy/hubserving/ocr_system/params.py | 4 +++- 3 files changed, 9 insertions(+), 3 deletions(-) diff --git a/deploy/hubserving/ocr_det/params.py b/deploy/hubserving/ocr_det/params.py index 0b950114..e88ab45c 100644 --- a/deploy/hubserving/ocr_det/params.py +++ b/deploy/hubserving/ocr_det/params.py @@ -36,4 +36,6 @@ def read_params(): # cfg.rec_char_dict_path = "./ppocr/utils/ppocr_keys_v1.txt" # cfg.use_space_char = True - return cfg \ No newline at end of file + cfg.use_zero_copy_run = False + + return cfg diff --git a/deploy/hubserving/ocr_rec/params.py b/deploy/hubserving/ocr_rec/params.py index a6b2ee19..59772e21 100644 --- a/deploy/hubserving/ocr_rec/params.py +++ b/deploy/hubserving/ocr_rec/params.py @@ -38,4 +38,6 @@ def read_params(): cfg.rec_char_dict_path = "./ppocr/utils/ppocr_keys_v1.txt" cfg.use_space_char = True - return cfg \ No newline at end of file + cfg.use_zero_copy_run = False + + return cfg diff --git a/deploy/hubserving/ocr_system/params.py b/deploy/hubserving/ocr_system/params.py index 6ece2d6f..0ff56d37 100644 --- a/deploy/hubserving/ocr_system/params.py +++ b/deploy/hubserving/ocr_system/params.py @@ -38,4 +38,6 @@ def read_params(): cfg.rec_char_dict_path = "./ppocr/utils/ppocr_keys_v1.txt" cfg.use_space_char = True - return cfg \ No newline at end of file + cfg.use_zero_copy_run = False + + return cfg From c4a3ecdcb6e8ec93752e7b5fb9880de4cc50e414 Mon Sep 17 00:00:00 2001 From: grasswolfs Date: Wed, 26 Aug 2020 16:43:41 +0800 Subject: [PATCH 24/42] test=develop,test=document_fix --- README.md | 298 +++++++++++++--------------- README_cn.md | 228 ---------------------- README_en.md | 231 ++++++++++++++++++++++ doc/doc_ch/FAQ.md | 481 +++++++++++++++++++++++++++++++++++++++++++--- 4 files changed, 823 insertions(+), 415 deletions(-) delete mode 100644 README_cn.md create mode 100644 README_en.md diff --git a/README.md b/README.md index a9210072..4a290960 100644 --- a/README.md +++ b/README.md @@ -1,231 +1,209 @@ -English | [简体中文](README_cn.md) +[English](README_en.md) | 简体中文 -## Introduction -PaddleOCR aims to create rich, leading, and practical OCR tools that help users train better models and apply them into practice. +## 简介 +PaddleOCR旨在打造一套丰富、领先、且实用的OCR工具库,助力使用者训练出更好的模型,并应用落地。 -**Recent updates** -- 2020.8.24 Support the use of PaddleOCR through whl package installation,pelease refer [PaddleOCR Package](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_en/whl_en.md) -- 2020.8.16, Release text detection algorithm [SAST](https://arxiv.org/abs/1908.05498) and text recognition algorithm [SRN](https://arxiv.org/abs/2003.12294) -- 2020.7.23, Release the playback and PPT of live class on BiliBili station, PaddleOCR Introduction, [address](https://aistudio.baidu.com/aistudio/course/introduce/1519) -- 2020.7.15, Add mobile App demo , support both iOS and Android ( based on easyedge and Paddle Lite) -- 2020.7.15, Improve the deployment ability, add the C + + inference , serving deployment. In addition, the benchmarks of the ultra-lightweight OCR model are provided. -- 2020.7.15, Add several related datasets, data annotation and synthesis tools. -- [more](./doc/doc_en/update_en.md) +**近期更新** +- 2020.8.26 更新OCR相关的83个常见问题及解答,具体参考[FAQ](./doc/doc_ch/FAQ.md) +- 2020.8.24 支持通过whl包安装使用PaddleOCR,具体参考[Paddleocr Package使用说明](./doc/doc_ch/whl.md) +- 2020.8.21 更新8月18日B站直播课回放和PPT,课节2,易学易用的OCR工具大礼包,[获取地址](https://aistudio.baidu.com/aistudio/education/group/info/1519) +- 2020.8.16 开源文本检测算法[SAST](https://arxiv.org/abs/1908.05498)和文本识别算法[SRN](https://arxiv.org/abs/2003.12294) +- 2020.7.23 发布7月21日B站直播课回放和PPT,课节1,PaddleOCR开源大礼包全面解读,[获取地址](https://aistudio.baidu.com/aistudio/course/introduce/1519) +- 2020.7.15 添加基于EasyEdge和Paddle-Lite的移动端DEMO,支持iOS和Android系统 +- [more](./doc/doc_ch/update.md) -## Features -- Ultra-lightweight OCR model, total model size is only 8.6M - - Single model supports Chinese/English numbers combination recognition, vertical text recognition, long text recognition - - Detection model DB (4.1M) + recognition model CRNN (4.5M) -- Various text detection algorithms: EAST, DB -- Various text recognition algorithms: Rosetta, CRNN, STAR-Net, RARE -- Support Linux, Windows, macOS and other systems. -## Visualization +## 特性 +- 超轻量级中文OCR模型,总模型仅8.6M + - 单模型支持中英文数字组合识别、竖排文本识别、长文本识别 + - 检测模型DB(4.1M)+识别模型CRNN(4.5M) +- 实用通用中文OCR模型 +- 多种预测推理部署方案,包括服务部署和端侧部署 +- 多种文本检测训练算法,EAST、DB、SAST +- 多种文本识别训练算法,Rosetta、CRNN、STAR-Net、RARE、SRN +- 可运行于Linux、Windows、MacOS等多种系统 -![](doc/imgs_results/11.jpg) +## 快速体验 -![](doc/imgs_results/img_10.jpg) +

-[More visualization](./doc/doc_en/visualization_en.md) +上图是超轻量级中文OCR模型效果展示,更多效果图请见[效果展示页面](./doc/doc_ch/visualization.md)。 -You can also quickly experience the ultra-lightweight OCR : [Online Experience](https://www.paddlepaddle.org.cn/hub/scene/ocr) +- 超轻量级中文OCR在线体验地址:https://www.paddlepaddle.org.cn/hub/scene/ocr +- 移动端DEMO体验(基于EasyEdge和Paddle-Lite, 支持iOS和Android系统):[安装包二维码获取地址](https://ai.baidu.com/easyedge/app/openSource?from=paddlelite) -Mobile DEMO experience (based on EasyEdge and Paddle-Lite, supports iOS and Android systems): [Sign in to the website to obtain the QR code for installing the App](https://ai.baidu.com/easyedge/app/openSource?from=paddlelite) - - Also, you can scan the QR code below to install the App (**Android support only**) + Android手机也可以扫描下面二维码安装体验。
-- [**OCR Quick Start**](./doc/doc_en/quickstart_en.md) -
+## 中文OCR模型列表 -### Supported Models: - -|Model Name|Description |Detection Model link|Recognition Model link| Support for space Recognition Model link| +|模型名称|模型简介|检测模型地址|识别模型地址|支持空格的识别模型地址| |-|-|-|-|-| -|db_crnn_mobile|ultra-lightweight OCR model|[inference model](https://paddleocr.bj.bcebos.com/ch_models/ch_det_mv3_db_infer.tar) / [pre-trained model](https://paddleocr.bj.bcebos.com/ch_models/ch_det_mv3_db.tar)|[inference model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_infer.tar) / [pre-trained model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn.tar)|[inference model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_enhance_infer.tar) / [pre-train model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_enhance.tar) -|db_crnn_server|General OCR model|[inference model](https://paddleocr.bj.bcebos.com/ch_models/ch_det_r50_vd_db_infer.tar) / [pre-trained model](https://paddleocr.bj.bcebos.com/ch_models/ch_det_r50_vd_db.tar)|[inference model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn_infer.tar) / [pre-trained model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn.tar)|[inference model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn_enhance_infer.tar) / [pre-train model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn_enhance.tar) +|chinese_db_crnn_mobile|超轻量级中文OCR模型|[inference模型](https://paddleocr.bj.bcebos.com/ch_models/ch_det_mv3_db_infer.tar) / [预训练模型](https://paddleocr.bj.bcebos.com/ch_models/ch_det_mv3_db.tar)|[inference模型](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_infer.tar) / [预训练模型](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn.tar)|[inference模型](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_enhance_infer.tar) / [预训练模型](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_enhance.tar) +|chinese_db_crnn_server|通用中文OCR模型|[inference模型](https://paddleocr.bj.bcebos.com/ch_models/ch_det_r50_vd_db_infer.tar) / [预训练模型](https://paddleocr.bj.bcebos.com/ch_models/ch_det_r50_vd_db.tar)|[inference模型](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn_infer.tar) / [预训练模型](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn.tar)|[inference模型](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn_enhance_infer.tar) / [预训练模型](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn_enhance.tar) +## 文档教程 +- [快速安装](./doc/doc_ch/installation.md) +- [中文OCR模型快速使用](./doc/doc_ch/quickstart.md) +- 算法介绍 + - [文本检测](#文本检测算法) + - [文本识别](#文本识别算法) +- 模型训练/评估 + - [文本检测](./doc/doc_ch/detection.md) + - [文本识别](./doc/doc_ch/recognition.md) + - [yml参数配置文件介绍](./doc/doc_ch/config.md) + - [中文OCR训练预测技巧](./doc/doc_ch/tricks.md) +- 预测部署 + - [基于Python预测引擎推理](./doc/doc_ch/inference.md) + - [基于C++预测引擎推理](./deploy/cpp_infer/readme.md) + - [服务化部署](./doc/doc_ch/serving.md) + - [端侧部署](./deploy/lite/readme.md) + - 模型量化压缩(coming soon) + - [Benchmark](./doc/doc_ch/benchmark.md) +- 数据集 + - [通用中英文OCR数据集](./doc/doc_ch/datasets.md) + - [手写中文OCR数据集](./doc/doc_ch/handwritten_datasets.md) + - [垂类多语言OCR数据集](./doc/doc_ch/vertical_and_multilingual_datasets.md) + - [常用数据标注工具](./doc/doc_ch/data_annotation.md) + - [常用数据合成工具](./doc/doc_ch/data_synthesis.md) +- 效果展示 + - [超轻量级中文OCR效果展示](#超轻量级中文OCR效果展示) + - [通用中文OCR效果展示](#通用中文OCR效果展示) + - [支持空格的中文OCR效果展示](#支持空格的中文OCR效果展示) +- FAQ + - [【精选】OCR精选10个问题](./doc/doc_ch/FAQ.md) + - [【理论篇】OCR通用21个问题](./doc/doc_ch/FAQ.md) + - [【实战篇】PaddleOCR实战53个问题](./doc/doc_ch/FAQ.md) +- [技术交流群](#欢迎加入PaddleOCR技术交流群) +- [参考文献](./doc/doc_ch/reference.md) +- [许可证书](#许可证书) +- [贡献代码](#贡献代码) -## Tutorials -- [Installation](./doc/doc_en/installation_en.md) -- [Quick Start](./doc/doc_en/quickstart_en.md) -- Algorithm introduction - - [Text Detection Algorithm](#TEXTDETECTIONALGORITHM) - - [Text Recognition Algorithm](#TEXTRECOGNITIONALGORITHM) - - [END-TO-END OCR Algorithm](#ENDENDOCRALGORITHM) -- Model training/evaluation - - [Text Detection](./doc/doc_en/detection_en.md) - - [Text Recognition](./doc/doc_en/recognition_en.md) - - [Yml Configuration](./doc/doc_en/config_en.md) - - [Tricks](./doc/doc_en/tricks_en.md) -- Deployment - - [Python Inference](./doc/doc_en/inference_en.md) - - [C++ Inference](./deploy/cpp_infer/readme_en.md) - - [Serving](./doc/doc_en/serving_en.md) - - [Mobile](./deploy/lite/readme_en.md) - - Model Quantization and Compression (coming soon) - - [Benchmark](./doc/doc_en/benchmark_en.md) -- Datasets - - [General OCR Datasets(Chinese/English)](./doc/doc_en/datasets_en.md) - - [HandWritten_OCR_Datasets(Chinese)](./doc/doc_en/handwritten_datasets_en.md) - - [Various OCR Datasets(multilingual)](./doc/doc_en/vertical_and_multilingual_datasets_en.md) - - [Data Annotation Tools](./doc/doc_en/data_annotation_en.md) - - [Data Synthesis Tools](./doc/doc_en/data_synthesis_en.md) -- [FAQ](#FAQ) -- Visualization - - [Ultra-lightweight Chinese/English OCR Visualization](#UCOCRVIS) - - [General Chinese/English OCR Visualization](#GeOCRVIS) - - [Chinese/English OCR Visualization (Support Space Recognition )](#SpaceOCRVIS) -- [Community](#Community) -- [References](./doc/doc_en/reference_en.md) -- [License](#LICENSE) -- [Contribution](#CONTRIBUTION) + +## 算法介绍 + +### 1.文本检测算法 - -## Text Detection Algorithm - -PaddleOCR open source text detection algorithms list: +PaddleOCR开源的文本检测算法列表: - [x] EAST([paper](https://arxiv.org/abs/1704.03155)) - [x] DB([paper](https://arxiv.org/abs/1911.08947)) -- [x] SAST([paper](https://arxiv.org/abs/1908.05498))(Baidu Self-Research) +- [x] SAST([paper](https://arxiv.org/abs/1908.05498))(百度自研) -On the ICDAR2015 dataset, the text detection result is as follows: +在ICDAR2015文本检测公开数据集上,算法效果如下: -|Model|Backbone|precision|recall|Hmean|Download link| +|模型|骨干网络|precision|recall|Hmean|下载链接| |-|-|-|-|-|-| -|EAST|ResNet50_vd|88.18%|85.51%|86.82%|[Download link](https://paddleocr.bj.bcebos.com/det_r50_vd_east.tar)| -|EAST|MobileNetV3|81.67%|79.83%|80.74%|[Download link](https://paddleocr.bj.bcebos.com/det_mv3_east.tar)| -|DB|ResNet50_vd|83.79%|80.65%|82.19%|[Download link](https://paddleocr.bj.bcebos.com/det_r50_vd_db.tar)| -|DB|MobileNetV3|75.92%|73.18%|74.53%|[Download link](https://paddleocr.bj.bcebos.com/det_mv3_db.tar)| -|SAST|ResNet50_vd|92.18%|82.96%|87.33%|[Download link](https://paddleocr.bj.bcebos.com/SAST/sast_r50_vd_icdar2015.tar)| +|EAST|ResNet50_vd|88.18%|85.51%|86.82%|[下载链接](https://paddleocr.bj.bcebos.com/det_r50_vd_east.tar)| +|EAST|MobileNetV3|81.67%|79.83%|80.74%|[下载链接](https://paddleocr.bj.bcebos.com/det_mv3_east.tar)| +|DB|ResNet50_vd|83.79%|80.65%|82.19%|[下载链接](https://paddleocr.bj.bcebos.com/det_r50_vd_db.tar)| +|DB|MobileNetV3|75.92%|73.18%|74.53%|[下载链接](https://paddleocr.bj.bcebos.com/det_mv3_db.tar)| +|SAST|ResNet50_vd|92.18%|82.96%|87.33%|[下载链接](https://paddleocr.bj.bcebos.com/SAST/sast_r50_vd_icdar2015.tar)| -On Total-Text dataset, the text detection result is as follows: +在Total-text文本检测公开数据集上,算法效果如下: -|Model|Backbone|precision|recall|Hmean|Download link| +|模型|骨干网络|precision|recall|Hmean|下载链接| |-|-|-|-|-|-| -|SAST|ResNet50_vd|88.74%|79.80%|84.03%|[Download link](https://paddleocr.bj.bcebos.com/SAST/sast_r50_vd_total_text.tar)| +|SAST|ResNet50_vd|88.74%|79.80%|84.03%|[下载链接](https://paddleocr.bj.bcebos.com/SAST/sast_r50_vd_total_text.tar)| -**Note:** Additional data, like icdar2013, icdar2017, COCO-Text, ArT, was added to the model training of SAST. Download English public dataset in organized format used by PaddleOCR from [Baidu Drive](https://pan.baidu.com/s/12cPnZcVuV1zn5DOd4mqjVw) (download code: 2bpi). +**说明:** SAST模型训练额外加入了icdar2013、icdar2017、COCO-Text、ArT等公开数据集进行调优。PaddleOCR用到的经过整理格式的英文公开数据集下载:[百度云地址](https://pan.baidu.com/s/12cPnZcVuV1zn5DOd4mqjVw) (提取码: 2bpi) -For use of [LSVT](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_en/datasets_en.md#1-icdar2019-lsvt) street view dataset with a total of 3w training data,the related configuration and pre-trained models for text detection task are as follows: -|Model|Backbone|Configuration file|Pre-trained model| + +使用[LSVT](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/datasets.md#1icdar2019-lsvt)街景数据集共3w张数据,训练中文检测模型的相关配置和预训练文件如下: + +|模型|骨干网络|配置文件|预训练模型| |-|-|-|-| -|ultra-lightweight OCR model|MobileNetV3|det_mv3_db.yml|[Download link](https://paddleocr.bj.bcebos.com/ch_models/ch_det_mv3_db.tar)| -|General OCR model|ResNet50_vd|det_r50_vd_db.yml|[Download link](https://paddleocr.bj.bcebos.com/ch_models/ch_det_r50_vd_db.tar)| +|超轻量中文模型|MobileNetV3|det_mv3_db.yml|[下载链接](https://paddleocr.bj.bcebos.com/ch_models/ch_det_mv3_db.tar)| +|通用中文OCR模型|ResNet50_vd|det_r50_vd_db.yml|[下载链接](https://paddleocr.bj.bcebos.com/ch_models/ch_det_r50_vd_db.tar)| -* Note: For the training and evaluation of the above DB model, post-processing parameters box_thresh=0.6 and unclip_ratio=1.5 need to be set. If using different datasets and different models for training, these two parameters can be adjusted for better result. +* 注: 上述DB模型的训练和评估,需设置后处理参数box_thresh=0.6,unclip_ratio=1.5,使用不同数据集、不同模型训练,可调整这两个参数进行优化 -For the training guide and use of PaddleOCR text detection algorithms, please refer to the document [Text detection model training/evaluation/prediction](./doc/doc_en/detection_en.md) +PaddleOCR文本检测算法的训练和使用请参考文档教程中[模型训练/评估中的文本检测部分](./doc/doc_ch/detection.md)。 - -## Text Recognition Algorithm + +### 2.文本识别算法 -PaddleOCR open-source text recognition algorithms list: +PaddleOCR开源的文本识别算法列表: - [x] CRNN([paper](https://arxiv.org/abs/1507.05717)) - [x] Rosetta([paper](https://arxiv.org/abs/1910.05085)) - [x] STAR-Net([paper](http://www.bmva.org/bmvc/2016/papers/paper043/index.html)) - [x] RARE([paper](https://arxiv.org/abs/1603.03915v1)) -- [x] SRN([paper](https://arxiv.org/abs/2003.12294))(Baidu Self-Research) +- [x] SRN([paper](https://arxiv.org/abs/2003.12294))(百度自研) -Refer to [DTRB](https://arxiv.org/abs/1904.01906), the training and evaluation result of these above text recognition (using MJSynth and SynthText for training, evaluate on IIIT, SVT, IC03, IC13, IC15, SVTP, CUTE) is as follow: +参考[DTRB](https://arxiv.org/abs/1904.01906)文字识别训练和评估流程,使用MJSynth和SynthText两个文字识别数据集训练,在IIIT, SVT, IC03, IC13, IC15, SVTP, CUTE数据集上进行评估,算法效果如下: -|Model|Backbone|Avg Accuracy|Module combination|Download link| +|模型|骨干网络|Avg Accuracy|模型存储命名|下载链接| |-|-|-|-|-| -|Rosetta|Resnet34_vd|80.24%|rec_r34_vd_none_none_ctc|[Download link](https://paddleocr.bj.bcebos.com/rec_r34_vd_none_none_ctc.tar)| -|Rosetta|MobileNetV3|78.16%|rec_mv3_none_none_ctc|[Download link](https://paddleocr.bj.bcebos.com/rec_mv3_none_none_ctc.tar)| -|CRNN|Resnet34_vd|82.20%|rec_r34_vd_none_bilstm_ctc|[Download link](https://paddleocr.bj.bcebos.com/rec_r34_vd_none_bilstm_ctc.tar)| -|CRNN|MobileNetV3|79.37%|rec_mv3_none_bilstm_ctc|[Download link](https://paddleocr.bj.bcebos.com/rec_mv3_none_bilstm_ctc.tar)| -|STAR-Net|Resnet34_vd|83.93%|rec_r34_vd_tps_bilstm_ctc|[Download link](https://paddleocr.bj.bcebos.com/rec_r34_vd_tps_bilstm_ctc.tar)| -|STAR-Net|MobileNetV3|81.56%|rec_mv3_tps_bilstm_ctc|[Download link](https://paddleocr.bj.bcebos.com/rec_mv3_tps_bilstm_ctc.tar)| -|RARE|Resnet34_vd|84.90%|rec_r34_vd_tps_bilstm_attn|[Download link](https://paddleocr.bj.bcebos.com/rec_r34_vd_tps_bilstm_attn.tar)| -|RARE|MobileNetV3|83.32%|rec_mv3_tps_bilstm_attn|[Download link](https://paddleocr.bj.bcebos.com/rec_mv3_tps_bilstm_attn.tar)| -|SRN|Resnet50_vd_fpn|88.33%|rec_r50fpn_vd_none_srn|[Download link](https://paddleocr.bj.bcebos.com/SRN/rec_r50fpn_vd_none_srn.tar)| +|Rosetta|Resnet34_vd|80.24%|rec_r34_vd_none_none_ctc|[下载链接](https://paddleocr.bj.bcebos.com/rec_r34_vd_none_none_ctc.tar)| +|Rosetta|MobileNetV3|78.16%|rec_mv3_none_none_ctc|[下载链接](https://paddleocr.bj.bcebos.com/rec_mv3_none_none_ctc.tar)| +|CRNN|Resnet34_vd|82.20%|rec_r34_vd_none_bilstm_ctc|[下载链接](https://paddleocr.bj.bcebos.com/rec_r34_vd_none_bilstm_ctc.tar)| +|CRNN|MobileNetV3|79.37%|rec_mv3_none_bilstm_ctc|[下载链接](https://paddleocr.bj.bcebos.com/rec_mv3_none_bilstm_ctc.tar)| +|STAR-Net|Resnet34_vd|83.93%|rec_r34_vd_tps_bilstm_ctc|[下载链接](https://paddleocr.bj.bcebos.com/rec_r34_vd_tps_bilstm_ctc.tar)| +|STAR-Net|MobileNetV3|81.56%|rec_mv3_tps_bilstm_ctc|[下载链接](https://paddleocr.bj.bcebos.com/rec_mv3_tps_bilstm_ctc.tar)| +|RARE|Resnet34_vd|84.90%|rec_r34_vd_tps_bilstm_attn|[下载链接](https://paddleocr.bj.bcebos.com/rec_r34_vd_tps_bilstm_attn.tar)| +|RARE|MobileNetV3|83.32%|rec_mv3_tps_bilstm_attn|[下载链接](https://paddleocr.bj.bcebos.com/rec_mv3_tps_bilstm_attn.tar)| +|SRN|Resnet50_vd_fpn|88.33%|rec_r50fpn_vd_none_srn|[下载链接](https://paddleocr.bj.bcebos.com/SRN/rec_r50fpn_vd_none_srn.tar)| -**Note:** SRN model uses data expansion method to expand the two training sets mentioned above, and the expanded data can be downloaded from [Baidu Drive](https://pan.baidu.com/s/1-HSZ-ZVdqBF2HaBZ5pRAKA) (download code: y3ry). +**说明:** SRN模型使用了数据扰动方法对上述提到对两个训练集进行增广,增广后的数据可以在[百度网盘](https://pan.baidu.com/s/1-HSZ-ZVdqBF2HaBZ5pRAKA)上下载,提取码: y3ry。 +原始论文使用两阶段训练平均精度为89.74%,PaddleOCR中使用one-stage训练,平均精度为88.33%。两种预训练权重均在[下载链接](https://paddleocr.bj.bcebos.com/SRN/rec_r50fpn_vd_none_srn.tar)中。 -The average accuracy of the two-stage training in the original paper is 89.74%, and that of one stage training in paddleocr is 88.33%. Both pre-trained weights can be downloaded [here](https://paddleocr.bj.bcebos.com/SRN/rec_r50fpn_vd_none_srn.tar). +使用[LSVT](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/datasets.md#1icdar2019-lsvt)街景数据集根据真值将图crop出来30w数据,进行位置校准。此外基于LSVT语料生成500w合成数据训练中文模型,相关配置和预训练文件如下: -We use [LSVT](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_en/datasets_en.md#1-icdar2019-lsvt) dataset and cropout 30w training data from original photos by using position groundtruth and make some calibration needed. In addition, based on the LSVT corpus, 500w synthetic data is generated to train the model. The related configuration and pre-trained models are as follows: - -|Model|Backbone|Configuration file|Pre-trained model| +|模型|骨干网络|配置文件|预训练模型| |-|-|-|-| -|ultra-lightweight OCR model|MobileNetV3|rec_chinese_lite_train.yml|[Download link](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn.tar)|[inference model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_enhance_infer.tar) & [pre-trained model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_enhance.tar)| -|General OCR model|Resnet34_vd|rec_chinese_common_train.yml|[Download link](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn.tar)|[inference model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn_enhance_infer.tar) & [pre-trained model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn_enhance.tar)| +|超轻量中文模型|MobileNetV3|rec_chinese_lite_train.yml|[下载链接](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn.tar)| +|通用中文OCR模型|Resnet34_vd|rec_chinese_common_train.yml|[下载链接](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn.tar)| -Please refer to the document for training guide and use of PaddleOCR text recognition algorithms [Text recognition model training/evaluation/prediction](./doc/doc_en/recognition_en.md) +PaddleOCR文本识别算法的训练和使用请参考文档教程中[模型训练/评估中的文本识别部分](./doc/doc_ch/recognition.md)。 - -## END-TO-END OCR Algorithm -- [ ] [End2End-PSL](https://arxiv.org/abs/1909.07808)(Baidu Self-Research, coming soon) +## 效果展示 -## Visualization - - -### 1.Ultra-lightweight Chinese/English OCR Visualization [more](./doc/doc_en/visualization_en.md) + +### 1.超轻量级中文OCR效果展示 [more](./doc/doc_ch/visualization.md)
- -### 2. General Chinese/English OCR Visualization [more](./doc/doc_en/visualization_en.md) + +### 2.通用中文OCR效果展示 [more](./doc/doc_ch/visualization.md)
- -### 3.Chinese/English OCR Visualization (Space_support) [more](./doc/doc_en/visualization_en.md) + +### 3.支持空格的中文OCR效果展示 [more](./doc/doc_ch/visualization.md)
- - -## FAQ -1. Error when using attention-based recognition model: KeyError: 'predict' - - The inference of recognition model based on attention loss is still being debugged. For Chinese text recognition, it is recommended to choose the recognition model based on CTC loss first. In practice, it is also found that the recognition model based on attention loss is not as effective as the one based on CTC loss. - -2. About inference speed - - When there are a lot of texts in the picture, the prediction time will increase. You can use `--rec_batch_num` to set a smaller prediction batch size. The default value is 30, which can be changed to 10 or other values. - -3. Service deployment and mobile deployment - - It is expected that the service deployment based on Serving and the mobile deployment based on Paddle Lite will be released successively in mid-to-late June. Stay tuned for more updates. - -4. Release time of self-developed algorithm - - Baidu Self-developed algorithms such as SAST, SRN and end2end PSL will be released in June or July. Please be patient. - -[more](./doc/doc_en/FAQ_en.md) - - -## Community -Scan the QR code below with your wechat and completing the questionnaire, you can access to offical technical exchange group. + +## 欢迎加入PaddleOCR技术交流群 +请扫描下面二维码,完成问卷填写,获取加群二维码和OCR方向的炼丹秘籍
- -## License -This project is released under Apache 2.0 license + +## 许可证书 +本项目的发布受Apache 2.0 license许可认证。 - -## Contribution -We welcome all the contributions to PaddleOCR and appreciate for your feedback very much. + +## 贡献代码 +我们非常欢迎你为PaddleOCR贡献代码,也十分感谢你的反馈。 -- Many thanks to [Khanh Tran](https://github.com/xxxpsyduck) and [Karl Horky](https://github.com/karlhorky) for contributing and revising the English documentation. -- Many thanks to [zhangxin](https://github.com/ZhangXinNan) for contributing the new visualize function、add .gitgnore and discard set PYTHONPATH manually. -- Many thanks to [lyl120117](https://github.com/lyl120117) for contributing the code for printing the network structure. -- Thanks [xiangyubo](https://github.com/xiangyubo) for contributing the handwritten Chinese OCR datasets. -- Thanks [authorfu](https://github.com/authorfu) for contributing Android demo and [xiadeye](https://github.com/xiadeye) contributing iOS demo, respectively. -- Thanks [BeyondYourself](https://github.com/BeyondYourself) for contributing many great suggestions and simplifying part of the code style. -- Thanks [tangmq](https://gitee.com/tangmq) for contributing Dockerized deployment services to PaddleOCR and supporting the rapid release of callable Restful API services. +- 非常感谢 [Khanh Tran](https://github.com/xxxpsyduck) 和 [Karl Horky](https://github.com/karlhorky) 贡献修改英文文档 +- 非常感谢 [zhangxin](https://github.com/ZhangXinNan)([Blog](https://blog.csdn.net/sdlypyzq)) 贡献新的可视化方式、添加.gitgnore、处理手动设置PYTHONPATH环境变量的问题 +- 非常感谢 [lyl120117](https://github.com/lyl120117) 贡献打印网络结构的代码 +- 非常感谢 [xiangyubo](https://github.com/xiangyubo) 贡献手写中文OCR数据集 +- 非常感谢 [authorfu](https://github.com/authorfu) 贡献Android和[xiadeye](https://github.com/xiadeye) 贡献IOS的demo代码 +- 非常感谢 [BeyondYourself](https://github.com/BeyondYourself) 给PaddleOCR提了很多非常棒的建议,并简化了PaddleOCR的部分代码风格。 +- 非常感谢 [tangmq](https://gitee.com/tangmq) 给PaddleOCR增加Docker化部署服务,支持快速发布可调用的Restful API服务。 diff --git a/README_cn.md b/README_cn.md deleted file mode 100644 index 8bdcce62..00000000 --- a/README_cn.md +++ /dev/null @@ -1,228 +0,0 @@ -[English](README.md) | 简体中文 - -## 简介 -PaddleOCR旨在打造一套丰富、领先、且实用的OCR工具库,助力使用者训练出更好的模型,并应用落地。 - -**近期更新** -- 2020.8.24 支持通过whl包安装使用PaddleOCR,具体参考[Paddleocr Package使用说明](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/whl.md) -- 2020.8.21 更新8月18日B站直播课回放和PPT,课节2,易学易用的OCR工具大礼包,[获取地址](https://aistudio.baidu.com/aistudio/education/group/info/1519) -- 2020.8.16 开源文本检测算法[SAST](https://arxiv.org/abs/1908.05498)和文本识别算法[SRN](https://arxiv.org/abs/2003.12294) -- 2020.7.23 发布7月21日B站直播课回放和PPT,课节1,PaddleOCR开源大礼包全面解读,[获取地址](https://aistudio.baidu.com/aistudio/course/introduce/1519) -- 2020.7.15 添加基于EasyEdge和Paddle-Lite的移动端DEMO,支持iOS和Android系统 -- [more](./doc/doc_ch/update.md) - - -## 特性 -- 超轻量级中文OCR模型,总模型仅8.6M - - 单模型支持中英文数字组合识别、竖排文本识别、长文本识别 - - 检测模型DB(4.1M)+识别模型CRNN(4.5M) -- 实用通用中文OCR模型 -- 多种预测推理部署方案,包括服务部署和端侧部署 -- 多种文本检测训练算法,EAST、DB -- 多种文本识别训练算法,Rosetta、CRNN、STAR-Net、RARE -- 可运行于Linux、Windows、MacOS等多种系统 - -## 快速体验 - -
- -
- -上图是超轻量级中文OCR模型效果展示,更多效果图请见[效果展示页面](./doc/doc_ch/visualization.md)。 - -- 超轻量级中文OCR在线体验地址:https://www.paddlepaddle.org.cn/hub/scene/ocr -- 移动端DEMO体验(基于EasyEdge和Paddle-Lite, 支持iOS和Android系统):[安装包二维码获取地址](https://ai.baidu.com/easyedge/app/openSource?from=paddlelite) - - Android手机也可以扫描下面二维码安装体验。 - -
- -
- -- [**中文OCR模型快速使用**](./doc/doc_ch/quickstart.md) - - -## 中文OCR模型列表 - -|模型名称|模型简介|检测模型地址|识别模型地址|支持空格的识别模型地址| -|-|-|-|-|-| -|chinese_db_crnn_mobile|超轻量级中文OCR模型|[inference模型](https://paddleocr.bj.bcebos.com/ch_models/ch_det_mv3_db_infer.tar) / [预训练模型](https://paddleocr.bj.bcebos.com/ch_models/ch_det_mv3_db.tar)|[inference模型](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_infer.tar) / [预训练模型](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn.tar)|[inference模型](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_enhance_infer.tar) / [预训练模型](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_enhance.tar) -|chinese_db_crnn_server|通用中文OCR模型|[inference模型](https://paddleocr.bj.bcebos.com/ch_models/ch_det_r50_vd_db_infer.tar) / [预训练模型](https://paddleocr.bj.bcebos.com/ch_models/ch_det_r50_vd_db.tar)|[inference模型](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn_infer.tar) / [预训练模型](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn.tar)|[inference模型](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn_enhance_infer.tar) / [预训练模型](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn_enhance.tar) - -## 文档教程 -- [快速安装](./doc/doc_ch/installation.md) -- [中文OCR模型快速使用](./doc/doc_ch/quickstart.md) -- 算法介绍 - - [文本检测](#文本检测算法) - - [文本识别](#文本识别算法) - - [端到端OCR](#端到端OCR算法) -- 模型训练/评估 - - [文本检测](./doc/doc_ch/detection.md) - - [文本识别](./doc/doc_ch/recognition.md) - - [yml参数配置文件介绍](./doc/doc_ch/config.md) - - [中文OCR训练预测技巧](./doc/doc_ch/tricks.md) -- 预测部署 - - [基于Python预测引擎推理](./doc/doc_ch/inference.md) - - [基于C++预测引擎推理](./deploy/cpp_infer/readme.md) - - [服务化部署](./doc/doc_ch/serving.md) - - [端侧部署](./deploy/lite/readme.md) - - 模型量化压缩(coming soon) - - [Benchmark](./doc/doc_ch/benchmark.md) -- 数据集 - - [通用中英文OCR数据集](./doc/doc_ch/datasets.md) - - [手写中文OCR数据集](./doc/doc_ch/handwritten_datasets.md) - - [垂类多语言OCR数据集](./doc/doc_ch/vertical_and_multilingual_datasets.md) - - [常用数据标注工具](./doc/doc_ch/data_annotation.md) - - [常用数据合成工具](./doc/doc_ch/data_synthesis.md) -- [FAQ](#FAQ) -- 效果展示 - - [超轻量级中文OCR效果展示](#超轻量级中文OCR效果展示) - - [通用中文OCR效果展示](#通用中文OCR效果展示) - - [支持空格的中文OCR效果展示](#支持空格的中文OCR效果展示) -- [技术交流群](#欢迎加入PaddleOCR技术交流群) -- [参考文献](./doc/doc_ch/reference.md) -- [许可证书](#许可证书) -- [贡献代码](#贡献代码) - - -## 算法介绍 - -### 1.文本检测算法 - -PaddleOCR开源的文本检测算法列表: -- [x] EAST([paper](https://arxiv.org/abs/1704.03155)) -- [x] DB([paper](https://arxiv.org/abs/1911.08947)) -- [x] SAST([paper](https://arxiv.org/abs/1908.05498))(百度自研) - -在ICDAR2015文本检测公开数据集上,算法效果如下: - -|模型|骨干网络|precision|recall|Hmean|下载链接| -|-|-|-|-|-|-| -|EAST|ResNet50_vd|88.18%|85.51%|86.82%|[下载链接](https://paddleocr.bj.bcebos.com/det_r50_vd_east.tar)| -|EAST|MobileNetV3|81.67%|79.83%|80.74%|[下载链接](https://paddleocr.bj.bcebos.com/det_mv3_east.tar)| -|DB|ResNet50_vd|83.79%|80.65%|82.19%|[下载链接](https://paddleocr.bj.bcebos.com/det_r50_vd_db.tar)| -|DB|MobileNetV3|75.92%|73.18%|74.53%|[下载链接](https://paddleocr.bj.bcebos.com/det_mv3_db.tar)| -|SAST|ResNet50_vd|92.18%|82.96%|87.33%|[下载链接](https://paddleocr.bj.bcebos.com/SAST/sast_r50_vd_icdar2015.tar)| - -在Total-text文本检测公开数据集上,算法效果如下: - -|模型|骨干网络|precision|recall|Hmean|下载链接| -|-|-|-|-|-|-| -|SAST|ResNet50_vd|88.74%|79.80%|84.03%|[下载链接](https://paddleocr.bj.bcebos.com/SAST/sast_r50_vd_total_text.tar)| - -**说明:** SAST模型训练额外加入了icdar2013、icdar2017、COCO-Text、ArT等公开数据集进行调优。PaddleOCR用到的经过整理格式的英文公开数据集下载:[百度云地址](https://pan.baidu.com/s/12cPnZcVuV1zn5DOd4mqjVw) (提取码: 2bpi) - - -使用[LSVT](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/datasets.md#1icdar2019-lsvt)街景数据集共3w张数据,训练中文检测模型的相关配置和预训练文件如下: - -|模型|骨干网络|配置文件|预训练模型| -|-|-|-|-| -|超轻量中文模型|MobileNetV3|det_mv3_db.yml|[下载链接](https://paddleocr.bj.bcebos.com/ch_models/ch_det_mv3_db.tar)| -|通用中文OCR模型|ResNet50_vd|det_r50_vd_db.yml|[下载链接](https://paddleocr.bj.bcebos.com/ch_models/ch_det_r50_vd_db.tar)| - -* 注: 上述DB模型的训练和评估,需设置后处理参数box_thresh=0.6,unclip_ratio=1.5,使用不同数据集、不同模型训练,可调整这两个参数进行优化 - -PaddleOCR文本检测算法的训练和使用请参考文档教程中[模型训练/评估中的文本检测部分](./doc/doc_ch/detection.md)。 - - -### 2.文本识别算法 - -PaddleOCR开源的文本识别算法列表: -- [x] CRNN([paper](https://arxiv.org/abs/1507.05717)) -- [x] Rosetta([paper](https://arxiv.org/abs/1910.05085)) -- [x] STAR-Net([paper](http://www.bmva.org/bmvc/2016/papers/paper043/index.html)) -- [x] RARE([paper](https://arxiv.org/abs/1603.03915v1)) -- [x] SRN([paper](https://arxiv.org/abs/2003.12294))(百度自研) - -参考[DTRB](https://arxiv.org/abs/1904.01906)文字识别训练和评估流程,使用MJSynth和SynthText两个文字识别数据集训练,在IIIT, SVT, IC03, IC13, IC15, SVTP, CUTE数据集上进行评估,算法效果如下: - -|模型|骨干网络|Avg Accuracy|模型存储命名|下载链接| -|-|-|-|-|-| -|Rosetta|Resnet34_vd|80.24%|rec_r34_vd_none_none_ctc|[下载链接](https://paddleocr.bj.bcebos.com/rec_r34_vd_none_none_ctc.tar)| -|Rosetta|MobileNetV3|78.16%|rec_mv3_none_none_ctc|[下载链接](https://paddleocr.bj.bcebos.com/rec_mv3_none_none_ctc.tar)| -|CRNN|Resnet34_vd|82.20%|rec_r34_vd_none_bilstm_ctc|[下载链接](https://paddleocr.bj.bcebos.com/rec_r34_vd_none_bilstm_ctc.tar)| -|CRNN|MobileNetV3|79.37%|rec_mv3_none_bilstm_ctc|[下载链接](https://paddleocr.bj.bcebos.com/rec_mv3_none_bilstm_ctc.tar)| -|STAR-Net|Resnet34_vd|83.93%|rec_r34_vd_tps_bilstm_ctc|[下载链接](https://paddleocr.bj.bcebos.com/rec_r34_vd_tps_bilstm_ctc.tar)| -|STAR-Net|MobileNetV3|81.56%|rec_mv3_tps_bilstm_ctc|[下载链接](https://paddleocr.bj.bcebos.com/rec_mv3_tps_bilstm_ctc.tar)| -|RARE|Resnet34_vd|84.90%|rec_r34_vd_tps_bilstm_attn|[下载链接](https://paddleocr.bj.bcebos.com/rec_r34_vd_tps_bilstm_attn.tar)| -|RARE|MobileNetV3|83.32%|rec_mv3_tps_bilstm_attn|[下载链接](https://paddleocr.bj.bcebos.com/rec_mv3_tps_bilstm_attn.tar)| -|SRN|Resnet50_vd_fpn|88.33%|rec_r50fpn_vd_none_srn|[下载链接](https://paddleocr.bj.bcebos.com/SRN/rec_r50fpn_vd_none_srn.tar)| - -**说明:** SRN模型使用了数据扰动方法对上述提到对两个训练集进行增广,增广后的数据可以在[百度网盘](https://pan.baidu.com/s/1-HSZ-ZVdqBF2HaBZ5pRAKA)上下载,提取码: y3ry。 -原始论文使用两阶段训练平均精度为89.74%,PaddleOCR中使用one-stage训练,平均精度为88.33%。两种预训练权重均在[下载链接](https://paddleocr.bj.bcebos.com/SRN/rec_r50fpn_vd_none_srn.tar)中。 - -使用[LSVT](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/datasets.md#1icdar2019-lsvt)街景数据集根据真值将图crop出来30w数据,进行位置校准。此外基于LSVT语料生成500w合成数据训练中文模型,相关配置和预训练文件如下: - -|模型|骨干网络|配置文件|预训练模型| -|-|-|-|-| -|超轻量中文模型|MobileNetV3|rec_chinese_lite_train.yml|[下载链接](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn.tar)| -|通用中文OCR模型|Resnet34_vd|rec_chinese_common_train.yml|[下载链接](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn.tar)| - -PaddleOCR文本识别算法的训练和使用请参考文档教程中[模型训练/评估中的文本识别部分](./doc/doc_ch/recognition.md)。 - - -### 3.端到端OCR算法 -- [ ] [End2End-PSL](https://arxiv.org/abs/1909.07808)(百度自研, coming soon) - -## 效果展示 - - -### 1.超轻量级中文OCR效果展示 [more](./doc/doc_ch/visualization.md) - -
- -
- - -### 2.通用中文OCR效果展示 [more](./doc/doc_ch/visualization.md) - -
- -
- - -### 3.支持空格的中文OCR效果展示 [more](./doc/doc_ch/visualization.md) - -
- -
- - -## FAQ -1. **转换attention识别模型时报错:KeyError: 'predict'** -问题已解,请更新到最新代码。 - -2. **关于推理速度** -图片中的文字较多时,预测时间会增,可以使用--rec_batch_num设置更小预测batch num,默认值为30,可以改为10或其他数值。 - -3. **服务部署与移动端部署** -预计6月中下旬会先后发布基于Serving的服务部署方案和基于Paddle Lite的移动端部署方案,欢迎持续关注。 - -4. **自研算法发布时间** -自研算法SAST、SRN、End2End-PSL都将在7-8月陆续发布,敬请期待。 - -[more](./doc/doc_ch/FAQ.md) - - -## 欢迎加入PaddleOCR技术交流群 -请扫描下面二维码,完成问卷填写,获取加群二维码和OCR方向的炼丹秘籍 - -
- -
- - -## 许可证书 -本项目的发布受Apache 2.0 license许可认证。 - - -## 贡献代码 -我们非常欢迎你为PaddleOCR贡献代码,也十分感谢你的反馈。 - -- 非常感谢 [Khanh Tran](https://github.com/xxxpsyduck) 和 [Karl Horky](https://github.com/karlhorky) 贡献修改英文文档 -- 非常感谢 [zhangxin](https://github.com/ZhangXinNan)([Blog](https://blog.csdn.net/sdlypyzq)) 贡献新的可视化方式、添加.gitgnore、处理手动设置PYTHONPATH环境变量的问题 -- 非常感谢 [lyl120117](https://github.com/lyl120117) 贡献打印网络结构的代码 -- 非常感谢 [xiangyubo](https://github.com/xiangyubo) 贡献手写中文OCR数据集 -- 非常感谢 [authorfu](https://github.com/authorfu) 贡献Android和[xiadeye](https://github.com/xiadeye) 贡献IOS的demo代码 -- 非常感谢 [BeyondYourself](https://github.com/BeyondYourself) 给PaddleOCR提了很多非常棒的建议,并简化了PaddleOCR的部分代码风格。 -- 非常感谢 [tangmq](https://gitee.com/tangmq) 给PaddleOCR增加Docker化部署服务,支持快速发布可调用的Restful API服务。 diff --git a/README_en.md b/README_en.md new file mode 100644 index 00000000..37250da2 --- /dev/null +++ b/README_en.md @@ -0,0 +1,231 @@ +English | [简体中文](README.md) + +## Introduction +PaddleOCR aims to create rich, leading, and practical OCR tools that help users train better models and apply them into practice. + +**Recent updates** +- 2020.8.24 Support the use of PaddleOCR through whl package installation,pelease refer [PaddleOCR Package](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_en/whl_en.md) +- 2020.8.16, Release text detection algorithm [SAST](https://arxiv.org/abs/1908.05498) and text recognition algorithm [SRN](https://arxiv.org/abs/2003.12294) +- 2020.7.23, Release the playback and PPT of live class on BiliBili station, PaddleOCR Introduction, [address](https://aistudio.baidu.com/aistudio/course/introduce/1519) +- 2020.7.15, Add mobile App demo , support both iOS and Android ( based on easyedge and Paddle Lite) +- 2020.7.15, Improve the deployment ability, add the C + + inference , serving deployment. In addition, the benchmarks of the ultra-lightweight OCR model are provided. +- 2020.7.15, Add several related datasets, data annotation and synthesis tools. +- [more](./doc/doc_en/update_en.md) + +## Features +- Ultra-lightweight OCR model, total model size is only 8.6M + - Single model supports Chinese/English numbers combination recognition, vertical text recognition, long text recognition + - Detection model DB (4.1M) + recognition model CRNN (4.5M) +- Various text detection algorithms: EAST, DB +- Various text recognition algorithms: Rosetta, CRNN, STAR-Net, RARE +- Support Linux, Windows, macOS and other systems. + +## Visualization + +![](doc/imgs_results/11.jpg) + +![](doc/imgs_results/img_10.jpg) + +[More visualization](./doc/doc_en/visualization_en.md) + +You can also quickly experience the ultra-lightweight OCR : [Online Experience](https://www.paddlepaddle.org.cn/hub/scene/ocr) + +Mobile DEMO experience (based on EasyEdge and Paddle-Lite, supports iOS and Android systems): [Sign in to the website to obtain the QR code for installing the App](https://ai.baidu.com/easyedge/app/openSource?from=paddlelite) + + Also, you can scan the QR code below to install the App (**Android support only**) + +
+ +
+ +- [**OCR Quick Start**](./doc/doc_en/quickstart_en.md) + + + +### Supported Models: + +|Model Name|Description |Detection Model link|Recognition Model link| Support for space Recognition Model link| +|-|-|-|-|-| +|db_crnn_mobile|ultra-lightweight OCR model|[inference model](https://paddleocr.bj.bcebos.com/ch_models/ch_det_mv3_db_infer.tar) / [pre-trained model](https://paddleocr.bj.bcebos.com/ch_models/ch_det_mv3_db.tar)|[inference model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_infer.tar) / [pre-trained model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn.tar)|[inference model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_enhance_infer.tar) / [pre-train model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_enhance.tar) +|db_crnn_server|General OCR model|[inference model](https://paddleocr.bj.bcebos.com/ch_models/ch_det_r50_vd_db_infer.tar) / [pre-trained model](https://paddleocr.bj.bcebos.com/ch_models/ch_det_r50_vd_db.tar)|[inference model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn_infer.tar) / [pre-trained model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn.tar)|[inference model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn_enhance_infer.tar) / [pre-train model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn_enhance.tar) + + +## Tutorials +- [Installation](./doc/doc_en/installation_en.md) +- [Quick Start](./doc/doc_en/quickstart_en.md) +- Algorithm introduction + - [Text Detection Algorithm](#TEXTDETECTIONALGORITHM) + - [Text Recognition Algorithm](#TEXTRECOGNITIONALGORITHM) + - [END-TO-END OCR Algorithm](#ENDENDOCRALGORITHM) +- Model training/evaluation + - [Text Detection](./doc/doc_en/detection_en.md) + - [Text Recognition](./doc/doc_en/recognition_en.md) + - [Yml Configuration](./doc/doc_en/config_en.md) + - [Tricks](./doc/doc_en/tricks_en.md) +- Deployment + - [Python Inference](./doc/doc_en/inference_en.md) + - [C++ Inference](./deploy/cpp_infer/readme_en.md) + - [Serving](./doc/doc_en/serving_en.md) + - [Mobile](./deploy/lite/readme_en.md) + - Model Quantization and Compression (coming soon) + - [Benchmark](./doc/doc_en/benchmark_en.md) +- Datasets + - [General OCR Datasets(Chinese/English)](./doc/doc_en/datasets_en.md) + - [HandWritten_OCR_Datasets(Chinese)](./doc/doc_en/handwritten_datasets_en.md) + - [Various OCR Datasets(multilingual)](./doc/doc_en/vertical_and_multilingual_datasets_en.md) + - [Data Annotation Tools](./doc/doc_en/data_annotation_en.md) + - [Data Synthesis Tools](./doc/doc_en/data_synthesis_en.md) +- [FAQ](#FAQ) +- Visualization + - [Ultra-lightweight Chinese/English OCR Visualization](#UCOCRVIS) + - [General Chinese/English OCR Visualization](#GeOCRVIS) + - [Chinese/English OCR Visualization (Support Space Recognition )](#SpaceOCRVIS) +- [Community](#Community) +- [References](./doc/doc_en/reference_en.md) +- [License](#LICENSE) +- [Contribution](#CONTRIBUTION) + + +## Text Detection Algorithm + +PaddleOCR open source text detection algorithms list: +- [x] EAST([paper](https://arxiv.org/abs/1704.03155)) +- [x] DB([paper](https://arxiv.org/abs/1911.08947)) +- [x] SAST([paper](https://arxiv.org/abs/1908.05498))(Baidu Self-Research) + +On the ICDAR2015 dataset, the text detection result is as follows: + +|Model|Backbone|precision|recall|Hmean|Download link| +|-|-|-|-|-|-| +|EAST|ResNet50_vd|88.18%|85.51%|86.82%|[Download link](https://paddleocr.bj.bcebos.com/det_r50_vd_east.tar)| +|EAST|MobileNetV3|81.67%|79.83%|80.74%|[Download link](https://paddleocr.bj.bcebos.com/det_mv3_east.tar)| +|DB|ResNet50_vd|83.79%|80.65%|82.19%|[Download link](https://paddleocr.bj.bcebos.com/det_r50_vd_db.tar)| +|DB|MobileNetV3|75.92%|73.18%|74.53%|[Download link](https://paddleocr.bj.bcebos.com/det_mv3_db.tar)| +|SAST|ResNet50_vd|92.18%|82.96%|87.33%|[Download link](https://paddleocr.bj.bcebos.com/SAST/sast_r50_vd_icdar2015.tar)| + +On Total-Text dataset, the text detection result is as follows: + +|Model|Backbone|precision|recall|Hmean|Download link| +|-|-|-|-|-|-| +|SAST|ResNet50_vd|88.74%|79.80%|84.03%|[Download link](https://paddleocr.bj.bcebos.com/SAST/sast_r50_vd_total_text.tar)| + +**Note:** Additional data, like icdar2013, icdar2017, COCO-Text, ArT, was added to the model training of SAST. Download English public dataset in organized format used by PaddleOCR from [Baidu Drive](https://pan.baidu.com/s/12cPnZcVuV1zn5DOd4mqjVw) (download code: 2bpi). + +For use of [LSVT](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_en/datasets_en.md#1-icdar2019-lsvt) street view dataset with a total of 3w training data,the related configuration and pre-trained models for text detection task are as follows: +|Model|Backbone|Configuration file|Pre-trained model| +|-|-|-|-| +|ultra-lightweight OCR model|MobileNetV3|det_mv3_db.yml|[Download link](https://paddleocr.bj.bcebos.com/ch_models/ch_det_mv3_db.tar)| +|General OCR model|ResNet50_vd|det_r50_vd_db.yml|[Download link](https://paddleocr.bj.bcebos.com/ch_models/ch_det_r50_vd_db.tar)| + +* Note: For the training and evaluation of the above DB model, post-processing parameters box_thresh=0.6 and unclip_ratio=1.5 need to be set. If using different datasets and different models for training, these two parameters can be adjusted for better result. + +For the training guide and use of PaddleOCR text detection algorithms, please refer to the document [Text detection model training/evaluation/prediction](./doc/doc_en/detection_en.md) + + +## Text Recognition Algorithm + +PaddleOCR open-source text recognition algorithms list: +- [x] CRNN([paper](https://arxiv.org/abs/1507.05717)) +- [x] Rosetta([paper](https://arxiv.org/abs/1910.05085)) +- [x] STAR-Net([paper](http://www.bmva.org/bmvc/2016/papers/paper043/index.html)) +- [x] RARE([paper](https://arxiv.org/abs/1603.03915v1)) +- [x] SRN([paper](https://arxiv.org/abs/2003.12294))(Baidu Self-Research) + +Refer to [DTRB](https://arxiv.org/abs/1904.01906), the training and evaluation result of these above text recognition (using MJSynth and SynthText for training, evaluate on IIIT, SVT, IC03, IC13, IC15, SVTP, CUTE) is as follow: + +|Model|Backbone|Avg Accuracy|Module combination|Download link| +|-|-|-|-|-| +|Rosetta|Resnet34_vd|80.24%|rec_r34_vd_none_none_ctc|[Download link](https://paddleocr.bj.bcebos.com/rec_r34_vd_none_none_ctc.tar)| +|Rosetta|MobileNetV3|78.16%|rec_mv3_none_none_ctc|[Download link](https://paddleocr.bj.bcebos.com/rec_mv3_none_none_ctc.tar)| +|CRNN|Resnet34_vd|82.20%|rec_r34_vd_none_bilstm_ctc|[Download link](https://paddleocr.bj.bcebos.com/rec_r34_vd_none_bilstm_ctc.tar)| +|CRNN|MobileNetV3|79.37%|rec_mv3_none_bilstm_ctc|[Download link](https://paddleocr.bj.bcebos.com/rec_mv3_none_bilstm_ctc.tar)| +|STAR-Net|Resnet34_vd|83.93%|rec_r34_vd_tps_bilstm_ctc|[Download link](https://paddleocr.bj.bcebos.com/rec_r34_vd_tps_bilstm_ctc.tar)| +|STAR-Net|MobileNetV3|81.56%|rec_mv3_tps_bilstm_ctc|[Download link](https://paddleocr.bj.bcebos.com/rec_mv3_tps_bilstm_ctc.tar)| +|RARE|Resnet34_vd|84.90%|rec_r34_vd_tps_bilstm_attn|[Download link](https://paddleocr.bj.bcebos.com/rec_r34_vd_tps_bilstm_attn.tar)| +|RARE|MobileNetV3|83.32%|rec_mv3_tps_bilstm_attn|[Download link](https://paddleocr.bj.bcebos.com/rec_mv3_tps_bilstm_attn.tar)| +|SRN|Resnet50_vd_fpn|88.33%|rec_r50fpn_vd_none_srn|[Download link](https://paddleocr.bj.bcebos.com/SRN/rec_r50fpn_vd_none_srn.tar)| + +**Note:** SRN model uses data expansion method to expand the two training sets mentioned above, and the expanded data can be downloaded from [Baidu Drive](https://pan.baidu.com/s/1-HSZ-ZVdqBF2HaBZ5pRAKA) (download code: y3ry). + +The average accuracy of the two-stage training in the original paper is 89.74%, and that of one stage training in paddleocr is 88.33%. Both pre-trained weights can be downloaded [here](https://paddleocr.bj.bcebos.com/SRN/rec_r50fpn_vd_none_srn.tar). + +We use [LSVT](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_en/datasets_en.md#1-icdar2019-lsvt) dataset and cropout 30w training data from original photos by using position groundtruth and make some calibration needed. In addition, based on the LSVT corpus, 500w synthetic data is generated to train the model. The related configuration and pre-trained models are as follows: + +|Model|Backbone|Configuration file|Pre-trained model| +|-|-|-|-| +|ultra-lightweight OCR model|MobileNetV3|rec_chinese_lite_train.yml|[Download link](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn.tar)|[inference model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_enhance_infer.tar) & [pre-trained model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_mv3_crnn_enhance.tar)| +|General OCR model|Resnet34_vd|rec_chinese_common_train.yml|[Download link](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn.tar)|[inference model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn_enhance_infer.tar) & [pre-trained model](https://paddleocr.bj.bcebos.com/ch_models/ch_rec_r34_vd_crnn_enhance.tar)| + +Please refer to the document for training guide and use of PaddleOCR text recognition algorithms [Text recognition model training/evaluation/prediction](./doc/doc_en/recognition_en.md) + + +## END-TO-END OCR Algorithm +- [ ] [End2End-PSL](https://arxiv.org/abs/1909.07808)(Baidu Self-Research, coming soon) + +## Visualization + + +### 1.Ultra-lightweight Chinese/English OCR Visualization [more](./doc/doc_en/visualization_en.md) + +
+ +
+ + +### 2. General Chinese/English OCR Visualization [more](./doc/doc_en/visualization_en.md) + +
+ +
+ + +### 3.Chinese/English OCR Visualization (Space_support) [more](./doc/doc_en/visualization_en.md) + +
+ +
+ + + +## FAQ +1. Error when using attention-based recognition model: KeyError: 'predict' + + The inference of recognition model based on attention loss is still being debugged. For Chinese text recognition, it is recommended to choose the recognition model based on CTC loss first. In practice, it is also found that the recognition model based on attention loss is not as effective as the one based on CTC loss. + +2. About inference speed + + When there are a lot of texts in the picture, the prediction time will increase. You can use `--rec_batch_num` to set a smaller prediction batch size. The default value is 30, which can be changed to 10 or other values. + +3. Service deployment and mobile deployment + + It is expected that the service deployment based on Serving and the mobile deployment based on Paddle Lite will be released successively in mid-to-late June. Stay tuned for more updates. + +4. Release time of self-developed algorithm + + Baidu Self-developed algorithms such as SAST, SRN and end2end PSL will be released in June or July. Please be patient. + +[more](./doc/doc_en/FAQ_en.md) + + +## Community +Scan the QR code below with your wechat and completing the questionnaire, you can access to offical technical exchange group. + +
+ +
+ + +## License +This project is released under Apache 2.0 license + + +## Contribution +We welcome all the contributions to PaddleOCR and appreciate for your feedback very much. + +- Many thanks to [Khanh Tran](https://github.com/xxxpsyduck) and [Karl Horky](https://github.com/karlhorky) for contributing and revising the English documentation. +- Many thanks to [zhangxin](https://github.com/ZhangXinNan) for contributing the new visualize function、add .gitgnore and discard set PYTHONPATH manually. +- Many thanks to [lyl120117](https://github.com/lyl120117) for contributing the code for printing the network structure. +- Thanks [xiangyubo](https://github.com/xiangyubo) for contributing the handwritten Chinese OCR datasets. +- Thanks [authorfu](https://github.com/authorfu) for contributing Android demo and [xiadeye](https://github.com/xiadeye) contributing iOS demo, respectively. +- Thanks [BeyondYourself](https://github.com/BeyondYourself) for contributing many great suggestions and simplifying part of the code style. +- Thanks [tangmq](https://gitee.com/tangmq) for contributing Dockerized deployment services to PaddleOCR and supporting the rapid release of callable Restful API services. diff --git a/doc/doc_ch/FAQ.md b/doc/doc_ch/FAQ.md index 752a4adb..346d4c2b 100644 --- a/doc/doc_ch/FAQ.md +++ b/doc/doc_ch/FAQ.md @@ -1,25 +1,292 @@ -## FAQ +# FAQ -1. **预测报错:got an unexpected keyword argument 'gradient_clip'** -安装的paddle版本不对,目前本项目仅支持paddle1.7,近期会适配到1.8。 +## 写在前面 -2. **转换attention识别模型时报错:KeyError: 'predict'** -问题已解决,请更新到最新代码。 +- 我们收集整理了issues和用户群中的常见问题和解答,并且会不断更新,旨在为OCR的开发者提供一些参考,也希望帮助大家少走一些弯路。 -3. **关于推理速度** -图片中的文字较多时,预测时间会增,可以使用--rec_batch_num设置更小预测batch num,默认值为30,可以改为10或其他数值。 +- OCR领域大佬众多,本文档回答主要依赖有限的项目实践,难免挂一漏万,如有遗漏和不足,也**希望有识之士帮忙补充和修正**,万分感谢。 -4. **服务部署与移动端部署** -预计6月中下旬会先后发布基于Serving的服务部署方案和基于Paddle Lite的移动端部署方案,欢迎持续关注。 -5. **自研算法发布时间** -自研算法SAST、SRN、End2End-PSL都将在7-8月陆续发布,敬请期待。 +## PaddleOCR常见问题汇总(持续更新) -6. **如何在Windows或Mac系统上运行** -PaddleOCR已完成Windows和Mac系统适配,运行时注意两点:1、在[快速安装](./installation.md)时,如果不想安装docker,可跳过第一步,直接从第二步安装paddle开始。2、inference模型下载时,如果没有安装wget,可直接点击模型链接或将链接地址复制到浏览器进行下载,并解压放置到相应目录。 +* [【精选】OCR精选10个问题](#【精选】OCR精选10个问题) +* [【理论篇】OCR通用21个问题](#【理论篇】OCR通用问题) + * [基础知识3题](#基础知识) + * [数据集4题](#数据集) + * [模型训练调优6题](#模型训练调优) + * [预测部署8题](#预测部署) +* [【实战篇】PaddleOCR实战53个问题](#【实战篇】PaddleOCR实战问题) + * [使用咨询16题](#使用咨询) + * [数据集9题](#数据集) + * [模型训练调优13题](#模型训练调优) + * [预测部署15题](#[预测部署) -7. **超轻量模型和通用OCR模型的区别** -目前PaddleOCR开源了2个中文模型,分别是8.6M超轻量中文模型和通用中文OCR模型。两者对比信息如下: + + + +## 【精选】OCR精选10个问题 + +#### Q1.1.1:基于深度学习的文字检测方法有哪几种?各有什么优缺点? + +**A**:常用的基于深度学习的文字检测方法一般可以分为基于回归的、基于分割的两大类,当然还有一些将两者进行结合的方法。 +(1)基于回归的方法分为box回归和像素值回归。a. 采用box回归的方法主要有CTPN、Textbox系列和EAST,这类算法对规则形状文本检测效果较好,但无法准确检测不规则形状文本。 b. 像素值回归的方法主要有CRAFT和SA-Text,这类算法能够检测弯曲文本且对小文本效果优秀但是实时性能不够。 +(2)基于分割的算法,如PSENet,这类算法不受文本形状的限制,对各种形状的文本都能取得较好的效果,但是往往后处理比较复杂,导致耗时严重。目前也有一些算法专门针对这个问题进行改进,如DB,将二值化进行近似,使其可导,融入训练,从而获取更准确的边界,大大降低了后处理的耗时。 + +#### Q1.1.2:对于中文行文本识别,CTC和Attention哪种更优? + +**A**:(1)从效果上来看,通用OCR场景CTC的识别效果优于Attention,因为带识别的字典中的字符比较多,常用中文汉字三千字以上,如果训练样本不足的情况下,对于这些字符的序列关系挖掘比较困难。中文场景下Attention模型的优势无法体现。而且Attention适合短语句识别,对长句子识别比较差。 +(2)从训练和预测速度上,Attention的串行解码结构限制了预测速度,而CTC网络结构更高效,预测速度上更有优势。 + +#### Q1.1.3:弯曲形变的文字识别需要怎么处理?TPS应用场景是什么,是否好用? + +**A**:(1)在大多数情况下,如果遇到的场景弯曲形变不是太严重,检测4个顶点,然后直接通过仿射变换转正识别就足够了。 +(2)如果不能满足需求,可以尝试使用TPS(Thin Plate Spline),即薄板样条插值。TPS是一种插值算法,经常用于图像变形等,通过少量的控制点就可以驱动图像进行变化。一般用在有弯曲形变的文本识别中,当检测到不规则的/弯曲的(如,使用基于分割的方法检测算法)文本区域,往往先使用TPS算法对文本区域矫正成矩形再进行识别,如,STAR-Net、RARE等识别算法中引入了TPS模块。 +**Warning**:TPS看起来美好,在实际应用时经常发现并不够鲁棒,并且会增加耗时,需要谨慎使用。 + +#### Q1.1.4:简单的对于精度要求不高的OCR任务,数据集需要准备多少张呢? + +**A**:(1)训练数据的数量和需要解决问题的复杂度有关系。难度越大,精度要求越高,则数据集需求越大,而且一般情况实际中的训练数据越多效果越好。 +(2)对于精度要求不高的场景,检测任务和识别任务需要的数据量是不一样的。对于检测任务,500张图像可以保证基本的检测效果。对于识别任务,需要保证识别字典中每个字符出现在不同场景的行文本图像数目需要大于200张(举例,如果有字典中有5个字,每个字都需要出现在200张图片以上,那么最少要求的图像数量应该在200-1000张之间),这样可以保证基本的识别效果。 + +#### Q1.1.5:背景干扰的文字(如印章盖到落款上,需要识别落款或者印章中的文字),如何识别? + +**A**:(1)在人眼确认可识别的条件下,对于背景有干扰的文字,首先要保证检测框足够准确,如果检测框不准确,需要考虑是否可以通过过滤颜色等方式对图像预处理并且增加更多相关的训练数据;在识别的部分,注意在训练数据中加入背景干扰类的扩增图像。 +(2)如果MobileNet模型不能满足需求,可以尝试ResNet系列大模型来获得更好的效果 +。 + +#### Q1.1.6:OCR领域常用的评估指标是什么? + +**A**:对于两阶段的可以分开来看,分别是检测和识别阶段 + +(1)检测阶段:先按照检测框和标注框的IOU评估,IOU大于某个阈值判断为检测准确。这里检测框和标注框不同于一般的通用目标检测框,是采用多边形进行表示。 + +检测准确率det_precision:正确的检测框个数在全部检测框的占比,主要是判断检测指标. + +检测召回率det_recall:正确的检测框个数在全部标注框的占比,主要是判断漏检的指标。 + +检测 F1-Score: +$$ F1\_Score= \frac{2 \times det\_precision \times det\_recall}{det\_precision+det\_recall}$$ + +(2)识别阶段: +字符识别准确率rec_precision,即正确识别的文本行占标注的文本行数量的比例,只有整行文本识别对才算正确识别。 + +(3)端到端统计: +端对端准确率e2e_precision:准确检测并正确识别文本行在全部标注文本行的占比; +端到端召回率e2e_recall:准确检测并正确识别文本行在 检测到的文本行数量 的占比;准确检测的标准是检测框与标注框的IOU大于某个阈值,正确识别的的检测框中的文本与标注的文本相同。 + + +端到端 F1-Score: +$$ F1\_Score= \frac{2 \times e2e\_precision \times e2e\_recall}{e2e\_precision+e2e\_recall}$$ + +#### Q1.1.7:单张图上多语种并存识别(如单张图印刷体和手写文字并存),应该如何处理? + +**A**:单张图像中存在多种类型文本的情况很常见,典型的以学生的试卷为代表,一张图像同时存在手写体和印刷体两种文本,这类情况下,可以尝试”1个检测模型+1个N分类模型+N个识别模型”的解决方案。 +其中不同类型文本共用同一个检测模型,N分类模型指额外训练一个分类器,将检测到的文本进行分类,如手写+印刷的情况就是二分类,N种语言就是N分类,在识别的部分,针对每个类型的文本单独训练一个识别模型,如手写+印刷的场景,就需要训练一个手写体识别模型,一个印刷体识别模型,如果一个文本框的分类结果是手写体,那么就传给手写体识别模型进行识别,其他情况同理。 + +#### Q1.1.8:请问PaddleOCR项目中的中文超轻量和通用模型用了哪些数据集?训练多少样本,gpu什么配置,跑了多少个epoch,大概跑了多久? + +**A**: +(1)检测的话,LSVT街景数据集共3W张图像,超轻量模型,150epoch左右,2卡V100 跑了不到2天;通用模型:2卡V100 150epoch 不到4天。 +(2) +识别的话,520W左右的数据集(真实数据26W+合成数据500W)训练,超轻量模型:4卡V100,总共训练了5天左右。通用模型:4卡V100,共训练6天。 + +超轻量模型训练分为2个阶段: +<1>全量数据训练50epoch,耗时3天 +<2>合成数据+真实数据按照1:1数据采样,进行finetune训练200epoch,耗时2天 + +通用模型训练: +真实数据+合成数据,动态采样(1:1)训练,200epoch,耗时 6天左右。 + + +#### Q1.1.9:PaddleOCR模型推理方式有几种?各自的优缺点是什么 + +**A**:目前推理方式支持基于训练引擎推理和基于预测引擎推理。 +(1)基于训练引擎推理不需要转换模型,但是需要先组网再load参数,语言只支持python,不适合系统集成。 +(2)基于预测引擎的推理需要先转换模型为inference格式,然后可以进行不需要组网的推理,语言支持c++和python,适合系统集成。 + +#### Q1.1.10:PaddleOCR中,对于模型预测加速,CPU加速的途径有哪些?基于TenorRT加速GPU对输入有什么要求? + +**A**:(1)CPU可以使用mkldnn进行加速;对于python inference的话,可以把enable_mkldnn改为true,[参考代码](https://github.com/PaddlePaddle/PaddleOCR/blob/549108fe0aa0d87c0a3b2d471f1c653e89daab80/tools/infer/utility.py#L73),对于cpp inference的话,在配置文件里面配置use_mkldnn 1即可,[参考代码](https://github.com/PaddlePaddle/PaddleOCR/blob/549108fe0aa0d87c0a3b2d471f1c653e89daab80/deploy/cpp_infer/tools/config.txt#L6) +(2)GPU需要注意变长输入问题等,TRT6 之后才支持变长输入 + + +## 【理论篇】OCR通用问题 +### 基础知识 + +#### Q2.1.1:CRNN能否识别两行的文字?还是说必须一行? + +**A**:CRNN是一种基于1D-CTC的算法,其原理决定无法识别2行或多行的文字,只能单行识别。 + +#### Q2.1.2:怎么判断行文本图像是否是颠倒的? + +**A**:有两种方案:(1)原始图像和颠倒图像都进行识别预测,取得分较高的为识别结果。 +(2)训练一个正常图像和颠倒图像的方向分类器进行判断。 + +#### Q2.1.3:目前OCR普遍是二阶段,端到端的方案在业界落地情况如何? + +**A**:端到端在文字分布密集的业务场景,效率会比较有保证,精度的话看自己业务数据积累情况,如果行级别的识别数据积累比较多的话two-stage会比较好。百度的落地场景,比如工业仪表识别、车牌识别都用到端到端解决方案。 + + +### 数据集 + +#### Q2.2.1:支持空格的模型,标注数据的时候是不是要标注空格?中间几个空格都要标注出来么? + +**A**:如果需要检测和识别模型,就需要在标注的时候把空格标注出来,而且在字典中增加空格对应的字符。标注过程中,如果中间几个空格标注一个就行。 + +#### Q2.2.2:如果考虑支持竖排文字识别,相关的数据集如何合成? + +**A**:竖排文字与横排文字合成方式相同,只是选择了垂直字体。合成工具推荐:[text_renderer](https://github.com/Sanster/text_renderer) + +#### Q2.2.3:训练文字识别模型,真实数据有30w,合成数据有500w,需要做样本均衡吗? + +**A**:需要,一般需要保证一个batch中真实数据样本和合成数据样本的比例是1:1~1:3左右效果比较理想。如果合成数据过大,会过拟合到合成数据,预测效果往往不佳。还有一种**启发性**的尝试是可以先用大量合成数据训练一个base模型,然后再用真实数据微调,在一些简单场景效果也是会有提升的。 + +#### Q2.2.4:请问一下,竖排文字识别时候,字的特征已经变了,这种情况在数据集和字典标注是新增一个类别还是多个角度的字共享一个类别? + +**A**:可以根据实际场景做不同的尝试,共享一个类别是可以收敛,效果也还不错。但是如果分开训练,同类样本之间一致性更好,更容易收敛,识别效果会更优。 + +### 训练训练调优 + +#### Q2.3.1:如何更换文本检测/识别的backbone? +**A**:无论是文字检测,还是文字识别,骨干网络的选择是预测效果和预测效率的权衡。一般,选择更大规模的骨干网络,例如ResNet101_vd,则检测或识别更准确,但预测耗时相应也会增加。而选择更小规模的骨干网络,例如MobileNetV3_small_x0_35,则预测更快,但检测或识别的准确率会大打折扣。幸运的是不同骨干网络的检测或识别效果与在ImageNet数据集图像1000分类任务效果正相关。[**飞桨图像分类套件PaddleClas**](https://github.com/PaddlePaddle/PaddleClas)汇总了ResNet_vd、Res2Net、HRNet、MobileNetV3、GhostNet等23种系列的分类网络结构,在上述图像分类任务的top1识别准确率,GPU(V100和T4)和CPU(骁龙855)的预测耗时以及相应的[**117个预训练模型下载地址**](https://paddleclas.readthedocs.io/zh_CN/latest/models/models_intro.html)。 + (1)文字检测骨干网络的替换,主要是确定类似与ResNet的4个stages,以方便集成后续的类似FPN的检测头。此外,对于文字检测问题,使用ImageNet训练的分类预训练模型,可以加速收敛和效果提升。 + (2)文字识别的骨干网络的替换,需要注意网络宽高stride的下降位置。由于文本识别一般宽高比例很大,因此高度下降频率少一些,宽度下降频率多一些。可以参考PaddleOCR中[MobileNetV3骨干网络](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/ppocr/modeling/backbones/rec_mobilenet_v3.py)的改动。 + +#### Q2.3.2:文本识别训练不加LSTM是否可以收敛? + +**A**:理论上是可以收敛的,加上LSTM模块主要是为了挖掘文字之间的序列关系,提升识别效果。对于有明显上下文语义的场景效果会比较明显。 + +#### Q2.3.3:文本识别中LSTM和GRU如何选择? + +**A**:从项目实践经验来看,序列模块采用LSTM的识别效果优于GRU,但是LSTM的计算量比GRU大一些,可以根据自己实际情况选择。 + +#### Q2.3.4:对于CRNN模型,backbone采用DenseNet和ResNet_vd,哪种网络结构更好? + +**A**:Backbone的识别效果在CRNN模型上的效果,与Imagenet 1000 图像分类任务上识别效果和效率一致。在图像分类任务上ResnNet_vd(79%+)的识别精度明显优于DenseNet(77%+),此外对于GPU,Nvidia针对ResNet系列模型做了优化,预测效率更高,所以相对而言,resnet_vd是较好选择。如果是移动端,可以优先考虑MobileNetV3系列。 + +#### Q2.3.5:训练识别时,如何选择合适的网络输入shape? + +**A**:一般高度采用32,最长宽度的选择,有两种方法: +(1)统计训练样本图像的宽高比分布。最大宽高比的选取考虑满足80%的训练样本。 +(2)统计训练样本文字数目。最长字符数目的选取考虑满足80%的训练样本。然后中文字符长宽比近似认为是1,英文认为3:1,预估一个最长宽度。 + +#### Q2.3.6:如何识别文字比较长的文本? + +**A**:在中文识别模型训练时,并不是采用直接将训练样本缩放到[3,32,320]进行训练,而是先等比例缩放图像,保证图像高度为32,宽度不足320的部分补0,宽高比大于10的样本直接丢弃。预测时,如果是单张图像预测,则按上述操作直接对图像缩放,不做宽度320的限制。如果是多张图预测,则采用batch方式预测,每个batch的宽度动态变换,采用这个batch中最长宽度。 + +### 预测部署 + +#### Q2.4.1:请问对于图片中的密集文字,有什么好的处理办法吗? + +**A**:可以先试用预训练模型测试一下,例如DB+CRNN,判断下密集文字图片中是检测还是识别的问题,然后针对性的改善。还有一种是如果图象中密集文字较小,可以尝试增大图像分辨率,对图像进行一定范围内的拉伸,将文字稀疏化,提高识别效果。 + +#### Q2.4.2:对于一些在识别时稍微模糊的文本,有没有一些图像增强的方式? + +**A**:在人类肉眼可以识别的前提下,可以考虑图像处理中的均值滤波、中值滤波或者高斯滤波等模糊算子尝试。也可以尝试从数据扩增扰动来强化模型鲁棒性,另外新的思路有对抗性训练和超分SR思路,可以尝试借鉴。但目前业界尚无普遍认可的最优方案,建议优先在数据采集阶段增加一些限制提升图片质量。 + +#### Q2.4.3:对于特定文字检测,例如身份证只检测姓名,检测指定区域文字更好,还是检测全部区域再筛选更好? + +**A**:两个角度来说明一般检测全部区域再筛选更好。 +(1)由于特定文字和非特定文字之间的视觉特征并没有很强的区分行,只检测指定区域,容易造成特定文字漏检。 +(2)产品的需求可能是变化的,不排除后续对于模型需求变化的可能性(比如又需要增加一个字段),相比于训练模型,后处理的逻辑会更容易调整。 + +#### Q2.4.4:对于小白如何快速入门中文OCR项目实践? + +**A**:建议可以先了解OCR方向的基础知识,大概了解基础的检测和识别模型算法。然后在Github上可以查看OCR方向相关的repo。目前来看,从内容的完备性来看,PaddleOCR的中英文双语教程文档是有明显优势的,在数据集、模型训练、预测部署文档详实,可以快速入手。而且还有微信用户群答疑,非常适合学习实践。项目地址:[PaddleOCR](https://github.com/PaddlePaddle/PaddleOCR) + +#### Q2.4.5:如何识别带空格的英文行文本图像? + +**A**:空格识别可以考虑以下两种方案: +(1)优化文本检测算法。检测结果在空格处将文本断开。这种方案在检测数据标注时,需要将含有空格的文本行分成好多段。 +(2)优化文本识别算法。在识别字典里面引入空格字符,然后在识别的训练数据中,如果用空行,进行标注。此外,合成数据时,通过拼接训练数据,生成含有空格的文本。 + +#### Q2.4.6:中英文一起识别时也可以加空格字符来训练吗 + +**A**:中文识别可以加空格当做分隔符训练,具体的效果如何没法给出直接评判,根据实际业务数据训练来判断。 + +#### Q2.4.7:低像素文字或者字号比较小的文字有什么超分辨率方法吗 + +**A**:超分辨率方法分为传统方法和基于深度学习的方法。基于深度学习的方法中,比较经典的有SRCNN,另外CVPR2020也有一篇超分辨率的工作可以参考:Unpaired Image Super-Resolution using Pseudo-Supervision,但是没有充分的实践验证过,需要看实际场景下的效果。 + +#### Q2.4.8:表格识别有什么好的模型 或者论文推荐么 + +**A**:表格目前学术界比较成熟的解决方案不多 ,可以尝试下分割的论文方案。 + + + +## 【实战篇】PaddleOCR实战问题 + +### 使用咨询 + +#### Q3.1.1:OSError: [WinError 126] 找不到指定的模块。mac pro python 3.4 shapely import 问题 + +**A**:这个问题是因为shapely库安装有误,可以参考 [#212](https://github.com/PaddlePaddle/PaddleOCR/issues/212) 这个issue重新安装一下 + +#### Q3.1.2:安装了paddle-gpu,运行时提示没有安装gpu版本的paddle,可能是什么原因? + +**A**:用户同时安装了paddle cpu和gpu版本,都删掉之后,重新安装gpu版本的padle就好了 + +#### Q3.1.3:试用报错:Cannot load cudnn shared library,是什么原因呢? + +**A**:需要把cudnn lib添加到LD_LIBRARY_PATH中去。 + +#### Q3.1.4:PaddlePaddle怎么指定GPU运行 os.environ["CUDA_VISIBLE_DEVICES"]这种不生效 + +**A**:通过设置 export CUDA_VISIBLE_DEVICES='0'环境变量 + +#### Q3.1.5:windows下训练没有问题,aistudio中提示数据路径有问题 + +**A**:需要把`\`改为`/`(windows和linux的文件夹分隔符不一样,windows下的是`\`,linux下是`/`) + +#### Q3.1.6:gpu版的paddle虽然能在cpu上运行,但是必须要有gpu设备 + +**A**:export CUDA_VISIBLE_DEVICES='',CPU是可以正常跑的 + +#### Q3.1.7:预测报错ImportError: dlopen: cannot load any more object with static TLS + +**A**:glibc的版本问题,运行需要glibc的版本号大于2.23。 + +#### Q3.1.8:提供的inference model和预训练模型的区别 + +**A**:inference model为固化模型,文件中包含网络结构和网络参数,多用于预测部署。预训练模型是训练过程中保存好的模型,多用于fine-tune训练或者断点训练。 + +#### Q3.1.9:模型的解码部分有后处理? + +**A**:有的检测的后处理在ppocr/postprocess路径下,识别的后处理均在ppocr/utils/character.py文件内 + +#### Q3.1.10:PaddleOCR中文模型是否支持数字识别? + +**A**:支持的,可以看下ppocr/utils/ppocr_keys_v1.txt 这个文件,是支持的识别字符列表,其中包含了数字识别。 + +#### Q3.1.11:PaddleOCR如何做到横排和竖排同时支持的? + +**A**:合成了一批竖排文字,逆时针旋转90度后加入训练集与横排一起训练。预测时根据图片长款比判断是否为竖排,若为竖排则将crop出的文本逆时针旋转90度后送入识别网络。 + +#### Q3.1.12:如何获取检测文本框的坐标? + +**A**:文本检测的结果有box和文本信息, 具体 [参考代码](https://github.com/PaddlePaddle/PaddleOCR/blob/9d33e36df550762b204d5fbfd7977a25e31b2c44/tools/infer/predict_system.py#L13) + +#### Q3.1.13:识别模型框出来的位置太紧凑,会丢失边缘的文字信息,导致识别错误 + +**A**: 可以在命令中加入 --det_db_unclip_ratio ,参数[定义位置](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/tools/infer/utility.py#L49),这个参数是检测后处理时控制文本框大小的,默认2.0,可以尝试改成2.5或者更大 +,反之,如果觉得文本框不够紧凑,也可以把该参数调小。 + +#### Q3.1.14:英文手写体识别有计划提供的预训练模型吗? + +**A**:近期也在开展需求调研,如果企业用户需求较多,我们会考虑增加相应的研发投入,后续提供对应的预训练模型,如果有需求欢迎通过issue或者加入微信群联系我们。 + +#### Q3.1.17:超轻量模型和通用OCR模型的区别? + + +**A**:理论上只要有相应的数据集,都是可以的。当然手写识别毕竟和印刷体有区别,对应训练调优策略可能需要适配性优化。 + + +#### Q3.1.16:PaddleOCR的算法可以用于手写文字检测识别吗?后续有计划推出手写预训练模型么? + +PaddleOCR已完成Windows和Mac系统适配,并且python预测支持使用pip包安装。运行时注意两点:1、在[快速安装](./installation.md)时,如果不想安装docker,可跳过第一步,直接从第二步安装paddle开始。2、inference模型下载时,如果没有安装wget,可直接点击模型链接或将链接地址复制到浏览器进行下载,并解压放置到相应目录。 + +#### Q3.1.15:PaddleOCR是否支持在Windows或Mac系统上运行? +**A**:目前PaddleOCR开源了2个中文模型,分别是8.6M超轻量中文模型和通用中文OCR模型。两者对比信息如下: - 相同点:两者使用相同的**算法**和**训练数据**; - 不同点:不同之处在于**骨干网络**和**通道参数**,超轻量模型使用MobileNetV3作为骨干网络,通用模型使用Resnet50_vd作为检测模型backbone,Resnet34_vd作为识别模型backbone,具体参数差异可对比两种模型训练的配置文件. @@ -28,26 +295,186 @@ PaddleOCR已完成Windows和Mac系统适配,运行时注意两点:1、在[ |8.6M超轻量中文OCR模型|MobileNetV3+MobileNetV3|det_mv3_db.yml|rec_chinese_lite_train.yml| |通用中文OCR模型|Resnet50_vd+Resnet34_vd|det_r50_vd_db.yml|rec_chinese_common_train.yml| -8. **是否有计划开源仅识别数字或仅识别英文+数字的模型** -暂不计划开源仅数字、仅数字+英文、或其他小垂类专用模型。PaddleOCR开源了多种检测、识别算法供用户自定义训练,两种中文模型也是基于开源的算法库训练产出,有小垂类需求的小伙伴,可以按照教程准备好数据,选择合适的配置文件,自行训练,相信能有不错的效果。训练有任何问题欢迎提issue或在交流群提问,我们会及时解答。 +#### Q3.1.18:是否有计划开源仅识别数字或仅识别英文+数字的模型 -9. **开源模型使用的训练数据是什么,能否开源** -目前开源的模型,数据集和量级如下: +**A**:目前主要是开源通用类OCR模型,暂不计划开源小垂类专用模型。PaddleOCR开源了多种检测、识别算法供用户自定义训练,两种中文模型也是基于开源的算法库训练产出,有小垂类需求的小伙伴,可以按照教程准备好数据,选择合适的配置文件,自行训练,相信能有不错的效果。训练有任何问题欢迎提issue或在交流群提问,我们会及时解答。 + + + +### 数据集 + +#### Q3.2.1:如何制作PaddleOCR支持的数据格式 + +**A**:可以参考检测与识别训练文档,里面有数据格式详细介绍。[检测文档](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/detection.md),[识别文档](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/recognition.md) + +#### Q3.2.2:请问一下,如果想用预训练模型,但是我的数据里面又出现了预训练模型字符集中没有的字符,新的字符是在字符集前面添加还是在后面添加? + +**A**:在后面添加,修改dict之后,就改变了模型最后一层fc的结构,之前训练到的参数没有用到,相当于从头训练,因此acc是0。 + +#### Q3.2.3:如何调试数据读取程序? + +**A**:tools/train.py中有一个test_reader()函数用于调试数据读取。 + +#### Q3.2.4:开源模型使用的训练数据是什么,能否开源? + +**A**:目前开源的模型,数据集和量级如下: - 检测: 英文数据集,ICDAR2015 中文数据集,LSVT街景数据集训练数据3w张图片 - 识别: 英文数据集,MJSynth和SynthText合成数据,数据量上千万。 中文数据集,LSVT街景数据集根据真值将图crop出来,并进行位置校准,总共30w张图像。此外基于LSVT的语料,合成数据500w。 - 其中,公开数据集都是开源的,用户可自行搜索下载,也可参考[中文数据集](./datasets.md),合成数据暂不开源,用户可使用开源合成工具自行合成,可参考的合成工具包括[text_renderer](https://github.com/Sanster/text_renderer)、[SynthText](https://github.com/ankush-me/SynthText)、[TextRecognitionDataGenerator](https://github.com/Belval/TextRecognitionDataGenerator)等。 -10. **使用带TPS的识别模型预测报错** -报错信息:Input(X) dims[3] and Input(Grid) dims[2] should be equal, but received X dimension[3](320) != Grid dimension[2](100) -原因:TPS模块暂时无法支持变长的输入,请设置 --rec_image_shape='3,32,100' --rec_char_type='en' 固定输入shape +#### Q3.2.5:请问中文字符集多大呢?支持生僻字识别吗? -11. **自定义字典训练的模型,识别结果出现字典里没出现的字** -预测时没有设置采用的自定义字典路径。设置方法是在预测时,通过增加输入参数rec_char_dict_path来设置。 +**A**:中文字符集是6623, 支持生僻字识别。训练样本中有部分生僻字,但样本不多,如果有特殊需求建议使用自己的数据集做fine-tune。 -12. **cpp infer与python inference的结果不一致,相差较大** -导出的inference model版本与预测库版本需要保持一致,比如在Windows下,Paddle官网提供的预测库版本是1.8,而PaddleOCR提供的inference model 版本是1.7,因此最终预测结果会有差别。可以在Paddle1.8环境下导出模型,再基于该模型进行预测。 +#### Q3.2.6:中文文本检测、文本识别构建训练集的话,大概需要多少数据量 + +**A**:检测需要的数据相对较少,在PaddleOCR模型的基础上进行Fine-tune,一般需要500张可达到不错的效果。 +识别分英文和中文,一般英文场景需要几十万数据可达到不错的效果,中文则需要几百万甚至更多。 + +#### Q3.2.7:中文识别模型如何选择? + +**A**:中文模型共有2大类:通用模型和超轻量模型。他们各自的优势如下: +超轻量模型具有更小的模型大小,更快的预测速度。适合用于端侧使用。 +通用模型具有更高的模型精度,适合对模型大小不敏感的场景。 +此外基于以上模型,PaddleOCR还提供了支持空格识别的模型,主要针对中文场景中的英文句子。 +您可以根据实际使用需求进行选择。 + +#### Q3.2.8:图像旋转90° 文本检测可以正常检测到具体文本位置,但是识别准确度大幅降低,是否会考虑增加相应的旋转预处理? + +**A**:目前模型只支持两种方向的文字:水平和垂直。 为了降低模型大小,加快模型预测速度,PaddleOCR暂时没有加入图片的方向判断。建议用户在识别前自行转正,后期也会考虑添加选择角度判断。 + +#### Q3.2.9:同一张图通用检测出21个条目,轻量级检测出26个 ,难道不是轻量级的好吗? + +**A**:可以主要参考可视化效果,通用模型更倾向于检测一整行文字,轻量级可能会有一行文字被分成两段检测的情况,不是数量越多,效果就越好。 + +### 模型训练 +调优 + +#### Q3.3.1:文本长度超过25,应该怎么处理? + +**A**:默认训练时的文本可识别的最大长度为25,超过25的文本会被忽略不参与训练。如果您训练样本中的长文本较多,可以修改配置文件中的 max\_text\_length 字段,设置为更大的最长文本长度,具体位置在[这里](https://github.com/PaddlePaddle/PaddleOCR/blob/fb9e47b262529386983edc21b33abfa16bbf06ac/configs/rec/rec_chinese_lite_train.yml#L13)。 + +#### Q3.3.2:配置文件里面检测的阈值设置么? + +**A**:有的,检测相关的参数主要有以下几个: +``max_side_len:预测时图像resize的长边尺寸 +thresh: 用于二值化输出图的阈值 +box_thresh:用于过滤文本框的阈值,低于此阈值的文本框不要 +unclip_ratio: 文本框扩张的系数,关系到文本框的大小`` + +这些参数的默认值见[代码](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/tools/infer/utility.py#L40),可以通过从命令行传递参数进行修改。 + +#### Q3.3.3:我想请教一下,你们在训练识别时候,lsvt里的非矩形框文字,你们是怎么做处理的呢。忽略掉还是去最小旋转框? + +**A**:现在是忽略处理的 + +#### Q3.3.4:训练过程中,如何恰当的停止训练(直接kill,经常还有显存占用的问题) + +**A**:可以通过下面的脚本终止所有包含train.py字段的进程,ps -axu | grep train.py | awk '{print $2}' | xargs kill -9 + +#### Q3.3.5:读数据进程数设置4~8时训练一会进程接连defunct后gpu利用率一直为0卡死 + +**A**:修改多进程的队列数后解决, 将[代码段]( https://github.com/PaddlePaddle/PaddleOCR/blob/549108fe0aa0d87c0a3b2d471f1c653e89daab80/ppocr/data/reader_main.py#L75 ) 修改为: + +``` +return paddle.reader.multiprocess_reader(readers, False, queue_size=320) + +``` + +#### Q3.3.6:可不可以将pretrain_weights设置为空呢?想从零开始训练一个model + +**A**:这个是可以的,在训练通用识别模型的时候,pretrain_weights就设置为空,但是这样可能需要更长的迭代轮数才能达到相同的精度。 + +#### Q3.3.7:PaddleOCR默认不是200个step保存一次模型吗?为啥文件夹下面都没有生成 + +**A**:eval_batch_step [4000, 5000]改为[0, 5000] 就是从第0次迭代开始,每5000迭代保存一次模型 + +#### Q3.3.8:如何进行模型微调? + +**A**:注意配置好匹配的数据集合适,然后在finetune训练时,可以加载我们提供的预训练模型,设置配置文件中Global.pretrain_weights 参数为要加载的预训练模型路径。 + +#### Q3.3.9:文本检测换成自己的数据没法训练,有一些”###”是什么意思? + +**A**:数据格式有问题,”###” 表示要被忽略的文本区域,所以你的数据都被跳过了,可以换成其他任意字符或者就写个空的。 + +#### Q3.3.10:copy_from_cpu这个地方,这块input不变(t_data的size不变)连续调用两次copy_from_cpu()时,这里面的gpu_place会重新malloc GPU内存吗?还是只有当ele_size变化时才会重新在GPU上malloc呢? + +**A**:小于等于的时候都不会重新分配,只有大于的时候才会重新分配 + +#### Q3.3.11:自己训练出来的未inference转换的模型 可以当作预训练模型吗? + +**A**:可以的,但是如果训练数据两量少的话,可能会过拟合到少量数据上,泛化性能不佳。 +#### Q3.3.13:使用带TPS的识别模型预测报错 + +**A**:直接更换配置文件里的Backbone.function即可,格式为:网络文件路径,网络Class名词。如果所需的backbone在PaddleOCR里没有提供,可以参照PaddleClas里面的网络结构,进行修改尝试。具体修改原则可以参考OCR通用问题中 "如何更换文本检测/识别的backbone" 的回答。 + +#### Q3.3.12:如何更换文本检测/识别的backbone? +**A**:报错信息:'''Input(X) dims[3] and Input(Grid) dims[2] should be equal, but received X dimension[3](320) != Grid dimension[2](100) +**A**:TPS模块暂时无法支持变长的输入,请设置 --rec_image_shape='3,32,100' --rec_char_type='en' 固定输入shape + +### 预测部署 + +#### Q3.4.1:如何pip安装opt模型转换工具? + +**A**:由于OCR端侧部署需要某些算子的支持,这些算子仅在Paddle-Lite 最新develop分支中,所以需要自己编译opt模型转换工具。opt工具可以通过编译PaddleLite获得,编译步骤参考:https://github.com/PaddlePaddle/PaddleOCR/blob/0791714b91/deploy/lite/readme.md 中2.1 模型优化部分。 + +#### Q3.4.2:如何将PaddleOCR预测模型封装成SDK + +**A**:如果是Python的话,可以使用tools/infer/predict_system.py中的TextSystem进行sdk封装,如果是c++的话,可以使用deploy/cpp_infer/src下面的DBDetector和CRNNRecognizer完成封装 + +#### Q3.4.3:服务部署可以只发布 文本识别模型么?(不带文本检测模型) + +**A**:可以的。默认的服务部署是检测和识别串联预测的。也支持单独发布文本检测或文本识别模型,比如使用PaddleHUBPaddleOCR 模型时,deploy下有三个文件夹,分别是 +ocr_det:检测预测 +ocr_rec: 识别预测 +ocr_system: 检测识别串联预测 +每个模块是单独分开的,所以可以选择只发布文本识别模型。使用PaddleServing部署时同理。 + + +#### Q3.4.4:为什么PaddleOCR检测预测是只支持一张图片测试?即test_batch_size_per_card=1 + +**A**:测试的时候,对图像等比例缩放,最长边960,不同图像等比例缩放后长宽不一致,无法组成batch,所以设置为test_batch_size为1。 + +#### Q3.4.5:为什么使用c++ inference和py inference结果不一致 + +**A**:可能是导出的inference model版本与预测库版本需要保持一致,比如在Windows下,Paddle官网提供的预测库版本是1.8,而PaddleOCR提供的inference model 版本是1.7,因此最终预测结果会有差别。可以在Paddle1.8环境下导出模型,再基于该模型进行预测。 +此外也需要保证两者的预测参数配置完全一致。 + +#### Q3.4.6:为什么第一张张图预测时间很长,第二张之后预测时间会降低? + +**A**:第一张图需要初始化,耗时较多。完成模型加载后,之后的预测时间很短。 + +#### Q3.4.70:请问opt工具可以直接转int8量化后的模型为.nb文件吗 + +**A**:有的,PaddleLite提供完善的opt工具,可以参考[文档](https://paddle-lite.readthedocs.io/zh/latest/user_guides/post_quant_with_data.html) + +#### Q3.4.8:请问在安卓端怎么设置这个参数 --det_db_unclip_ratio=3 + +**A**:在安卓APK上无法设置,没有暴露这个接口,如果使用的是PaddledOCR/deploy/lite/的demo,可以修改config.txt中的对应参数来设置 + +#### Q3.4.9:PaddleOCR模型是否可以转换成ONNX模型? + +**A**:目前不支持转ONNX + +#### Q3.4.1:使用opt工具对检测模型转换时报错 can not found op arguments for node conv2_b_attr + +**A**:这个问题大概率是编译opt工具的Paddle-Lite不是develop分支,建议使用Paddle-Lite 的develop分支编译opt工具。 + +#### Q3.4.11:libopenblas.so找不到是什么意思? + +**A**:目前包括mkl和openblas两种版本的预测库,推荐使用mkl的预测库,如果下载的预测库是mkl的,编译的时候也需要勾选`with_mkl`选项 +,以Linux下编译为例,需要在设置这里为ON,`-DWITH_MKL=ON`,[参考链接](https://github.com/PaddlePaddle/PaddleOCR/blob/8a78af26df0dd8f15b734cc8db13e25d2a3656a2/deploy/cpp_infer/tools/build.sh#L12)。此外,使用预测库时,推荐在Linux或者Windows上进行开发,不推荐在MacOS上开发。 +#### Q3.4.12:使用自定义字典训练,inference时如何修改 + +**A**:使用了自定义字典的话,用inference预测时,需要通过 --rec_char_dict_path 修改字典路径。详细操作可参考[文档](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/inference.md#%E8%87%AA%E5%AE%9A%E4%B9%89%E6%96%87%E6%9C%AC%E8%AF%86%E5%88%AB%E5%AD%97%E5%85%B8%E7%9A%84%E6%8E%A8%E7%90%86) + +#### Q3.4.13:能否返回单字字符的位置? + +**A**:训练的时候标注是整个文本行的标注,所以预测的也是文本行位置,如果要获取单字符位置信息,可以根据预测的文本,计算字符数量,再去根据整个文本行的位置信息,估计文本块中每个字符的位置。 + +#### Q3.4.16: +**A**:目前有Inference部署,serving部署和手机端Paddle Lite部署,可根据不同场景做灵活的选择:Inference部署适用于本地离线部署,serving部署适用于云端部署,Paddle Lite部署适用于手机端集成。 From 29ba105c91540bd42fbf007ab7d4337e6f5a52b8 Mon Sep 17 00:00:00 2001 From: grasswolfs Date: Wed, 26 Aug 2020 17:17:07 +0800 Subject: [PATCH 25/42] test=develop,update_docs --- doc/doc_ch/FAQ.md | 27 +++++++++++---------------- 1 file changed, 11 insertions(+), 16 deletions(-) diff --git a/doc/doc_ch/FAQ.md b/doc/doc_ch/FAQ.md index 346d4c2b..d95d4cbf 100644 --- a/doc/doc_ch/FAQ.md +++ b/doc/doc_ch/FAQ.md @@ -10,7 +10,7 @@ ## PaddleOCR常见问题汇总(持续更新) * [【精选】OCR精选10个问题](#【精选】OCR精选10个问题) -* [【理论篇】OCR通用21个问题](#【理论篇】OCR通用问题) +* [【理论篇】OCR通用21个问题](#【理论篇】OCR通用问题) * [基础知识3题](#基础知识) * [数据集4题](#数据集) * [模型训练调优6题](#模型训练调优) @@ -60,24 +60,19 @@ (1)检测阶段:先按照检测框和标注框的IOU评估,IOU大于某个阈值判断为检测准确。这里检测框和标注框不同于一般的通用目标检测框,是采用多边形进行表示。 -检测准确率det_precision:正确的检测框个数在全部检测框的占比,主要是判断检测指标. +检测准确率:正确的检测框个数在全部检测框的占比,主要是判断检测指标. -检测召回率det_recall:正确的检测框个数在全部标注框的占比,主要是判断漏检的指标。 +检测召回率:正确的检测框个数在全部标注框的占比,主要是判断漏检的指标。 -检测 F1-Score: -$$ F1\_Score= \frac{2 \times det\_precision \times det\_recall}{det\_precision+det\_recall}$$ (2)识别阶段: -字符识别准确率rec_precision,即正确识别的文本行占标注的文本行数量的比例,只有整行文本识别对才算正确识别。 +字符识别准确率,即正确识别的文本行占标注的文本行数量的比例,只有整行文本识别对才算正确识别。 (3)端到端统计: -端对端准确率e2e_precision:准确检测并正确识别文本行在全部标注文本行的占比; -端到端召回率e2e_recall:准确检测并正确识别文本行在 检测到的文本行数量 的占比;准确检测的标准是检测框与标注框的IOU大于某个阈值,正确识别的的检测框中的文本与标注的文本相同。 +端对端准确率:准确检测并正确识别文本行在全部标注文本行的占比; +端到端召回率:准确检测并正确识别文本行在 检测到的文本行数量 的占比;准确检测的标准是检测框与标注框的IOU大于某个阈值,正确识别的的检测框中的文本与标注的文本相同。 -端到端 F1-Score: -$$ F1\_Score= \frac{2 \times e2e\_precision \times e2e\_recall}{e2e\_precision+e2e\_recall}$$ - #### Q1.1.7:单张图上多语种并存识别(如单张图印刷体和手写文字并存),应该如何处理? **A**:单张图像中存在多种类型文本的情况很常见,典型的以学生的试卷为代表,一张图像同时存在手写体和印刷体两种文本,这类情况下,可以尝试”1个检测模型+1个N分类模型+N个识别模型”的解决方案。 @@ -91,8 +86,8 @@ $$ F1\_Score= \frac{2 \times e2e\_precision \times e2e\_recall}{e2e\_precision+e 识别的话,520W左右的数据集(真实数据26W+合成数据500W)训练,超轻量模型:4卡V100,总共训练了5天左右。通用模型:4卡V100,共训练6天。 超轻量模型训练分为2个阶段: -<1>全量数据训练50epoch,耗时3天 -<2>合成数据+真实数据按照1:1数据采样,进行finetune训练200epoch,耗时2天 +(1)全量数据训练50epoch,耗时3天 +(2)合成数据+真实数据按照1:1数据采样,进行finetune训练200epoch,耗时2天 通用模型训练: 真实数据+合成数据,动态采样(1:1)训练,200epoch,耗时 6天左右。 @@ -448,7 +443,7 @@ ocr_system: 检测识别串联预测 **A**:第一张图需要初始化,耗时较多。完成模型加载后,之后的预测时间很短。 -#### Q3.4.70:请问opt工具可以直接转int8量化后的模型为.nb文件吗 +#### Q3.4.7:请问opt工具可以直接转int8量化后的模型为.nb文件吗 **A**:有的,PaddleLite提供完善的opt工具,可以参考[文档](https://paddle-lite.readthedocs.io/zh/latest/user_guides/post_quant_with_data.html) @@ -460,7 +455,7 @@ ocr_system: 检测识别串联预测 **A**:目前不支持转ONNX -#### Q3.4.1:使用opt工具对检测模型转换时报错 can not found op arguments for node conv2_b_attr +#### Q3.4.10:使用opt工具对检测模型转换时报错 can not found op arguments for node conv2_b_attr **A**:这个问题大概率是编译opt工具的Paddle-Lite不是develop分支,建议使用Paddle-Lite 的develop分支编译opt工具。 @@ -476,5 +471,5 @@ ocr_system: 检测识别串联预测 **A**:训练的时候标注是整个文本行的标注,所以预测的也是文本行位置,如果要获取单字符位置信息,可以根据预测的文本,计算字符数量,再去根据整个文本行的位置信息,估计文本块中每个字符的位置。 -#### Q3.4.16: +#### Q3.4.16:PaddleOCR模型部署方式有哪几种? **A**:目前有Inference部署,serving部署和手机端Paddle Lite部署,可根据不同场景做灵活的选择:Inference部署适用于本地离线部署,serving部署适用于云端部署,Paddle Lite部署适用于手机端集成。 From 46af364e121c6346d6640a6083e895c43957aeab Mon Sep 17 00:00:00 2001 From: dyning Date: Wed, 26 Aug 2020 17:22:08 +0800 Subject: [PATCH 26/42] Update FAQ.md --- doc/doc_ch/FAQ.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/doc/doc_ch/FAQ.md b/doc/doc_ch/FAQ.md index d95d4cbf..de22d1fe 100644 --- a/doc/doc_ch/FAQ.md +++ b/doc/doc_ch/FAQ.md @@ -471,5 +471,5 @@ ocr_system: 检测识别串联预测 **A**:训练的时候标注是整个文本行的标注,所以预测的也是文本行位置,如果要获取单字符位置信息,可以根据预测的文本,计算字符数量,再去根据整个文本行的位置信息,估计文本块中每个字符的位置。 -#### Q3.4.16:PaddleOCR模型部署方式有哪几种? +#### Q3.4.14:PaddleOCR模型部署方式有哪几种? **A**:目前有Inference部署,serving部署和手机端Paddle Lite部署,可根据不同场景做灵活的选择:Inference部署适用于本地离线部署,serving部署适用于云端部署,Paddle Lite部署适用于手机端集成。 From 6b73e5f47a78f744ceed7987f645918d990ebe01 Mon Sep 17 00:00:00 2001 From: dyning Date: Wed, 26 Aug 2020 17:25:52 +0800 Subject: [PATCH 27/42] Update FAQ.md --- doc/doc_ch/FAQ.md | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/doc/doc_ch/FAQ.md b/doc/doc_ch/FAQ.md index de22d1fe..ca548423 100644 --- a/doc/doc_ch/FAQ.md +++ b/doc/doc_ch/FAQ.md @@ -270,7 +270,7 @@ **A**:近期也在开展需求调研,如果企业用户需求较多,我们会考虑增加相应的研发投入,后续提供对应的预训练模型,如果有需求欢迎通过issue或者加入微信群联系我们。 -#### Q3.1.17:超轻量模型和通用OCR模型的区别? +#### Q3.1.15:超轻量模型和通用OCR模型的区别? **A**:理论上只要有相应的数据集,都是可以的。当然手写识别毕竟和印刷体有区别,对应训练调优策略可能需要适配性优化。 @@ -280,7 +280,7 @@ PaddleOCR已完成Windows和Mac系统适配,并且python预测支持使用pip包安装。运行时注意两点:1、在[快速安装](./installation.md)时,如果不想安装docker,可跳过第一步,直接从第二步安装paddle开始。2、inference模型下载时,如果没有安装wget,可直接点击模型链接或将链接地址复制到浏览器进行下载,并解压放置到相应目录。 -#### Q3.1.15:PaddleOCR是否支持在Windows或Mac系统上运行? +#### Q3.1.17:PaddleOCR是否支持在Windows或Mac系统上运行? **A**:目前PaddleOCR开源了2个中文模型,分别是8.6M超轻量中文模型和通用中文OCR模型。两者对比信息如下: - 相同点:两者使用相同的**算法**和**训练数据**; - 不同点:不同之处在于**骨干网络**和**通道参数**,超轻量模型使用MobileNetV3作为骨干网络,通用模型使用Resnet50_vd作为检测模型backbone,Resnet34_vd作为识别模型backbone,具体参数差异可对比两种模型训练的配置文件. @@ -377,7 +377,6 @@ unclip_ratio: 文本框扩张的系数,关系到文本框的大小`` ``` return paddle.reader.multiprocess_reader(readers, False, queue_size=320) - ``` #### Q3.3.6:可不可以将pretrain_weights设置为空呢?想从零开始训练一个model @@ -403,11 +402,13 @@ return paddle.reader.multiprocess_reader(readers, False, queue_size=320) #### Q3.3.11:自己训练出来的未inference转换的模型 可以当作预训练模型吗? **A**:可以的,但是如果训练数据两量少的话,可能会过拟合到少量数据上,泛化性能不佳。 -#### Q3.3.13:使用带TPS的识别模型预测报错 + +#### Q3.3.12:如何更换文本检测/识别的backbone? **A**:直接更换配置文件里的Backbone.function即可,格式为:网络文件路径,网络Class名词。如果所需的backbone在PaddleOCR里没有提供,可以参照PaddleClas里面的网络结构,进行修改尝试。具体修改原则可以参考OCR通用问题中 "如何更换文本检测/识别的backbone" 的回答。 -#### Q3.3.12:如何更换文本检测/识别的backbone? +#### Q3.3.13:使用带TPS的识别模型预测报错 + **A**:报错信息:'''Input(X) dims[3] and Input(Grid) dims[2] should be equal, but received X dimension[3](320) != Grid dimension[2](100) **A**:TPS模块暂时无法支持变长的输入,请设置 --rec_image_shape='3,32,100' --rec_char_type='en' 固定输入shape From 8deee752aae9e4e4a1094a8e5e11f2c993bd1846 Mon Sep 17 00:00:00 2001 From: dyning Date: Wed, 26 Aug 2020 17:27:41 +0800 Subject: [PATCH 28/42] Update FAQ.md --- doc/doc_ch/FAQ.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/doc/doc_ch/FAQ.md b/doc/doc_ch/FAQ.md index ca548423..a97b8cc3 100644 --- a/doc/doc_ch/FAQ.md +++ b/doc/doc_ch/FAQ.md @@ -15,11 +15,11 @@ * [数据集4题](#数据集) * [模型训练调优6题](#模型训练调优) * [预测部署8题](#预测部署) -* [【实战篇】PaddleOCR实战53个问题](#【实战篇】PaddleOCR实战问题) - * [使用咨询16题](#使用咨询) +* [【实战篇】PaddleOCR实战54个问题](#【实战篇】PaddleOCR实战问题) + * [使用咨询18题](#使用咨询) * [数据集9题](#数据集) * [模型训练调优13题](#模型训练调优) - * [预测部署15题](#[预测部署) + * [预测部署14题](#[预测部署) From 6c60f8e2e7ae287442496a4d6c652bc3d333eb30 Mon Sep 17 00:00:00 2001 From: dyning Date: Wed, 26 Aug 2020 17:27:55 +0800 Subject: [PATCH 29/42] Update README.md --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 4a290960..c828163f 100644 --- a/README.md +++ b/README.md @@ -4,7 +4,7 @@ PaddleOCR旨在打造一套丰富、领先、且实用的OCR工具库,助力使用者训练出更好的模型,并应用落地。 **近期更新** -- 2020.8.26 更新OCR相关的83个常见问题及解答,具体参考[FAQ](./doc/doc_ch/FAQ.md) +- 2020.8.26 更新OCR相关的85个常见问题及解答,具体参考[FAQ](./doc/doc_ch/FAQ.md) - 2020.8.24 支持通过whl包安装使用PaddleOCR,具体参考[Paddleocr Package使用说明](./doc/doc_ch/whl.md) - 2020.8.21 更新8月18日B站直播课回放和PPT,课节2,易学易用的OCR工具大礼包,[获取地址](https://aistudio.baidu.com/aistudio/education/group/info/1519) - 2020.8.16 开源文本检测算法[SAST](https://arxiv.org/abs/1908.05498)和文本识别算法[SRN](https://arxiv.org/abs/2003.12294) From bf321ecd984f863b032252ac5599fa9eab855c17 Mon Sep 17 00:00:00 2001 From: dyning Date: Wed, 26 Aug 2020 17:30:57 +0800 Subject: [PATCH 30/42] Update FAQ.md --- doc/doc_ch/FAQ.md | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/doc/doc_ch/FAQ.md b/doc/doc_ch/FAQ.md index a97b8cc3..affe9e6d 100644 --- a/doc/doc_ch/FAQ.md +++ b/doc/doc_ch/FAQ.md @@ -263,7 +263,7 @@ #### Q3.1.13:识别模型框出来的位置太紧凑,会丢失边缘的文字信息,导致识别错误 -**A**: 可以在命令中加入 --det_db_unclip_ratio ,参数[定义位置](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/tools/infer/utility.py#L49),这个参数是检测后处理时控制文本框大小的,默认2.0,可以尝试改成2.5或者更大 +**A**: 可以在命令中加入 --det_db_unclip_ratio ,参考[定义位置](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/tools/infer/utility.py#L49),这个参数是检测后处理时控制文本框大小的,默认2.0,可以尝试改成2.5或者更大 ,反之,如果觉得文本框不够紧凑,也可以把该参数调小。 #### Q3.1.14:英文手写体识别有计划提供的预训练模型吗? @@ -272,13 +272,12 @@ #### Q3.1.15:超轻量模型和通用OCR模型的区别? - **A**:理论上只要有相应的数据集,都是可以的。当然手写识别毕竟和印刷体有区别,对应训练调优策略可能需要适配性优化。 #### Q3.1.16:PaddleOCR的算法可以用于手写文字检测识别吗?后续有计划推出手写预训练模型么? -PaddleOCR已完成Windows和Mac系统适配,并且python预测支持使用pip包安装。运行时注意两点:1、在[快速安装](./installation.md)时,如果不想安装docker,可跳过第一步,直接从第二步安装paddle开始。2、inference模型下载时,如果没有安装wget,可直接点击模型链接或将链接地址复制到浏览器进行下载,并解压放置到相应目录。 +**A**:PaddleOCR已完成Windows和Mac系统适配,并且python预测支持使用pip包安装。运行时注意两点:1、在[快速安装](./installation.md)时,如果不想安装docker,可跳过第一步,直接从第二步安装paddle开始。2、inference模型下载时,如果没有安装wget,可直接点击模型链接或将链接地址复制到浏览器进行下载,并解压放置到相应目录。 #### Q3.1.17:PaddleOCR是否支持在Windows或Mac系统上运行? **A**:目前PaddleOCR开源了2个中文模型,分别是8.6M超轻量中文模型和通用中文OCR模型。两者对比信息如下: @@ -295,7 +294,6 @@ PaddleOCR已完成Windows和Mac系统适配,并且python预测支持使用pip **A**:目前主要是开源通用类OCR模型,暂不计划开源小垂类专用模型。PaddleOCR开源了多种检测、识别算法供用户自定义训练,两种中文模型也是基于开源的算法库训练产出,有小垂类需求的小伙伴,可以按照教程准备好数据,选择合适的配置文件,自行训练,相信能有不错的效果。训练有任何问题欢迎提issue或在交流群提问,我们会及时解答。 - ### 数据集 #### Q3.2.1:如何制作PaddleOCR支持的数据格式 From cbb82c6b2f0d1f90058ab53db7b1904b71d96807 Mon Sep 17 00:00:00 2001 From: grasswolfs Date: Wed, 26 Aug 2020 20:16:52 +0800 Subject: [PATCH 31/42] test=develop,update_docs --- doc/doc_ch/FAQ.md | 49 ++++++++++++++++++++++++++--------------------- 1 file changed, 27 insertions(+), 22 deletions(-) diff --git a/doc/doc_ch/FAQ.md b/doc/doc_ch/FAQ.md index affe9e6d..90a92bb0 100644 --- a/doc/doc_ch/FAQ.md +++ b/doc/doc_ch/FAQ.md @@ -9,48 +9,54 @@ ## PaddleOCR常见问题汇总(持续更新) -* [【精选】OCR精选10个问题](#【精选】OCR精选10个问题) -* [【理论篇】OCR通用21个问题](#【理论篇】OCR通用问题) +* [【精选】OCR精选10个问题](#OCR精选10个问题) +* [【理论篇】OCR通用21个问题](#OCR通用问题) * [基础知识3题](#基础知识) * [数据集4题](#数据集) * [模型训练调优6题](#模型训练调优) * [预测部署8题](#预测部署) -* [【实战篇】PaddleOCR实战54个问题](#【实战篇】PaddleOCR实战问题) - * [使用咨询18题](#使用咨询) +* [【实战篇】PaddleOCR实战53个问题](#PaddleOCR实战问题) + * [使用咨询17题](#使用咨询) * [数据集9题](#数据集) * [模型训练调优13题](#模型训练调优) * [预测部署14题](#[预测部署) - + ## 【精选】OCR精选10个问题 #### Q1.1.1:基于深度学习的文字检测方法有哪几种?各有什么优缺点? **A**:常用的基于深度学习的文字检测方法一般可以分为基于回归的、基于分割的两大类,当然还有一些将两者进行结合的方法。 + (1)基于回归的方法分为box回归和像素值回归。a. 采用box回归的方法主要有CTPN、Textbox系列和EAST,这类算法对规则形状文本检测效果较好,但无法准确检测不规则形状文本。 b. 像素值回归的方法主要有CRAFT和SA-Text,这类算法能够检测弯曲文本且对小文本效果优秀但是实时性能不够。 + (2)基于分割的算法,如PSENet,这类算法不受文本形状的限制,对各种形状的文本都能取得较好的效果,但是往往后处理比较复杂,导致耗时严重。目前也有一些算法专门针对这个问题进行改进,如DB,将二值化进行近似,使其可导,融入训练,从而获取更准确的边界,大大降低了后处理的耗时。 #### Q1.1.2:对于中文行文本识别,CTC和Attention哪种更优? **A**:(1)从效果上来看,通用OCR场景CTC的识别效果优于Attention,因为带识别的字典中的字符比较多,常用中文汉字三千字以上,如果训练样本不足的情况下,对于这些字符的序列关系挖掘比较困难。中文场景下Attention模型的优势无法体现。而且Attention适合短语句识别,对长句子识别比较差。 + (2)从训练和预测速度上,Attention的串行解码结构限制了预测速度,而CTC网络结构更高效,预测速度上更有优势。 #### Q1.1.3:弯曲形变的文字识别需要怎么处理?TPS应用场景是什么,是否好用? **A**:(1)在大多数情况下,如果遇到的场景弯曲形变不是太严重,检测4个顶点,然后直接通过仿射变换转正识别就足够了。 + (2)如果不能满足需求,可以尝试使用TPS(Thin Plate Spline),即薄板样条插值。TPS是一种插值算法,经常用于图像变形等,通过少量的控制点就可以驱动图像进行变化。一般用在有弯曲形变的文本识别中,当检测到不规则的/弯曲的(如,使用基于分割的方法检测算法)文本区域,往往先使用TPS算法对文本区域矫正成矩形再进行识别,如,STAR-Net、RARE等识别算法中引入了TPS模块。 **Warning**:TPS看起来美好,在实际应用时经常发现并不够鲁棒,并且会增加耗时,需要谨慎使用。 #### Q1.1.4:简单的对于精度要求不高的OCR任务,数据集需要准备多少张呢? **A**:(1)训练数据的数量和需要解决问题的复杂度有关系。难度越大,精度要求越高,则数据集需求越大,而且一般情况实际中的训练数据越多效果越好。 + (2)对于精度要求不高的场景,检测任务和识别任务需要的数据量是不一样的。对于检测任务,500张图像可以保证基本的检测效果。对于识别任务,需要保证识别字典中每个字符出现在不同场景的行文本图像数目需要大于200张(举例,如果有字典中有5个字,每个字都需要出现在200张图片以上,那么最少要求的图像数量应该在200-1000张之间),这样可以保证基本的识别效果。 #### Q1.1.5:背景干扰的文字(如印章盖到落款上,需要识别落款或者印章中的文字),如何识别? **A**:(1)在人眼确认可识别的条件下,对于背景有干扰的文字,首先要保证检测框足够准确,如果检测框不准确,需要考虑是否可以通过过滤颜色等方式对图像预处理并且增加更多相关的训练数据;在识别的部分,注意在训练数据中加入背景干扰类的扩增图像。 + (2)如果MobileNet模型不能满足需求,可以尝试ResNet系列大模型来获得更好的效果 。 @@ -96,15 +102,18 @@ #### Q1.1.9:PaddleOCR模型推理方式有几种?各自的优缺点是什么 **A**:目前推理方式支持基于训练引擎推理和基于预测引擎推理。 + (1)基于训练引擎推理不需要转换模型,但是需要先组网再load参数,语言只支持python,不适合系统集成。 + (2)基于预测引擎的推理需要先转换模型为inference格式,然后可以进行不需要组网的推理,语言支持c++和python,适合系统集成。 #### Q1.1.10:PaddleOCR中,对于模型预测加速,CPU加速的途径有哪些?基于TenorRT加速GPU对输入有什么要求? **A**:(1)CPU可以使用mkldnn进行加速;对于python inference的话,可以把enable_mkldnn改为true,[参考代码](https://github.com/PaddlePaddle/PaddleOCR/blob/549108fe0aa0d87c0a3b2d471f1c653e89daab80/tools/infer/utility.py#L73),对于cpp inference的话,在配置文件里面配置use_mkldnn 1即可,[参考代码](https://github.com/PaddlePaddle/PaddleOCR/blob/549108fe0aa0d87c0a3b2d471f1c653e89daab80/deploy/cpp_infer/tools/config.txt#L6) + (2)GPU需要注意变长输入问题等,TRT6 之后才支持变长输入 - + ## 【理论篇】OCR通用问题 ### 基础知识 @@ -144,7 +153,9 @@ #### Q2.3.1:如何更换文本检测/识别的backbone? **A**:无论是文字检测,还是文字识别,骨干网络的选择是预测效果和预测效率的权衡。一般,选择更大规模的骨干网络,例如ResNet101_vd,则检测或识别更准确,但预测耗时相应也会增加。而选择更小规模的骨干网络,例如MobileNetV3_small_x0_35,则预测更快,但检测或识别的准确率会大打折扣。幸运的是不同骨干网络的检测或识别效果与在ImageNet数据集图像1000分类任务效果正相关。[**飞桨图像分类套件PaddleClas**](https://github.com/PaddlePaddle/PaddleClas)汇总了ResNet_vd、Res2Net、HRNet、MobileNetV3、GhostNet等23种系列的分类网络结构,在上述图像分类任务的top1识别准确率,GPU(V100和T4)和CPU(骁龙855)的预测耗时以及相应的[**117个预训练模型下载地址**](https://paddleclas.readthedocs.io/zh_CN/latest/models/models_intro.html)。 + (1)文字检测骨干网络的替换,主要是确定类似与ResNet的4个stages,以方便集成后续的类似FPN的检测头。此外,对于文字检测问题,使用ImageNet训练的分类预训练模型,可以加速收敛和效果提升。 + (2)文字识别的骨干网络的替换,需要注意网络宽高stride的下降位置。由于文本识别一般宽高比例很大,因此高度下降频率少一些,宽度下降频率多一些。可以参考PaddleOCR中[MobileNetV3骨干网络](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/ppocr/modeling/backbones/rec_mobilenet_v3.py)的改动。 #### Q2.3.2:文本识别训练不加LSTM是否可以收敛? @@ -208,7 +219,7 @@ **A**:表格目前学术界比较成熟的解决方案不多 ,可以尝试下分割的论文方案。 - + ## 【实战篇】PaddleOCR实战问题 ### 使用咨询 @@ -263,23 +274,21 @@ #### Q3.1.13:识别模型框出来的位置太紧凑,会丢失边缘的文字信息,导致识别错误 -**A**: 可以在命令中加入 --det_db_unclip_ratio ,参考[定义位置](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/tools/infer/utility.py#L49),这个参数是检测后处理时控制文本框大小的,默认2.0,可以尝试改成2.5或者更大 -,反之,如果觉得文本框不够紧凑,也可以把该参数调小。 +**A**: 可以在命令中加入 --det_db_unclip_ratio ,参数[定义位置](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/tools/infer/utility.py#L49),这个参数是检测后处理时控制文本框大小的,默认2.0,可以尝试改成2.5或者更大,反之,如果觉得文本框不够紧凑,也可以把该参数调小。 #### Q3.1.14:英文手写体识别有计划提供的预训练模型吗? **A**:近期也在开展需求调研,如果企业用户需求较多,我们会考虑增加相应的研发投入,后续提供对应的预训练模型,如果有需求欢迎通过issue或者加入微信群联系我们。 -#### Q3.1.15:超轻量模型和通用OCR模型的区别? - +#### Q3.1.15:PaddleOCR的算法可以用于手写文字检测识别吗?后续有计划推出手写预训练模型么? **A**:理论上只要有相应的数据集,都是可以的。当然手写识别毕竟和印刷体有区别,对应训练调优策略可能需要适配性优化。 -#### Q3.1.16:PaddleOCR的算法可以用于手写文字检测识别吗?后续有计划推出手写预训练模型么? +#### Q3.1.16:PaddleOCR是否支持在Windows或Mac系统上运行? -**A**:PaddleOCR已完成Windows和Mac系统适配,并且python预测支持使用pip包安装。运行时注意两点:1、在[快速安装](./installation.md)时,如果不想安装docker,可跳过第一步,直接从第二步安装paddle开始。2、inference模型下载时,如果没有安装wget,可直接点击模型链接或将链接地址复制到浏览器进行下载,并解压放置到相应目录。 +**A**:PaddleOCR已完成Windows和Mac系统适配,运行时注意两点:1、在[快速安装](./installation.md)时,如果不想安装docker,可跳过第一步,直接从第二步安装paddle开始。2、inference模型下载时,如果没有安装wget,可直接点击模型链接或将链接地址复制到浏览器进行下载,并解压放置到相应目录。 -#### Q3.1.17:PaddleOCR是否支持在Windows或Mac系统上运行? +#### Q3.1.17:PaddleOCR开源的超轻量模型和通用OCR模型的区别? **A**:目前PaddleOCR开源了2个中文模型,分别是8.6M超轻量中文模型和通用中文OCR模型。两者对比信息如下: - 相同点:两者使用相同的**算法**和**训练数据**; - 不同点:不同之处在于**骨干网络**和**通道参数**,超轻量模型使用MobileNetV3作为骨干网络,通用模型使用Resnet50_vd作为检测模型backbone,Resnet34_vd作为识别模型backbone,具体参数差异可对比两种模型训练的配置文件. @@ -289,10 +298,6 @@ |8.6M超轻量中文OCR模型|MobileNetV3+MobileNetV3|det_mv3_db.yml|rec_chinese_lite_train.yml| |通用中文OCR模型|Resnet50_vd+Resnet34_vd|det_r50_vd_db.yml|rec_chinese_common_train.yml| -#### Q3.1.18:是否有计划开源仅识别数字或仅识别英文+数字的模型 - -**A**:目前主要是开源通用类OCR模型,暂不计划开源小垂类专用模型。PaddleOCR开源了多种检测、识别算法供用户自定义训练,两种中文模型也是基于开源的算法库训练产出,有小垂类需求的小伙伴,可以按照教程准备好数据,选择合适的配置文件,自行训练,相信能有不错的效果。训练有任何问题欢迎提issue或在交流群提问,我们会及时解答。 - ### 数据集 @@ -375,6 +380,7 @@ unclip_ratio: 文本框扩张的系数,关系到文本框的大小`` ``` return paddle.reader.multiprocess_reader(readers, False, queue_size=320) + ``` #### Q3.3.6:可不可以将pretrain_weights设置为空呢?想从零开始训练一个model @@ -400,13 +406,11 @@ return paddle.reader.multiprocess_reader(readers, False, queue_size=320) #### Q3.3.11:自己训练出来的未inference转换的模型 可以当作预训练模型吗? **A**:可以的,但是如果训练数据两量少的话,可能会过拟合到少量数据上,泛化性能不佳。 - -#### Q3.3.12:如何更换文本检测/识别的backbone? +#### Q3.3.12:使用带TPS的识别模型预测报错 **A**:直接更换配置文件里的Backbone.function即可,格式为:网络文件路径,网络Class名词。如果所需的backbone在PaddleOCR里没有提供,可以参照PaddleClas里面的网络结构,进行修改尝试。具体修改原则可以参考OCR通用问题中 "如何更换文本检测/识别的backbone" 的回答。 -#### Q3.3.13:使用带TPS的识别模型预测报错 - +#### Q3.3.13:如何更换文本检测/识别的backbone? **A**:报错信息:'''Input(X) dims[3] and Input(Grid) dims[2] should be equal, but received X dimension[3](320) != Grid dimension[2](100) **A**:TPS模块暂时无法支持变长的输入,请设置 --rec_image_shape='3,32,100' --rec_char_type='en' 固定输入shape @@ -462,6 +466,7 @@ ocr_system: 检测识别串联预测 **A**:目前包括mkl和openblas两种版本的预测库,推荐使用mkl的预测库,如果下载的预测库是mkl的,编译的时候也需要勾选`with_mkl`选项 ,以Linux下编译为例,需要在设置这里为ON,`-DWITH_MKL=ON`,[参考链接](https://github.com/PaddlePaddle/PaddleOCR/blob/8a78af26df0dd8f15b734cc8db13e25d2a3656a2/deploy/cpp_infer/tools/build.sh#L12)。此外,使用预测库时,推荐在Linux或者Windows上进行开发,不推荐在MacOS上开发。 + #### Q3.4.12:使用自定义字典训练,inference时如何修改 **A**:使用了自定义字典的话,用inference预测时,需要通过 --rec_char_dict_path 修改字典路径。详细操作可参考[文档](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_ch/inference.md#%E8%87%AA%E5%AE%9A%E4%B9%89%E6%96%87%E6%9C%AC%E8%AF%86%E5%88%AB%E5%AD%97%E5%85%B8%E7%9A%84%E6%8E%A8%E7%90%86) From 98a979a6bf2a19fe2dc3a1a9f7a0115ca2913bdd Mon Sep 17 00:00:00 2001 From: grasswolfs Date: Wed, 26 Aug 2020 20:44:17 +0800 Subject: [PATCH 32/42] test=develop,update_docs --- doc/doc_ch/FAQ.md | 31 +++++++++++++++++++------------ 1 file changed, 19 insertions(+), 12 deletions(-) diff --git a/doc/doc_ch/FAQ.md b/doc/doc_ch/FAQ.md index 90a92bb0..0a419c12 100644 --- a/doc/doc_ch/FAQ.md +++ b/doc/doc_ch/FAQ.md @@ -290,8 +290,8 @@ #### Q3.1.17:PaddleOCR开源的超轻量模型和通用OCR模型的区别? **A**:目前PaddleOCR开源了2个中文模型,分别是8.6M超轻量中文模型和通用中文OCR模型。两者对比信息如下: - - 相同点:两者使用相同的**算法**和**训练数据**; - - 不同点:不同之处在于**骨干网络**和**通道参数**,超轻量模型使用MobileNetV3作为骨干网络,通用模型使用Resnet50_vd作为检测模型backbone,Resnet34_vd作为识别模型backbone,具体参数差异可对比两种模型训练的配置文件. +- 相同点:两者使用相同的**算法**和**训练数据**; +- 不同点:不同之处在于**骨干网络**和**通道参数**,超轻量模型使用MobileNetV3作为骨干网络,通用模型使用Resnet50_vd作为检测模型backbone,Resnet34_vd作为识别模型backbone,具体参数差异可对比两种模型训练的配置文件. |模型|骨干网络|检测训练配置|识别训练配置| |-|-|-|-| @@ -316,13 +316,16 @@ #### Q3.2.4:开源模型使用的训练数据是什么,能否开源? **A**:目前开源的模型,数据集和量级如下: - - 检测: - 英文数据集,ICDAR2015 - 中文数据集,LSVT街景数据集训练数据3w张图片 - - 识别: - 英文数据集,MJSynth和SynthText合成数据,数据量上千万。 - 中文数据集,LSVT街景数据集根据真值将图crop出来,并进行位置校准,总共30w张图像。此外基于LSVT的语料,合成数据500w。 - 其中,公开数据集都是开源的,用户可自行搜索下载,也可参考[中文数据集](./datasets.md),合成数据暂不开源,用户可使用开源合成工具自行合成,可参考的合成工具包括[text_renderer](https://github.com/Sanster/text_renderer)、[SynthText](https://github.com/ankush-me/SynthText)、[TextRecognitionDataGenerator](https://github.com/Belval/TextRecognitionDataGenerator)等。 + +- 检测: + - 英文数据集,ICDAR2015 + - 中文数据集,LSVT街景数据集训练数据3w张图片 + +- 识别: + - 英文数据集,MJSynth和SynthText合成数据,数据量上千万。 + - 中文数据集,LSVT街景数据集根据真值将图crop出来,并进行位置校准,总共30w张图像。此外基于LSVT的语料,合成数据500w。 + +其中,公开数据集都是开源的,用户可自行搜索下载,也可参考[中文数据集](./datasets.md),合成数据暂不开源,用户可使用开源合成工具自行合成,可参考的合成工具包括[text_renderer](https://github.com/Sanster/text_renderer)、[SynthText](https://github.com/ankush-me/SynthText)、[TextRecognitionDataGenerator](https://github.com/Belval/TextRecognitionDataGenerator)等。 #### Q3.2.5:请问中文字符集多大呢?支持生僻字识别吗? @@ -372,7 +375,12 @@ unclip_ratio: 文本框扩张的系数,关系到文本框的大小`` #### Q3.3.4:训练过程中,如何恰当的停止训练(直接kill,经常还有显存占用的问题) -**A**:可以通过下面的脚本终止所有包含train.py字段的进程,ps -axu | grep train.py | awk '{print $2}' | xargs kill -9 +**A**:可以通过下面的脚本终止所有包含train.py字段的进程, + +``` +ps -axu | grep train.py | awk '{print $2}' | xargs kill -9 + +``` #### Q3.3.5:读数据进程数设置4~8时训练一会进程接连defunct后gpu利用率一直为0卡死 @@ -410,8 +418,7 @@ return paddle.reader.multiprocess_reader(readers, False, queue_size=320) **A**:直接更换配置文件里的Backbone.function即可,格式为:网络文件路径,网络Class名词。如果所需的backbone在PaddleOCR里没有提供,可以参照PaddleClas里面的网络结构,进行修改尝试。具体修改原则可以参考OCR通用问题中 "如何更换文本检测/识别的backbone" 的回答。 -#### Q3.3.13:如何更换文本检测/识别的backbone? -**A**:报错信息:'''Input(X) dims[3] and Input(Grid) dims[2] should be equal, but received X dimension[3](320) != Grid dimension[2](100) +#### Q3.3.13:如何更换文本检测/识别的backbone?报错信息:'''Input(X) dims[3] and Input(Grid) dims[2] should be equal, but received X dimension[3](320) != Grid dimension[2](100) **A**:TPS模块暂时无法支持变长的输入,请设置 --rec_image_shape='3,32,100' --rec_char_type='en' 固定输入shape ### 预测部署 From 0b7d93d51322d5beee1c23469aa60ec1dc7e63bc Mon Sep 17 00:00:00 2001 From: grasswolfs Date: Wed, 26 Aug 2020 21:21:24 +0800 Subject: [PATCH 33/42] test=develop,update_docs --- doc/doc_ch/FAQ.md | 56 +++++++++++++++++++++++++++-------------------- 1 file changed, 32 insertions(+), 24 deletions(-) diff --git a/doc/doc_ch/FAQ.md b/doc/doc_ch/FAQ.md index 0a419c12..fe36c44e 100644 --- a/doc/doc_ch/FAQ.md +++ b/doc/doc_ch/FAQ.md @@ -2,7 +2,7 @@ ## 写在前面 -- 我们收集整理了issues和用户群中的常见问题和解答,并且会不断更新,旨在为OCR的开发者提供一些参考,也希望帮助大家少走一些弯路。 +- 我们收集整理了开源以来在issues和用户群中的常见问题并且给出了简要解答,旨在为OCR的开发者提供一些参考,也希望帮助大家少走一些弯路。 - OCR领域大佬众多,本文档回答主要依赖有限的项目实践,难免挂一漏万,如有遗漏和不足,也**希望有识之士帮忙补充和修正**,万分感谢。 @@ -19,7 +19,7 @@ * [使用咨询17题](#使用咨询) * [数据集9题](#数据集) * [模型训练调优13题](#模型训练调优) - * [预测部署14题](#[预测部署) + * [预测部署14题](#预测部署) @@ -64,11 +64,7 @@ **A**:对于两阶段的可以分开来看,分别是检测和识别阶段 -(1)检测阶段:先按照检测框和标注框的IOU评估,IOU大于某个阈值判断为检测准确。这里检测框和标注框不同于一般的通用目标检测框,是采用多边形进行表示。 - -检测准确率:正确的检测框个数在全部检测框的占比,主要是判断检测指标. - -检测召回率:正确的检测框个数在全部标注框的占比,主要是判断漏检的指标。 +(1)检测阶段:先按照检测框和标注框的IOU评估,IOU大于某个阈值判断为检测准确。这里检测框和标注框不同于一般的通用目标检测框,是采用多边形进行表示。检测准确率:正确的检测框个数在全部检测框的占比,主要是判断检测指标。检测召回率:正确的检测框个数在全部标注框的占比,主要是判断漏检的指标。 (2)识别阶段: @@ -149,7 +145,7 @@ **A**:可以根据实际场景做不同的尝试,共享一个类别是可以收敛,效果也还不错。但是如果分开训练,同类样本之间一致性更好,更容易收敛,识别效果会更优。 -### 训练训练调优 +### 模型训练调优 #### Q2.3.1:如何更换文本检测/识别的backbone? **A**:无论是文字检测,还是文字识别,骨干网络的选择是预测效果和预测效率的权衡。一般,选择更大规模的骨干网络,例如ResNet101_vd,则检测或识别更准确,但预测耗时相应也会增加。而选择更小规模的骨干网络,例如MobileNetV3_small_x0_35,则预测更快,但检测或识别的准确率会大打折扣。幸运的是不同骨干网络的检测或识别效果与在ImageNet数据集图像1000分类任务效果正相关。[**飞桨图像分类套件PaddleClas**](https://github.com/PaddlePaddle/PaddleClas)汇总了ResNet_vd、Res2Net、HRNet、MobileNetV3、GhostNet等23种系列的分类网络结构,在上述图像分类任务的top1识别准确率,GPU(V100和T4)和CPU(骁龙855)的预测耗时以及相应的[**117个预训练模型下载地址**](https://paddleclas.readthedocs.io/zh_CN/latest/models/models_intro.html)。 @@ -173,7 +169,9 @@ #### Q2.3.5:训练识别时,如何选择合适的网络输入shape? **A**:一般高度采用32,最长宽度的选择,有两种方法: + (1)统计训练样本图像的宽高比分布。最大宽高比的选取考虑满足80%的训练样本。 + (2)统计训练样本文字数目。最长字符数目的选取考虑满足80%的训练样本。然后中文字符长宽比近似认为是1,英文认为3:1,预估一个最长宽度。 #### Q2.3.6:如何识别文字比较长的文本? @@ -193,7 +191,9 @@ #### Q2.4.3:对于特定文字检测,例如身份证只检测姓名,检测指定区域文字更好,还是检测全部区域再筛选更好? **A**:两个角度来说明一般检测全部区域再筛选更好。 + (1)由于特定文字和非特定文字之间的视觉特征并没有很强的区分行,只检测指定区域,容易造成特定文字漏检。 + (2)产品的需求可能是变化的,不排除后续对于模型需求变化的可能性(比如又需要增加一个字段),相比于训练模型,后处理的逻辑会更容易调整。 #### Q2.4.4:对于小白如何快速入门中文OCR项目实践? @@ -203,7 +203,9 @@ #### Q2.4.5:如何识别带空格的英文行文本图像? **A**:空格识别可以考虑以下两种方案: + (1)优化文本检测算法。检测结果在空格处将文本断开。这种方案在检测数据标注时,需要将含有空格的文本行分成好多段。 + (2)优化文本识别算法。在识别字典里面引入空格字符,然后在识别的训练数据中,如果用空行,进行标注。此外,合成数据时,通过拼接训练数据,生成含有空格的文本。 #### Q2.4.6:中英文一起识别时也可以加空格字符来训练吗 @@ -212,7 +214,7 @@ #### Q2.4.7:低像素文字或者字号比较小的文字有什么超分辨率方法吗 -**A**:超分辨率方法分为传统方法和基于深度学习的方法。基于深度学习的方法中,比较经典的有SRCNN,另外CVPR2020也有一篇超分辨率的工作可以参考:Unpaired Image Super-Resolution using Pseudo-Supervision,但是没有充分的实践验证过,需要看实际场景下的效果。 +**A**:超分辨率方法分为传统方法和基于深度学习的方法。基于深度学习的方法中,比较经典的有SRCNN,另外CVPR2020也有一篇超分辨率的工作可以参考文章:Unpaired Image Super-Resolution using Pseudo-Supervision,但是没有充分的实践验证过,需要看实际场景下的效果。 #### Q2.4.8:表格识别有什么好的模型 或者论文推荐么 @@ -286,7 +288,11 @@ #### Q3.1.16:PaddleOCR是否支持在Windows或Mac系统上运行? -**A**:PaddleOCR已完成Windows和Mac系统适配,运行时注意两点:1、在[快速安装](./installation.md)时,如果不想安装docker,可跳过第一步,直接从第二步安装paddle开始。2、inference模型下载时,如果没有安装wget,可直接点击模型链接或将链接地址复制到浏览器进行下载,并解压放置到相应目录。 +**A**:PaddleOCR已完成Windows和Mac系统适配,运行时注意两点: + +(1)在[快速安装](./installation.md)时,如果不想安装docker,可跳过第一步,直接从第二步安装paddle开始。 + +(2)inference模型下载时,如果没有安装wget,可直接点击模型链接或将链接地址复制到浏览器进行下载,并解压放置到相应目录。 #### Q3.1.17:PaddleOCR开源的超轻量模型和通用OCR模型的区别? **A**:目前PaddleOCR开源了2个中文模型,分别是8.6M超轻量中文模型和通用中文OCR模型。两者对比信息如下: @@ -352,8 +358,7 @@ **A**:可以主要参考可视化效果,通用模型更倾向于检测一整行文字,轻量级可能会有一行文字被分成两段检测的情况,不是数量越多,效果就越好。 -### 模型训练 -调优 +### 模型训练调优 #### Q3.3.1:文本长度超过25,应该怎么处理? @@ -379,7 +384,6 @@ unclip_ratio: 文本框扩张的系数,关系到文本框的大小`` ``` ps -axu | grep train.py | awk '{print $2}' | xargs kill -9 - ``` #### Q3.3.5:读数据进程数设置4~8时训练一会进程接连defunct后gpu利用率一直为0卡死 @@ -397,7 +401,7 @@ return paddle.reader.multiprocess_reader(readers, False, queue_size=320) #### Q3.3.7:PaddleOCR默认不是200个step保存一次模型吗?为啥文件夹下面都没有生成 -**A**:eval_batch_step [4000, 5000]改为[0, 5000] 就是从第0次迭代开始,每5000迭代保存一次模型 +**A**:因为默认保存的起始点不是0,而是4000,将eval_batch_step [4000, 5000]改为[0, 2000] 就是从第0次迭代开始,每2000迭代保存一次模型 #### Q3.3.8:如何进行模型微调? @@ -414,29 +418,33 @@ return paddle.reader.multiprocess_reader(readers, False, queue_size=320) #### Q3.3.11:自己训练出来的未inference转换的模型 可以当作预训练模型吗? **A**:可以的,但是如果训练数据两量少的话,可能会过拟合到少量数据上,泛化性能不佳。 + #### Q3.3.12:使用带TPS的识别模型预测报错 **A**:直接更换配置文件里的Backbone.function即可,格式为:网络文件路径,网络Class名词。如果所需的backbone在PaddleOCR里没有提供,可以参照PaddleClas里面的网络结构,进行修改尝试。具体修改原则可以参考OCR通用问题中 "如何更换文本检测/识别的backbone" 的回答。 -#### Q3.3.13:如何更换文本检测/识别的backbone?报错信息:'''Input(X) dims[3] and Input(Grid) dims[2] should be equal, but received X dimension[3](320) != Grid dimension[2](100) -**A**:TPS模块暂时无法支持变长的输入,请设置 --rec_image_shape='3,32,100' --rec_char_type='en' 固定输入shape +#### Q3.3.13:如何更换文本检测/识别的backbone?报错信息:``Input(X) dims[3] and Input(Grid) dims[2] should be equal, but received X dimension[3](320) != Grid dimension[2](100) `` + +**A**:TPS模块暂时无法支持变长的输入,请设置 ``--rec_image_shape='3,32,100' --rec_char_type='en' 固定输入shape`` ### 预测部署 #### Q3.4.1:如何pip安装opt模型转换工具? -**A**:由于OCR端侧部署需要某些算子的支持,这些算子仅在Paddle-Lite 最新develop分支中,所以需要自己编译opt模型转换工具。opt工具可以通过编译PaddleLite获得,编译步骤参考:https://github.com/PaddlePaddle/PaddleOCR/blob/0791714b91/deploy/lite/readme.md 中2.1 模型优化部分。 +**A**:由于OCR端侧部署需要某些算子的支持,这些算子仅在Paddle-Lite 最新develop分支中,所以需要自己编译opt模型转换工具。opt工具可以通过编译PaddleLite获得,编译步骤参考[lite部署文档](https://github.com/PaddlePaddle/PaddleOCR/blob/0791714b91/deploy/lite/readme.md) 中2.1 模型优化部分。 #### Q3.4.2:如何将PaddleOCR预测模型封装成SDK **A**:如果是Python的话,可以使用tools/infer/predict_system.py中的TextSystem进行sdk封装,如果是c++的话,可以使用deploy/cpp_infer/src下面的DBDetector和CRNNRecognizer完成封装 -#### Q3.4.3:服务部署可以只发布 文本识别模型么?(不带文本检测模型) +#### Q3.4.3:服务部署可以只发布文本识别,而不带文本检测模型么? **A**:可以的。默认的服务部署是检测和识别串联预测的。也支持单独发布文本检测或文本识别模型,比如使用PaddleHUBPaddleOCR 模型时,deploy下有三个文件夹,分别是 -ocr_det:检测预测 -ocr_rec: 识别预测 -ocr_system: 检测识别串联预测 + +- ocr_det:检测预测 +- ocr_rec: 识别预测 +- ocr_system: 检测识别串联预测 + 每个模块是单独分开的,所以可以选择只发布文本识别模型。使用PaddleServing部署时同理。 @@ -444,14 +452,14 @@ ocr_system: 检测识别串联预测 **A**:测试的时候,对图像等比例缩放,最长边960,不同图像等比例缩放后长宽不一致,无法组成batch,所以设置为test_batch_size为1。 -#### Q3.4.5:为什么使用c++ inference和py inference结果不一致 +#### Q3.4.5:为什么使用c++ inference和python inference结果不一致? **A**:可能是导出的inference model版本与预测库版本需要保持一致,比如在Windows下,Paddle官网提供的预测库版本是1.8,而PaddleOCR提供的inference model 版本是1.7,因此最终预测结果会有差别。可以在Paddle1.8环境下导出模型,再基于该模型进行预测。 此外也需要保证两者的预测参数配置完全一致。 #### Q3.4.6:为什么第一张张图预测时间很长,第二张之后预测时间会降低? -**A**:第一张图需要初始化,耗时较多。完成模型加载后,之后的预测时间很短。 +**A**:第一张图需要显存资源初始化,耗时较多。完成模型加载后,之后的预测时间会明显缩短。 #### Q3.4.7:请问opt工具可以直接转int8量化后的模型为.nb文件吗 @@ -463,7 +471,7 @@ ocr_system: 检测识别串联预测 #### Q3.4.9:PaddleOCR模型是否可以转换成ONNX模型? -**A**:目前不支持转ONNX +**A**:目前暂不支持转ONNX,相关工作在研发中。 #### Q3.4.10:使用opt工具对检测模型转换时报错 can not found op arguments for node conv2_b_attr From 1faec73faddc4de9da12a6ef4d8ab9df4f3c666f Mon Sep 17 00:00:00 2001 From: dyning Date: Wed, 26 Aug 2020 21:38:29 +0800 Subject: [PATCH 34/42] Update README.md --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index c828163f..3243f3ce 100644 --- a/README.md +++ b/README.md @@ -4,7 +4,7 @@ PaddleOCR旨在打造一套丰富、领先、且实用的OCR工具库,助力使用者训练出更好的模型,并应用落地。 **近期更新** -- 2020.8.26 更新OCR相关的85个常见问题及解答,具体参考[FAQ](./doc/doc_ch/FAQ.md) +- 2020.8.26 更新OCR相关的84个常见问题及解答,具体参考[FAQ](./doc/doc_ch/FAQ.md) - 2020.8.24 支持通过whl包安装使用PaddleOCR,具体参考[Paddleocr Package使用说明](./doc/doc_ch/whl.md) - 2020.8.21 更新8月18日B站直播课回放和PPT,课节2,易学易用的OCR工具大礼包,[获取地址](https://aistudio.baidu.com/aistudio/education/group/info/1519) - 2020.8.16 开源文本检测算法[SAST](https://arxiv.org/abs/1908.05498)和文本识别算法[SRN](https://arxiv.org/abs/2003.12294) From 0d4ccd456ba52068fada7a4116a8f818452ff63b Mon Sep 17 00:00:00 2001 From: dyning Date: Thu, 27 Aug 2020 09:56:00 +0800 Subject: [PATCH 35/42] Update FAQ.md --- doc/doc_ch/FAQ.md | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/doc/doc_ch/FAQ.md b/doc/doc_ch/FAQ.md index fe36c44e..f782a164 100644 --- a/doc/doc_ch/FAQ.md +++ b/doc/doc_ch/FAQ.md @@ -71,8 +71,9 @@ 字符识别准确率,即正确识别的文本行占标注的文本行数量的比例,只有整行文本识别对才算正确识别。 (3)端到端统计: -端对端准确率:准确检测并正确识别文本行在全部标注文本行的占比; -端到端召回率:准确检测并正确识别文本行在 检测到的文本行数量 的占比;准确检测的标准是检测框与标注框的IOU大于某个阈值,正确识别的的检测框中的文本与标注的文本相同。 +端对端召回率:准确检测并正确识别文本行在全部标注文本行的占比; +端到端准确率:准确检测并正确识别文本行在 检测到的文本行数量 的占比; +准确检测的标准是检测框与标注框的IOU大于某个阈值,正确识别的的检测框中的文本与标注的文本相同。 #### Q1.1.7:单张图上多语种并存识别(如单张图印刷体和手写文字并存),应该如何处理? From 1147bd3a81ba79a413fcd1357d67f4cbecbed89f Mon Sep 17 00:00:00 2001 From: WenmuZhou Date: Thu, 27 Aug 2020 15:10:41 +0800 Subject: [PATCH 36/42] =?UTF-8?q?=E6=B7=BB=E5=8A=A0use=5Fzero=5Fcopy=5Frun?= =?UTF-8?q?=E5=8F=82=E6=95=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- paddleocr.py | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/paddleocr.py b/paddleocr.py index 65bca7ae..d3d73cb1 100644 --- a/paddleocr.py +++ b/paddleocr.py @@ -129,6 +129,7 @@ def parse_args(): parser.add_argument("--det", type=str2bool, default=True) parser.add_argument("--rec", type=str2bool, default=True) + parser.add_argument("--use_zero_copy_run", type=bool, default=False) return parser.parse_args() @@ -209,4 +210,4 @@ def main(): print(img_path) result = ocr_engine.ocr(img_path, det=args.det, rec=args.rec) for line in result: - print(line) + print(line) \ No newline at end of file From 725b17a11176f1cecb5c2d05623778e45fd45973 Mon Sep 17 00:00:00 2001 From: grasswolfs Date: Tue, 1 Sep 2020 14:31:43 +0800 Subject: [PATCH 37/42] test=develop, test=document_fix --- README.md | 2 +- doc/joinus.PNG | Bin 0 -> 16090 bytes doc/joinus.jpg | Bin 30114 -> 0 bytes 3 files changed, 1 insertion(+), 1 deletion(-) create mode 100644 doc/joinus.PNG delete mode 100644 doc/joinus.jpg diff --git a/README.md b/README.md index 3243f3ce..9520152b 100644 --- a/README.md +++ b/README.md @@ -189,7 +189,7 @@ PaddleOCR文本识别算法的训练和使用请参考文档教程中[模型训 请扫描下面二维码,完成问卷填写,获取加群二维码和OCR方向的炼丹秘籍
- +
diff --git a/doc/joinus.PNG b/doc/joinus.PNG new file mode 100644 index 0000000000000000000000000000000000000000..fa11f286d7d2d56d18d94e9034c3be77c974d42f GIT binary patch literal 16090 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 X*uSf{|L@=bz4YS$Z)-&4e))d@K$vES From e33026f38ab88dd773c50294ba577c0ecf9fb8d8 Mon Sep 17 00:00:00 2001 From: dyning Date: Tue, 1 Sep 2020 14:44:56 +0800 Subject: [PATCH 38/42] Update README.md --- README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README.md b/README.md index 9520152b..4ebbf2f0 100644 --- a/README.md +++ b/README.md @@ -189,7 +189,7 @@ PaddleOCR文本识别算法的训练和使用请参考文档教程中[模型训 请扫描下面二维码,完成问卷填写,获取加群二维码和OCR方向的炼丹秘籍
- +
From c75ad203e909c95965532e37b007c15df716d00d Mon Sep 17 00:00:00 2001 From: dyning Date: Tue, 1 Sep 2020 14:45:31 +0800 Subject: [PATCH 39/42] Update README_en.md --- README_en.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/README_en.md b/README_en.md index 37250da2..362cbb5f 100644 --- a/README_en.md +++ b/README_en.md @@ -211,7 +211,7 @@ Please refer to the document for training guide and use of PaddleOCR text recogn Scan the QR code below with your wechat and completing the questionnaire, you can access to offical technical exchange group.
- +
From f76ef16e9f8bdd0af8782225b08d2c64eb37e01a Mon Sep 17 00:00:00 2001 From: LiXiaYu Date: Tue, 1 Sep 2020 22:55:11 +0800 Subject: [PATCH 40/42] Update serving.md Added model installation method --- doc/doc_ch/serving.md | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/doc/doc_ch/serving.md b/doc/doc_ch/serving.md index 89274567..99fe3006 100644 --- a/doc/doc_ch/serving.md +++ b/doc/doc_ch/serving.md @@ -61,6 +61,14 @@ hub install deploy\hubserving\ocr_rec\ hub install deploy\hubserving\ocr_system\ ``` +#### 安装模型 +安装服务模块前,需要将训练好的模型放到对应的文件夹内。默认使用的是: +./inference/ch_det_mv3_db/ +和 +./inference/ch_rec_mv3_crnn/ +这两个模型可以在https://github.com/PaddlePaddle/PaddleOCR 下载 +可以在./deploy/hubserving/ocr_system/params.py 里面修改成自己的模型 + ### 3. 启动服务 #### 方式1. 命令行命令启动(仅支持CPU) **启动命令:** From 3ebf46dae686d6b10a84ebd6faa8cf9335b1341d Mon Sep 17 00:00:00 2001 From: dyning Date: Wed, 2 Sep 2020 10:05:04 +0800 Subject: [PATCH 41/42] Update README_en.md --- README_en.md | 5 ----- 1 file changed, 5 deletions(-) diff --git a/README_en.md b/README_en.md index 362cbb5f..c0f17b57 100644 --- a/README_en.md +++ b/README_en.md @@ -56,7 +56,6 @@ Mobile DEMO experience (based on EasyEdge and Paddle-Lite, supports iOS and Andr - Algorithm introduction - [Text Detection Algorithm](#TEXTDETECTIONALGORITHM) - [Text Recognition Algorithm](#TEXTRECOGNITIONALGORITHM) - - [END-TO-END OCR Algorithm](#ENDENDOCRALGORITHM) - Model training/evaluation - [Text Detection](./doc/doc_en/detection_en.md) - [Text Recognition](./doc/doc_en/recognition_en.md) @@ -158,10 +157,6 @@ We use [LSVT](https://github.com/PaddlePaddle/PaddleOCR/blob/develop/doc/doc_en/ Please refer to the document for training guide and use of PaddleOCR text recognition algorithms [Text recognition model training/evaluation/prediction](./doc/doc_en/recognition_en.md) - -## END-TO-END OCR Algorithm -- [ ] [End2End-PSL](https://arxiv.org/abs/1909.07808)(Baidu Self-Research, coming soon) - ## Visualization From 7165f5899d27d1122f760d2a48eab48d9c81b5ee Mon Sep 17 00:00:00 2001 From: littletomatodonkey Date: Thu, 3 Sep 2020 04:50:40 +0000 Subject: [PATCH 42/42] rm duplicate readme --- docker/hubserving/readme.md | 58 ------------------------------------- 1 file changed, 58 deletions(-) delete mode 100644 docker/hubserving/readme.md diff --git a/docker/hubserving/readme.md b/docker/hubserving/readme.md deleted file mode 100644 index 71e2377d..00000000 --- a/docker/hubserving/readme.md +++ /dev/null @@ -1,58 +0,0 @@ -English | [简体中文](README_cn.md) - -## Introduction -Many user hopes package the PaddleOCR service into an docker image, so that it can be quickly released and used in the docker or k8s environment. - -This page provide some standardized code to achieve this goal. You can quickly publish the PaddleOCR project into a callable Restful API service through the following steps. (At present, the deployment based on the HubServing mode is implemented first, and author plans to increase the deployment of the PaddleServing mode in the futrue) - -## 1. Prerequisites - -You need to install the following basic components first: -a. Docker -b. Graphics driver and CUDA 10.0+(GPU) -c. NVIDIA Container Toolkit(GPU,Docker 19.03+ can skip this) -d. cuDNN 7.6+(GPU) - -## 2. Build Image -a. Download PaddleOCR sourcecode -``` -git clone https://github.com/PaddlePaddle/PaddleOCR.git -``` -b. Goto Dockerfile directory(ps:Need to distinguish between cpu and gpu version, the following takes cpu as an example, gpu version needs to replace the keyword) -``` -cd docker/cpu -``` -c. Build image -``` -docker build -t paddleocr:cpu . -``` - -## 3. Start container -a. CPU version -``` -sudo docker run -dp 8866:8866 --name paddle_ocr paddleocr:cpu -``` -b. GPU version (base on NVIDIA Container Toolkit) -``` -sudo nvidia-docker run -dp 8866:8866 --name paddle_ocr paddleocr:gpu -``` -c. GPU version (Docker 19.03++) -``` -sudo docker run -dp 8866:8866 --gpus all --name paddle_ocr paddleocr:gpu -``` -d. Check service status(If you can see the following statement then it means completed:Successfully installed ocr_system && Running on http://0.0.0.0:8866/) -``` -docker logs -f paddle_ocr -``` - -## 4. Test -a. Calculate the Base64 encoding of the picture to be recognized (if you just test, you can use a free online tool, like:https://freeonlinetools24.com/base64-image/) -b. Post a service request(sample request in sample_request.txt) - -``` -curl -H "Content-Type:application/json" -X POST --data "{\"images\": [\"Input image Base64 encode(need to delete the code 'data:image/jpg;base64,')\"]}" http://localhost:8866/predict/ocr_system -``` -c. Get resposne(If the call is successful, the following result will be returned) -``` -{"msg":"","results":[[{"confidence":0.8403433561325073,"text":"约定","text_region":[[345,377],[641,390],[634,540],[339,528]]},{"confidence":0.8131805658340454,"text":"最终相遇","text_region":[[356,532],[624,530],[624,596],[356,598]]}]],"status":"0"} -```