pyxllib 0.3.96__py3-none-any.whl → 0.3.197__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- pyxllib/algo/geo.py +12 -0
- pyxllib/algo/intervals.py +1 -1
- pyxllib/algo/matcher.py +78 -0
- pyxllib/algo/pupil.py +187 -19
- pyxllib/algo/specialist.py +2 -1
- pyxllib/algo/stat.py +38 -2
- {pyxlpr → pyxllib/autogui}/__init__.py +1 -1
- pyxllib/autogui/activewin.py +246 -0
- pyxllib/autogui/all.py +9 -0
- pyxllib/{ext/autogui → autogui}/autogui.py +40 -11
- pyxllib/autogui/uiautolib.py +362 -0
- pyxllib/autogui/wechat.py +827 -0
- pyxllib/autogui/wechat_msg.py +421 -0
- pyxllib/autogui/wxautolib.py +84 -0
- pyxllib/cv/slidercaptcha.py +137 -0
- pyxllib/data/echarts.py +123 -12
- pyxllib/data/jsonlib.py +89 -0
- pyxllib/data/pglib.py +514 -30
- pyxllib/data/sqlite.py +231 -4
- pyxllib/ext/JLineViewer.py +14 -1
- pyxllib/ext/drissionlib.py +277 -0
- pyxllib/ext/kq5034lib.py +0 -1594
- pyxllib/ext/robustprocfile.py +497 -0
- pyxllib/ext/unixlib.py +6 -5
- pyxllib/ext/utools.py +108 -95
- pyxllib/ext/webhook.py +32 -14
- pyxllib/ext/wjxlib.py +88 -0
- pyxllib/ext/wpsapi.py +124 -0
- pyxllib/ext/xlwork.py +9 -0
- pyxllib/ext/yuquelib.py +1003 -71
- pyxllib/file/docxlib.py +1 -1
- pyxllib/file/libreoffice.py +165 -0
- pyxllib/file/movielib.py +9 -0
- pyxllib/file/packlib/__init__.py +112 -75
- pyxllib/file/pdflib.py +1 -1
- pyxllib/file/pupil.py +1 -1
- pyxllib/file/specialist/dirlib.py +1 -1
- pyxllib/file/specialist/download.py +10 -3
- pyxllib/file/specialist/filelib.py +266 -55
- pyxllib/file/xlsxlib.py +205 -50
- pyxllib/file/xlsyncfile.py +341 -0
- pyxllib/prog/cachetools.py +64 -0
- pyxllib/prog/filelock.py +42 -0
- pyxllib/prog/multiprogs.py +940 -0
- pyxllib/prog/newbie.py +9 -2
- pyxllib/prog/pupil.py +129 -60
- pyxllib/prog/specialist/__init__.py +176 -2
- pyxllib/prog/specialist/bc.py +5 -2
- pyxllib/prog/specialist/browser.py +11 -2
- pyxllib/prog/specialist/datetime.py +68 -0
- pyxllib/prog/specialist/tictoc.py +12 -13
- pyxllib/prog/specialist/xllog.py +5 -5
- pyxllib/prog/xlosenv.py +7 -0
- pyxllib/text/airscript.js +744 -0
- pyxllib/text/charclasslib.py +17 -5
- pyxllib/text/jiebalib.py +6 -3
- pyxllib/text/jinjalib.py +32 -0
- pyxllib/text/jsa_ai_prompt.md +271 -0
- pyxllib/text/jscode.py +159 -4
- pyxllib/text/nestenv.py +1 -1
- pyxllib/text/newbie.py +12 -0
- pyxllib/text/pupil/common.py +26 -0
- pyxllib/text/specialist/ptag.py +2 -2
- pyxllib/text/templates/echart_base.html +11 -0
- pyxllib/text/templates/highlight_code.html +17 -0
- pyxllib/text/templates/latex_editor.html +103 -0
- pyxllib/text/xmllib.py +76 -14
- pyxllib/xl.py +2 -1
- pyxllib-0.3.197.dist-info/METADATA +48 -0
- pyxllib-0.3.197.dist-info/RECORD +126 -0
- {pyxllib-0.3.96.dist-info → pyxllib-0.3.197.dist-info}/WHEEL +1 -2
- pyxllib/ext/autogui/__init__.py +0 -8
- pyxllib-0.3.96.dist-info/METADATA +0 -51
- pyxllib-0.3.96.dist-info/RECORD +0 -333
- pyxllib-0.3.96.dist-info/top_level.txt +0 -2
- pyxlpr/ai/__init__.py +0 -5
- pyxlpr/ai/clientlib.py +0 -1281
- pyxlpr/ai/specialist.py +0 -286
- pyxlpr/ai/torch_app.py +0 -172
- pyxlpr/ai/xlpaddle.py +0 -655
- pyxlpr/ai/xltorch.py +0 -705
- pyxlpr/data/__init__.py +0 -11
- pyxlpr/data/coco.py +0 -1325
- pyxlpr/data/datacls.py +0 -365
- pyxlpr/data/datasets.py +0 -200
- pyxlpr/data/gptlib.py +0 -1291
- pyxlpr/data/icdar/__init__.py +0 -96
- pyxlpr/data/icdar/deteval.py +0 -377
- pyxlpr/data/icdar/icdar2013.py +0 -341
- pyxlpr/data/icdar/iou.py +0 -340
- pyxlpr/data/icdar/rrc_evaluation_funcs_1_1.py +0 -463
- pyxlpr/data/imtextline.py +0 -473
- pyxlpr/data/labelme.py +0 -866
- pyxlpr/data/removeline.py +0 -179
- pyxlpr/data/specialist.py +0 -57
- pyxlpr/eval/__init__.py +0 -85
- pyxlpr/paddleocr.py +0 -776
- pyxlpr/ppocr/__init__.py +0 -15
- pyxlpr/ppocr/configs/rec/multi_language/generate_multi_language_configs.py +0 -226
- pyxlpr/ppocr/data/__init__.py +0 -135
- pyxlpr/ppocr/data/imaug/ColorJitter.py +0 -26
- pyxlpr/ppocr/data/imaug/__init__.py +0 -67
- pyxlpr/ppocr/data/imaug/copy_paste.py +0 -170
- pyxlpr/ppocr/data/imaug/east_process.py +0 -437
- pyxlpr/ppocr/data/imaug/gen_table_mask.py +0 -244
- pyxlpr/ppocr/data/imaug/iaa_augment.py +0 -114
- pyxlpr/ppocr/data/imaug/label_ops.py +0 -789
- pyxlpr/ppocr/data/imaug/make_border_map.py +0 -184
- pyxlpr/ppocr/data/imaug/make_pse_gt.py +0 -106
- pyxlpr/ppocr/data/imaug/make_shrink_map.py +0 -126
- pyxlpr/ppocr/data/imaug/operators.py +0 -433
- pyxlpr/ppocr/data/imaug/pg_process.py +0 -906
- pyxlpr/ppocr/data/imaug/randaugment.py +0 -143
- pyxlpr/ppocr/data/imaug/random_crop_data.py +0 -239
- pyxlpr/ppocr/data/imaug/rec_img_aug.py +0 -533
- pyxlpr/ppocr/data/imaug/sast_process.py +0 -777
- pyxlpr/ppocr/data/imaug/text_image_aug/__init__.py +0 -17
- pyxlpr/ppocr/data/imaug/text_image_aug/augment.py +0 -120
- pyxlpr/ppocr/data/imaug/text_image_aug/warp_mls.py +0 -168
- pyxlpr/ppocr/data/lmdb_dataset.py +0 -115
- pyxlpr/ppocr/data/pgnet_dataset.py +0 -104
- pyxlpr/ppocr/data/pubtab_dataset.py +0 -107
- pyxlpr/ppocr/data/simple_dataset.py +0 -372
- pyxlpr/ppocr/losses/__init__.py +0 -61
- pyxlpr/ppocr/losses/ace_loss.py +0 -52
- pyxlpr/ppocr/losses/basic_loss.py +0 -135
- pyxlpr/ppocr/losses/center_loss.py +0 -88
- pyxlpr/ppocr/losses/cls_loss.py +0 -30
- pyxlpr/ppocr/losses/combined_loss.py +0 -67
- pyxlpr/ppocr/losses/det_basic_loss.py +0 -208
- pyxlpr/ppocr/losses/det_db_loss.py +0 -80
- pyxlpr/ppocr/losses/det_east_loss.py +0 -63
- pyxlpr/ppocr/losses/det_pse_loss.py +0 -149
- pyxlpr/ppocr/losses/det_sast_loss.py +0 -121
- pyxlpr/ppocr/losses/distillation_loss.py +0 -272
- pyxlpr/ppocr/losses/e2e_pg_loss.py +0 -140
- pyxlpr/ppocr/losses/kie_sdmgr_loss.py +0 -113
- pyxlpr/ppocr/losses/rec_aster_loss.py +0 -99
- pyxlpr/ppocr/losses/rec_att_loss.py +0 -39
- pyxlpr/ppocr/losses/rec_ctc_loss.py +0 -44
- pyxlpr/ppocr/losses/rec_enhanced_ctc_loss.py +0 -70
- pyxlpr/ppocr/losses/rec_nrtr_loss.py +0 -30
- pyxlpr/ppocr/losses/rec_sar_loss.py +0 -28
- pyxlpr/ppocr/losses/rec_srn_loss.py +0 -47
- pyxlpr/ppocr/losses/table_att_loss.py +0 -109
- pyxlpr/ppocr/metrics/__init__.py +0 -44
- pyxlpr/ppocr/metrics/cls_metric.py +0 -45
- pyxlpr/ppocr/metrics/det_metric.py +0 -82
- pyxlpr/ppocr/metrics/distillation_metric.py +0 -73
- pyxlpr/ppocr/metrics/e2e_metric.py +0 -86
- pyxlpr/ppocr/metrics/eval_det_iou.py +0 -274
- pyxlpr/ppocr/metrics/kie_metric.py +0 -70
- pyxlpr/ppocr/metrics/rec_metric.py +0 -75
- pyxlpr/ppocr/metrics/table_metric.py +0 -50
- pyxlpr/ppocr/modeling/architectures/__init__.py +0 -32
- pyxlpr/ppocr/modeling/architectures/base_model.py +0 -88
- pyxlpr/ppocr/modeling/architectures/distillation_model.py +0 -60
- pyxlpr/ppocr/modeling/backbones/__init__.py +0 -54
- pyxlpr/ppocr/modeling/backbones/det_mobilenet_v3.py +0 -268
- pyxlpr/ppocr/modeling/backbones/det_resnet_vd.py +0 -246
- pyxlpr/ppocr/modeling/backbones/det_resnet_vd_sast.py +0 -285
- pyxlpr/ppocr/modeling/backbones/e2e_resnet_vd_pg.py +0 -265
- pyxlpr/ppocr/modeling/backbones/kie_unet_sdmgr.py +0 -186
- pyxlpr/ppocr/modeling/backbones/rec_mobilenet_v3.py +0 -138
- pyxlpr/ppocr/modeling/backbones/rec_mv1_enhance.py +0 -258
- pyxlpr/ppocr/modeling/backbones/rec_nrtr_mtb.py +0 -48
- pyxlpr/ppocr/modeling/backbones/rec_resnet_31.py +0 -210
- pyxlpr/ppocr/modeling/backbones/rec_resnet_aster.py +0 -143
- pyxlpr/ppocr/modeling/backbones/rec_resnet_fpn.py +0 -307
- pyxlpr/ppocr/modeling/backbones/rec_resnet_vd.py +0 -286
- pyxlpr/ppocr/modeling/heads/__init__.py +0 -54
- pyxlpr/ppocr/modeling/heads/cls_head.py +0 -52
- pyxlpr/ppocr/modeling/heads/det_db_head.py +0 -118
- pyxlpr/ppocr/modeling/heads/det_east_head.py +0 -121
- pyxlpr/ppocr/modeling/heads/det_pse_head.py +0 -37
- pyxlpr/ppocr/modeling/heads/det_sast_head.py +0 -128
- pyxlpr/ppocr/modeling/heads/e2e_pg_head.py +0 -253
- pyxlpr/ppocr/modeling/heads/kie_sdmgr_head.py +0 -206
- pyxlpr/ppocr/modeling/heads/multiheadAttention.py +0 -163
- pyxlpr/ppocr/modeling/heads/rec_aster_head.py +0 -393
- pyxlpr/ppocr/modeling/heads/rec_att_head.py +0 -202
- pyxlpr/ppocr/modeling/heads/rec_ctc_head.py +0 -88
- pyxlpr/ppocr/modeling/heads/rec_nrtr_head.py +0 -826
- pyxlpr/ppocr/modeling/heads/rec_sar_head.py +0 -402
- pyxlpr/ppocr/modeling/heads/rec_srn_head.py +0 -280
- pyxlpr/ppocr/modeling/heads/self_attention.py +0 -406
- pyxlpr/ppocr/modeling/heads/table_att_head.py +0 -246
- pyxlpr/ppocr/modeling/necks/__init__.py +0 -32
- pyxlpr/ppocr/modeling/necks/db_fpn.py +0 -111
- pyxlpr/ppocr/modeling/necks/east_fpn.py +0 -188
- pyxlpr/ppocr/modeling/necks/fpn.py +0 -138
- pyxlpr/ppocr/modeling/necks/pg_fpn.py +0 -314
- pyxlpr/ppocr/modeling/necks/rnn.py +0 -92
- pyxlpr/ppocr/modeling/necks/sast_fpn.py +0 -284
- pyxlpr/ppocr/modeling/necks/table_fpn.py +0 -110
- pyxlpr/ppocr/modeling/transforms/__init__.py +0 -28
- pyxlpr/ppocr/modeling/transforms/stn.py +0 -135
- pyxlpr/ppocr/modeling/transforms/tps.py +0 -308
- pyxlpr/ppocr/modeling/transforms/tps_spatial_transformer.py +0 -156
- pyxlpr/ppocr/optimizer/__init__.py +0 -61
- pyxlpr/ppocr/optimizer/learning_rate.py +0 -228
- pyxlpr/ppocr/optimizer/lr_scheduler.py +0 -49
- pyxlpr/ppocr/optimizer/optimizer.py +0 -160
- pyxlpr/ppocr/optimizer/regularizer.py +0 -52
- pyxlpr/ppocr/postprocess/__init__.py +0 -55
- pyxlpr/ppocr/postprocess/cls_postprocess.py +0 -33
- pyxlpr/ppocr/postprocess/db_postprocess.py +0 -234
- pyxlpr/ppocr/postprocess/east_postprocess.py +0 -143
- pyxlpr/ppocr/postprocess/locality_aware_nms.py +0 -200
- pyxlpr/ppocr/postprocess/pg_postprocess.py +0 -52
- pyxlpr/ppocr/postprocess/pse_postprocess/__init__.py +0 -15
- pyxlpr/ppocr/postprocess/pse_postprocess/pse/__init__.py +0 -29
- pyxlpr/ppocr/postprocess/pse_postprocess/pse/setup.py +0 -14
- pyxlpr/ppocr/postprocess/pse_postprocess/pse_postprocess.py +0 -118
- pyxlpr/ppocr/postprocess/rec_postprocess.py +0 -654
- pyxlpr/ppocr/postprocess/sast_postprocess.py +0 -355
- pyxlpr/ppocr/tools/__init__.py +0 -14
- pyxlpr/ppocr/tools/eval.py +0 -83
- pyxlpr/ppocr/tools/export_center.py +0 -77
- pyxlpr/ppocr/tools/export_model.py +0 -129
- pyxlpr/ppocr/tools/infer/predict_cls.py +0 -151
- pyxlpr/ppocr/tools/infer/predict_det.py +0 -300
- pyxlpr/ppocr/tools/infer/predict_e2e.py +0 -169
- pyxlpr/ppocr/tools/infer/predict_rec.py +0 -414
- pyxlpr/ppocr/tools/infer/predict_system.py +0 -204
- pyxlpr/ppocr/tools/infer/utility.py +0 -629
- pyxlpr/ppocr/tools/infer_cls.py +0 -83
- pyxlpr/ppocr/tools/infer_det.py +0 -134
- pyxlpr/ppocr/tools/infer_e2e.py +0 -122
- pyxlpr/ppocr/tools/infer_kie.py +0 -153
- pyxlpr/ppocr/tools/infer_rec.py +0 -146
- pyxlpr/ppocr/tools/infer_table.py +0 -107
- pyxlpr/ppocr/tools/program.py +0 -596
- pyxlpr/ppocr/tools/test_hubserving.py +0 -117
- pyxlpr/ppocr/tools/train.py +0 -163
- pyxlpr/ppocr/tools/xlprog.py +0 -748
- pyxlpr/ppocr/utils/EN_symbol_dict.txt +0 -94
- pyxlpr/ppocr/utils/__init__.py +0 -24
- pyxlpr/ppocr/utils/dict/ar_dict.txt +0 -117
- pyxlpr/ppocr/utils/dict/arabic_dict.txt +0 -162
- pyxlpr/ppocr/utils/dict/be_dict.txt +0 -145
- pyxlpr/ppocr/utils/dict/bg_dict.txt +0 -140
- pyxlpr/ppocr/utils/dict/chinese_cht_dict.txt +0 -8421
- pyxlpr/ppocr/utils/dict/cyrillic_dict.txt +0 -163
- pyxlpr/ppocr/utils/dict/devanagari_dict.txt +0 -167
- pyxlpr/ppocr/utils/dict/en_dict.txt +0 -63
- pyxlpr/ppocr/utils/dict/fa_dict.txt +0 -136
- pyxlpr/ppocr/utils/dict/french_dict.txt +0 -136
- pyxlpr/ppocr/utils/dict/german_dict.txt +0 -143
- pyxlpr/ppocr/utils/dict/hi_dict.txt +0 -162
- pyxlpr/ppocr/utils/dict/it_dict.txt +0 -118
- pyxlpr/ppocr/utils/dict/japan_dict.txt +0 -4399
- pyxlpr/ppocr/utils/dict/ka_dict.txt +0 -153
- pyxlpr/ppocr/utils/dict/korean_dict.txt +0 -3688
- pyxlpr/ppocr/utils/dict/latin_dict.txt +0 -185
- pyxlpr/ppocr/utils/dict/mr_dict.txt +0 -153
- pyxlpr/ppocr/utils/dict/ne_dict.txt +0 -153
- pyxlpr/ppocr/utils/dict/oc_dict.txt +0 -96
- pyxlpr/ppocr/utils/dict/pu_dict.txt +0 -130
- pyxlpr/ppocr/utils/dict/rs_dict.txt +0 -91
- pyxlpr/ppocr/utils/dict/rsc_dict.txt +0 -134
- pyxlpr/ppocr/utils/dict/ru_dict.txt +0 -125
- pyxlpr/ppocr/utils/dict/ta_dict.txt +0 -128
- pyxlpr/ppocr/utils/dict/table_dict.txt +0 -277
- pyxlpr/ppocr/utils/dict/table_structure_dict.txt +0 -2759
- pyxlpr/ppocr/utils/dict/te_dict.txt +0 -151
- pyxlpr/ppocr/utils/dict/ug_dict.txt +0 -114
- pyxlpr/ppocr/utils/dict/uk_dict.txt +0 -142
- pyxlpr/ppocr/utils/dict/ur_dict.txt +0 -137
- pyxlpr/ppocr/utils/dict/xi_dict.txt +0 -110
- pyxlpr/ppocr/utils/dict90.txt +0 -90
- pyxlpr/ppocr/utils/e2e_metric/Deteval.py +0 -574
- pyxlpr/ppocr/utils/e2e_metric/polygon_fast.py +0 -83
- pyxlpr/ppocr/utils/e2e_utils/extract_batchsize.py +0 -87
- pyxlpr/ppocr/utils/e2e_utils/extract_textpoint_fast.py +0 -457
- pyxlpr/ppocr/utils/e2e_utils/extract_textpoint_slow.py +0 -592
- pyxlpr/ppocr/utils/e2e_utils/pgnet_pp_utils.py +0 -162
- pyxlpr/ppocr/utils/e2e_utils/visual.py +0 -162
- pyxlpr/ppocr/utils/en_dict.txt +0 -95
- pyxlpr/ppocr/utils/gen_label.py +0 -81
- pyxlpr/ppocr/utils/ic15_dict.txt +0 -36
- pyxlpr/ppocr/utils/iou.py +0 -54
- pyxlpr/ppocr/utils/logging.py +0 -69
- pyxlpr/ppocr/utils/network.py +0 -84
- pyxlpr/ppocr/utils/ppocr_keys_v1.txt +0 -6623
- pyxlpr/ppocr/utils/profiler.py +0 -110
- pyxlpr/ppocr/utils/save_load.py +0 -150
- pyxlpr/ppocr/utils/stats.py +0 -72
- pyxlpr/ppocr/utils/utility.py +0 -80
- pyxlpr/ppstructure/__init__.py +0 -13
- pyxlpr/ppstructure/predict_system.py +0 -187
- pyxlpr/ppstructure/table/__init__.py +0 -13
- pyxlpr/ppstructure/table/eval_table.py +0 -72
- pyxlpr/ppstructure/table/matcher.py +0 -192
- pyxlpr/ppstructure/table/predict_structure.py +0 -136
- pyxlpr/ppstructure/table/predict_table.py +0 -221
- pyxlpr/ppstructure/table/table_metric/__init__.py +0 -16
- pyxlpr/ppstructure/table/table_metric/parallel.py +0 -51
- pyxlpr/ppstructure/table/table_metric/table_metric.py +0 -247
- pyxlpr/ppstructure/table/tablepyxl/__init__.py +0 -13
- pyxlpr/ppstructure/table/tablepyxl/style.py +0 -283
- pyxlpr/ppstructure/table/tablepyxl/tablepyxl.py +0 -118
- pyxlpr/ppstructure/utility.py +0 -71
- pyxlpr/xlai.py +0 -10
- /pyxllib/{ext/autogui → autogui}/virtualkey.py +0 -0
- {pyxllib-0.3.96.dist-info → pyxllib-0.3.197.dist-info/licenses}/LICENSE +0 -0
@@ -1,184 +0,0 @@
|
|
1
|
-
# copyright (c) 2020 PaddlePaddle Authors. All Rights Reserve.
|
2
|
-
#
|
3
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
4
|
-
# you may not use this file except in compliance with the License.
|
5
|
-
# You may obtain a copy of the License at
|
6
|
-
#
|
7
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
8
|
-
#
|
9
|
-
# Unless required by applicable law or agreed to in writing, software
|
10
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
11
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
12
|
-
# See the License for the specific language governing permissions and
|
13
|
-
# limitations under the License.
|
14
|
-
"""
|
15
|
-
This code is refer from:
|
16
|
-
https://github.com/WenmuZhou/DBNet.pytorch/blob/master/data_loader/modules/make_border_map.py
|
17
|
-
"""
|
18
|
-
from __future__ import absolute_import
|
19
|
-
from __future__ import division
|
20
|
-
from __future__ import print_function
|
21
|
-
from __future__ import unicode_literals
|
22
|
-
|
23
|
-
import numpy as np
|
24
|
-
import cv2
|
25
|
-
|
26
|
-
np.seterr(divide='ignore', invalid='ignore')
|
27
|
-
import pyclipper
|
28
|
-
from shapely.geometry import Polygon
|
29
|
-
import sys
|
30
|
-
import warnings
|
31
|
-
|
32
|
-
warnings.simplefilter("ignore")
|
33
|
-
|
34
|
-
__all__ = ['MakeBorderMap']
|
35
|
-
|
36
|
-
|
37
|
-
class MakeBorderMap(object):
|
38
|
-
""" 计算文本区域阈值图标签类
|
39
|
-
|
40
|
-
ppocr db模型代码阅读理解_垚1234的博客-CSDN博客:
|
41
|
-
https://blog.csdn.net/weixin_41393000/article/details/118740663
|
42
|
-
"""
|
43
|
-
def __init__(self,
|
44
|
-
shrink_ratio=0.4,
|
45
|
-
thresh_min=0.3,
|
46
|
-
thresh_max=0.7,
|
47
|
-
**kwargs):
|
48
|
-
self.shrink_ratio = shrink_ratio
|
49
|
-
self.thresh_min = thresh_min
|
50
|
-
self.thresh_max = thresh_max
|
51
|
-
|
52
|
-
def __call__(self, data):
|
53
|
-
img = data['image']
|
54
|
-
text_polys = data['polys']
|
55
|
-
ignore_tags = data['ignore_tags']
|
56
|
-
|
57
|
-
# 1. 生成空模版
|
58
|
-
canvas = np.zeros(img.shape[:2], dtype=np.float32)
|
59
|
-
mask = np.zeros(img.shape[:2], dtype=np.float32)
|
60
|
-
|
61
|
-
for i in range(len(text_polys)):
|
62
|
-
if ignore_tags[i]:
|
63
|
-
continue
|
64
|
-
|
65
|
-
# 2. draw_border_map函数根据解码后的box信息计算阈值图标签
|
66
|
-
self.draw_border_map(text_polys[i], canvas, mask=mask)
|
67
|
-
canvas = canvas * (self.thresh_max - self.thresh_min) + self.thresh_min
|
68
|
-
|
69
|
-
data['threshold_map'] = canvas
|
70
|
-
data['threshold_mask'] = mask
|
71
|
-
|
72
|
-
# from pyxllib.ai.paddlelib import show_feature_map
|
73
|
-
# show_feature_map([[data['image'][:,:,0].astype('float32') / 255, canvas, mask]])
|
74
|
-
return data
|
75
|
-
|
76
|
-
def draw_border_map(self, polygon, canvas, mask):
|
77
|
-
polygon = np.array(polygon)
|
78
|
-
assert polygon.ndim == 2
|
79
|
-
assert polygon.shape[1] == 2
|
80
|
-
|
81
|
-
polygon_shape = Polygon(polygon)
|
82
|
-
if polygon_shape.area <= 0:
|
83
|
-
return
|
84
|
-
# 多边形内缩
|
85
|
-
distance = polygon_shape.area * (
|
86
|
-
1 - np.power(self.shrink_ratio, 2)) / polygon_shape.length
|
87
|
-
subject = [tuple(l) for l in polygon]
|
88
|
-
padding = pyclipper.PyclipperOffset()
|
89
|
-
padding.AddPath(subject, pyclipper.JT_ROUND, pyclipper.ET_CLOSEDPOLYGON)
|
90
|
-
# 计算mask
|
91
|
-
padded_polygon = np.array(padding.Execute(distance)[0])
|
92
|
-
cv2.fillPoly(mask, [padded_polygon.astype(np.int32)], 1.0)
|
93
|
-
|
94
|
-
xmin = padded_polygon[:, 0].min()
|
95
|
-
xmax = padded_polygon[:, 0].max()
|
96
|
-
ymin = padded_polygon[:, 1].min()
|
97
|
-
ymax = padded_polygon[:, 1].max()
|
98
|
-
width = xmax - xmin + 1
|
99
|
-
height = ymax - ymin + 1
|
100
|
-
|
101
|
-
polygon[:, 0] = polygon[:, 0] - xmin
|
102
|
-
polygon[:, 1] = polygon[:, 1] - ymin
|
103
|
-
|
104
|
-
xs = np.broadcast_to(
|
105
|
-
np.linspace(
|
106
|
-
0, width - 1, num=width).reshape(1, width), (height, width))
|
107
|
-
ys = np.broadcast_to(
|
108
|
-
np.linspace(
|
109
|
-
0, height - 1, num=height).reshape(height, 1), (height, width))
|
110
|
-
|
111
|
-
distance_map = np.zeros(
|
112
|
-
(polygon.shape[0], height, width), dtype=np.float32)
|
113
|
-
for i in range(polygon.shape[0]):
|
114
|
-
j = (i + 1) % polygon.shape[0]
|
115
|
-
# 计算点到线的距离
|
116
|
-
absolute_distance = self._distance(xs, ys, polygon[i], polygon[j])
|
117
|
-
distance_map[i] = np.clip(absolute_distance / distance, 0, 1)
|
118
|
-
distance_map = distance_map.min(axis=0)
|
119
|
-
|
120
|
-
xmin_valid = min(max(0, xmin), canvas.shape[1] - 1)
|
121
|
-
xmax_valid = min(max(0, xmax), canvas.shape[1] - 1)
|
122
|
-
ymin_valid = min(max(0, ymin), canvas.shape[0] - 1)
|
123
|
-
ymax_valid = min(max(0, ymax), canvas.shape[0] - 1)
|
124
|
-
canvas[ymin_valid:ymax_valid + 1, xmin_valid:xmax_valid + 1] = np.fmax(
|
125
|
-
1 - distance_map[ymin_valid - ymin:ymax_valid - ymax + height,
|
126
|
-
xmin_valid - xmin:xmax_valid - xmax + width],
|
127
|
-
canvas[ymin_valid:ymax_valid + 1, xmin_valid:xmax_valid + 1])
|
128
|
-
|
129
|
-
def _distance(self, xs, ys, point_1, point_2):
|
130
|
-
'''
|
131
|
-
compute the distance from point to a line
|
132
|
-
ys: coordinates in the first axis
|
133
|
-
xs: coordinates in the second axis
|
134
|
-
point_1, point_2: (x, y), the end of the line
|
135
|
-
'''
|
136
|
-
height, width = xs.shape[:2]
|
137
|
-
square_distance_1 = np.square(xs - point_1[0]) + np.square(ys - point_1[
|
138
|
-
1])
|
139
|
-
square_distance_2 = np.square(xs - point_2[0]) + np.square(ys - point_2[
|
140
|
-
1])
|
141
|
-
square_distance = np.square(point_1[0] - point_2[0]) + np.square(
|
142
|
-
point_1[1] - point_2[1])
|
143
|
-
|
144
|
-
cosin = (square_distance - square_distance_1 - square_distance_2) / (
|
145
|
-
2 * np.sqrt(square_distance_1 * square_distance_2))
|
146
|
-
square_sin = 1 - np.square(cosin)
|
147
|
-
square_sin = np.nan_to_num(square_sin)
|
148
|
-
result = np.sqrt(square_distance_1 * square_distance_2 * square_sin /
|
149
|
-
square_distance)
|
150
|
-
|
151
|
-
result[cosin <
|
152
|
-
0] = np.sqrt(np.fmin(square_distance_1, square_distance_2))[cosin
|
153
|
-
< 0]
|
154
|
-
# self.extend_line(point_1, point_2, result)
|
155
|
-
return result
|
156
|
-
|
157
|
-
def extend_line(self, point_1, point_2, result, shrink_ratio):
|
158
|
-
ex_point_1 = (int(
|
159
|
-
round(point_1[0] + (point_1[0] - point_2[0]) * (1 + shrink_ratio))),
|
160
|
-
int(
|
161
|
-
round(point_1[1] + (point_1[1] - point_2[1]) * (
|
162
|
-
1 + shrink_ratio))))
|
163
|
-
cv2.line(
|
164
|
-
result,
|
165
|
-
tuple(ex_point_1),
|
166
|
-
tuple(point_1),
|
167
|
-
4096.0,
|
168
|
-
1,
|
169
|
-
lineType=cv2.LINE_AA,
|
170
|
-
shift=0)
|
171
|
-
ex_point_2 = (int(
|
172
|
-
round(point_2[0] + (point_2[0] - point_1[0]) * (1 + shrink_ratio))),
|
173
|
-
int(
|
174
|
-
round(point_2[1] + (point_2[1] - point_1[1]) * (
|
175
|
-
1 + shrink_ratio))))
|
176
|
-
cv2.line(
|
177
|
-
result,
|
178
|
-
tuple(ex_point_2),
|
179
|
-
tuple(point_2),
|
180
|
-
4096.0,
|
181
|
-
1,
|
182
|
-
lineType=cv2.LINE_AA,
|
183
|
-
shift=0)
|
184
|
-
return ex_point_1, ex_point_2
|
@@ -1,106 +0,0 @@
|
|
1
|
-
# copyright (c) 2021 PaddlePaddle Authors. All Rights Reserve.
|
2
|
-
#
|
3
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
4
|
-
# you may not use this file except in compliance with the License.
|
5
|
-
# You may obtain a copy of the License at
|
6
|
-
#
|
7
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
8
|
-
#
|
9
|
-
# Unless required by applicable law or agreed to in writing, software
|
10
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
11
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
12
|
-
# See the License for the specific language governing permissions and
|
13
|
-
# limitations under the License.
|
14
|
-
|
15
|
-
from __future__ import absolute_import
|
16
|
-
from __future__ import division
|
17
|
-
from __future__ import print_function
|
18
|
-
from __future__ import unicode_literals
|
19
|
-
|
20
|
-
import cv2
|
21
|
-
import numpy as np
|
22
|
-
import pyclipper
|
23
|
-
from shapely.geometry import Polygon
|
24
|
-
|
25
|
-
__all__ = ['MakePseGt']
|
26
|
-
|
27
|
-
|
28
|
-
class MakePseGt(object):
|
29
|
-
def __init__(self, kernel_num=7, size=640, min_shrink_ratio=0.4, **kwargs):
|
30
|
-
self.kernel_num = kernel_num
|
31
|
-
self.min_shrink_ratio = min_shrink_ratio
|
32
|
-
self.size = size
|
33
|
-
|
34
|
-
def __call__(self, data):
|
35
|
-
|
36
|
-
image = data['image']
|
37
|
-
text_polys = data['polys']
|
38
|
-
ignore_tags = data['ignore_tags']
|
39
|
-
|
40
|
-
h, w, _ = image.shape
|
41
|
-
short_edge = min(h, w)
|
42
|
-
if short_edge < self.size:
|
43
|
-
# keep short_size >= self.size
|
44
|
-
scale = self.size / short_edge
|
45
|
-
image = cv2.resize(image, dsize=None, fx=scale, fy=scale)
|
46
|
-
text_polys *= scale
|
47
|
-
|
48
|
-
gt_kernels = []
|
49
|
-
for i in range(1, self.kernel_num + 1):
|
50
|
-
# s1->sn, from big to small
|
51
|
-
rate = 1.0 - (1.0 - self.min_shrink_ratio) / (self.kernel_num - 1
|
52
|
-
) * i
|
53
|
-
text_kernel, ignore_tags = self.generate_kernel(
|
54
|
-
image.shape[0:2], rate, text_polys, ignore_tags)
|
55
|
-
gt_kernels.append(text_kernel)
|
56
|
-
|
57
|
-
training_mask = np.ones(image.shape[0:2], dtype='uint8')
|
58
|
-
for i in range(text_polys.shape[0]):
|
59
|
-
if ignore_tags[i]:
|
60
|
-
cv2.fillPoly(training_mask,
|
61
|
-
text_polys[i].astype(np.int32)[np.newaxis, :, :],
|
62
|
-
0)
|
63
|
-
|
64
|
-
gt_kernels = np.array(gt_kernels)
|
65
|
-
gt_kernels[gt_kernels > 0] = 1
|
66
|
-
|
67
|
-
data['image'] = image
|
68
|
-
data['polys'] = text_polys
|
69
|
-
data['gt_kernels'] = gt_kernels[0:]
|
70
|
-
data['gt_text'] = gt_kernels[0]
|
71
|
-
data['mask'] = training_mask.astype('float32')
|
72
|
-
return data
|
73
|
-
|
74
|
-
def generate_kernel(self,
|
75
|
-
img_size,
|
76
|
-
shrink_ratio,
|
77
|
-
text_polys,
|
78
|
-
ignore_tags=None):
|
79
|
-
"""
|
80
|
-
Refer to part of the code:
|
81
|
-
https://github.com/open-mmlab/mmocr/blob/main/mmocr/datasets/pipelines/textdet_targets/base_textdet_targets.py
|
82
|
-
"""
|
83
|
-
|
84
|
-
h, w = img_size
|
85
|
-
text_kernel = np.zeros((h, w), dtype=np.float32)
|
86
|
-
for i, poly in enumerate(text_polys):
|
87
|
-
polygon = Polygon(poly)
|
88
|
-
distance = polygon.area * (1 - shrink_ratio * shrink_ratio) / (
|
89
|
-
polygon.length + 1e-6)
|
90
|
-
subject = [tuple(l) for l in poly]
|
91
|
-
pco = pyclipper.PyclipperOffset()
|
92
|
-
pco.AddPath(subject, pyclipper.JT_ROUND, pyclipper.ET_CLOSEDPOLYGON)
|
93
|
-
shrinked = np.array(pco.Execute(-distance))
|
94
|
-
|
95
|
-
if len(shrinked) == 0 or shrinked.size == 0:
|
96
|
-
if ignore_tags is not None:
|
97
|
-
ignore_tags[i] = True
|
98
|
-
continue
|
99
|
-
try:
|
100
|
-
shrinked = np.array(shrinked[0]).reshape(-1, 2)
|
101
|
-
except:
|
102
|
-
if ignore_tags is not None:
|
103
|
-
ignore_tags[i] = True
|
104
|
-
continue
|
105
|
-
cv2.fillPoly(text_kernel, [shrinked.astype(np.int32)], i + 1)
|
106
|
-
return text_kernel, ignore_tags
|
@@ -1,126 +0,0 @@
|
|
1
|
-
# copyright (c) 2020 PaddlePaddle Authors. All Rights Reserve.
|
2
|
-
#
|
3
|
-
# Licensed under the Apache License, Version 2.0 (the "License");
|
4
|
-
# you may not use this file except in compliance with the License.
|
5
|
-
# You may obtain a copy of the License at
|
6
|
-
#
|
7
|
-
# http://www.apache.org/licenses/LICENSE-2.0
|
8
|
-
#
|
9
|
-
# Unless required by applicable law or agreed to in writing, software
|
10
|
-
# distributed under the License is distributed on an "AS IS" BASIS,
|
11
|
-
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
12
|
-
# See the License for the specific language governing permissions and
|
13
|
-
# limitations under the License.
|
14
|
-
"""
|
15
|
-
This code is refer from:
|
16
|
-
https://github.com/WenmuZhou/DBNet.pytorch/blob/master/data_loader/modules/make_shrink_map.py
|
17
|
-
"""
|
18
|
-
from __future__ import absolute_import
|
19
|
-
from __future__ import division
|
20
|
-
from __future__ import print_function
|
21
|
-
from __future__ import unicode_literals
|
22
|
-
|
23
|
-
import numpy as np
|
24
|
-
import cv2
|
25
|
-
from shapely.geometry import Polygon
|
26
|
-
import pyclipper
|
27
|
-
|
28
|
-
__all__ = ['MakeShrinkMap']
|
29
|
-
|
30
|
-
|
31
|
-
class MakeShrinkMap(object):
|
32
|
-
r'''
|
33
|
-
Making binary mask from detection data with ICDAR format.
|
34
|
-
Typically following the process of class `MakeICDARData`.
|
35
|
-
'''
|
36
|
-
|
37
|
-
def __init__(self, min_text_size=8, shrink_ratio=0.4, **kwargs):
|
38
|
-
self.min_text_size = min_text_size
|
39
|
-
self.shrink_ratio = shrink_ratio
|
40
|
-
|
41
|
-
def __call__(self, data):
|
42
|
-
image = data['image']
|
43
|
-
text_polys = data['polys']
|
44
|
-
ignore_tags = data['ignore_tags']
|
45
|
-
|
46
|
-
h, w = image.shape[:2]
|
47
|
-
# 1 校验文本检测标签
|
48
|
-
text_polys, ignore_tags = self.validate_polygons(text_polys,
|
49
|
-
ignore_tags, h, w)
|
50
|
-
gt = np.zeros((h, w), dtype=np.float32)
|
51
|
-
mask = np.ones((h, w), dtype=np.float32)
|
52
|
-
# 2 根据文本检测框计算文本区域概率图
|
53
|
-
for i in range(len(text_polys)):
|
54
|
-
polygon = text_polys[i]
|
55
|
-
height = max(polygon[:, 1]) - min(polygon[:, 1])
|
56
|
-
width = max(polygon[:, 0]) - min(polygon[:, 0])
|
57
|
-
if ignore_tags[i] or min(height, width) < self.min_text_size:
|
58
|
-
cv2.fillPoly(mask,
|
59
|
-
polygon.astype(np.int32)[np.newaxis, :, :], 0)
|
60
|
-
ignore_tags[i] = True
|
61
|
-
else:
|
62
|
-
# 多边形内缩
|
63
|
-
polygon_shape = Polygon(polygon)
|
64
|
-
subject = [tuple(l) for l in polygon]
|
65
|
-
padding = pyclipper.PyclipperOffset()
|
66
|
-
padding.AddPath(subject, pyclipper.JT_ROUND,
|
67
|
-
pyclipper.ET_CLOSEDPOLYGON)
|
68
|
-
shrinked = []
|
69
|
-
|
70
|
-
# Increase the shrink ratio every time we get multiple polygon returned back
|
71
|
-
possible_ratios = np.arange(self.shrink_ratio, 1,
|
72
|
-
self.shrink_ratio)
|
73
|
-
np.append(possible_ratios, 1)
|
74
|
-
# print(possible_ratios)
|
75
|
-
for ratio in possible_ratios:
|
76
|
-
# print(f"Change shrink ratio to {ratio}")
|
77
|
-
distance = polygon_shape.area * (
|
78
|
-
1 - np.power(ratio, 2)) / polygon_shape.length
|
79
|
-
shrinked = padding.Execute(-distance)
|
80
|
-
if len(shrinked) == 1:
|
81
|
-
break
|
82
|
-
|
83
|
-
if shrinked == []:
|
84
|
-
cv2.fillPoly(mask,
|
85
|
-
polygon.astype(np.int32)[np.newaxis, :, :], 0)
|
86
|
-
ignore_tags[i] = True
|
87
|
-
continue
|
88
|
-
|
89
|
-
# 填充
|
90
|
-
for each_shirnk in shrinked:
|
91
|
-
shirnk = np.array(each_shirnk).reshape(-1, 2)
|
92
|
-
cv2.fillPoly(gt, [shirnk.astype(np.int32)], 1)
|
93
|
-
|
94
|
-
data['shrink_map'] = gt
|
95
|
-
data['shrink_mask'] = mask
|
96
|
-
return data
|
97
|
-
|
98
|
-
def validate_polygons(self, polygons, ignore_tags, h, w):
|
99
|
-
'''
|
100
|
-
polygons (numpy.array, required): of shape (num_instances, num_points, 2)
|
101
|
-
'''
|
102
|
-
if len(polygons) == 0:
|
103
|
-
return polygons, ignore_tags
|
104
|
-
assert len(polygons) == len(ignore_tags)
|
105
|
-
for polygon in polygons:
|
106
|
-
polygon[:, 0] = np.clip(polygon[:, 0], 0, w - 1)
|
107
|
-
polygon[:, 1] = np.clip(polygon[:, 1], 0, h - 1)
|
108
|
-
|
109
|
-
for i in range(len(polygons)):
|
110
|
-
area = self.polygon_area(polygons[i])
|
111
|
-
if abs(area) < 1:
|
112
|
-
ignore_tags[i] = True
|
113
|
-
if area > 0:
|
114
|
-
polygons[i] = polygons[i][::-1, :]
|
115
|
-
return polygons, ignore_tags
|
116
|
-
|
117
|
-
def polygon_area(self, polygon):
|
118
|
-
"""
|
119
|
-
compute polygon area
|
120
|
-
"""
|
121
|
-
area = 0
|
122
|
-
q = polygon[-1]
|
123
|
-
for p in polygon:
|
124
|
-
area += p[0] * q[1] - p[1] * q[0]
|
125
|
-
q = p
|
126
|
-
return area / 2.0
|