PaddleX Multi-Hardware Usage Guide¶
This document focuses on the usage guide of PaddleX for Huawei Ascend NPU, Cambricon MLU, Kunlun XPU, and Hygon DCU hardware platforms.
1. Installation¶
1.1 PaddlePaddle Installation¶
First, please complete the installation of PaddlePaddle according to your hardware platform. The installation tutorials for each hardware are as follows:
Ascend NPU: Ascend NPU PaddlePaddle Installation Guide
Cambricon MLU: Cambricon MLU PaddlePaddle Installation Guide
Kunlun XPU: Kunlun XPU PaddlePaddle Installation Guide
Hygon DCU: Hygon DCU PaddlePaddle Installation Guide
1.2 PaddleX Installation¶
Welcome to use PaddlePaddle's low-code development tool, PaddleX. Before we officially start the local installation, please clarify your development needs and choose the appropriate installation mode based on your requirements.
PaddleX offers two installation modes: Wheel Package Installation and Plugin Installation. The following details the application scenarios and installation methods for these two modes.
1.2.1 Wheel Package Installation Mode¶
If your application scenario for PaddleX is model inference and integration, we recommend using the more convenient and lightweight Wheel Package Installation Mode.
After installing PaddlePaddle, you can directly execute the following commands to quickly install the PaddleX Wheel package:
1.2.2 Plugin Installation Mode¶
If your application scenario for PaddleX is secondary development, we recommend using the more powerful Plugin Installation Mode.
After installing the PaddleX plugins you need, you can not only perform inference and integration on the models supported by the plugins but also conduct more advanced operations such as model training for secondary development.
The plugins supported by PaddleX are as follows. Please determine the name(s) of the plugin(s) you need based on your development requirements:
👉 Plugin and Pipeline Correspondence (Click to Expand)
Pipeline | Module | Corresponding Plugin |
---|---|---|
General Image Classification | Image Classification | PaddleClas |
General Object Detection | Object Detection | PaddleDetection |
General Semantic Segmentation | Semantic Segmentation | PaddleSeg |
General Instance Segmentation | Instance Segmentation | PaddleDetection |
General OCR | Text Detection Text Recognition |
PaddleOCR |
General Table Recognition | Layout Region Detection Table Structure Recognition Text Detection Text Recognition |
PaddleOCR PaddleDetection |
Document Scene Information Extraction v3 | Table Structure Recognition Layout Region Detection Text Detection Text Recognition Seal Text Detection Document Image Correction Document Image Orientation Classification |
PaddleOCR PaddleDetection PaddleClas |
Time Series Prediction | Time Series Prediction Module | PaddleTS |
Time Series Anomaly Detection | Time Series Anomaly Detection Module | PaddleTS |
Time Series Classification | Time Series Classification Module | PaddleTS |
General Multi-label Classification | Image Multi-label Classification | PaddleClas |
Small Object Detection | Small Object Detection | PaddleDetection |
Image Anomaly Detection | Unsupervised Anomaly Detection | PaddleSeg |
If the plugin(s) you need to install is/are PaddleXXX (can be multiple), after installing PaddlePaddle, you can directly execute the following commands to quickly install the corresponding PaddleX plugin(s):
# obtain PaddleX source code
git clone https://github.com/PaddlePaddle/PaddleX.git
cd PaddleX
# Install PaddleX whl
# -e: Install in editable mode, so changes to the current project's code will directly affect the installed PaddleX Wheel
pip install -e .
# Install PaddleX Plugins
paddlex --install PaddleXXX
If you wish to install all plugins, you do not need to specify the plugin names. Simply execute the following command:
The default clone source for plugins is github.com, but it also supports gitee.com. You can specify the clone source using --platform
.
For instance, if you want to install all PaddleX plugins using the gitee.com clone source, execute the following command:
Upon successful installation, you will see the following prompt:
2. Usage¶
The usage of PaddleX model pipeline development tool on hardware platforms such as Ascend NPU, Cambricon MLU, Kunlun XPU, Hygon DCU and Enflame GCU is identical to that on GPU. You only need to modify the device configuration parameters according to your hardware platform. Taking the general OCR pipeline as an example to introduce the pipeline development tools.The General OCR Pipeline is designed to solve text recognition tasks, extracting text information from images and outputting it in text form. PP-OCRv4 is an end-to-end OCR system that achieves millisecond-level text content prediction on CPUs, reaching state-of-the-art (SOTA) performance in open-source projects for general scenarios.You can directly use the pre-trained models provided by OCR pipeline for inference. * Command line
paddlex --pipeline OCR --input general_ocr_002.png --device npu:0 # change the device name to npu, mlu, xpu, dcu or gcu
from paddlex import create_pipeline
pipeline = create_pipeline(pipeline="OCR", device="npu:0") # change the device name to npu, mlu, xpu, dcu or gcu
output = pipeline.predict("general_ocr_002.png")
for res in output:
res.print()
res.save_to_img("./output/")
# train
python main.py -c paddlex/configs/text_detection/PP-OCRv4_mobile_det.yaml \
-o Global.mode=train \
-o Global.dataset_dir=./dataset/ocr_det_dataset_examples \ # change the dataset_dir to your own dataset path
-o Global.device=npu:0,1,2,3 # change the device name to npu, mlu, xpu, dcu or gcu
# predict
python main.py -c paddlex/configs/text_detection/PP-OCRv4_mobile_det.yaml \
-o Global.mode=predict \
-o Predict.model_dir="./output/best_accuracy/inference" \
-o Predict.input="general_ocr_001.png"
-o Global.device=npu # change the device name to npu, mlu, xpu, dcu or gcu