curator
Scalable data pre processing and curation toolkit for LLMs
Science Score: 44.0%
This score indicates how likely this project is to be science-related based on various indicators:
-
✓CITATION.cff file
Found CITATION.cff file -
✓codemeta.json file
Found codemeta.json file -
✓.zenodo.json file
Found .zenodo.json file -
○DOI references
-
○Academic publication links
-
○Academic email domains
-
○Institutional organization owner
-
○JOSS paper metadata
-
○Scientific vocabulary similarity
Low similarity (14.5%) to scientific vocabulary
Keywords
Repository
Scalable data pre processing and curation toolkit for LLMs
Basic Info
Statistics
- Stars: 1,111
- Watchers: 17
- Forks: 166
- Open Issues: 95
- Releases: 18
Topics
Metadata Files
README.md
Accelerate Data Processing and Streamline Synthetic Data Generation with NVIDIA NeMo Curator
NeMo Curator, part of the NVIDIA NeMo software suite for managing the AI agent lifecycle, is a Python library specifically designed for fast and scalable data processing and curation for generative AI use cases such as foundation language model pretraining, text-to-image model training, domain-adaptive pretraining (DAPT), supervised fine-tuning (SFT) and parameter-efficient fine-tuning (PEFT).
It greatly accelerates data processing and curation by leveraging GPUs with Dask and RAPIDS, resulting in significant time savings. The library provides a customizable and modular interface, simplifying pipeline expansion and accelerating model convergence through the preparation of high-quality tokens.
NeMo Curator also provides pre-built pipelines for synthetic data generation for customization and evaluation of generative AI systems. You can use any OpenAI API compatible model and plug it in NeMo Curator's synthetic data generation pipelines to process and curate high-quality synthetic data for various use cases.
Getting Started
New to NeMo Curator? Start with our quickstart guides for hands-on experience:
- Text Curation Quickstart - Set up your environment and run your first text curation pipeline in under 30 minutes
- Image Curation Quickstart - Learn to curate large-scale image-text datasets for generative model training
For production deployments and advanced configurations, see our Setup & Deployment documentation.
Key Features
With NeMo Curator, you can process raw data and curate high-quality data for training and customizing generative AI models such as LLMs, VLMs and WFMs. NeMo Curator provides a collection of scalable data processing modules for text and image curation.
Text Curation
All of our text pipelines have great multilingual support. With NeMo Curator, you can pick and choose the features you want and build your data curation pipelines. Text curation follows a three-stage workflow: Load → Process → Generate. A typical pipeline starts by downloading raw data from public resources, then applies cleaning and filtering steps, and optionally generates synthetic data for training enhancement.
Load Data
- Download and Extraction - Default implementations for Common Crawl, Wikipedia, and ArXiv sources with easy customization for other sources
Process Data
Quality Assessment & Filtering
- Heuristic Filtering - 30+ heuristic filters for punctuation density, length, and repetition analysis
- fastText Classification - Fast language and quality classification
- GPU-Accelerated Classification - Domain, Quality, Safety, Educational Content, Content Type, and Prompt Task/Complexity Classification
Deduplication
- Exact Deduplication - Remove identical documents efficiently
- Fuzzy Deduplication - MinHash Locality Sensitive Hashing with optional False Positive Check
- Semantic Deduplication - GPU-accelerated semantic deduplication using RAPIDS cuML, cuDF, and PyTorch
Content Processing & Cleaning
- Text Cleaning - Remove improperly decoded Unicode characters, inconsistent line spacing, and excessive URLs
- PII Redaction - Identify and remove personally identifiable information from training datasets
Specialized Processing
- Language Identification - Accurate language detection using fastText
- Task Decontamination - Remove potential evaluation data leakage from training datasets
Generate Data
- Synthetic Data Pipelines - Pre-built pipelines for generating high-quality synthetic training data:
- Open Q&A Generation - Create question-answer pairs for instruction tuning
- Math Problem Generation - Generate mathematical problems for educational content
- Coding Tasks - Create programming challenges and code examples
- Writing Prompts - Generate creative writing and content creation tasks
- Dialogue Generation - Create conversational data for chat models
- Nemotron Pipelines - Wikipedia-style rewriting and knowledge distillation
Image Curation
NeMo Curator provides powerful image curation features to curate high-quality image data for training generative AI models such as LLMs, VLMs, and WFMs. Image curation follows a Load → Process workflow: download datasets in WebDataset format, create embeddings, apply quality filters (NSFW and Aesthetic), and remove duplicates using semantic deduplication.
Load Data
- WebDataset Loading - Load large-scale image-text datasets in WebDataset format
Process Data
Embeddings & Feature Extraction
- Image Embedding Creation - Generate CLIP embeddings for image analysis
Quality Assessment & Filtering
- Aesthetic Classification - Filter images based on aesthetic quality
- NSFW Classification - Remove inappropriate content from datasets
Deduplication
- Semantic Deduplication - Remove visually similar images using embedding-based clustering
Module Ablation and Compute Performance
The modules within NeMo Curator were primarily designed to process and curate high-quality documents at scale. To evaluate the quality of the data, we curated Common Crawl documents and conducted a series of ablation experiments. In these experiments, we trained a 357M-parameter GPT-style model using datasets generated at various stages of our data curation pipeline, which was implemented in NeMo Curator.
The following figure shows that the use of different data curation modules implemented in NeMo Curator led to improved model zero-shot downstream task performance.
NeMo Curator leverages NVIDIA RAPIDS™ libraries like cuDF, cuML, and cuGraph along with Dask to scale workloads across multi-node, multi-GPU environments, significantly reducing data processing time. With NeMo Curator, developers achieve approximately 16× faster fuzzy‑deduplication on an 8 TB RedPajama‑v2 subset, with ~40% lower TCO and near‑linear scaling on 1–4 H100 80 GB nodes. Refer to the chart below to learn more details.
NeMo Curator exhibits near‑linear scaling for fuzzy deduplication. On an 8 TB RedPajama‑v2 subset (~1.78 trillion tokens), processing time drops from 2.05 hours on one H100 80 GB node to 0.50 hours on four nodes. Refer to the scaling chart below to learn more:
Contribute to NeMo Curator
We welcome community contributions! Please refer to CONTRIBUTING.md for the process.
Owner
- Name: NVIDIA-NeMo
- Login: NVIDIA-NeMo
- Kind: organization
- Repositories: 1
- Profile: https://github.com/NVIDIA-NeMo
Citation (CITATION.cff)
cff-version: 1.0.0
message: "If you use this software, please cite it as below."
title: "NeMo-Curator: a toolkit for data curation"
repository-code: https://github.com/NVIDIA/NeMo-Curator
authors:
- family-names: Jennings
given-names: Joseph
- family-names: Patwary
given-names: Mostofa
- family-names: Subramanian
given-names: Sandeep
- family-names: Prabhumoye
given-names: Shrimai
- family-names: Dattagupta
given-names: Ayush
- family-names: Jawa
given-names: Vibhu
- family-names: Liu
given-names: Jiwei
- family-names: Wolf
given-names: Ryan
- family-names: Yurick
given-names: Sarah
- family-names: Singh
given-names: Varun
Issues and Pull Requests
Last synced: 4 months ago
All Time
- Total issues: 38
- Total pull requests: 168
- Average time to close issues: 6 months
- Average time to close pull requests: 13 days
- Total issue authors: 16
- Total pull request authors: 25
- Average comments per issue: 0.63
- Average comments per pull request: 1.38
- Merged pull requests: 81
- Bot issues: 0
- Bot pull requests: 1
Past Year
- Issues: 36
- Pull requests: 167
- Average time to close issues: 3 months
- Average time to close pull requests: 8 days
- Issue authors: 15
- Pull request authors: 24
- Average comments per issue: 0.5
- Average comments per pull request: 1.37
- Merged pull requests: 81
- Bot issues: 0
- Bot pull requests: 1
Top Authors
Issue Authors
- sarahyurick (9)
- VibhuJawa (6)
- abhinavg4 (4)
- praateekmahajan (4)
- sithape2025 (2)
- ayushdg (2)
- chtruong814 (2)
- richardliaw (1)
- ronjer30 (1)
- CharlieTruong (1)
- bschifferer (1)
- suiyoubi (1)
- leekaimao (1)
- miguelusque (1)
- QuyAnh2005 (1)
Pull Request Authors
- praateekmahajan (29)
- chtruong814 (28)
- suiyoubi (17)
- thomasdhc (16)
- sarahyurick (15)
- ayushdg (13)
- abhinavg4 (10)
- lbliii (8)
- Copilot (5)
- huvunvidia (4)
- VibhuJawa (3)
- Maghoumi (3)
- TsukiSama9292 (3)
- arhamm1 (2)
- karpnv (2)
Top Labels
Issue Labels
Pull Request Labels
Dependencies
- dask *
- actions/checkout v4 composite
- actions/setup-python v5 composite