Project Icon

nougat

神经网络模型用于解析学术PDF文档

Nougat是一个开源的神经网络模型,专门用于解析学术PDF文档。该模型能够理解LaTeX数学公式和表格,支持单个文件和批量处理。Nougat提供命令行界面和API接口,输出采用轻量级标记语言,与Mathpix Markdown兼容。此外,Nougat还支持数据集生成、模型训练和评估功能。项目托管在GitHub上,可通过pip安装使用。

Nougat: 学术文献的神经光学理解

论文 GitHub PyPI Python 3.9+ 代码风格: black Hugging Face Spaces

这是Nougat的官方代码库,Nougat是一个能够理解LaTeX数学公式和表格的学术文献PDF解析器。

项目主页:https://facebookresearch.github.io/nougat/

安装

从pip安装:

pip install nougat-ocr

从代码库安装:

pip install git+https://github.com/facebookresearch/nougat

注意,Windows用户:如果你想使用GPU,请确保先安装正确版本的PyTorch。请按照这里的说明进行操作。

如果你想通过API调用模型或生成数据集,还需要额外的依赖项。 通过以下方式安装:

pip install "nougat-ocr[api]"pip install "nougat-ocr[dataset]"

获取PDF的预测结果

命令行界面

要获取PDF的预测结果,运行:

$ nougat path/to/file.pdf -o output_directory

也可以将目录路径或每行包含PDF路径的文件路径作为位置参数传递:

$ nougat path/to/directory -o output_directory
用法:nougat [-h] [--batchsize BATCHSIZE] [--checkpoint CHECKPOINT] [--model MODEL] [--out OUT]
              [--recompute] [--markdown] [--no-skipping] pdf [pdf ...]

位置参数:
  pdf                   要处理的PDF文件。

选项:
  -h, --help            显示此帮助信息并退出
  --batchsize BATCHSIZE, -b BATCHSIZE
                        要使用的批处理大小。
  --checkpoint CHECKPOINT, -c CHECKPOINT
                        检查点目录路径。
  --model MODEL_TAG, -m MODEL_TAG
                        要使用的模型标签。
  --out OUT, -o OUT     输出目录。
  --recompute           重新计算已处理的PDF,丢弃之前的预测结果。
  --full-precision      使用float32而不是bfloat16。对某些设置可以加速CPU转换。
  --no-markdown         不添加Markdown兼容性的后处理步骤。
  --markdown            添加Markdown兼容性的后处理步骤(默认)。
  --no-skipping         不应用失败检测启发式。
  --pages PAGES, -p PAGES
                        提供页码,如'1-4,7'表示第1页到第4页和第7页。仅适用于单个PDF文件。

默认的模型标签是0.1.0-small。如果你想使用基础模型,使用0.1.0-base

$ nougat path/to/file.pdf -o output_directory -m 0.1.0-base

在输出目录中,每个PDF将被保存为一个.mmd文件,这是一种轻量级标记语言,主要与Mathpix Markdown兼容(我们使用了LaTeX表格)。

注意:在某些设备上,失败检测启发式可能无法正常工作。如果你遇到大量[MISSING_PAGE]响应,请尝试使用--no-skipping标志运行。相关问题:#11#67

API

通过额外的依赖项,你可以使用app.py启动API。运行:

$ nougat_api

要通过向 http://127.0.0.1:8503/predict/ 发送 POST 请求来获取 PDF 文件的预测结果。它还接受参数 startstop 来限制计算的页码范围(包含边界)。

响应是一个包含文档 markdown 文本的字符串。

curl -X 'POST' \
  'http://127.0.0.1:8503/predict/' \
  -H 'accept: application/json' \
  -H 'Content-Type: multipart/form-data' \
  -F 'file=@<PDFFILE.pdf>;type=application/pdf'

要将转换限制在第 1 页到第 5 页,请在请求 URL 中使用 start/stop 参数:http://127.0.0.1:8503/predict/?start=1&stop=5

数据集

生成数据集

要生成数据集,你需要:

  1. 包含 PDF 文件的目录
  2. 包含 .html 文件(由 LaTeXML 处理的 .tex 文件)的目录,具有相同的文件夹结构
  3. pdffigures2 的二进制文件和相应的环境变量 export PDFFIGURES_PATH="/path/to/binary.jar"

接下来运行

python -m nougat.dataset.split_htmls_to_pages --html path/html/root --pdfs path/pdf/root --out path/paired/output --figure path/pdffigures/outputs

其他参数包括

参数描述
--recompute重新计算所有分割
--markdown MARKDOWNMarkdown 输出目录
--workers WORKERS使用的进程数
--dpi DPI页面保存的分辨率
--timeout TIMEOUT每篇论文的最大处理时间(秒)
--tesseract对每页进行 Tesseract OCR 预测

最后创建一个包含所有图像路径、markdown 文本和元信息的 jsonl 文件。

python -m nougat.dataset.create_index --dir path/paired/output --out index.jsonl

对于每个 jsonl 文件,你还需要生成一个寻址映射以加快数据加载:

python -m nougat.dataset.gen_seek file.jsonl

生成的目录结构可能如下所示:

root/
├── images
├── train.jsonl
├── train.seek.map
├── test.jsonl
├── test.seek.map
├── validation.jsonl
└── validation.seek.map

注意,path/paired/output(此处为 images)中的 .mmd.json 文件不再需要。 这对于将数据推送到 S3 存储桶时减少文件数量很有用。

训练

要训练或微调 Nougat 模型,运行

python train.py --config config/train_nougat.yaml

评估

运行

python test.py --checkpoint path/to/checkpoint --dataset path/to/test.jsonl --save_path path/to/results.json

要获取不同文本模态的结果,运行

python -m nougat.metrics path/to/results.json

常见问题

  • 为什么我只得到 [MISSING_PAGE]

    Nougat 是在 arXiv 和 PMC 上的科学论文上训练的。你正在处理的文档是否与之类似? 文档使用什么语言?Nougat 最适合英语论文,其他基于拉丁字母的语言可能也能工作。中文、俄语、日语等将无法工作。 如果这些要求都满足,可能是由于在 CPU 或较旧的 GPU 上计算时失败检测出现误报(#11)。现在可以尝试传递 --no-skipping 标志。

  • 在哪里可以下载模型检查点?

    它们上传在 GitHub 的发布部分。你也可以在程序首次执行时下载它们。通过传递 --model 0.1.0-{base,small} 来选择首选模型。

引用

@misc{blecher2023nougat,
      title={Nougat: Neural Optical Understanding for Academic Documents}, 
      author={Lukas Blecher and Guillem Cucurull and Thomas Scialom and Robert Stojnic},
      year={2023},
      eprint={2308.13418},
      archivePrefix={arXiv},
      primaryClass={cs.LG}
}

致谢

本仓库是在 Donut 仓库的基础上构建的。

许可证

Nougat 代码库采用 MIT 许可证。

Nougat 模型权重采用 CC-BY-NC 许可证。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号