Skip to content

Latest commit

 

History

History
264 lines (175 loc) · 11.9 KB

File metadata and controls

264 lines (175 loc) · 11.9 KB

DataFlow

Documents

🎉 如果你认可我们的项目,欢迎在 GitHub 上点个 ⭐ Star,关注项目最新进展。

简体中文 | English

Dataflow_10M.mp4

📰 1. 最新动态

  • [2025-06-28] 🎉 我们全新发布的以数据为中心的系统DataFlow已开源 —— 敬请关注后续更新!

🔍 2. 项目概述

DataFlow 是一个数据准备系统,旨在从噪声数据源(PDF、纯文本、低质量问答)中解析,生成,加工并评估高质量数据,以提升大语言模型(LLMs)在特定领域的表现,支持预训练、监督微调(SFT)、强化学习训练以及基于知识库的 RAG 系统。我们在医疗、金融和法律等多个垂类领域实证验证了 DataFlow 的有效性。

我们构建了多种基于规则、深度学习、大语言模型及其 API 的 数据算子(Operators),并将其系统性地整合为多条 数据流水线(Pipelines),共同组成完整的 DataFlow 系统。此外,我们还构建了智能的 DataFlow-Agent,支持按需动态编排已有算子,合成新的数据流水线。

🛠️ 3. 数据算子功能介绍

🔧 3.1 算子工作机制

DataFlow采用模块化的算子设计理念,通过组合不同类型的算子来构建灵活的数据处理流水线。算子作为数据处理的基本单元,能够接收结构化数据输入(如json/jsonl/csv格式),经过智能处理后输出高质量的数据结果。详细的算子使用指南请参考:项目文档

📊 3.2 算子分类体系

在DataFlow框架中,算子按功能特性分为三大核心类别:

算子类型 数量 主要功能
通用算子 (Generic Operators) 80+ 涵盖文本评估、处理和合成的通用功能
领域专用算子 (Domain-Specific Operators) 40+ 针对特定领域(如医疗、金融、法律)的专业处理
评估算子 (Evaluation Operators) 20+ 从6个维度全面评估数据质量

🛠️ 4. 数据流程功能介绍

🔧 4.1 推荐使用的完整流水线

目前 DataFlow 包含以下主要数据处理流程:

  • 📝 文本处理流程(Text Pipeline):从大规模纯文本(多为网络爬取)中挖掘问答对,用于监督微调和强化学习训练。

  • 🧠 推理流程(Reasoning Pipeline):增强已有问答对,添加 (1) 长链式推理(Chain-of-Thought),(2) 类别标注,(3) 难度估计。

  • 🗃️ Text2SQL 流程:将自然语言问题转化为 SQL 查询,辅以解释、思维链推理和数据库结构上下文信息。

  • 📚 知识库清洗流程:从表格、PDF 和 Word 文档等非结构化数据源中提取并整理知识,将其转化为可用于下游 RAG 或 QA 配对生成的可用条目。

  • 🤖 Agent式RAG流程:从已有问答或知识库中挖掘需要外部知识才能作答的问答对,用于训练 Agentic RAG 模型。

⚙️ 4.2 算子自由组合的灵活流水线

在本框架中,算子可灵活组合构建数据处理流水线,按功能分为基础算子(Fundamental Operators)、通用算子(Generic Operators)、领域特定算子(Domain-Specific Operators)和评估算子(Evaluation Operators)等,覆盖从清洗到评估的多种任务。详见项目文档了解具体用法。

🤖 4.3 Agent驱动的流水线自动编排

  • DataFlow-Agent:智能助手,可执行数据分析、编写自定义算子,并根据任务目标自动编排算子构建数据处理流水线。

⚡ 5. 快速开始

🛠️ 5.1 环境配置和安装

请使用如下命令进行环境配置和安装👇

conda create -n dataflow python=3.10 
conda activate dataflow

pip install open-dataflow

如果你想要用你自己的GPU完成本地推理,则需要:

pip install open-dataflow[vllm]

Dataflow 支持 Python>=3.10 的环境

安装完成后,你可以用如下指令查看dataflow是否正确安装:

dataflow -v

如果安装正确,应该会看到:

open-dataflow codebase version: 1.0.0
        Checking for updates...
        Local version:  1.0.0
        PyPI newest version:  1.0.0
