paddlex 3.0.0b2__py3-none-any.whl → 3.0.0rc0__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.
- paddlex/.version +1 -1
- paddlex/__init__.py +1 -0
- paddlex/__main__.py +3 -4
- paddlex/configs/modules/3d_bev_detection/BEVFusion.yaml +38 -0
- paddlex/configs/modules/face_feature/MobileFaceNet.yaml +41 -0
- paddlex/configs/modules/face_feature/ResNet50_face.yaml +41 -0
- paddlex/configs/modules/formula_recognition/LaTeX_OCR_rec.yaml +40 -0
- paddlex/configs/modules/formula_recognition/PP-FormulaNet-L.yaml +40 -0
- paddlex/configs/modules/formula_recognition/PP-FormulaNet-S.yaml +40 -0
- paddlex/configs/modules/formula_recognition/UniMERNet.yaml +40 -0
- paddlex/configs/modules/image_classification/CLIP_vit_base_patch16_224.yaml +41 -0
- paddlex/configs/modules/image_classification/CLIP_vit_large_patch14_224.yaml +41 -0
- paddlex/configs/modules/image_classification/ConvNeXt_large_384.yaml +41 -0
- paddlex/configs/modules/keypoint_detection/PP-TinyPose_128x96.yaml +40 -0
- paddlex/configs/modules/keypoint_detection/PP-TinyPose_256x192.yaml +40 -0
- paddlex/configs/modules/layout_detection/PP-DocLayout-L.yaml +40 -0
- paddlex/configs/modules/layout_detection/PP-DocLayout-M.yaml +40 -0
- paddlex/configs/modules/layout_detection/PP-DocLayout-S.yaml +40 -0
- paddlex/configs/modules/multilingual_speech_recognition/whisper_base.yaml +12 -0
- paddlex/configs/modules/multilingual_speech_recognition/whisper_large.yaml +12 -0
- paddlex/configs/modules/multilingual_speech_recognition/whisper_medium.yaml +12 -0
- paddlex/configs/modules/multilingual_speech_recognition/whisper_small.yaml +12 -0
- paddlex/configs/modules/multilingual_speech_recognition/whisper_tiny.yaml +12 -0
- paddlex/configs/modules/object_detection/Co-DINO-R50.yaml +40 -0
- paddlex/configs/modules/object_detection/Co-DINO-Swin-L.yaml +40 -0
- paddlex/configs/modules/object_detection/Co-Deformable-DETR-R50.yaml +40 -0
- paddlex/configs/modules/object_detection/Co-Deformable-DETR-Swin-T.yaml +40 -0
- paddlex/configs/modules/object_detection/YOLOX-X.yaml +40 -0
- paddlex/configs/modules/open_vocabulary_detection/GroundingDINO-T.yaml +13 -0
- paddlex/configs/modules/open_vocabulary_segmentation/SAM-H_box.yaml +17 -0
- paddlex/configs/modules/open_vocabulary_segmentation/SAM-H_point.yaml +15 -0
- paddlex/configs/modules/rotated_object_detection/PP-YOLOE-R-L.yaml +40 -0
- paddlex/configs/modules/semantic_segmentation/MaskFormer_small.yaml +42 -0
- paddlex/configs/modules/semantic_segmentation/MaskFormer_tiny.yaml +42 -0
- paddlex/configs/modules/semantic_segmentation/SeaFormer_base.yaml +40 -0
- paddlex/configs/modules/semantic_segmentation/SeaFormer_large.yaml +40 -0
- paddlex/configs/modules/semantic_segmentation/SeaFormer_small.yaml +40 -0
- paddlex/configs/modules/semantic_segmentation/SeaFormer_tiny.yaml +40 -0
- paddlex/configs/modules/table_cells_detection/RT-DETR-L_wired_table_cell_det.yaml +40 -0
- paddlex/configs/modules/table_cells_detection/RT-DETR-L_wireless_table_cell_det.yaml +40 -0
- paddlex/configs/modules/table_classification/PP-LCNet_x1_0_table_cls.yaml +41 -0
- paddlex/configs/modules/table_structure_recognition/SLANeXt_wired.yaml +39 -0
- paddlex/configs/modules/table_structure_recognition/SLANeXt_wireless.yaml +39 -0
- paddlex/configs/modules/text_detection/PP-OCRv3_mobile_det.yaml +40 -0
- paddlex/configs/modules/text_detection/PP-OCRv3_server_det.yaml +40 -0
- paddlex/configs/modules/text_recognition/PP-OCRv3_mobile_rec.yaml +39 -0
- paddlex/configs/modules/text_recognition/PP-OCRv4_server_rec_doc.yaml +39 -0
- paddlex/configs/modules/text_recognition/arabic_PP-OCRv3_mobile_rec.yaml +39 -0
- paddlex/configs/modules/text_recognition/chinese_cht_PP-OCRv3_mobile_rec.yaml +39 -0
- paddlex/configs/modules/text_recognition/cyrillic_PP-OCRv3_mobile_rec.yaml +39 -0
- paddlex/configs/modules/text_recognition/devanagari_PP-OCRv3_mobile_rec.yaml +39 -0
- paddlex/configs/modules/text_recognition/en_PP-OCRv3_mobile_rec.yaml +39 -0
- paddlex/configs/modules/text_recognition/en_PP-OCRv4_mobile_rec.yaml +39 -0
- paddlex/configs/modules/text_recognition/japan_PP-OCRv3_mobile_rec.yaml +39 -0
- paddlex/configs/modules/text_recognition/ka_PP-OCRv3_mobile_rec.yaml +39 -0
- paddlex/configs/modules/text_recognition/korean_PP-OCRv3_mobile_rec.yaml +39 -0
- paddlex/configs/modules/text_recognition/latin_PP-OCRv3_mobile_rec.yaml +39 -0
- paddlex/configs/modules/text_recognition/ta_PP-OCRv3_mobile_rec.yaml +39 -0
- paddlex/configs/modules/text_recognition/te_PP-OCRv3_mobile_rec.yaml +39 -0
- paddlex/configs/modules/textline_orientation/PP-LCNet_x0_25_textline_ori.yaml +41 -0
- paddlex/configs/modules/video_classification/PP-TSM-R50_8frames_uniform.yaml +42 -0
- paddlex/configs/modules/video_classification/PP-TSMv2-LCNetV2_16frames_uniform.yaml +42 -0
- paddlex/configs/modules/video_classification/PP-TSMv2-LCNetV2_8frames_uniform.yaml +42 -0
- paddlex/configs/modules/video_detection/YOWO.yaml +40 -0
- paddlex/configs/pipelines/3d_bev_detection.yaml +9 -0
- paddlex/configs/pipelines/OCR.yaml +44 -0
- paddlex/configs/pipelines/PP-ChatOCRv3-doc.yaml +149 -0
- paddlex/configs/pipelines/PP-ChatOCRv4-doc.yaml +184 -0
- paddlex/configs/pipelines/PP-ShiTuV2.yaml +18 -0
- paddlex/configs/pipelines/PP-StructureV3.yaml +226 -0
- paddlex/configs/pipelines/anomaly_detection.yaml +8 -0
- paddlex/configs/pipelines/doc_preprocessor.yaml +15 -0
- paddlex/configs/pipelines/face_recognition.yaml +18 -0
- paddlex/configs/pipelines/formula_recognition.yaml +39 -0
- paddlex/configs/pipelines/human_keypoint_detection.yaml +17 -0
- paddlex/configs/pipelines/image_classification.yaml +10 -0
- paddlex/configs/pipelines/image_multilabel_classification.yaml +9 -0
- paddlex/configs/pipelines/instance_segmentation.yaml +10 -0
- paddlex/configs/pipelines/layout_parsing.yaml +101 -0
- paddlex/configs/pipelines/multilingual_speech_recognition.yaml +9 -0
- paddlex/configs/pipelines/object_detection.yaml +10 -0
- paddlex/configs/pipelines/open_vocabulary_detection.yaml +12 -0
- paddlex/configs/pipelines/open_vocabulary_segmentation.yaml +13 -0
- paddlex/configs/pipelines/pedestrian_attribute_recognition.yaml +15 -0
- paddlex/configs/pipelines/rotated_object_detection.yaml +10 -0
- paddlex/configs/pipelines/seal_recognition.yaml +51 -0
- paddlex/configs/pipelines/semantic_segmentation.yaml +10 -0
- paddlex/configs/pipelines/small_object_detection.yaml +10 -0
- paddlex/configs/pipelines/table_recognition.yaml +56 -0
- paddlex/configs/pipelines/table_recognition_v2.yaml +76 -0
- paddlex/configs/pipelines/ts_anomaly_detection.yaml +8 -0
- paddlex/configs/pipelines/ts_classification.yaml +8 -0
- paddlex/configs/pipelines/ts_forecast.yaml +8 -0
- paddlex/configs/pipelines/vehicle_attribute_recognition.yaml +15 -0
- paddlex/configs/pipelines/video_classification.yaml +9 -0
- paddlex/configs/pipelines/video_detection.yaml +10 -0
- paddlex/engine.py +1 -1
- paddlex/hpip_links.html +19 -0
- paddlex/inference/__init__.py +3 -1
- paddlex/inference/common/batch_sampler/__init__.py +20 -0
- paddlex/inference/common/batch_sampler/audio_batch_sampler.py +84 -0
- paddlex/inference/common/batch_sampler/base_batch_sampler.py +90 -0
- paddlex/inference/common/batch_sampler/det_3d_batch_sampler.py +147 -0
- paddlex/inference/common/batch_sampler/image_batch_sampler.py +136 -0
- paddlex/inference/common/batch_sampler/ts_batch_sampler.py +110 -0
- paddlex/inference/common/batch_sampler/video_batch_sampler.py +94 -0
- paddlex/inference/common/reader/__init__.py +19 -0
- paddlex/inference/common/reader/audio_reader.py +46 -0
- paddlex/inference/common/reader/det_3d_reader.py +239 -0
- paddlex/inference/common/reader/image_reader.py +69 -0
- paddlex/inference/common/reader/ts_reader.py +45 -0
- paddlex/inference/common/reader/video_reader.py +42 -0
- paddlex/inference/common/result/__init__.py +29 -0
- paddlex/inference/common/result/base_cv_result.py +31 -0
- paddlex/inference/common/result/base_result.py +70 -0
- paddlex/inference/common/result/base_ts_result.py +42 -0
- paddlex/inference/common/result/base_video_result.py +36 -0
- paddlex/inference/common/result/mixin.py +703 -0
- paddlex/inference/models/3d_bev_detection/__init__.py +15 -0
- paddlex/inference/models/3d_bev_detection/predictor.py +314 -0
- paddlex/inference/models/3d_bev_detection/processors.py +978 -0
- paddlex/inference/models/3d_bev_detection/result.py +65 -0
- paddlex/inference/models/3d_bev_detection/visualizer_3d.py +131 -0
- paddlex/inference/models/__init__.py +37 -13
- paddlex/inference/models/anomaly_detection/__init__.py +15 -0
- paddlex/inference/models/anomaly_detection/predictor.py +145 -0
- paddlex/inference/models/anomaly_detection/processors.py +46 -0
- paddlex/inference/models/anomaly_detection/result.py +70 -0
- paddlex/inference/models/base/__init__.py +1 -2
- paddlex/inference/models/base/predictor/__init__.py +16 -0
- paddlex/inference/models/base/predictor/base_predictor.py +175 -0
- paddlex/inference/models/base/predictor/basic_predictor.py +139 -0
- paddlex/inference/models/common/__init__.py +35 -0
- paddlex/inference/models/common/static_infer.py +329 -0
- paddlex/inference/models/common/tokenizer/__init__.py +17 -0
- paddlex/inference/models/common/tokenizer/bert_tokenizer.py +655 -0
- paddlex/inference/models/common/tokenizer/gpt_tokenizer.py +451 -0
- paddlex/inference/models/common/tokenizer/tokenizer_utils.py +2141 -0
- paddlex/inference/models/common/tokenizer/tokenizer_utils_base.py +3504 -0
- paddlex/inference/models/common/tokenizer/utils.py +66 -0
- paddlex/inference/models/common/tokenizer/vocab.py +647 -0
- paddlex/inference/models/common/ts/__init__.py +15 -0
- paddlex/inference/models/common/ts/funcs.py +533 -0
- paddlex/inference/models/common/ts/processors.py +313 -0
- paddlex/inference/models/common/vision/__init__.py +23 -0
- paddlex/inference/models/common/vision/funcs.py +93 -0
- paddlex/inference/models/common/vision/processors.py +270 -0
- paddlex/inference/models/face_feature/__init__.py +15 -0
- paddlex/inference/models/face_feature/predictor.py +65 -0
- paddlex/inference/models/formula_recognition/__init__.py +15 -0
- paddlex/inference/models/formula_recognition/predictor.py +203 -0
- paddlex/inference/models/formula_recognition/processors.py +986 -0
- paddlex/inference/models/formula_recognition/result.py +403 -0
- paddlex/inference/models/image_classification/__init__.py +15 -0
- paddlex/inference/models/image_classification/predictor.py +182 -0
- paddlex/inference/models/image_classification/processors.py +87 -0
- paddlex/inference/models/image_classification/result.py +92 -0
- paddlex/inference/models/image_feature/__init__.py +15 -0
- paddlex/inference/models/image_feature/predictor.py +156 -0
- paddlex/inference/models/image_feature/processors.py +29 -0
- paddlex/inference/models/image_feature/result.py +33 -0
- paddlex/inference/models/image_multilabel_classification/__init__.py +15 -0
- paddlex/inference/models/image_multilabel_classification/predictor.py +94 -0
- paddlex/inference/models/image_multilabel_classification/processors.py +85 -0
- paddlex/inference/models/image_multilabel_classification/result.py +95 -0
- paddlex/inference/models/image_unwarping/__init__.py +15 -0
- paddlex/inference/models/image_unwarping/predictor.py +105 -0
- paddlex/inference/models/image_unwarping/processors.py +88 -0
- paddlex/inference/models/image_unwarping/result.py +45 -0
- paddlex/inference/models/instance_segmentation/__init__.py +15 -0
- paddlex/inference/models/instance_segmentation/predictor.py +210 -0
- paddlex/inference/models/instance_segmentation/processors.py +105 -0
- paddlex/inference/models/instance_segmentation/result.py +161 -0
- paddlex/inference/models/keypoint_detection/__init__.py +15 -0
- paddlex/inference/models/keypoint_detection/predictor.py +188 -0
- paddlex/inference/models/keypoint_detection/processors.py +359 -0
- paddlex/inference/models/keypoint_detection/result.py +192 -0
- paddlex/inference/models/multilingual_speech_recognition/__init__.py +15 -0
- paddlex/inference/models/multilingual_speech_recognition/predictor.py +141 -0
- paddlex/inference/models/multilingual_speech_recognition/processors.py +1941 -0
- paddlex/inference/models/multilingual_speech_recognition/result.py +21 -0
- paddlex/inference/models/object_detection/__init__.py +15 -0
- paddlex/inference/models/object_detection/predictor.py +348 -0
- paddlex/inference/models/object_detection/processors.py +855 -0
- paddlex/inference/models/object_detection/result.py +113 -0
- paddlex/inference/models/object_detection/utils.py +68 -0
- paddlex/inference/models/open_vocabulary_detection/__init__.py +15 -0
- paddlex/inference/models/open_vocabulary_detection/predictor.py +155 -0
- paddlex/inference/models/open_vocabulary_detection/processors/__init__.py +15 -0
- paddlex/inference/models/open_vocabulary_detection/processors/groundingdino_processors.py +485 -0
- paddlex/inference/models/open_vocabulary_segmentation/__init__.py +15 -0
- paddlex/inference/models/open_vocabulary_segmentation/predictor.py +120 -0
- paddlex/inference/models/open_vocabulary_segmentation/processors/__init__.py +15 -0
- paddlex/inference/models/open_vocabulary_segmentation/processors/sam_processer.py +249 -0
- paddlex/inference/models/open_vocabulary_segmentation/results/__init__.py +15 -0
- paddlex/inference/models/open_vocabulary_segmentation/results/sam_result.py +147 -0
- paddlex/inference/models/semantic_segmentation/__init__.py +15 -0
- paddlex/inference/models/semantic_segmentation/predictor.py +167 -0
- paddlex/inference/models/semantic_segmentation/processors.py +114 -0
- paddlex/inference/models/semantic_segmentation/result.py +72 -0
- paddlex/inference/models/table_structure_recognition/__init__.py +15 -0
- paddlex/inference/models/table_structure_recognition/predictor.py +171 -0
- paddlex/inference/models/table_structure_recognition/processors.py +235 -0
- paddlex/inference/models/table_structure_recognition/result.py +70 -0
- paddlex/inference/models/text_detection/__init__.py +15 -0
- paddlex/inference/models/text_detection/predictor.py +191 -0
- paddlex/inference/models/text_detection/processors.py +466 -0
- paddlex/inference/models/text_detection/result.py +51 -0
- paddlex/inference/models/text_recognition/__init__.py +15 -0
- paddlex/inference/models/text_recognition/predictor.py +106 -0
- paddlex/inference/models/text_recognition/processors.py +231 -0
- paddlex/inference/models/text_recognition/result.py +75 -0
- paddlex/inference/models/ts_anomaly_detection/__init__.py +15 -0
- paddlex/inference/models/ts_anomaly_detection/predictor.py +146 -0
- paddlex/inference/models/ts_anomaly_detection/processors.py +94 -0
- paddlex/inference/models/ts_anomaly_detection/result.py +72 -0
- paddlex/inference/models/ts_classification/__init__.py +15 -0
- paddlex/inference/models/ts_classification/predictor.py +135 -0
- paddlex/inference/models/ts_classification/processors.py +117 -0
- paddlex/inference/models/ts_classification/result.py +78 -0
- paddlex/inference/models/ts_forecasting/__init__.py +15 -0
- paddlex/inference/models/ts_forecasting/predictor.py +159 -0
- paddlex/inference/models/ts_forecasting/processors.py +149 -0
- paddlex/inference/models/ts_forecasting/result.py +83 -0
- paddlex/inference/models/video_classification/__init__.py +15 -0
- paddlex/inference/models/video_classification/predictor.py +147 -0
- paddlex/inference/models/video_classification/processors.py +409 -0
- paddlex/inference/models/video_classification/result.py +92 -0
- paddlex/inference/models/video_detection/__init__.py +15 -0
- paddlex/inference/models/video_detection/predictor.py +136 -0
- paddlex/inference/models/video_detection/processors.py +450 -0
- paddlex/inference/models/video_detection/result.py +104 -0
- paddlex/inference/pipelines/3d_bev_detection/__init__.py +15 -0
- paddlex/inference/pipelines/3d_bev_detection/pipeline.py +67 -0
- paddlex/inference/pipelines/__init__.py +174 -73
- paddlex/inference/pipelines/anomaly_detection/__init__.py +15 -0
- paddlex/inference/pipelines/anomaly_detection/pipeline.py +62 -0
- paddlex/inference/pipelines/attribute_recognition/__init__.py +15 -0
- paddlex/inference/pipelines/attribute_recognition/pipeline.py +105 -0
- paddlex/inference/pipelines/attribute_recognition/result.py +100 -0
- paddlex/inference/pipelines/base.py +103 -57
- paddlex/inference/pipelines/components/__init__.py +23 -0
- paddlex/inference/pipelines/components/chat_server/__init__.py +16 -0
- paddlex/inference/pipelines/components/chat_server/base.py +39 -0
- paddlex/inference/pipelines/components/chat_server/openai_bot_chat.py +236 -0
- paddlex/inference/pipelines/components/common/__init__.py +18 -0
- paddlex/inference/pipelines/components/common/base_operator.py +36 -0
- paddlex/inference/pipelines/components/common/base_result.py +65 -0
- paddlex/inference/pipelines/components/common/convert_points_and_boxes.py +46 -0
- paddlex/inference/pipelines/components/common/crop_image_regions.py +550 -0
- paddlex/inference/pipelines/components/common/seal_det_warp.py +941 -0
- paddlex/inference/pipelines/components/common/sort_boxes.py +83 -0
- paddlex/inference/pipelines/components/faisser.py +352 -0
- paddlex/inference/pipelines/components/prompt_engineering/__init__.py +16 -0
- paddlex/inference/pipelines/components/prompt_engineering/base.py +35 -0
- paddlex/inference/pipelines/components/prompt_engineering/generate_ensemble_prompt.py +127 -0
- paddlex/inference/pipelines/components/prompt_engineering/generate_kie_prompt.py +148 -0
- paddlex/inference/pipelines/components/retriever/__init__.py +16 -0
- paddlex/inference/pipelines/components/retriever/base.py +226 -0
- paddlex/inference/pipelines/components/retriever/openai_bot_retriever.py +70 -0
- paddlex/inference/pipelines/components/retriever/qianfan_bot_retriever.py +163 -0
- paddlex/inference/pipelines/components/utils/__init__.py +13 -0
- paddlex/inference/pipelines/components/utils/mixin.py +206 -0
- paddlex/inference/pipelines/doc_preprocessor/__init__.py +15 -0
- paddlex/inference/pipelines/doc_preprocessor/pipeline.py +190 -0
- paddlex/inference/pipelines/doc_preprocessor/result.py +103 -0
- paddlex/inference/pipelines/face_recognition/__init__.py +15 -0
- paddlex/inference/pipelines/face_recognition/pipeline.py +61 -0
- paddlex/inference/pipelines/face_recognition/result.py +43 -0
- paddlex/inference/pipelines/formula_recognition/__init__.py +15 -0
- paddlex/inference/pipelines/formula_recognition/pipeline.py +303 -0
- paddlex/inference/pipelines/formula_recognition/result.py +291 -0
- paddlex/inference/pipelines/image_classification/__init__.py +15 -0
- paddlex/inference/pipelines/image_classification/pipeline.py +71 -0
- paddlex/inference/pipelines/image_multilabel_classification/__init__.py +15 -0
- paddlex/inference/pipelines/image_multilabel_classification/pipeline.py +78 -0
- paddlex/inference/pipelines/instance_segmentation/__init__.py +15 -0
- paddlex/inference/pipelines/instance_segmentation/pipeline.py +70 -0
- paddlex/inference/pipelines/keypoint_detection/__init__.py +15 -0
- paddlex/inference/pipelines/keypoint_detection/pipeline.py +137 -0
- paddlex/inference/pipelines/layout_parsing/__init__.py +2 -1
- paddlex/inference/pipelines/layout_parsing/pipeline.py +570 -0
- paddlex/inference/pipelines/layout_parsing/pipeline_v2.py +739 -0
- paddlex/inference/pipelines/layout_parsing/result.py +203 -0
- paddlex/inference/pipelines/layout_parsing/result_v2.py +470 -0
- paddlex/inference/pipelines/layout_parsing/utils.py +2385 -0
- paddlex/inference/pipelines/multilingual_speech_recognition/__init__.py +15 -0
- paddlex/inference/pipelines/multilingual_speech_recognition/pipeline.py +67 -0
- paddlex/inference/pipelines/object_detection/__init__.py +15 -0
- paddlex/inference/pipelines/object_detection/pipeline.py +95 -0
- paddlex/inference/pipelines/ocr/__init__.py +15 -0
- paddlex/inference/pipelines/ocr/pipeline.py +389 -0
- paddlex/inference/pipelines/ocr/result.py +248 -0
- paddlex/inference/pipelines/open_vocabulary_detection/__init__.py +15 -0
- paddlex/inference/pipelines/open_vocabulary_detection/pipeline.py +75 -0
- paddlex/inference/pipelines/open_vocabulary_segmentation/__init__.py +15 -0
- paddlex/inference/pipelines/open_vocabulary_segmentation/pipeline.py +89 -0
- paddlex/inference/pipelines/pp_chatocr/__init__.py +16 -0
- paddlex/inference/pipelines/pp_chatocr/pipeline_base.py +102 -0
- paddlex/inference/pipelines/pp_chatocr/pipeline_v3.py +773 -0
- paddlex/inference/pipelines/pp_chatocr/pipeline_v4.py +977 -0
- paddlex/inference/pipelines/pp_shitu_v2/__init__.py +15 -0
- paddlex/inference/pipelines/pp_shitu_v2/pipeline.py +152 -0
- paddlex/inference/pipelines/pp_shitu_v2/result.py +126 -0
- paddlex/inference/pipelines/rotated_object_detection/__init__.py +15 -0
- paddlex/inference/pipelines/rotated_object_detection/pipeline.py +74 -0
- paddlex/inference/pipelines/seal_recognition/__init__.py +15 -0
- paddlex/inference/pipelines/seal_recognition/pipeline.py +271 -0
- paddlex/inference/pipelines/seal_recognition/result.py +87 -0
- paddlex/inference/pipelines/semantic_segmentation/__init__.py +15 -0
- paddlex/inference/pipelines/semantic_segmentation/pipeline.py +74 -0
- paddlex/inference/pipelines/small_object_detection/__init__.py +15 -0
- paddlex/inference/pipelines/small_object_detection/pipeline.py +74 -0
- paddlex/inference/pipelines/table_recognition/__init__.py +2 -1
- paddlex/inference/pipelines/table_recognition/pipeline.py +462 -0
- paddlex/inference/pipelines/table_recognition/pipeline_v2.py +792 -0
- paddlex/inference/pipelines/table_recognition/result.py +216 -0
- paddlex/inference/pipelines/table_recognition/table_recognition_post_processing.py +362 -0
- paddlex/inference/pipelines/table_recognition/table_recognition_post_processing_v2.py +470 -0
- paddlex/inference/pipelines/table_recognition/utils.py +23 -436
- paddlex/inference/pipelines/ts_anomaly_detection/__init__.py +15 -0
- paddlex/inference/pipelines/ts_anomaly_detection/pipeline.py +62 -0
- paddlex/inference/pipelines/ts_classification/__init__.py +15 -0
- paddlex/inference/pipelines/ts_classification/pipeline.py +62 -0
- paddlex/inference/pipelines/ts_forecasting/__init__.py +15 -0
- paddlex/inference/pipelines/ts_forecasting/pipeline.py +62 -0
- paddlex/inference/pipelines/video_classification/__init__.py +15 -0
- paddlex/inference/pipelines/video_classification/pipeline.py +68 -0
- paddlex/inference/pipelines/video_detection/__init__.py +15 -0
- paddlex/inference/pipelines/video_detection/pipeline.py +73 -0
- paddlex/inference/serving/__init__.py +13 -0
- paddlex/inference/serving/basic_serving/__init__.py +18 -0
- paddlex/inference/serving/basic_serving/_app.py +209 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/__init__.py +41 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/_common/__init__.py +13 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/_common/common.py +96 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/_common/image_recognition.py +36 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/_common/ocr.py +90 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/anomaly_detection.py +64 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/doc_preprocessor.py +97 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/face_recognition.py +223 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/formula_recognition.py +97 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/human_keypoint_detection.py +78 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/image_classification.py +66 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/image_multilabel_classification.py +70 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/instance_segmentation.py +81 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/layout_parsing.py +115 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/m_3d_bev_detection.py +76 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/multilingual_speech_recognition.py +89 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/object_detection.py +74 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/ocr.py +99 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/open_vocabulary_detection.py +78 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/open_vocabulary_segmentation.py +85 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/pedestrian_attribute_recognition.py +81 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/pp_chatocrv3_doc.py +191 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/pp_chatocrv4_doc.py +221 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/pp_shituv2.py +218 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/pp_structurev3.py +136 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/rotated_object_detection.py +78 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/seal_recognition.py +103 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/semantic_segmentation.py +64 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/small_object_detection.py +69 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/table_recognition.py +105 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/table_recognition_v2.py +107 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/ts_anomaly_detection.py +62 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/ts_classification.py +61 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/ts_forecast.py +62 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/vehicle_attribute_recognition.py +81 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/video_classification.py +73 -0
- paddlex/inference/serving/basic_serving/_pipeline_apps/video_detection.py +89 -0
- paddlex/inference/serving/basic_serving/_server.py +35 -0
- paddlex/inference/serving/infra/__init__.py +13 -0
- paddlex/inference/serving/infra/config.py +36 -0
- paddlex/inference/serving/infra/models.py +72 -0
- paddlex/inference/serving/infra/storage.py +175 -0
- paddlex/inference/serving/infra/utils.py +259 -0
- paddlex/inference/serving/schemas/__init__.py +13 -0
- paddlex/inference/serving/schemas/anomaly_detection.py +39 -0
- paddlex/inference/serving/schemas/doc_preprocessor.py +54 -0
- paddlex/inference/serving/schemas/face_recognition.py +124 -0
- paddlex/inference/serving/schemas/formula_recognition.py +56 -0
- paddlex/inference/serving/schemas/human_keypoint_detection.py +55 -0
- paddlex/inference/serving/schemas/image_classification.py +45 -0
- paddlex/inference/serving/schemas/image_multilabel_classification.py +47 -0
- paddlex/inference/serving/schemas/instance_segmentation.py +53 -0
- paddlex/inference/serving/schemas/layout_parsing.py +72 -0
- paddlex/inference/serving/schemas/m_3d_bev_detection.py +48 -0
- paddlex/inference/serving/schemas/multilingual_speech_recognition.py +57 -0
- paddlex/inference/serving/schemas/object_detection.py +52 -0
- paddlex/inference/serving/schemas/ocr.py +60 -0
- paddlex/inference/serving/schemas/open_vocabulary_detection.py +52 -0
- paddlex/inference/serving/schemas/open_vocabulary_segmentation.py +52 -0
- paddlex/inference/serving/schemas/pedestrian_attribute_recognition.py +61 -0
- paddlex/inference/serving/schemas/pp_chatocrv3_doc.py +134 -0
- paddlex/inference/serving/schemas/pp_chatocrv4_doc.py +151 -0
- paddlex/inference/serving/schemas/pp_shituv2.py +124 -0
- paddlex/inference/serving/schemas/pp_structurev3.py +84 -0
- paddlex/inference/serving/schemas/rotated_object_detection.py +52 -0
- paddlex/inference/serving/schemas/seal_recognition.py +62 -0
- paddlex/inference/serving/schemas/semantic_segmentation.py +45 -0
- paddlex/inference/serving/schemas/shared/__init__.py +13 -0
- paddlex/inference/serving/schemas/shared/classification.py +23 -0
- paddlex/inference/serving/schemas/shared/image_segmentation.py +28 -0
- paddlex/inference/serving/schemas/shared/object_detection.py +24 -0
- paddlex/inference/serving/schemas/shared/ocr.py +25 -0
- paddlex/inference/serving/schemas/small_object_detection.py +52 -0
- paddlex/inference/serving/schemas/table_recognition.py +64 -0
- paddlex/inference/serving/schemas/table_recognition_v2.py +66 -0
- paddlex/inference/serving/schemas/ts_anomaly_detection.py +37 -0
- paddlex/inference/serving/schemas/ts_classification.py +38 -0
- paddlex/inference/serving/schemas/ts_forecast.py +37 -0
- paddlex/inference/serving/schemas/vehicle_attribute_recognition.py +61 -0
- paddlex/inference/serving/schemas/video_classification.py +44 -0
- paddlex/inference/serving/schemas/video_detection.py +56 -0
- paddlex/inference/utils/benchmark.py +23 -11
- paddlex/inference/utils/get_pipeline_path.py +2 -1
- paddlex/inference/utils/io/__init__.py +3 -0
- paddlex/inference/utils/io/readers.py +164 -17
- paddlex/inference/utils/io/writers.py +85 -2
- paddlex/inference/utils/new_ir_blacklist.py +6 -0
- paddlex/inference/utils/official_models.py +277 -211
- paddlex/inference/utils/pp_option.py +24 -4
- paddlex/model.py +12 -5
- paddlex/modules/3d_bev_detection/__init__.py +18 -0
- paddlex/modules/3d_bev_detection/dataset_checker/__init__.py +95 -0
- paddlex/modules/3d_bev_detection/dataset_checker/dataset_src/__init__.py +17 -0
- paddlex/modules/3d_bev_detection/dataset_checker/dataset_src/analyse_dataset.py +106 -0
- paddlex/modules/3d_bev_detection/dataset_checker/dataset_src/check_dataset.py +102 -0
- paddlex/modules/3d_bev_detection/evaluator.py +46 -0
- paddlex/modules/3d_bev_detection/exportor.py +22 -0
- paddlex/modules/3d_bev_detection/model_list.py +18 -0
- paddlex/modules/3d_bev_detection/trainer.py +70 -0
- paddlex/modules/__init__.py +34 -1
- paddlex/modules/base/build_model.py +1 -1
- paddlex/modules/base/dataset_checker/dataset_checker.py +6 -1
- paddlex/modules/base/evaluator.py +20 -4
- paddlex/modules/base/exportor.py +30 -5
- paddlex/modules/base/trainer.py +29 -6
- paddlex/modules/face_recognition/trainer.py +1 -23
- paddlex/modules/formula_recognition/__init__.py +5 -0
- paddlex/modules/formula_recognition/dataset_checker/__init__.py +113 -0
- paddlex/modules/formula_recognition/dataset_checker/dataset_src/__init__.py +19 -0
- paddlex/modules/formula_recognition/dataset_checker/dataset_src/analyse_dataset.py +157 -0
- paddlex/modules/formula_recognition/dataset_checker/dataset_src/check_dataset.py +80 -0
- paddlex/modules/formula_recognition/dataset_checker/dataset_src/convert_dataset.py +94 -0
- paddlex/modules/formula_recognition/dataset_checker/dataset_src/split_dataset.py +81 -0
- paddlex/modules/formula_recognition/evaluator.py +77 -0
- paddlex/modules/formula_recognition/exportor.py +22 -0
- paddlex/modules/formula_recognition/model_list.py +3 -0
- paddlex/modules/formula_recognition/trainer.py +121 -0
- paddlex/modules/image_classification/model_list.py +2 -0
- paddlex/modules/instance_segmentation/dataset_checker/__init__.py +15 -0
- paddlex/modules/keypoint_detection/__init__.py +18 -0
- paddlex/modules/keypoint_detection/dataset_checker/__init__.py +56 -0
- paddlex/modules/keypoint_detection/dataset_checker/dataset_src/__init__.py +15 -0
- paddlex/modules/keypoint_detection/dataset_checker/dataset_src/check_dataset.py +86 -0
- paddlex/modules/keypoint_detection/dataset_checker/dataset_src/utils/__init__.py +13 -0
- paddlex/modules/keypoint_detection/dataset_checker/dataset_src/utils/visualizer.py +119 -0
- paddlex/modules/keypoint_detection/evaluator.py +41 -0
- paddlex/modules/keypoint_detection/exportor.py +22 -0
- paddlex/modules/keypoint_detection/model_list.py +16 -0
- paddlex/modules/keypoint_detection/trainer.py +39 -0
- paddlex/modules/multilingual_speech_recognition/__init__.py +18 -0
- paddlex/modules/multilingual_speech_recognition/dataset_checker.py +27 -0
- paddlex/modules/multilingual_speech_recognition/evaluator.py +27 -0
- paddlex/modules/multilingual_speech_recognition/exportor.py +27 -0
- paddlex/modules/multilingual_speech_recognition/model_list.py +22 -0
- paddlex/modules/multilingual_speech_recognition/trainer.py +40 -0
- paddlex/modules/object_detection/evaluator.py +12 -1
- paddlex/modules/object_detection/model_list.py +10 -0
- paddlex/modules/object_detection/trainer.py +15 -1
- paddlex/modules/open_vocabulary_detection/__init__.py +18 -0
- paddlex/modules/open_vocabulary_detection/dataset_checker.py +29 -0
- paddlex/modules/open_vocabulary_detection/evaluator.py +29 -0
- paddlex/modules/open_vocabulary_detection/exportor.py +29 -0
- paddlex/modules/open_vocabulary_detection/model_list.py +18 -0
- paddlex/modules/open_vocabulary_detection/trainer.py +42 -0
- paddlex/modules/open_vocabulary_segmentation/__init__.py +18 -0
- paddlex/modules/open_vocabulary_segmentation/dataset_checker.py +29 -0
- paddlex/modules/open_vocabulary_segmentation/evaluator.py +29 -0
- paddlex/modules/open_vocabulary_segmentation/exportor.py +29 -0
- paddlex/modules/open_vocabulary_segmentation/model_list.py +19 -0
- paddlex/modules/open_vocabulary_segmentation/trainer.py +42 -0
- paddlex/modules/semantic_segmentation/dataset_checker/__init__.py +15 -0
- paddlex/modules/semantic_segmentation/exportor.py +9 -0
- paddlex/modules/semantic_segmentation/model_list.py +2 -0
- paddlex/modules/semantic_segmentation/trainer.py +2 -0
- paddlex/modules/table_recognition/dataset_checker/__init__.py +16 -1
- paddlex/modules/table_recognition/dataset_checker/dataset_src/check_dataset.py +13 -14
- paddlex/modules/table_recognition/model_list.py +2 -0
- paddlex/modules/text_detection/dataset_checker/__init__.py +16 -1
- paddlex/modules/text_detection/dataset_checker/dataset_src/check_dataset.py +13 -3
- paddlex/modules/text_detection/model_list.py +2 -0
- paddlex/modules/text_recognition/dataset_checker/__init__.py +16 -4
- paddlex/modules/text_recognition/dataset_checker/dataset_src/check_dataset.py +13 -3
- paddlex/modules/text_recognition/evaluator.py +4 -3
- paddlex/modules/text_recognition/exportor.py +0 -3
- paddlex/modules/text_recognition/model_list.py +14 -0
- paddlex/modules/text_recognition/trainer.py +4 -3
- paddlex/modules/ts_anomaly_detection/dataset_checker/__init__.py +15 -0
- paddlex/modules/ts_anomaly_detection/trainer.py +17 -1
- paddlex/modules/ts_classification/dataset_checker/__init__.py +15 -0
- paddlex/modules/ts_classification/trainer.py +17 -1
- paddlex/modules/ts_forecast/dataset_checker/__init__.py +15 -0
- paddlex/modules/ts_forecast/trainer.py +17 -1
- paddlex/modules/video_classification/__init__.py +18 -0
- paddlex/modules/video_classification/dataset_checker/__init__.py +93 -0
- paddlex/modules/video_classification/dataset_checker/dataset_src/__init__.py +18 -0
- paddlex/modules/video_classification/dataset_checker/dataset_src/analyse_dataset.py +93 -0
- paddlex/modules/video_classification/dataset_checker/dataset_src/check_dataset.py +121 -0
- paddlex/modules/video_classification/dataset_checker/dataset_src/split_dataset.py +82 -0
- paddlex/modules/video_classification/evaluator.py +44 -0
- paddlex/modules/video_classification/exportor.py +22 -0
- paddlex/modules/video_classification/model_list.py +19 -0
- paddlex/modules/video_classification/trainer.py +88 -0
- paddlex/modules/video_detection/__init__.py +18 -0
- paddlex/modules/video_detection/dataset_checker/__init__.py +86 -0
- paddlex/modules/video_detection/dataset_checker/dataset_src/__init__.py +17 -0
- paddlex/modules/video_detection/dataset_checker/dataset_src/analyse_dataset.py +101 -0
- paddlex/modules/video_detection/dataset_checker/dataset_src/check_dataset.py +134 -0
- paddlex/modules/video_detection/evaluator.py +42 -0
- paddlex/modules/video_detection/exportor.py +22 -0
- paddlex/modules/video_detection/model_list.py +15 -0
- paddlex/modules/video_detection/trainer.py +82 -0
- paddlex/ops/__init__.py +149 -0
- paddlex/ops/iou3d_nms/iou3d_cpu.cpp +264 -0
- paddlex/ops/iou3d_nms/iou3d_cpu.h +27 -0
- paddlex/ops/iou3d_nms/iou3d_nms.cpp +204 -0
- paddlex/ops/iou3d_nms/iou3d_nms.h +33 -0
- paddlex/ops/iou3d_nms/iou3d_nms_api.cpp +108 -0
- paddlex/ops/iou3d_nms/iou3d_nms_kernel.cu +482 -0
- paddlex/ops/setup.py +37 -0
- paddlex/ops/voxel/voxelize_op.cc +191 -0
- paddlex/ops/voxel/voxelize_op.cu +346 -0
- paddlex/paddle2onnx_requirements.txt +1 -0
- paddlex/paddlex_cli.py +339 -72
- paddlex/repo_apis/Paddle3D_api/__init__.py +17 -0
- paddlex/repo_apis/Paddle3D_api/bev_fusion/__init__.py +18 -0
- paddlex/repo_apis/Paddle3D_api/bev_fusion/config.py +118 -0
- paddlex/repo_apis/Paddle3D_api/bev_fusion/model.py +238 -0
- paddlex/repo_apis/Paddle3D_api/bev_fusion/register.py +55 -0
- paddlex/repo_apis/Paddle3D_api/bev_fusion/runner.py +104 -0
- paddlex/repo_apis/Paddle3D_api/pp3d_config.py +144 -0
- paddlex/repo_apis/PaddleClas_api/cls/model.py +6 -0
- paddlex/repo_apis/PaddleClas_api/cls/register.py +20 -2
- paddlex/repo_apis/PaddleDetection_api/instance_seg/config.py +8 -4
- paddlex/repo_apis/PaddleDetection_api/instance_seg/model.py +6 -0
- paddlex/repo_apis/PaddleDetection_api/object_det/config.py +27 -5
- paddlex/repo_apis/PaddleDetection_api/object_det/model.py +6 -0
- paddlex/repo_apis/PaddleDetection_api/object_det/official_categories.py +81 -0
- paddlex/repo_apis/PaddleDetection_api/object_det/register.py +182 -3
- paddlex/repo_apis/PaddleOCR_api/__init__.py +1 -0
- paddlex/repo_apis/PaddleOCR_api/formula_rec/__init__.py +16 -0
- paddlex/repo_apis/PaddleOCR_api/formula_rec/config.py +570 -0
- paddlex/repo_apis/PaddleOCR_api/formula_rec/model.py +402 -0
- paddlex/repo_apis/PaddleOCR_api/formula_rec/register.py +73 -0
- paddlex/repo_apis/PaddleOCR_api/formula_rec/runner.py +240 -0
- paddlex/repo_apis/PaddleOCR_api/table_rec/register.py +18 -0
- paddlex/repo_apis/PaddleOCR_api/text_det/register.py +18 -0
- paddlex/repo_apis/PaddleOCR_api/text_rec/config.py +21 -0
- paddlex/repo_apis/PaddleOCR_api/text_rec/model.py +6 -0
- paddlex/repo_apis/PaddleOCR_api/text_rec/register.py +126 -7
- paddlex/repo_apis/PaddleSeg_api/seg/config.py +9 -0
- paddlex/repo_apis/PaddleSeg_api/seg/model.py +10 -0
- paddlex/repo_apis/PaddleSeg_api/seg/register.py +20 -0
- paddlex/repo_apis/PaddleTS_api/ts_base/config.py +24 -0
- paddlex/repo_apis/PaddleTS_api/ts_base/model.py +11 -7
- paddlex/repo_apis/PaddleVideo_api/__init__.py +17 -0
- paddlex/repo_apis/PaddleVideo_api/config_utils.py +51 -0
- paddlex/repo_apis/PaddleVideo_api/video_cls/__init__.py +19 -0
- paddlex/repo_apis/PaddleVideo_api/video_cls/config.py +547 -0
- paddlex/repo_apis/PaddleVideo_api/video_cls/model.py +346 -0
- paddlex/repo_apis/PaddleVideo_api/video_cls/register.py +71 -0
- paddlex/repo_apis/PaddleVideo_api/video_cls/runner.py +205 -0
- paddlex/repo_apis/PaddleVideo_api/video_det/__init__.py +19 -0
- paddlex/repo_apis/PaddleVideo_api/video_det/config.py +548 -0
- paddlex/repo_apis/PaddleVideo_api/video_det/model.py +298 -0
- paddlex/repo_apis/PaddleVideo_api/video_det/register.py +45 -0
- paddlex/repo_apis/PaddleVideo_api/video_det/runner.py +200 -0
- paddlex/repo_apis/base/runner.py +2 -1
- paddlex/repo_manager/meta.py +29 -2
- paddlex/repo_manager/repo.py +24 -5
- paddlex/repo_manager/requirements.txt +10 -7
- paddlex/repo_manager/utils.py +62 -1
- paddlex/serving_requirements.txt +9 -0
- paddlex/utils/config.py +4 -3
- paddlex/utils/custom_device_whitelist.py +457 -0
- paddlex/utils/device.py +74 -26
- paddlex/utils/env.py +28 -0
- paddlex/utils/flags.py +4 -0
- paddlex/utils/fonts/__init__.py +48 -5
- paddlex/utils/lazy_loader.py +2 -0
- paddlex/utils/logging.py +1 -2
- paddlex/utils/pipeline_arguments.py +711 -0
- paddlex-3.0.0rc0.dist-info/METADATA +1035 -0
- paddlex-3.0.0rc0.dist-info/RECORD +1015 -0
- paddlex-3.0.0rc0.dist-info/WHEEL +5 -0
- paddlex/configs/face_recognition/MobileFaceNet.yaml +0 -44
- paddlex/configs/face_recognition/ResNet50_face.yaml +0 -44
- paddlex/configs/formula_recognition/LaTeX_OCR_rec.yaml +0 -40
- paddlex/configs/image_classification/CLIP_vit_base_patch16_224.yaml +0 -41
- paddlex/configs/image_classification/CLIP_vit_large_patch14_224.yaml +0 -41
- paddlex/configs/image_classification/ConvNeXt_large_384.yaml +0 -41
- paddlex/configs/object_detection/YOLOX-X.yaml +0 -40
- paddlex/configs/semantic_segmentation/SeaFormer_base.yaml +0 -40
- paddlex/configs/semantic_segmentation/SeaFormer_large.yaml +0 -40
- paddlex/configs/semantic_segmentation/SeaFormer_small.yaml +0 -40
- paddlex/configs/semantic_segmentation/SeaFormer_tiny.yaml +0 -40
- paddlex/inference/components/__init__.py +0 -18
- paddlex/inference/components/base.py +0 -292
- paddlex/inference/components/llm/__init__.py +0 -25
- paddlex/inference/components/llm/base.py +0 -65
- paddlex/inference/components/llm/erniebot.py +0 -212
- paddlex/inference/components/paddle_predictor/__init__.py +0 -20
- paddlex/inference/components/paddle_predictor/predictor.py +0 -332
- paddlex/inference/components/retrieval/__init__.py +0 -15
- paddlex/inference/components/retrieval/faiss.py +0 -359
- paddlex/inference/components/task_related/__init__.py +0 -33
- paddlex/inference/components/task_related/clas.py +0 -124
- paddlex/inference/components/task_related/det.py +0 -284
- paddlex/inference/components/task_related/instance_seg.py +0 -89
- paddlex/inference/components/task_related/seal_det_warp.py +0 -940
- paddlex/inference/components/task_related/seg.py +0 -40
- paddlex/inference/components/task_related/table_rec.py +0 -191
- paddlex/inference/components/task_related/text_det.py +0 -895
- paddlex/inference/components/task_related/text_rec.py +0 -353
- paddlex/inference/components/task_related/warp.py +0 -43
- paddlex/inference/components/transforms/__init__.py +0 -16
- paddlex/inference/components/transforms/image/__init__.py +0 -15
- paddlex/inference/components/transforms/image/common.py +0 -598
- paddlex/inference/components/transforms/image/funcs.py +0 -58
- paddlex/inference/components/transforms/read_data.py +0 -67
- paddlex/inference/components/transforms/ts/__init__.py +0 -15
- paddlex/inference/components/transforms/ts/common.py +0 -393
- paddlex/inference/components/transforms/ts/funcs.py +0 -424
- paddlex/inference/models/anomaly_detection.py +0 -87
- paddlex/inference/models/base/base_predictor.py +0 -76
- paddlex/inference/models/base/basic_predictor.py +0 -122
- paddlex/inference/models/face_recognition.py +0 -21
- paddlex/inference/models/formula_recognition.py +0 -55
- paddlex/inference/models/general_recognition.py +0 -99
- paddlex/inference/models/image_classification.py +0 -101
- paddlex/inference/models/image_unwarping.py +0 -43
- paddlex/inference/models/instance_segmentation.py +0 -66
- paddlex/inference/models/multilabel_classification.py +0 -33
- paddlex/inference/models/object_detection.py +0 -129
- paddlex/inference/models/semantic_segmentation.py +0 -86
- paddlex/inference/models/table_recognition.py +0 -106
- paddlex/inference/models/text_detection.py +0 -105
- paddlex/inference/models/text_recognition.py +0 -78
- paddlex/inference/models/ts_ad.py +0 -68
- paddlex/inference/models/ts_cls.py +0 -57
- paddlex/inference/models/ts_fc.py +0 -73
- paddlex/inference/pipelines/attribute_recognition.py +0 -92
- paddlex/inference/pipelines/face_recognition.py +0 -49
- paddlex/inference/pipelines/formula_recognition.py +0 -102
- paddlex/inference/pipelines/layout_parsing/layout_parsing.py +0 -362
- paddlex/inference/pipelines/ocr.py +0 -80
- paddlex/inference/pipelines/pp_shitu_v2.py +0 -152
- paddlex/inference/pipelines/ppchatocrv3/__init__.py +0 -15
- paddlex/inference/pipelines/ppchatocrv3/ch_prompt.yaml +0 -14
- paddlex/inference/pipelines/ppchatocrv3/ppchatocrv3.py +0 -717
- paddlex/inference/pipelines/ppchatocrv3/utils.py +0 -168
- paddlex/inference/pipelines/seal_recognition.py +0 -152
- paddlex/inference/pipelines/serving/__init__.py +0 -17
- paddlex/inference/pipelines/serving/_pipeline_apps/__init__.py +0 -205
- paddlex/inference/pipelines/serving/_pipeline_apps/anomaly_detection.py +0 -80
- paddlex/inference/pipelines/serving/_pipeline_apps/face_recognition.py +0 -317
- paddlex/inference/pipelines/serving/_pipeline_apps/formula_recognition.py +0 -119
- paddlex/inference/pipelines/serving/_pipeline_apps/image_classification.py +0 -101
- paddlex/inference/pipelines/serving/_pipeline_apps/instance_segmentation.py +0 -112
- paddlex/inference/pipelines/serving/_pipeline_apps/layout_parsing.py +0 -205
- paddlex/inference/pipelines/serving/_pipeline_apps/multi_label_image_classification.py +0 -90
- paddlex/inference/pipelines/serving/_pipeline_apps/object_detection.py +0 -90
- paddlex/inference/pipelines/serving/_pipeline_apps/ocr.py +0 -98
- paddlex/inference/pipelines/serving/_pipeline_apps/pedestrian_attribute_recognition.py +0 -102
- paddlex/inference/pipelines/serving/_pipeline_apps/pp_shitu_v2.py +0 -319
- paddlex/inference/pipelines/serving/_pipeline_apps/ppchatocrv3.py +0 -445
- paddlex/inference/pipelines/serving/_pipeline_apps/seal_recognition.py +0 -110
- paddlex/inference/pipelines/serving/_pipeline_apps/semantic_segmentation.py +0 -82
- paddlex/inference/pipelines/serving/_pipeline_apps/small_object_detection.py +0 -92
- paddlex/inference/pipelines/serving/_pipeline_apps/table_recognition.py +0 -110
- paddlex/inference/pipelines/serving/_pipeline_apps/ts_ad.py +0 -68
- paddlex/inference/pipelines/serving/_pipeline_apps/ts_cls.py +0 -68
- paddlex/inference/pipelines/serving/_pipeline_apps/ts_fc.py +0 -68
- paddlex/inference/pipelines/serving/_pipeline_apps/vehicle_attribute_recognition.py +0 -102
- paddlex/inference/pipelines/serving/app.py +0 -164
- paddlex/inference/pipelines/serving/models.py +0 -30
- paddlex/inference/pipelines/serving/server.py +0 -25
- paddlex/inference/pipelines/serving/storage.py +0 -161
- paddlex/inference/pipelines/serving/utils.py +0 -190
- paddlex/inference/pipelines/single_model_pipeline.py +0 -76
- paddlex/inference/pipelines/table_recognition/table_recognition.py +0 -193
- paddlex/inference/results/__init__.py +0 -31
- paddlex/inference/results/attribute_rec.py +0 -89
- paddlex/inference/results/base.py +0 -43
- paddlex/inference/results/chat_ocr.py +0 -158
- paddlex/inference/results/clas.py +0 -133
- paddlex/inference/results/det.py +0 -86
- paddlex/inference/results/face_rec.py +0 -34
- paddlex/inference/results/formula_rec.py +0 -363
- paddlex/inference/results/instance_seg.py +0 -152
- paddlex/inference/results/ocr.py +0 -157
- paddlex/inference/results/seal_rec.py +0 -50
- paddlex/inference/results/seg.py +0 -72
- paddlex/inference/results/shitu.py +0 -35
- paddlex/inference/results/table_rec.py +0 -109
- paddlex/inference/results/text_det.py +0 -33
- paddlex/inference/results/text_rec.py +0 -66
- paddlex/inference/results/ts.py +0 -37
- paddlex/inference/results/utils/mixin.py +0 -204
- paddlex/inference/results/warp.py +0 -31
- paddlex/inference/utils/process_hook.py +0 -54
- paddlex/pipelines/OCR.yaml +0 -8
- paddlex/pipelines/PP-ChatOCRv3-doc.yaml +0 -27
- paddlex/pipelines/PP-ShiTuV2.yaml +0 -13
- paddlex/pipelines/anomaly_detection.yaml +0 -7
- paddlex/pipelines/face_recognition.yaml +0 -13
- paddlex/pipelines/formula_recognition.yaml +0 -8
- paddlex/pipelines/image_classification.yaml +0 -7
- paddlex/pipelines/instance_segmentation.yaml +0 -7
- paddlex/pipelines/layout_parsing.yaml +0 -14
- paddlex/pipelines/multi_label_image_classification.yaml +0 -7
- paddlex/pipelines/object_detection.yaml +0 -7
- paddlex/pipelines/pedestrian_attribute_recognition.yaml +0 -7
- paddlex/pipelines/seal_recognition.yaml +0 -10
- paddlex/pipelines/semantic_segmentation.yaml +0 -7
- paddlex/pipelines/small_object_detection.yaml +0 -7
- paddlex/pipelines/table_recognition.yaml +0 -12
- paddlex/pipelines/ts_ad.yaml +0 -7
- paddlex/pipelines/ts_cls.yaml +0 -7
- paddlex/pipelines/ts_fc.yaml +0 -7
- paddlex/pipelines/vehicle_attribute_recognition.yaml +0 -7
- paddlex/utils/fonts/PingFang-SC-Regular.ttf +0 -0
- paddlex-3.0.0b2.dist-info/METADATA +0 -760
- paddlex-3.0.0b2.dist-info/RECORD +0 -646
- paddlex-3.0.0b2.dist-info/WHEEL +0 -5
- /paddlex/configs/{doc_text_orientation → modules/doc_text_orientation}/PP-LCNet_x1_0_doc_ori.yaml +0 -0
- /paddlex/configs/{face_detection → modules/face_detection}/BlazeFace-FPN-SSH.yaml +0 -0
- /paddlex/configs/{face_detection → modules/face_detection}/BlazeFace.yaml +0 -0
- /paddlex/configs/{face_detection → modules/face_detection}/PP-YOLOE_plus-S_face.yaml +0 -0
- /paddlex/configs/{face_detection → modules/face_detection}/PicoDet_LCNet_x2_5_face.yaml +0 -0
- /paddlex/configs/{human_detection → modules/human_detection}/PP-YOLOE-L_human.yaml +0 -0
- /paddlex/configs/{human_detection → modules/human_detection}/PP-YOLOE-S_human.yaml +0 -0
- /paddlex/configs/{anomaly_detection → modules/image_anomaly_detection}/STFPM.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/ConvNeXt_base_224.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/ConvNeXt_base_384.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/ConvNeXt_large_224.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/ConvNeXt_small.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/ConvNeXt_tiny.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/FasterNet-L.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/FasterNet-M.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/FasterNet-S.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/FasterNet-T0.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/FasterNet-T1.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/FasterNet-T2.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV1_x0_25.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV1_x0_5.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV1_x0_75.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV1_x1_0.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV2_x0_25.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV2_x0_5.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV2_x1_0.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV2_x1_5.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV2_x2_0.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV3_large_x0_35.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV3_large_x0_5.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV3_large_x0_75.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV3_large_x1_0.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV3_large_x1_25.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV3_small_x0_35.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV3_small_x0_5.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV3_small_x0_75.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV3_small_x1_0.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV3_small_x1_25.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV4_conv_large.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV4_conv_medium.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV4_conv_small.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV4_hybrid_large.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/MobileNetV4_hybrid_medium.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-HGNetV2-B0.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-HGNetV2-B1.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-HGNetV2-B2.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-HGNetV2-B3.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-HGNetV2-B4.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-HGNetV2-B5.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-HGNetV2-B6.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-HGNet_base.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-HGNet_small.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-HGNet_tiny.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-LCNetV2_base.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-LCNetV2_large.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-LCNetV2_small.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-LCNet_x0_25.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-LCNet_x0_35.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-LCNet_x0_5.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-LCNet_x0_75.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-LCNet_x1_0.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-LCNet_x1_5.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-LCNet_x2_0.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/PP-LCNet_x2_5.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/ResNet101.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/ResNet101_vd.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/ResNet152.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/ResNet152_vd.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/ResNet18.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/ResNet18_vd.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/ResNet200_vd.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/ResNet34.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/ResNet34_vd.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/ResNet50.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/ResNet50_vd.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/StarNet-S1.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/StarNet-S2.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/StarNet-S3.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/StarNet-S4.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/SwinTransformer_base_patch4_window12_384.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/SwinTransformer_base_patch4_window7_224.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/SwinTransformer_large_patch4_window12_384.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/SwinTransformer_large_patch4_window7_224.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/SwinTransformer_small_patch4_window7_224.yaml +0 -0
- /paddlex/configs/{image_classification → modules/image_classification}/SwinTransformer_tiny_patch4_window7_224.yaml +0 -0
- /paddlex/configs/{general_recognition → modules/image_feature}/PP-ShiTuV2_rec.yaml +0 -0
- /paddlex/configs/{general_recognition → modules/image_feature}/PP-ShiTuV2_rec_CLIP_vit_base.yaml +0 -0
- /paddlex/configs/{general_recognition → modules/image_feature}/PP-ShiTuV2_rec_CLIP_vit_large.yaml +0 -0
- /paddlex/configs/{multilabel_classification → modules/image_multilabel_classification}/CLIP_vit_base_patch16_448_ML.yaml +0 -0
- /paddlex/configs/{multilabel_classification → modules/image_multilabel_classification}/PP-HGNetV2-B0_ML.yaml +0 -0
- /paddlex/configs/{multilabel_classification → modules/image_multilabel_classification}/PP-HGNetV2-B4_ML.yaml +0 -0
- /paddlex/configs/{multilabel_classification → modules/image_multilabel_classification}/PP-HGNetV2-B6_ML.yaml +0 -0
- /paddlex/configs/{multilabel_classification → modules/image_multilabel_classification}/PP-LCNet_x1_0_ML.yaml +0 -0
- /paddlex/configs/{multilabel_classification → modules/image_multilabel_classification}/ResNet50_ML.yaml +0 -0
- /paddlex/configs/{image_unwarping → modules/image_unwarping}/UVDoc.yaml +0 -0
- /paddlex/configs/{instance_segmentation → modules/instance_segmentation}/Cascade-MaskRCNN-ResNet50-FPN.yaml +0 -0
- /paddlex/configs/{instance_segmentation → modules/instance_segmentation}/Cascade-MaskRCNN-ResNet50-vd-SSLDv2-FPN.yaml +0 -0
- /paddlex/configs/{instance_segmentation → modules/instance_segmentation}/Mask-RT-DETR-H.yaml +0 -0
- /paddlex/configs/{instance_segmentation → modules/instance_segmentation}/Mask-RT-DETR-L.yaml +0 -0
- /paddlex/configs/{instance_segmentation → modules/instance_segmentation}/Mask-RT-DETR-M.yaml +0 -0
- /paddlex/configs/{instance_segmentation → modules/instance_segmentation}/Mask-RT-DETR-S.yaml +0 -0
- /paddlex/configs/{instance_segmentation → modules/instance_segmentation}/Mask-RT-DETR-X.yaml +0 -0
- /paddlex/configs/{instance_segmentation → modules/instance_segmentation}/MaskRCNN-ResNeXt101-vd-FPN.yaml +0 -0
- /paddlex/configs/{instance_segmentation → modules/instance_segmentation}/MaskRCNN-ResNet101-FPN.yaml +0 -0
- /paddlex/configs/{instance_segmentation → modules/instance_segmentation}/MaskRCNN-ResNet101-vd-FPN.yaml +0 -0
- /paddlex/configs/{instance_segmentation → modules/instance_segmentation}/MaskRCNN-ResNet50-FPN.yaml +0 -0
- /paddlex/configs/{instance_segmentation → modules/instance_segmentation}/MaskRCNN-ResNet50-vd-FPN.yaml +0 -0
- /paddlex/configs/{instance_segmentation → modules/instance_segmentation}/MaskRCNN-ResNet50.yaml +0 -0
- /paddlex/configs/{instance_segmentation → modules/instance_segmentation}/PP-YOLOE_seg-S.yaml +0 -0
- /paddlex/configs/{instance_segmentation → modules/instance_segmentation}/SOLOv2.yaml +0 -0
- /paddlex/configs/{structure_analysis → modules/layout_detection}/PicoDet-L_layout_17cls.yaml +0 -0
- /paddlex/configs/{structure_analysis → modules/layout_detection}/PicoDet-L_layout_3cls.yaml +0 -0
- /paddlex/configs/{structure_analysis → modules/layout_detection}/PicoDet-S_layout_17cls.yaml +0 -0
- /paddlex/configs/{structure_analysis → modules/layout_detection}/PicoDet-S_layout_3cls.yaml +0 -0
- /paddlex/configs/{structure_analysis → modules/layout_detection}/PicoDet_layout_1x.yaml +0 -0
- /paddlex/configs/{structure_analysis → modules/layout_detection}/PicoDet_layout_1x_table.yaml +0 -0
- /paddlex/configs/{structure_analysis → modules/layout_detection}/RT-DETR-H_layout_17cls.yaml +0 -0
- /paddlex/configs/{structure_analysis → modules/layout_detection}/RT-DETR-H_layout_3cls.yaml +0 -0
- /paddlex/configs/{mainbody_detection → modules/mainbody_detection}/PP-ShiTuV2_det.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/Cascade-FasterRCNN-ResNet50-FPN.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/Cascade-FasterRCNN-ResNet50-vd-SSLDv2-FPN.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/CenterNet-DLA-34.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/CenterNet-ResNet50.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/DETR-R50.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/FCOS-ResNet50.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/FasterRCNN-ResNeXt101-vd-FPN.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/FasterRCNN-ResNet101-FPN.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/FasterRCNN-ResNet101.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/FasterRCNN-ResNet34-FPN.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/FasterRCNN-ResNet50-FPN.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/FasterRCNN-ResNet50-vd-FPN.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/FasterRCNN-ResNet50-vd-SSLDv2-FPN.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/FasterRCNN-ResNet50.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/FasterRCNN-Swin-Tiny-FPN.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/PP-YOLOE_plus-L.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/PP-YOLOE_plus-M.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/PP-YOLOE_plus-S.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/PP-YOLOE_plus-X.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/PicoDet-L.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/PicoDet-M.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/PicoDet-S.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/PicoDet-XS.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/RT-DETR-H.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/RT-DETR-L.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/RT-DETR-R18.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/RT-DETR-R50.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/RT-DETR-X.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/YOLOX-L.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/YOLOX-M.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/YOLOX-N.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/YOLOX-S.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/YOLOX-T.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/YOLOv3-DarkNet53.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/YOLOv3-MobileNetV3.yaml +0 -0
- /paddlex/configs/{object_detection → modules/object_detection}/YOLOv3-ResNet50_vd_DCN.yaml +0 -0
- /paddlex/configs/{pedestrian_attribute → modules/pedestrian_attribute_recognition}/PP-LCNet_x1_0_pedestrian_attribute.yaml +0 -0
- /paddlex/configs/{text_detection_seal → modules/seal_text_detection}/PP-OCRv4_mobile_seal_det.yaml +0 -0
- /paddlex/configs/{text_detection_seal → modules/seal_text_detection}/PP-OCRv4_server_seal_det.yaml +0 -0
- /paddlex/configs/{semantic_segmentation → modules/semantic_segmentation}/Deeplabv3-R101.yaml +0 -0
- /paddlex/configs/{semantic_segmentation → modules/semantic_segmentation}/Deeplabv3-R50.yaml +0 -0
- /paddlex/configs/{semantic_segmentation → modules/semantic_segmentation}/Deeplabv3_Plus-R101.yaml +0 -0
- /paddlex/configs/{semantic_segmentation → modules/semantic_segmentation}/Deeplabv3_Plus-R50.yaml +0 -0
- /paddlex/configs/{semantic_segmentation → modules/semantic_segmentation}/OCRNet_HRNet-W18.yaml +0 -0
- /paddlex/configs/{semantic_segmentation → modules/semantic_segmentation}/OCRNet_HRNet-W48.yaml +0 -0
- /paddlex/configs/{semantic_segmentation → modules/semantic_segmentation}/PP-LiteSeg-B.yaml +0 -0
- /paddlex/configs/{semantic_segmentation → modules/semantic_segmentation}/PP-LiteSeg-T.yaml +0 -0
- /paddlex/configs/{semantic_segmentation → modules/semantic_segmentation}/SegFormer-B0.yaml +0 -0
- /paddlex/configs/{semantic_segmentation → modules/semantic_segmentation}/SegFormer-B1.yaml +0 -0
- /paddlex/configs/{semantic_segmentation → modules/semantic_segmentation}/SegFormer-B2.yaml +0 -0
- /paddlex/configs/{semantic_segmentation → modules/semantic_segmentation}/SegFormer-B3.yaml +0 -0
- /paddlex/configs/{semantic_segmentation → modules/semantic_segmentation}/SegFormer-B4.yaml +0 -0
- /paddlex/configs/{semantic_segmentation → modules/semantic_segmentation}/SegFormer-B5.yaml +0 -0
- /paddlex/configs/{small_object_detection → modules/small_object_detection}/PP-YOLOE_plus_SOD-L.yaml +0 -0
- /paddlex/configs/{small_object_detection → modules/small_object_detection}/PP-YOLOE_plus_SOD-S.yaml +0 -0
- /paddlex/configs/{small_object_detection → modules/small_object_detection}/PP-YOLOE_plus_SOD-largesize-L.yaml +0 -0
- /paddlex/configs/{table_recognition → modules/table_structure_recognition}/SLANet.yaml +0 -0
- /paddlex/configs/{table_recognition → modules/table_structure_recognition}/SLANet_plus.yaml +0 -0
- /paddlex/configs/{text_detection → modules/text_detection}/PP-OCRv4_mobile_det.yaml +0 -0
- /paddlex/configs/{text_detection → modules/text_detection}/PP-OCRv4_server_det.yaml +0 -0
- /paddlex/configs/{text_recognition → modules/text_recognition}/PP-OCRv4_mobile_rec.yaml +0 -0
- /paddlex/configs/{text_recognition → modules/text_recognition}/PP-OCRv4_server_rec.yaml +0 -0
- /paddlex/configs/{text_recognition → modules/text_recognition}/ch_RepSVTR_rec.yaml +0 -0
- /paddlex/configs/{text_recognition → modules/text_recognition}/ch_SVTRv2_rec.yaml +0 -0
- /paddlex/configs/{ts_anomaly_detection → modules/ts_anomaly_detection}/AutoEncoder_ad.yaml +0 -0
- /paddlex/configs/{ts_anomaly_detection → modules/ts_anomaly_detection}/DLinear_ad.yaml +0 -0
- /paddlex/configs/{ts_anomaly_detection → modules/ts_anomaly_detection}/Nonstationary_ad.yaml +0 -0
- /paddlex/configs/{ts_anomaly_detection → modules/ts_anomaly_detection}/PatchTST_ad.yaml +0 -0
- /paddlex/configs/{ts_anomaly_detection → modules/ts_anomaly_detection}/TimesNet_ad.yaml +0 -0
- /paddlex/configs/{ts_classification → modules/ts_classification}/TimesNet_cls.yaml +0 -0
- /paddlex/configs/{ts_forecast → modules/ts_forecast}/DLinear.yaml +0 -0
- /paddlex/configs/{ts_forecast → modules/ts_forecast}/NLinear.yaml +0 -0
- /paddlex/configs/{ts_forecast → modules/ts_forecast}/Nonstationary.yaml +0 -0
- /paddlex/configs/{ts_forecast → modules/ts_forecast}/PatchTST.yaml +0 -0
- /paddlex/configs/{ts_forecast → modules/ts_forecast}/RLinear.yaml +0 -0
- /paddlex/configs/{ts_forecast → modules/ts_forecast}/TiDE.yaml +0 -0
- /paddlex/configs/{ts_forecast → modules/ts_forecast}/TimesNet.yaml +0 -0
- /paddlex/configs/{vehicle_attribute → modules/vehicle_attribute_recognition}/PP-LCNet_x1_0_vehicle_attribute.yaml +0 -0
- /paddlex/configs/{vehicle_detection → modules/vehicle_detection}/PP-YOLOE-L_vehicle.yaml +0 -0
- /paddlex/configs/{vehicle_detection → modules/vehicle_detection}/PP-YOLOE-S_vehicle.yaml +0 -0
- /paddlex/inference/{results/utils → common}/__init__.py +0 -0
- {paddlex-3.0.0b2.dist-info → paddlex-3.0.0rc0.dist-info}/LICENSE +0 -0
- {paddlex-3.0.0b2.dist-info → paddlex-3.0.0rc0.dist-info}/entry_points.txt +0 -0
- {paddlex-3.0.0b2.dist-info → paddlex-3.0.0rc0.dist-info}/top_level.txt +0 -0
@@ -1,895 +0,0 @@
|
|
1
|
-
# copyright (c) 2024 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
|
-
|
16
|
-
import os
|
17
|
-
import sys
|
18
|
-
import cv2
|
19
|
-
import copy
|
20
|
-
import math
|
21
|
-
import pyclipper
|
22
|
-
import numpy as np
|
23
|
-
from numpy.linalg import norm
|
24
|
-
from PIL import Image
|
25
|
-
from shapely.geometry import Polygon
|
26
|
-
|
27
|
-
from ...utils.io import ImageReader
|
28
|
-
from ....utils import logging
|
29
|
-
from ..base import BaseComponent
|
30
|
-
from .seal_det_warp import AutoRectifier
|
31
|
-
|
32
|
-
|
33
|
-
__all__ = ["DetResizeForTest", "NormalizeImage", "DBPostProcess", "CropByPolys"]
|
34
|
-
|
35
|
-
|
36
|
-
class DetResizeForTest(BaseComponent):
|
37
|
-
"""DetResizeForTest"""
|
38
|
-
|
39
|
-
INPUT_KEYS = ["img"]
|
40
|
-
OUTPUT_KEYS = ["img", "img_shape"]
|
41
|
-
DEAULT_INPUTS = {"img": "img"}
|
42
|
-
DEAULT_OUTPUTS = {"img": "img", "img_shape": "img_shape"}
|
43
|
-
|
44
|
-
def __init__(self, **kwargs):
|
45
|
-
super().__init__()
|
46
|
-
self.resize_type = 0
|
47
|
-
self.keep_ratio = False
|
48
|
-
if "image_shape" in kwargs:
|
49
|
-
self.image_shape = kwargs["image_shape"]
|
50
|
-
self.resize_type = 1
|
51
|
-
if "keep_ratio" in kwargs:
|
52
|
-
self.keep_ratio = kwargs["keep_ratio"]
|
53
|
-
elif "limit_side_len" in kwargs:
|
54
|
-
self.limit_side_len = kwargs["limit_side_len"]
|
55
|
-
self.limit_type = kwargs.get("limit_type", "min")
|
56
|
-
elif "resize_long" in kwargs:
|
57
|
-
self.resize_type = 2
|
58
|
-
self.resize_long = kwargs.get("resize_long", 960)
|
59
|
-
else:
|
60
|
-
self.limit_side_len = 736
|
61
|
-
self.limit_type = "min"
|
62
|
-
|
63
|
-
def apply(self, img):
|
64
|
-
"""apply"""
|
65
|
-
src_h, src_w, _ = img.shape
|
66
|
-
if sum([src_h, src_w]) < 64:
|
67
|
-
img = self.image_padding(img)
|
68
|
-
|
69
|
-
if self.resize_type == 0:
|
70
|
-
# img, shape = self.resize_image_type0(img)
|
71
|
-
img, [ratio_h, ratio_w] = self.resize_image_type0(img)
|
72
|
-
elif self.resize_type == 2:
|
73
|
-
img, [ratio_h, ratio_w] = self.resize_image_type2(img)
|
74
|
-
else:
|
75
|
-
# img, shape = self.resize_image_type1(img)
|
76
|
-
img, [ratio_h, ratio_w] = self.resize_image_type1(img)
|
77
|
-
return {"img": img, "img_shape": np.array([src_h, src_w, ratio_h, ratio_w])}
|
78
|
-
|
79
|
-
def image_padding(self, im, value=0):
|
80
|
-
"""padding image"""
|
81
|
-
h, w, c = im.shape
|
82
|
-
im_pad = np.zeros((max(32, h), max(32, w), c), np.uint8) + value
|
83
|
-
im_pad[:h, :w, :] = im
|
84
|
-
return im_pad
|
85
|
-
|
86
|
-
def resize_image_type1(self, img):
|
87
|
-
"""resize the image"""
|
88
|
-
resize_h, resize_w = self.image_shape
|
89
|
-
ori_h, ori_w = img.shape[:2] # (h, w, c)
|
90
|
-
if self.keep_ratio is True:
|
91
|
-
resize_w = ori_w * resize_h / ori_h
|
92
|
-
N = math.ceil(resize_w / 32)
|
93
|
-
resize_w = N * 32
|
94
|
-
ratio_h = float(resize_h) / ori_h
|
95
|
-
ratio_w = float(resize_w) / ori_w
|
96
|
-
img = cv2.resize(img, (int(resize_w), int(resize_h)))
|
97
|
-
# return img, np.array([ori_h, ori_w])
|
98
|
-
return img, [ratio_h, ratio_w]
|
99
|
-
|
100
|
-
def resize_image_type0(self, img):
|
101
|
-
"""
|
102
|
-
resize image to a size multiple of 32 which is required by the network
|
103
|
-
args:
|
104
|
-
img(array): array with shape [h, w, c]
|
105
|
-
return(tuple):
|
106
|
-
img, (ratio_h, ratio_w)
|
107
|
-
"""
|
108
|
-
limit_side_len = self.limit_side_len
|
109
|
-
h, w, c = img.shape
|
110
|
-
|
111
|
-
# limit the max side
|
112
|
-
if self.limit_type == "max":
|
113
|
-
if max(h, w) > limit_side_len:
|
114
|
-
if h > w:
|
115
|
-
ratio = float(limit_side_len) / h
|
116
|
-
else:
|
117
|
-
ratio = float(limit_side_len) / w
|
118
|
-
else:
|
119
|
-
ratio = 1.0
|
120
|
-
elif self.limit_type == "min":
|
121
|
-
if min(h, w) < limit_side_len:
|
122
|
-
if h < w:
|
123
|
-
ratio = float(limit_side_len) / h
|
124
|
-
else:
|
125
|
-
ratio = float(limit_side_len) / w
|
126
|
-
else:
|
127
|
-
ratio = 1.0
|
128
|
-
elif self.limit_type == "resize_long":
|
129
|
-
ratio = float(limit_side_len) / max(h, w)
|
130
|
-
else:
|
131
|
-
raise Exception("not support limit type, image ")
|
132
|
-
resize_h = int(h * ratio)
|
133
|
-
resize_w = int(w * ratio)
|
134
|
-
|
135
|
-
resize_h = max(int(round(resize_h / 32) * 32), 32)
|
136
|
-
resize_w = max(int(round(resize_w / 32) * 32), 32)
|
137
|
-
|
138
|
-
try:
|
139
|
-
if int(resize_w) <= 0 or int(resize_h) <= 0:
|
140
|
-
return None, (None, None)
|
141
|
-
img = cv2.resize(img, (int(resize_w), int(resize_h)))
|
142
|
-
except:
|
143
|
-
logging.info(img.shape, resize_w, resize_h)
|
144
|
-
sys.exit(0)
|
145
|
-
ratio_h = resize_h / float(h)
|
146
|
-
ratio_w = resize_w / float(w)
|
147
|
-
return img, [ratio_h, ratio_w]
|
148
|
-
|
149
|
-
def resize_image_type2(self, img):
|
150
|
-
"""resize image size"""
|
151
|
-
h, w, _ = img.shape
|
152
|
-
|
153
|
-
resize_w = w
|
154
|
-
resize_h = h
|
155
|
-
|
156
|
-
if resize_h > resize_w:
|
157
|
-
ratio = float(self.resize_long) / resize_h
|
158
|
-
else:
|
159
|
-
ratio = float(self.resize_long) / resize_w
|
160
|
-
|
161
|
-
resize_h = int(resize_h * ratio)
|
162
|
-
resize_w = int(resize_w * ratio)
|
163
|
-
|
164
|
-
max_stride = 128
|
165
|
-
resize_h = (resize_h + max_stride - 1) // max_stride * max_stride
|
166
|
-
resize_w = (resize_w + max_stride - 1) // max_stride * max_stride
|
167
|
-
img = cv2.resize(img, (int(resize_w), int(resize_h)))
|
168
|
-
ratio_h = resize_h / float(h)
|
169
|
-
ratio_w = resize_w / float(w)
|
170
|
-
|
171
|
-
return img, [ratio_h, ratio_w]
|
172
|
-
|
173
|
-
|
174
|
-
class NormalizeImage(BaseComponent):
|
175
|
-
"""normalize image such as substract mean, divide std"""
|
176
|
-
|
177
|
-
INPUT_KEYS = ["img"]
|
178
|
-
OUTPUT_KEYS = ["img"]
|
179
|
-
DEAULT_INPUTS = {"img": "img"}
|
180
|
-
DEAULT_OUTPUTS = {"img": "img"}
|
181
|
-
|
182
|
-
def __init__(self, scale=None, mean=None, std=None, order="chw", **kwargs):
|
183
|
-
super().__init__()
|
184
|
-
if isinstance(scale, str):
|
185
|
-
scale = eval(scale)
|
186
|
-
self.scale = np.float32(scale if scale is not None else 1.0 / 255.0)
|
187
|
-
mean = mean if mean is not None else [0.485, 0.456, 0.406]
|
188
|
-
std = std if std is not None else [0.229, 0.224, 0.225]
|
189
|
-
|
190
|
-
shape = (3, 1, 1) if order == "chw" else (1, 1, 3)
|
191
|
-
self.mean = np.array(mean).reshape(shape).astype("float32")
|
192
|
-
self.std = np.array(std).reshape(shape).astype("float32")
|
193
|
-
|
194
|
-
def apply(self, img):
|
195
|
-
"""apply"""
|
196
|
-
from PIL import Image
|
197
|
-
|
198
|
-
if isinstance(img, Image.Image):
|
199
|
-
img = np.array(img)
|
200
|
-
assert isinstance(img, np.ndarray), "invalid input 'img' in NormalizeImage"
|
201
|
-
img = (img.astype("float32") * self.scale - self.mean) / self.std
|
202
|
-
return {"img": img}
|
203
|
-
|
204
|
-
|
205
|
-
class DBPostProcess(BaseComponent):
|
206
|
-
"""
|
207
|
-
The post process for Differentiable Binarization (DB).
|
208
|
-
"""
|
209
|
-
|
210
|
-
INPUT_KEYS = ["pred", "img_shape"]
|
211
|
-
OUTPUT_KEYS = ["dt_polys", "dt_scores"]
|
212
|
-
DEAULT_INPUTS = {"pred": "pred", "img_shape": "img_shape"}
|
213
|
-
DEAULT_OUTPUTS = {"dt_polys": "dt_polys", "dt_scores": "dt_scores"}
|
214
|
-
|
215
|
-
def __init__(
|
216
|
-
self,
|
217
|
-
thresh=0.3,
|
218
|
-
box_thresh=0.7,
|
219
|
-
max_candidates=1000,
|
220
|
-
unclip_ratio=2.0,
|
221
|
-
use_dilation=False,
|
222
|
-
score_mode="fast",
|
223
|
-
box_type="quad",
|
224
|
-
**kwargs
|
225
|
-
):
|
226
|
-
super().__init__()
|
227
|
-
self.thresh = thresh
|
228
|
-
self.box_thresh = box_thresh
|
229
|
-
self.max_candidates = max_candidates
|
230
|
-
self.unclip_ratio = unclip_ratio
|
231
|
-
self.min_size = 3
|
232
|
-
self.score_mode = score_mode
|
233
|
-
self.box_type = box_type
|
234
|
-
assert score_mode in [
|
235
|
-
"slow",
|
236
|
-
"fast",
|
237
|
-
], "Score mode must be in [slow, fast] but got: {}".format(score_mode)
|
238
|
-
|
239
|
-
self.dilation_kernel = None if not use_dilation else np.array([[1, 1], [1, 1]])
|
240
|
-
|
241
|
-
def polygons_from_bitmap(self, pred, _bitmap, dest_width, dest_height):
|
242
|
-
"""_bitmap: single map with shape (1, H, W), whose values are binarized as {0, 1}"""
|
243
|
-
|
244
|
-
bitmap = _bitmap
|
245
|
-
height, width = bitmap.shape
|
246
|
-
|
247
|
-
boxes = []
|
248
|
-
scores = []
|
249
|
-
|
250
|
-
contours, _ = cv2.findContours(
|
251
|
-
(bitmap * 255).astype(np.uint8), cv2.RETR_LIST, cv2.CHAIN_APPROX_SIMPLE
|
252
|
-
)
|
253
|
-
|
254
|
-
for contour in contours[: self.max_candidates]:
|
255
|
-
epsilon = 0.002 * cv2.arcLength(contour, True)
|
256
|
-
approx = cv2.approxPolyDP(contour, epsilon, True)
|
257
|
-
points = approx.reshape((-1, 2))
|
258
|
-
if points.shape[0] < 4:
|
259
|
-
continue
|
260
|
-
|
261
|
-
score = self.box_score_fast(pred, points.reshape(-1, 2))
|
262
|
-
if self.box_thresh > score:
|
263
|
-
continue
|
264
|
-
|
265
|
-
if points.shape[0] > 2:
|
266
|
-
box = self.unclip(points, self.unclip_ratio)
|
267
|
-
if len(box) > 1:
|
268
|
-
continue
|
269
|
-
else:
|
270
|
-
continue
|
271
|
-
box = box.reshape(-1, 2)
|
272
|
-
|
273
|
-
if len(box) > 0:
|
274
|
-
_, sside = self.get_mini_boxes(box.reshape((-1, 1, 2)))
|
275
|
-
if sside < self.min_size + 2:
|
276
|
-
continue
|
277
|
-
else:
|
278
|
-
continue
|
279
|
-
|
280
|
-
box = np.array(box)
|
281
|
-
box[:, 0] = np.clip(np.round(box[:, 0] / width * dest_width), 0, dest_width)
|
282
|
-
box[:, 1] = np.clip(
|
283
|
-
np.round(box[:, 1] / height * dest_height), 0, dest_height
|
284
|
-
)
|
285
|
-
boxes.append(box)
|
286
|
-
scores.append(score)
|
287
|
-
return boxes, scores
|
288
|
-
|
289
|
-
def boxes_from_bitmap(self, pred, _bitmap, dest_width, dest_height):
|
290
|
-
"""_bitmap: single map with shape (1, H, W), whose values are binarized as {0, 1}"""
|
291
|
-
|
292
|
-
bitmap = _bitmap
|
293
|
-
height, width = bitmap.shape
|
294
|
-
|
295
|
-
outs = cv2.findContours(
|
296
|
-
(bitmap * 255).astype(np.uint8), cv2.RETR_LIST, cv2.CHAIN_APPROX_SIMPLE
|
297
|
-
)
|
298
|
-
if len(outs) == 3:
|
299
|
-
img, contours, _ = outs[0], outs[1], outs[2]
|
300
|
-
elif len(outs) == 2:
|
301
|
-
contours, _ = outs[0], outs[1]
|
302
|
-
|
303
|
-
num_contours = min(len(contours), self.max_candidates)
|
304
|
-
|
305
|
-
boxes = []
|
306
|
-
scores = []
|
307
|
-
for index in range(num_contours):
|
308
|
-
contour = contours[index]
|
309
|
-
points, sside = self.get_mini_boxes(contour)
|
310
|
-
if sside < self.min_size:
|
311
|
-
continue
|
312
|
-
points = np.array(points)
|
313
|
-
if self.score_mode == "fast":
|
314
|
-
score = self.box_score_fast(pred, points.reshape(-1, 2))
|
315
|
-
else:
|
316
|
-
score = self.box_score_slow(pred, contour)
|
317
|
-
if self.box_thresh > score:
|
318
|
-
continue
|
319
|
-
|
320
|
-
box = self.unclip(points, self.unclip_ratio).reshape(-1, 1, 2)
|
321
|
-
box, sside = self.get_mini_boxes(box)
|
322
|
-
if sside < self.min_size + 2:
|
323
|
-
continue
|
324
|
-
box = np.array(box)
|
325
|
-
|
326
|
-
box[:, 0] = np.clip(np.round(box[:, 0] / width * dest_width), 0, dest_width)
|
327
|
-
box[:, 1] = np.clip(
|
328
|
-
np.round(box[:, 1] / height * dest_height), 0, dest_height
|
329
|
-
)
|
330
|
-
boxes.append(box.astype(np.int16))
|
331
|
-
scores.append(score)
|
332
|
-
return np.array(boxes, dtype=np.int16), scores
|
333
|
-
|
334
|
-
def unclip(self, box, unclip_ratio):
|
335
|
-
"""unclip"""
|
336
|
-
poly = Polygon(box)
|
337
|
-
distance = poly.area * unclip_ratio / poly.length
|
338
|
-
offset = pyclipper.PyclipperOffset()
|
339
|
-
offset.AddPath(box, pyclipper.JT_ROUND, pyclipper.ET_CLOSEDPOLYGON)
|
340
|
-
try:
|
341
|
-
expanded = np.array(offset.Execute(distance))
|
342
|
-
except ValueError:
|
343
|
-
expanded = np.array(offset.Execute(distance)[0])
|
344
|
-
return expanded
|
345
|
-
|
346
|
-
def get_mini_boxes(self, contour):
|
347
|
-
"""get mini boxes"""
|
348
|
-
bounding_box = cv2.minAreaRect(contour)
|
349
|
-
points = sorted(list(cv2.boxPoints(bounding_box)), key=lambda x: x[0])
|
350
|
-
|
351
|
-
index_1, index_2, index_3, index_4 = 0, 1, 2, 3
|
352
|
-
if points[1][1] > points[0][1]:
|
353
|
-
index_1 = 0
|
354
|
-
index_4 = 1
|
355
|
-
else:
|
356
|
-
index_1 = 1
|
357
|
-
index_4 = 0
|
358
|
-
if points[3][1] > points[2][1]:
|
359
|
-
index_2 = 2
|
360
|
-
index_3 = 3
|
361
|
-
else:
|
362
|
-
index_2 = 3
|
363
|
-
index_3 = 2
|
364
|
-
|
365
|
-
box = [points[index_1], points[index_2], points[index_3], points[index_4]]
|
366
|
-
return box, min(bounding_box[1])
|
367
|
-
|
368
|
-
def box_score_fast(self, bitmap, _box):
|
369
|
-
"""box_score_fast: use bbox mean score as the mean score"""
|
370
|
-
h, w = bitmap.shape[:2]
|
371
|
-
box = _box.copy()
|
372
|
-
xmin = np.clip(np.floor(box[:, 0].min()).astype("int"), 0, w - 1)
|
373
|
-
xmax = np.clip(np.ceil(box[:, 0].max()).astype("int"), 0, w - 1)
|
374
|
-
ymin = np.clip(np.floor(box[:, 1].min()).astype("int"), 0, h - 1)
|
375
|
-
ymax = np.clip(np.ceil(box[:, 1].max()).astype("int"), 0, h - 1)
|
376
|
-
|
377
|
-
mask = np.zeros((ymax - ymin + 1, xmax - xmin + 1), dtype=np.uint8)
|
378
|
-
box[:, 0] = box[:, 0] - xmin
|
379
|
-
box[:, 1] = box[:, 1] - ymin
|
380
|
-
cv2.fillPoly(mask, box.reshape(1, -1, 2).astype(np.int32), 1)
|
381
|
-
return cv2.mean(bitmap[ymin : ymax + 1, xmin : xmax + 1], mask)[0]
|
382
|
-
|
383
|
-
def box_score_slow(self, bitmap, contour):
|
384
|
-
"""box_score_slow: use polyon mean score as the mean score"""
|
385
|
-
h, w = bitmap.shape[:2]
|
386
|
-
contour = contour.copy()
|
387
|
-
contour = np.reshape(contour, (-1, 2))
|
388
|
-
|
389
|
-
xmin = np.clip(np.min(contour[:, 0]), 0, w - 1)
|
390
|
-
xmax = np.clip(np.max(contour[:, 0]), 0, w - 1)
|
391
|
-
ymin = np.clip(np.min(contour[:, 1]), 0, h - 1)
|
392
|
-
ymax = np.clip(np.max(contour[:, 1]), 0, h - 1)
|
393
|
-
|
394
|
-
mask = np.zeros((ymax - ymin + 1, xmax - xmin + 1), dtype=np.uint8)
|
395
|
-
|
396
|
-
contour[:, 0] = contour[:, 0] - xmin
|
397
|
-
contour[:, 1] = contour[:, 1] - ymin
|
398
|
-
|
399
|
-
cv2.fillPoly(mask, contour.reshape(1, -1, 2).astype(np.int32), 1)
|
400
|
-
return cv2.mean(bitmap[ymin : ymax + 1, xmin : xmax + 1], mask)[0]
|
401
|
-
|
402
|
-
def apply(self, pred, img_shape):
|
403
|
-
"""apply"""
|
404
|
-
pred = pred[0][0, :, :]
|
405
|
-
segmentation = pred > self.thresh
|
406
|
-
|
407
|
-
src_h, src_w, ratio_h, ratio_w = img_shape
|
408
|
-
if self.dilation_kernel is not None:
|
409
|
-
mask = cv2.dilate(
|
410
|
-
np.array(segmentation).astype(np.uint8),
|
411
|
-
self.dilation_kernel,
|
412
|
-
)
|
413
|
-
else:
|
414
|
-
mask = segmentation
|
415
|
-
if self.box_type == "poly":
|
416
|
-
boxes, scores = self.polygons_from_bitmap(pred, mask, src_w, src_h)
|
417
|
-
elif self.box_type == "quad":
|
418
|
-
boxes, scores = self.boxes_from_bitmap(pred, mask, src_w, src_h)
|
419
|
-
else:
|
420
|
-
raise ValueError("box_type can only be one of ['quad', 'poly']")
|
421
|
-
|
422
|
-
return {"dt_polys": boxes, "dt_scores": scores}
|
423
|
-
|
424
|
-
|
425
|
-
class CropByPolys(BaseComponent):
|
426
|
-
"""Crop Image by Polys"""
|
427
|
-
|
428
|
-
INPUT_KEYS = ["input_path", "dt_polys"]
|
429
|
-
OUTPUT_KEYS = ["img"]
|
430
|
-
DEAULT_INPUTS = {"input_path": "input_path", "dt_polys": "dt_polys"}
|
431
|
-
DEAULT_OUTPUTS = {"img": "img"}
|
432
|
-
|
433
|
-
def __init__(self, det_box_type="quad"):
|
434
|
-
super().__init__()
|
435
|
-
self.det_box_type = det_box_type
|
436
|
-
self._reader = ImageReader(backend="opencv")
|
437
|
-
|
438
|
-
def apply(self, input_path, dt_polys):
|
439
|
-
"""apply"""
|
440
|
-
img = self._reader.read(input_path)
|
441
|
-
|
442
|
-
if self.det_box_type == "quad":
|
443
|
-
dt_boxes = np.array(dt_polys)
|
444
|
-
output_list = []
|
445
|
-
for bno in range(len(dt_boxes)):
|
446
|
-
tmp_box = copy.deepcopy(dt_boxes[bno])
|
447
|
-
img_crop = self.get_minarea_rect_crop(img, tmp_box)
|
448
|
-
output_list.append(
|
449
|
-
{
|
450
|
-
"img": img_crop,
|
451
|
-
"img_size": [img_crop.shape[1], img_crop.shape[0]],
|
452
|
-
}
|
453
|
-
)
|
454
|
-
elif self.det_box_type == "poly":
|
455
|
-
output_list = []
|
456
|
-
dt_boxes = dt_polys
|
457
|
-
for bno in range(len(dt_boxes)):
|
458
|
-
tmp_box = copy.deepcopy(dt_boxes[bno])
|
459
|
-
img_crop = self.get_poly_rect_crop(img.copy(), tmp_box)
|
460
|
-
output_list.append(
|
461
|
-
{
|
462
|
-
"img": img_crop,
|
463
|
-
"img_size": [img_crop.shape[1], img_crop.shape[0]],
|
464
|
-
}
|
465
|
-
)
|
466
|
-
else:
|
467
|
-
raise NotImplementedError
|
468
|
-
|
469
|
-
return output_list
|
470
|
-
|
471
|
-
def get_minarea_rect_crop(self, img, points):
|
472
|
-
"""get_minarea_rect_crop"""
|
473
|
-
bounding_box = cv2.minAreaRect(np.array(points).astype(np.int32))
|
474
|
-
points = sorted(list(cv2.boxPoints(bounding_box)), key=lambda x: x[0])
|
475
|
-
|
476
|
-
index_a, index_b, index_c, index_d = 0, 1, 2, 3
|
477
|
-
if points[1][1] > points[0][1]:
|
478
|
-
index_a = 0
|
479
|
-
index_d = 1
|
480
|
-
else:
|
481
|
-
index_a = 1
|
482
|
-
index_d = 0
|
483
|
-
if points[3][1] > points[2][1]:
|
484
|
-
index_b = 2
|
485
|
-
index_c = 3
|
486
|
-
else:
|
487
|
-
index_b = 3
|
488
|
-
index_c = 2
|
489
|
-
|
490
|
-
box = [points[index_a], points[index_b], points[index_c], points[index_d]]
|
491
|
-
crop_img = self.get_rotate_crop_image(img, np.array(box))
|
492
|
-
return crop_img
|
493
|
-
|
494
|
-
def get_rotate_crop_image(self, img, points):
|
495
|
-
"""
|
496
|
-
img_height, img_width = img.shape[0:2]
|
497
|
-
left = int(np.min(points[:, 0]))
|
498
|
-
right = int(np.max(points[:, 0]))
|
499
|
-
top = int(np.min(points[:, 1]))
|
500
|
-
bottom = int(np.max(points[:, 1]))
|
501
|
-
img_crop = img[top:bottom, left:right, :].copy()
|
502
|
-
points[:, 0] = points[:, 0] - left
|
503
|
-
points[:, 1] = points[:, 1] - top
|
504
|
-
"""
|
505
|
-
assert len(points) == 4, "shape of points must be 4*2"
|
506
|
-
img_crop_width = int(
|
507
|
-
max(
|
508
|
-
np.linalg.norm(points[0] - points[1]),
|
509
|
-
np.linalg.norm(points[2] - points[3]),
|
510
|
-
)
|
511
|
-
)
|
512
|
-
img_crop_height = int(
|
513
|
-
max(
|
514
|
-
np.linalg.norm(points[0] - points[3]),
|
515
|
-
np.linalg.norm(points[1] - points[2]),
|
516
|
-
)
|
517
|
-
)
|
518
|
-
pts_std = np.float32(
|
519
|
-
[
|
520
|
-
[0, 0],
|
521
|
-
[img_crop_width, 0],
|
522
|
-
[img_crop_width, img_crop_height],
|
523
|
-
[0, img_crop_height],
|
524
|
-
]
|
525
|
-
)
|
526
|
-
M = cv2.getPerspectiveTransform(points, pts_std)
|
527
|
-
dst_img = cv2.warpPerspective(
|
528
|
-
img,
|
529
|
-
M,
|
530
|
-
(img_crop_width, img_crop_height),
|
531
|
-
borderMode=cv2.BORDER_REPLICATE,
|
532
|
-
flags=cv2.INTER_CUBIC,
|
533
|
-
)
|
534
|
-
dst_img_height, dst_img_width = dst_img.shape[0:2]
|
535
|
-
if dst_img_height * 1.0 / dst_img_width >= 1.5:
|
536
|
-
dst_img = np.rot90(dst_img)
|
537
|
-
return dst_img
|
538
|
-
|
539
|
-
def reorder_poly_edge(self, points):
|
540
|
-
"""Get the respective points composing head edge, tail edge, top
|
541
|
-
sideline and bottom sideline.
|
542
|
-
|
543
|
-
Args:
|
544
|
-
points (ndarray): The points composing a text polygon.
|
545
|
-
|
546
|
-
Returns:
|
547
|
-
head_edge (ndarray): The two points composing the head edge of text
|
548
|
-
polygon.
|
549
|
-
tail_edge (ndarray): The two points composing the tail edge of text
|
550
|
-
polygon.
|
551
|
-
top_sideline (ndarray): The points composing top curved sideline of
|
552
|
-
text polygon.
|
553
|
-
bot_sideline (ndarray): The points composing bottom curved sideline
|
554
|
-
of text polygon.
|
555
|
-
"""
|
556
|
-
|
557
|
-
assert points.ndim == 2
|
558
|
-
assert points.shape[0] >= 4
|
559
|
-
assert points.shape[1] == 2
|
560
|
-
|
561
|
-
orientation_thr = 2.0 # 一个经验超参数
|
562
|
-
|
563
|
-
head_inds, tail_inds = self.find_head_tail(points, orientation_thr)
|
564
|
-
head_edge, tail_edge = points[head_inds], points[tail_inds]
|
565
|
-
|
566
|
-
pad_points = np.vstack([points, points])
|
567
|
-
if tail_inds[1] < 1:
|
568
|
-
tail_inds[1] = len(points)
|
569
|
-
sideline1 = pad_points[head_inds[1] : tail_inds[1]]
|
570
|
-
sideline2 = pad_points[tail_inds[1] : (head_inds[1] + len(points))]
|
571
|
-
return head_edge, tail_edge, sideline1, sideline2
|
572
|
-
|
573
|
-
def vector_slope(self, vec):
|
574
|
-
assert len(vec) == 2
|
575
|
-
return abs(vec[1] / (vec[0] + 1e-8))
|
576
|
-
|
577
|
-
def find_head_tail(self, points, orientation_thr):
|
578
|
-
"""Find the head edge and tail edge of a text polygon.
|
579
|
-
|
580
|
-
Args:
|
581
|
-
points (ndarray): The points composing a text polygon.
|
582
|
-
orientation_thr (float): The threshold for distinguishing between
|
583
|
-
head edge and tail edge among the horizontal and vertical edges
|
584
|
-
of a quadrangle.
|
585
|
-
|
586
|
-
Returns:
|
587
|
-
head_inds (list): The indexes of two points composing head edge.
|
588
|
-
tail_inds (list): The indexes of two points composing tail edge.
|
589
|
-
"""
|
590
|
-
|
591
|
-
assert points.ndim == 2
|
592
|
-
assert points.shape[0] >= 4
|
593
|
-
assert points.shape[1] == 2
|
594
|
-
assert isinstance(orientation_thr, float)
|
595
|
-
|
596
|
-
if len(points) > 4:
|
597
|
-
pad_points = np.vstack([points, points[0]])
|
598
|
-
edge_vec = pad_points[1:] - pad_points[:-1]
|
599
|
-
|
600
|
-
theta_sum = []
|
601
|
-
adjacent_vec_theta = []
|
602
|
-
for i, edge_vec1 in enumerate(edge_vec):
|
603
|
-
adjacent_ind = [x % len(edge_vec) for x in [i - 1, i + 1]]
|
604
|
-
adjacent_edge_vec = edge_vec[adjacent_ind]
|
605
|
-
temp_theta_sum = np.sum(self.vector_angle(edge_vec1, adjacent_edge_vec))
|
606
|
-
temp_adjacent_theta = self.vector_angle(
|
607
|
-
adjacent_edge_vec[0], adjacent_edge_vec[1]
|
608
|
-
)
|
609
|
-
theta_sum.append(temp_theta_sum)
|
610
|
-
adjacent_vec_theta.append(temp_adjacent_theta)
|
611
|
-
theta_sum_score = np.array(theta_sum) / np.pi
|
612
|
-
adjacent_theta_score = np.array(adjacent_vec_theta) / np.pi
|
613
|
-
poly_center = np.mean(points, axis=0)
|
614
|
-
edge_dist = np.maximum(
|
615
|
-
norm(pad_points[1:] - poly_center, axis=-1),
|
616
|
-
norm(pad_points[:-1] - poly_center, axis=-1),
|
617
|
-
)
|
618
|
-
dist_score = edge_dist / np.max(edge_dist)
|
619
|
-
position_score = np.zeros(len(edge_vec))
|
620
|
-
score = 0.5 * theta_sum_score + 0.15 * adjacent_theta_score
|
621
|
-
score += 0.35 * dist_score
|
622
|
-
if len(points) % 2 == 0:
|
623
|
-
position_score[(len(score) // 2 - 1)] += 1
|
624
|
-
position_score[-1] += 1
|
625
|
-
score += 0.1 * position_score
|
626
|
-
pad_score = np.concatenate([score, score])
|
627
|
-
score_matrix = np.zeros((len(score), len(score) - 3))
|
628
|
-
x = np.arange(len(score) - 3) / float(len(score) - 4)
|
629
|
-
gaussian = (
|
630
|
-
1.0
|
631
|
-
/ (np.sqrt(2.0 * np.pi) * 0.5)
|
632
|
-
* np.exp(-np.power((x - 0.5) / 0.5, 2.0) / 2)
|
633
|
-
)
|
634
|
-
gaussian = gaussian / np.max(gaussian)
|
635
|
-
for i in range(len(score)):
|
636
|
-
score_matrix[i, :] = (
|
637
|
-
score[i]
|
638
|
-
+ pad_score[(i + 2) : (i + len(score) - 1)] * gaussian * 0.3
|
639
|
-
)
|
640
|
-
|
641
|
-
head_start, tail_increment = np.unravel_index(
|
642
|
-
score_matrix.argmax(), score_matrix.shape
|
643
|
-
)
|
644
|
-
tail_start = (head_start + tail_increment + 2) % len(points)
|
645
|
-
head_end = (head_start + 1) % len(points)
|
646
|
-
tail_end = (tail_start + 1) % len(points)
|
647
|
-
|
648
|
-
if head_end > tail_end:
|
649
|
-
head_start, tail_start = tail_start, head_start
|
650
|
-
head_end, tail_end = tail_end, head_end
|
651
|
-
head_inds = [head_start, head_end]
|
652
|
-
tail_inds = [tail_start, tail_end]
|
653
|
-
else:
|
654
|
-
if self.vector_slope(points[1] - points[0]) + self.vector_slope(
|
655
|
-
points[3] - points[2]
|
656
|
-
) < self.vector_slope(points[2] - points[1]) + self.vector_slope(
|
657
|
-
points[0] - points[3]
|
658
|
-
):
|
659
|
-
horizontal_edge_inds = [[0, 1], [2, 3]]
|
660
|
-
vertical_edge_inds = [[3, 0], [1, 2]]
|
661
|
-
else:
|
662
|
-
horizontal_edge_inds = [[3, 0], [1, 2]]
|
663
|
-
vertical_edge_inds = [[0, 1], [2, 3]]
|
664
|
-
|
665
|
-
vertical_len_sum = norm(
|
666
|
-
points[vertical_edge_inds[0][0]] - points[vertical_edge_inds[0][1]]
|
667
|
-
) + norm(
|
668
|
-
points[vertical_edge_inds[1][0]] - points[vertical_edge_inds[1][1]]
|
669
|
-
)
|
670
|
-
horizontal_len_sum = norm(
|
671
|
-
points[horizontal_edge_inds[0][0]] - points[horizontal_edge_inds[0][1]]
|
672
|
-
) + norm(
|
673
|
-
points[horizontal_edge_inds[1][0]] - points[horizontal_edge_inds[1][1]]
|
674
|
-
)
|
675
|
-
|
676
|
-
if vertical_len_sum > horizontal_len_sum * orientation_thr:
|
677
|
-
head_inds = horizontal_edge_inds[0]
|
678
|
-
tail_inds = horizontal_edge_inds[1]
|
679
|
-
else:
|
680
|
-
head_inds = vertical_edge_inds[0]
|
681
|
-
tail_inds = vertical_edge_inds[1]
|
682
|
-
|
683
|
-
return head_inds, tail_inds
|
684
|
-
|
685
|
-
def vector_angle(self, vec1, vec2):
|
686
|
-
if vec1.ndim > 1:
|
687
|
-
unit_vec1 = vec1 / (norm(vec1, axis=-1) + 1e-8).reshape((-1, 1))
|
688
|
-
else:
|
689
|
-
unit_vec1 = vec1 / (norm(vec1, axis=-1) + 1e-8)
|
690
|
-
if vec2.ndim > 1:
|
691
|
-
unit_vec2 = vec2 / (norm(vec2, axis=-1) + 1e-8).reshape((-1, 1))
|
692
|
-
else:
|
693
|
-
unit_vec2 = vec2 / (norm(vec2, axis=-1) + 1e-8)
|
694
|
-
return np.arccos(np.clip(np.sum(unit_vec1 * unit_vec2, axis=-1), -1.0, 1.0))
|
695
|
-
|
696
|
-
def get_minarea_rect(self, img, points):
|
697
|
-
bounding_box = cv2.minAreaRect(points)
|
698
|
-
points = sorted(list(cv2.boxPoints(bounding_box)), key=lambda x: x[0])
|
699
|
-
|
700
|
-
index_a, index_b, index_c, index_d = 0, 1, 2, 3
|
701
|
-
if points[1][1] > points[0][1]:
|
702
|
-
index_a = 0
|
703
|
-
index_d = 1
|
704
|
-
else:
|
705
|
-
index_a = 1
|
706
|
-
index_d = 0
|
707
|
-
if points[3][1] > points[2][1]:
|
708
|
-
index_b = 2
|
709
|
-
index_c = 3
|
710
|
-
else:
|
711
|
-
index_b = 3
|
712
|
-
index_c = 2
|
713
|
-
|
714
|
-
box = [points[index_a], points[index_b], points[index_c], points[index_d]]
|
715
|
-
crop_img = self.get_rotate_crop_image(img, np.array(box))
|
716
|
-
return crop_img, box
|
717
|
-
|
718
|
-
def sample_points_on_bbox_bp(self, line, n=50):
|
719
|
-
"""Resample n points on a line.
|
720
|
-
|
721
|
-
Args:
|
722
|
-
line (ndarray): The points composing a line.
|
723
|
-
n (int): The resampled points number.
|
724
|
-
|
725
|
-
Returns:
|
726
|
-
resampled_line (ndarray): The points composing the resampled line.
|
727
|
-
"""
|
728
|
-
from numpy.linalg import norm
|
729
|
-
|
730
|
-
# 断言检查输入参数的有效性
|
731
|
-
assert line.ndim == 2
|
732
|
-
assert line.shape[0] >= 2
|
733
|
-
assert line.shape[1] == 2
|
734
|
-
assert isinstance(n, int)
|
735
|
-
assert n > 0
|
736
|
-
|
737
|
-
length_list = [norm(line[i + 1] - line[i]) for i in range(len(line) - 1)]
|
738
|
-
total_length = sum(length_list)
|
739
|
-
length_cumsum = np.cumsum([0.0] + length_list)
|
740
|
-
delta_length = total_length / (float(n) + 1e-8)
|
741
|
-
current_edge_ind = 0
|
742
|
-
resampled_line = [line[0]]
|
743
|
-
|
744
|
-
for i in range(1, n):
|
745
|
-
current_line_len = i * delta_length
|
746
|
-
while (
|
747
|
-
current_edge_ind + 1 < len(length_cumsum)
|
748
|
-
and current_line_len >= length_cumsum[current_edge_ind + 1]
|
749
|
-
):
|
750
|
-
current_edge_ind += 1
|
751
|
-
current_edge_end_shift = current_line_len - length_cumsum[current_edge_ind]
|
752
|
-
if current_edge_ind >= len(length_list):
|
753
|
-
break
|
754
|
-
end_shift_ratio = current_edge_end_shift / length_list[current_edge_ind]
|
755
|
-
current_point = (
|
756
|
-
line[current_edge_ind]
|
757
|
-
+ (line[current_edge_ind + 1] - line[current_edge_ind])
|
758
|
-
* end_shift_ratio
|
759
|
-
)
|
760
|
-
resampled_line.append(current_point)
|
761
|
-
resampled_line.append(line[-1])
|
762
|
-
resampled_line = np.array(resampled_line)
|
763
|
-
return resampled_line
|
764
|
-
|
765
|
-
def sample_points_on_bbox(self, line, n=50):
|
766
|
-
"""Resample n points on a line.
|
767
|
-
|
768
|
-
Args:
|
769
|
-
line (ndarray): The points composing a line.
|
770
|
-
n (int): The resampled points number.
|
771
|
-
|
772
|
-
Returns:
|
773
|
-
resampled_line (ndarray): The points composing the resampled line.
|
774
|
-
"""
|
775
|
-
assert line.ndim == 2
|
776
|
-
assert line.shape[0] >= 2
|
777
|
-
assert line.shape[1] == 2
|
778
|
-
assert isinstance(n, int)
|
779
|
-
assert n > 0
|
780
|
-
|
781
|
-
length_list = [norm(line[i + 1] - line[i]) for i in range(len(line) - 1)]
|
782
|
-
total_length = sum(length_list)
|
783
|
-
mean_length = total_length / (len(length_list) + 1e-8)
|
784
|
-
group = [[0]]
|
785
|
-
for i in range(len(length_list)):
|
786
|
-
point_id = i + 1
|
787
|
-
if length_list[i] < 0.9 * mean_length:
|
788
|
-
for g in group:
|
789
|
-
if i in g:
|
790
|
-
g.append(point_id)
|
791
|
-
break
|
792
|
-
else:
|
793
|
-
g = [point_id]
|
794
|
-
group.append(g)
|
795
|
-
|
796
|
-
top_tail_len = norm(line[0] - line[-1])
|
797
|
-
if top_tail_len < 0.9 * mean_length:
|
798
|
-
group[0].extend(g)
|
799
|
-
group.remove(g)
|
800
|
-
mean_positions = []
|
801
|
-
for indices in group:
|
802
|
-
x_sum = 0
|
803
|
-
y_sum = 0
|
804
|
-
for index in indices:
|
805
|
-
x, y = line[index]
|
806
|
-
x_sum += x
|
807
|
-
y_sum += y
|
808
|
-
num_points = len(indices)
|
809
|
-
mean_x = x_sum / num_points
|
810
|
-
mean_y = y_sum / num_points
|
811
|
-
mean_positions.append((mean_x, mean_y))
|
812
|
-
resampled_line = np.array(mean_positions)
|
813
|
-
return resampled_line
|
814
|
-
|
815
|
-
def get_poly_rect_crop(self, img, points):
|
816
|
-
"""
|
817
|
-
修改该函数,实现使用polygon,对不规则、弯曲文本的矫正以及crop
|
818
|
-
args: img: 图片 ndarrary格式
|
819
|
-
points: polygon格式的多点坐标 N*2 shape, ndarray格式
|
820
|
-
return: 矫正后的图片 ndarray格式
|
821
|
-
"""
|
822
|
-
points = np.array(points).astype(np.int32).reshape(-1, 2)
|
823
|
-
temp_crop_img, temp_box = self.get_minarea_rect(img, points)
|
824
|
-
|
825
|
-
# 计算最小外接矩形与polygon的IoU
|
826
|
-
def get_union(pD, pG):
|
827
|
-
return Polygon(pD).union(Polygon(pG)).area
|
828
|
-
|
829
|
-
def get_intersection_over_union(pD, pG):
|
830
|
-
return get_intersection(pD, pG) / (get_union(pD, pG) + 1e-10)
|
831
|
-
|
832
|
-
def get_intersection(pD, pG):
|
833
|
-
return Polygon(pD).intersection(Polygon(pG)).area
|
834
|
-
|
835
|
-
cal_IoU = get_intersection_over_union(points, temp_box)
|
836
|
-
|
837
|
-
if cal_IoU >= 0.7:
|
838
|
-
points = self.sample_points_on_bbox_bp(points, 31)
|
839
|
-
return temp_crop_img
|
840
|
-
|
841
|
-
points_sample = self.sample_points_on_bbox(points)
|
842
|
-
points_sample = points_sample.astype(np.int32)
|
843
|
-
head_edge, tail_edge, top_line, bot_line = self.reorder_poly_edge(points_sample)
|
844
|
-
|
845
|
-
resample_top_line = self.sample_points_on_bbox_bp(top_line, 15)
|
846
|
-
resample_bot_line = self.sample_points_on_bbox_bp(bot_line, 15)
|
847
|
-
|
848
|
-
sideline_mean_shift = np.mean(resample_top_line, axis=0) - np.mean(
|
849
|
-
resample_bot_line, axis=0
|
850
|
-
)
|
851
|
-
if sideline_mean_shift[1] > 0:
|
852
|
-
resample_bot_line, resample_top_line = resample_top_line, resample_bot_line
|
853
|
-
rectifier = AutoRectifier()
|
854
|
-
new_points = np.concatenate([resample_top_line, resample_bot_line])
|
855
|
-
new_points_list = list(new_points.astype(np.float32).reshape(1, -1).tolist())
|
856
|
-
|
857
|
-
if len(img.shape) == 2:
|
858
|
-
img = np.stack((img,) * 3, axis=-1)
|
859
|
-
img_crop, image = rectifier.run(img, new_points_list, mode="homography")
|
860
|
-
return np.array(img_crop[0], dtype=np.uint8)
|
861
|
-
|
862
|
-
|
863
|
-
class SortBoxes(BaseComponent):
|
864
|
-
|
865
|
-
YIELD_BATCH = False
|
866
|
-
|
867
|
-
INPUT_KEYS = ["dt_polys"]
|
868
|
-
OUTPUT_KEYS = ["dt_polys"]
|
869
|
-
DEAULT_INPUTS = {"dt_polys": "dt_polys"}
|
870
|
-
DEAULT_OUTPUTS = {"dt_polys": "dt_polys"}
|
871
|
-
|
872
|
-
def apply(self, dt_polys):
|
873
|
-
"""
|
874
|
-
Sort text boxes in order from top to bottom, left to right
|
875
|
-
args:
|
876
|
-
dt_boxes(array):detected text boxes with shape [4, 2]
|
877
|
-
return:
|
878
|
-
sorted boxes(array) with shape [4, 2]
|
879
|
-
"""
|
880
|
-
dt_boxes = np.array(dt_polys)
|
881
|
-
num_boxes = dt_boxes.shape[0]
|
882
|
-
sorted_boxes = sorted(dt_boxes, key=lambda x: (x[0][1], x[0][0]))
|
883
|
-
_boxes = list(sorted_boxes)
|
884
|
-
|
885
|
-
for i in range(num_boxes - 1):
|
886
|
-
for j in range(i, -1, -1):
|
887
|
-
if abs(_boxes[j + 1][0][1] - _boxes[j][0][1]) < 10 and (
|
888
|
-
_boxes[j + 1][0][0] < _boxes[j][0][0]
|
889
|
-
):
|
890
|
-
tmp = _boxes[j]
|
891
|
-
_boxes[j] = _boxes[j + 1]
|
892
|
-
_boxes[j + 1] = tmp
|
893
|
-
else:
|
894
|
-
break
|
895
|
-
return {"dt_polys": _boxes}
|