A Docling plugin for PaddlePaddle PP-DocLayout-V3 model document layout detection.
Project description
docling-pp-doc-layout
A Docling plugin that provides document layout detection using the PaddlePaddle PP-DocLayout-V3 model.
This plugin seamlessly integrates with Docling's standard pipeline to replace the default layout models with PP-DocLayout-V3, enabling high-accuracy, instance segmentation-based layout analysis with polygon bounding box support, properly processed in optimized batches for enterprise scalability.
Overview
docling-pp-doc-layout provides the PPDocLayoutV3Model layout engine for Docling. It automatically registers itself into Docling's plugin system upon installation. When configured in a Docling DocumentConverter, it intercepts page images, batches them, and infers document structural elements (text, tables, figures, headers, etc.) using HuggingFace's transformers library.
Key Features:
- High Accuracy Layout Parsing: Uses the RT-DETR instance segmentation framework.
- Polygon Conversion: Gracefully flattens complex polygon masks to Docling-compatible bounding boxes.
- Enterprise Scalability: Configurable batch sizing avoids out-of-memory (OOM) errors on large documents.
Architecture & Integration
When you install this package, Docling discovers it automatically through standard Python package entry points.
flowchart TD
A[Docling DocumentConverter] --> B[PdfPipeline]
subgraph Plugin System
C[Docling PluginManager] -.->|Discovers via entry-points| D[docling-pp-doc-layout]
D -.->|Registers| E[PPDocLayoutV3Model]
end
B -->|Initialization| C
B -->|Predict Layout Pages| E
E -->|Batched Tensors| F[HuggingFace AutoModel]
F -->|Raw Polygons / Boxes| E
E -->|Post-processed Clusters & BoundingBoxes| B
Requirements
- Python 3.13+
docling>=2.73transformers>=5.1.0torch
Installation
# with uv (recommended)
uv add docling-pp-doc-layout
# with pip
pip install docling-pp-doc-layout
Usage
Using docling-pp-doc-layout is exactly like configuring standard Docling options.
from docling.document_converter import DocumentConverter, PdfFormatOption
from docling.datamodel.pipeline_options import PdfPipelineOptions
from docling_pp_doc_layout.options import PPDocLayoutV3Options
# 1. Define Pipeline Options
pipeline_options = PdfPipelineOptions()
# 2. Configure our custom PPDocLayoutV3Options
pipeline_options.layout_options = PPDocLayoutV3Options(
batch_size=8, # Tweak for GPU VRAM usage
confidence_threshold=0.5, # Filter low-confidence detections
model_name="PaddlePaddle/PP-DocLayoutV3_safetensors" # Target HuggingFace model repo
)
# 3. Create the converter
converter = DocumentConverter(
format_options={
"pdf": PdfFormatOption(pipeline_options=pipeline_options)
}
)
# 4. Convert Document
result = converter.convert("path/to/your/document.pdf")
print("Converted elements:", len(result.document.elements))
Configuration Options
All options can be set via environment variables (useful for Docker / Compose
deployments) or programmatically via PPDocLayoutV3Options. Explicit
constructor arguments always take precedence over environment variables.
Environment variables
| Variable | Description | Default |
|---|---|---|
PP_DOC_LAYOUT_MODEL_NAME |
HuggingFace model repository ID | PaddlePaddle/PP-DocLayoutV3_safetensors |
PP_DOC_LAYOUT_CONFIDENCE_THRESHOLD |
Minimum detection confidence (0.0–1.0) | 0.5 |
PP_DOC_LAYOUT_BATCH_SIZE |
Batch size for layout inference | 8 |
PP_DOC_LAYOUT_CREATE_ORPHAN_CLUSTERS |
Create clusters for orphaned elements (true/false) |
true |
PP_DOC_LAYOUT_KEEP_EMPTY_CLUSTERS |
Retain empty clusters in results (true/false) |
false |
PP_DOC_LAYOUT_SKIP_CELL_ASSIGNMENT |
Skip table-cell assignment (true/false) |
false |
Boolean variables accept true, 1, yes (case-insensitive) as truthy values; any other value is treated as false.
PPDocLayoutV3Options
The PPDocLayoutV3Options class gives you full control over the engine:
| Parameter | Type | Default | Description |
|---|---|---|---|
model_name |
str |
PP_DOC_LAYOUT_MODEL_NAME env or "PaddlePaddle/PP-DocLayoutV3_safetensors" |
HuggingFace repository ID. Allows overriding if you host your local copy or a fine-tuned version. |
confidence_threshold |
float |
PP_DOC_LAYOUT_CONFIDENCE_THRESHOLD env or 0.5 |
The minimum confidence score (0.0–1.0) required to keep a layout detection cluster. |
batch_size |
int |
PP_DOC_LAYOUT_BATCH_SIZE env or 8 |
How many pages to process per single step. Decrease to lower memory usage; Increase to speed up processing of large documents. |
create_orphan_clusters |
bool |
PP_DOC_LAYOUT_CREATE_ORPHAN_CLUSTERS env or True |
Create clusters for orphaned elements not assigned to any structure. |
keep_empty_clusters |
bool |
PP_DOC_LAYOUT_KEEP_EMPTY_CLUSTERS env or False |
Retain empty clusters in layout analysis results. |
skip_cell_assignment |
bool |
PP_DOC_LAYOUT_SKIP_CELL_ASSIGNMENT env or False |
Skip assignment of cells to table structures during layout analysis. |
Development
If you wish to contribute or modify the plugin locally:
git clone https://github.com/DCC-BS/docling-pp-doc-layout.git
cd docling-pp-doc-layout
# Install dependencies and pre-commit hooks
make install
# Run checks (ruff, ty) and tests (pytest)
make check
make test
License
MIT © DCC Data Competence Center
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file docling_pp_doc_layout-0.2.2.tar.gz.
File metadata
- Download URL: docling_pp_doc_layout-0.2.2.tar.gz
- Upload date:
- Size: 157.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.10.6 {"installer":{"name":"uv","version":"0.10.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a6867ba2f780cd21f7a38724dab4476d697e408a23235fe19666f33f08ca0cef
|
|
| MD5 |
311ce00d0b61cdebdd7a94f24e780622
|
|
| BLAKE2b-256 |
f6b6da9389872e159209452e296d92da61e23cfb223d7c68f13034da1e28122a
|
File details
Details for the file docling_pp_doc_layout-0.2.2-py3-none-any.whl.
File metadata
- Download URL: docling_pp_doc_layout-0.2.2-py3-none-any.whl
- Upload date:
- Size: 10.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.10.6 {"installer":{"name":"uv","version":"0.10.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
18280eaf4db76917a60b40719a67e60ce719af7cca806bd4ad42b13a513af0f9
|
|
| MD5 |
b4d6524d69fd4a399c6587e2f1a032b6
|
|
| BLAKE2b-256 |
b8fae20b67f75c31d4c0e5a55a7eebbf42ba8cc06ea4f0b06554bb83fabc8e7f
|