You are using the latest version: 1.0.0.

🚀 5.2 使用Gradio Web界面

DataFlow提供了两个交互式Web界面,帮助你使用算子、流水线和智能体:

5.2.1 DataFlow算子界面

启动DataFlow算子界面来测试和可视化所有算子和流水线:

dataflow webui

该命令将启动一个交互式 Web 界面,使你能够可视化并灵活使用所有算子和流水线。

5.2.2 DataFlow智能体界面

启动DataFlow智能体界面进行算子编写和流水线设计:

dataflow webui agent

该命令将启动 DataFlow-Agent 界面,提供自动化算子编写功能和流水线推荐服务。

DataFlow_Gradio_10M.mp4

🌐 5.3 ADP智能数据平台

除了本地Gradio界面,DataFlow还提供了基于Web的ADP智能数据平台:https://adp.originhub.tech/login

ADP是OriginHub推出的智能数据平台,具备四大核心能力:DataFlow数据准备全流程自动化、融合大规模多模态知识库的知识系统、多Agent协同的智能协作,以及支撑数据全链路管理的AI数据库,旨在加速企业通过AI能力充分发挥独有数据的价值。

📖 5.4 参考DataFlow项目文档

详细使用说明入门指南,请参考我们的 项目文档

🧪 6. 实验结果

如需详细的实验设置,请参考文档或论文说明。

📝 6.1 文本流程(Text Pipeline)

6.1.1 预训练数据过滤流程

我们将 预训练数据处理流程 应用于从 RedPajama 数据集中随机采样的数据,最终保留率为 13.65%。使用 QuratingScorer 进行质量评估,结果如下图所示:在写作风格、专业性要求、事实准确性和教育价值四个维度上,过滤后的数据显著优于原始数据,验证了 DataFlow 预训练数据处理流程的有效性。

6.1.2 微调(SFT)数据过滤流程

我们从 alpaca 数据集中筛选了 3000 条高质量数据,与随机选取的 3000 条 alpaca 数据进行对比,并在 Qwen2.5-7B 模型上进行 SFT 训练。对比结果如下:

🧠 6.2 推理流程(Reasoning Pipeline)

我们在 Qwen2.5-32B-Instruct 模型上,使用 Reasoning Pipeline 合成的 1000 条和 5000 条数据进行了微调训练(SFT),评估其对模型推理能力的提升,结果如下图所示:

🗃️ 6.3 Text2SQL 流程

我们使用 DataFlow-Text2SQL 流程构建数据,并分别通过监督微调(SFT)与强化学习(RL)对 Qwen2.5-Coder-7B-Instruct 模型进行了训练。实验结果如下:

📄 7. 发表论文

我们团队已发表以下论文,并作为构成DataFlow系统的核心组件:

论文标题 DataFlow组件 会议 年份
MM-Verify: Enhancing Multimodal Reasoning with Chain-of-Thought Verification 多模态推理验证框架,用于数据处理和评估 ACL 2025
Efficient Pretraining Data Selection for Language Models via Multi-Actor Collaboration 多智能体协作数据选择机制,增强数据筛选和处理能力 ACL 2025

合作机构: PKU HKUST CAS Shanghai AI Lab Baichuan Ant Group

💐 8. 致谢

我们衷心感谢 MinerU 的卓越工作,其强大的 PDF/文档文本提取功能为数据加载提供了关键支持。

🤝 9. 社区与支持

欢迎加入 DataFlow 开源社区,提出问题、分享想法、与其他开发者一起共建项目!

• 📮 GitHub Issues:提交 Bug 或功能建议。

• 🔧 GitHub Pull Requests:贡献代码改进。

• 💬 欢迎扫码加入下方社群(微信群、小红书、Twitter),与我们和其他开发者互动交流~

📜 10. 引用

如果 DataFlow 对你的研究或项目有帮助,欢迎引用支持我们:

@misc{dataflow2025,
  author       = {DataFlow Develop Team},
  title        = {DataFlow: A Unified Framework for Data-Centric AI},
  year         = {2025},
  howpublished = {\url{https://github.com/OpenDCAI/DataFlow}},
  note         = {Accessed: 2025-07-08}
}

📊 11. 统计信息


想了解更多?欢迎关注我们 PKU-DCAI 课题组,小红书账号:26133106768