***
layout: overview
slug: nemo-curator/nemo\_curator/utils/grouping
title: nemo\_curator.utils.grouping
-----------------------------------
Utility Functions for grouping iterables.
This module provides a collection of utility functions designed to assist with common tasks related to manipulating
and transforming iterables in Python.
These utilities are generic and work with any iterable types. They're particularly useful for data processing tasks,
batching operations, and other scenarios where dividing data into specific groupings is necessary.
## Module Contents
### Functions
| Name | Description |
| ------------------------------------------------------------------------- | ---------------------------------------------------------- |
| [`pairwise`](#nemo_curator-utils-grouping-pairwise) | Return pairs of consecutive items from the input iterable. |
| [`split_by_chunk_size`](#nemo_curator-utils-grouping-split_by_chunk_size) | Split an iterable into chunks of the specified size. |
| [`split_into_n_chunks`](#nemo_curator-utils-grouping-split_into_n_chunks) | Split an iterable into a specified number of chunks. |
### Data
[`T`](#nemo_curator-utils-grouping-T)
### API
```python
nemo_curator.utils.grouping.pairwise(
iterable: collections.abc.Iterable[nemo_curator.utils.grouping.T]
) -> collections.abc.Iterable[tuple[nemo_curator.utils.grouping.T, nemo_curator.utils.grouping.T]]
```
Return pairs of consecutive items from the input iterable.
**Parameters:**
The input iterable.
**Returns:** `Iterable[tuple[T, T]]`
Iterable\[tuple\[T, T]]: Pairs of consecutive items.
```python
nemo_curator.utils.grouping.split_by_chunk_size(
iterable: collections.abc.Iterable[nemo_curator.utils.grouping.T],
chunk_size: int,
custom_size_func: typing.Callable[[T], int] = lambda x: 1,
drop_incomplete_chunk: bool = False
) -> collections.abc.Generator[list[nemo_curator.utils.grouping.T], None, None]
```
Split an iterable into chunks of the specified size.
Yields:
* Generator\[list\[T], None, None]: Chunks of the input iterable.
**Parameters:**
The input iterable to be split.
Size of each chunk.
function
If True, drops the last chunk if its size is less than the
specified chunk size. Defaults to False.
```python
nemo_curator.utils.grouping.split_into_n_chunks(
iterable: collections.abc.Iterable[nemo_curator.utils.grouping.T],
num_chunks: int
) -> collections.abc.Generator[list[nemo_curator.utils.grouping.T], None, None]
```
Split an iterable into a specified number of chunks.
Yields:
* Generator\[list\[T], None, None]: Chunks of the input iterable.
**Parameters:**
The input iterable to be split.
The desired number of chunks.
```python
nemo_curator.utils.grouping.T = typing.TypeVar('T')
```