DocLayout-YOLO:文档布局分析的新突破

摘要

DocLayout-YOLO是基于YOLO-v10的文档布局分析工具,通过多样化的合成数据和全局到局部的自适应感知增强文档布局分析,提升了处理速度和准确性。它能够对多样性文档进行实时鲁棒的检测。

新闻 🚀🚀🚀

  • 2024.10.25 🎉🎉 基于Mesh-candidate Bestfit的数据合成代码开源,可以合成类型多样、真实感强的高质量布局检测数据集。
  • 2024.10.23 🎉🎉 DocSynth300K数据集现在已经上线🤗Huggingface,大幅提升下游微调性能。
  • 2024.10.21 🎉🎉 在线演示上线🤗Huggingface。
  • 2024.10.18 🎉🎉 DocLayout-YOLO接入文档内容提取工具包PDF-Extract-Kit
  • 2024.10.16 🎉🎉 论文上线ArXiv。

快速使用

在线演示

在线演示目前已经上线。对于本地开发部署,参考以下步骤:

环境配置

bash

conda create -n doclayout_yolo python=3.10
conda activate doclayout_yolo
pip install -e .

如果只想使用DocLayout-YOLO的推理功能,直接通过pip进行安装:

bash

pip install doclayout-yolo

模型推理

脚本推理

通过以下命令运行推理脚本demo.py来进行推理:

bash

python demo.py --model path/to/model --image-path path/to/image
SDK推理

直接通过SDK进行模型推理:

python

import cv2
from doclayout_yolo import YOLOv10

# Load the pre-trained model
model = YOLOv10("path/to/provided/model")

# Perform prediction
det_res = model.predict(
    "path/to/image",   # Image to predict
    imgsz=1024,        # Prediction image size
    conf=0.2,          # Confidence threshold
    device="cuda:0"    # Device to use (e.g., 'cuda:0' or 'cpu')
)

# Annotate and save the result
annotated_frame = det_res[0].plot(pil=True, line_width=5, font_size=20)
cv2.imwrite("result.jpg", annotated_frame)

请使用在DocStructBench上微调的模型来进行推理,适用于实际场景中多种类型文档。模型下载地址在链接,示例图像路径为assets/example。

注意事项

  • 对于PDF或者文档内容提取,请参考PDF-Extract-Kit和MinerU。
  • 感谢NielsRogge,DocLayout-YOLO现在支持直接从🤗Huggingface进行调用,加载模型示例如下:

    python

    filepath = hf_hub_download(repo_id="juliozhao/DocLayout-YOLO-DocStructBench", filename="doclayout_yolo_docstructbench_imgsz1024.pt")
    model = YOLOv10(filepath)
    或者直接通过from_pretrained进行加载:

    python

    model = YOLOv10.from_pretrained("juliozhao/DocLayout-YOLO-DocStructBench")
  • 感谢luciaganlulu,DocLayout-YOLO可以进行batch推理。具体来说,在model.predict的demo.py函数中传入图像路径的列表,而不是单张图像。

DocSynth300K数据集

数据下载

使用以下指令下载数据集(约113G):

python

from huggingface_hub import snapshot_download
# Download DocSynth300K
snapshot_download(repo_id="juliozhao/DocSynth300K", local_dir="./docsynth300k-hf", repo_type="dataset")
# If the download was disrupted and the file is not complete, you can resume the download
snapshot_download(repo_id="juliozhao/DocSynth300K", local_dir="./docsynth300k-hf", repo_type="dataset", resume_download=True)

数据准备 & 预训练

如果想要进行DocSynth300K预训练,首先使用format_docsynth300k.py将原始数据集的.parquet格式转换成YOLO格式。格式转换后的数据存储在./layout_data/docsynth300k。

python

python format_docsynth300k.py

使用此处命令来进行DocSynth300K预训练。默认使用8张GPU进行训练。为了达到最好的性能,可以通过调整预训练超参数例如imgsz以及lr,根据下游微调数据集的分布或者训练设置来调整。

公开文档版面分析(DLA)数据集训练验证

数据准备

指定数据根目录,找到ultralytics配置文件(对于Linux用户配置文件在$HOME/.config/Ultralytics/settings.yaml),将datasets_dir改成项目根目录。

下载整理好的YOLO格式D4LA以及DocLayNet数据,放置在路径./layout_data并且解压缩。

模型训练验证

模型训练使用8张GPU,全局batch size大小为64(8张图片每个GPU)。其他详细的配置、命令、以及模型权重如下:

数据集模型是否DocSynth300K预训练?图像尺寸学习率训练验证AP50mAP模型权重
D4LADocLayout-YOLO16000.04命令命令81.769.8权重
D4LADocLayout-YOLO16000.04命令命令82.470.3权重
DocLayNetDocLayout-YOLO11200.02命令命令93.077.7权重
DocLayNetDocLayout-YOLO11200.02命令命令93.479.7权重

使用DocSynth300K预训练过的预训练模型可以从这里进行下载。验证时,将命令中的checkpoint.pt改成需要验证的模型。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码农工具百宝箱

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值