TextChunker is an Elixir library for segmenting large text documents, optimizing them for efficient embedding and storage within vector databases for use in retrieval augmented generation (RAG) applications.
It prioritizes context preservation and adaptability, and is therefore ideal for analytical, NLP, and other applications where understanding the relationship between text segments is crucial.
Fill the gap in the Elixir ecosystem for a good semantic text chunker, and give access to langchain-style chunking.
- Semantic Chunking: Prioritizes chunking text into meaningful blocks based on separators relevant to the specified format (e.g., headings, paragraphs in Markdown).
- Configurable Chunking: Fine-tune the chunking process with options for, text chunk size, overlap and format.
- Metadata Tracking: Automatically generates Chunk structs containing byte range information for accurately reassembling the original text if needed.
- Extensibility: Designed to accommodate additional chunking strategies in the future.
Add TextChunker to your mix.exs:
def deps do
[
{:text_chunker, "~> 0.3.1"}
]
end
Fetch dependencies:
mix deps.get
Chunk your text using the split
function:
text = "Your text to be split..."
chunks = TextChunker.split(text)
This will chunk up your text using the default parameters - a chunk size of 1000
, chunk overlap of 200
, format of :plaintext
and using the RecursiveChunk
strategy.
The split method returns Chunks
of your text. These chunks include the start and end bytes of each chunk.
%TextChunker.Chunk{
start_byte: 0,
end_byte: 44,
text: "This is a sample text. It will be split into",
}
If you wish to adjust these parameters, configuration can optionally be passed via a keyword list.
chunk_size
- The approximate target chunk size, as measured per code points. This means that botha
and👻
count as one. Chunks will not exceed this maximum, but may sometimes be smaller. Important note This means that graphemes may be split. For example,👩🚒
may be split into👩,🚒
or not depending on the split boundary.chunk_overlap
- The contextual overlap between chunks, as measured per code point. Overlap is not guaranteed; again this should be treated as a maximum. The size of an individual overlap will depend on the semantics of the text being split.format
- What informs separator selection. Because we are trying to preserve meaning between the chunks, the format of the text we are splitting is important. It's important to split newlines in plain text; it's important to split###
headings in markdown.
text = """
## Your text to be split
Let's split your text up properly!
"""
opts = [chunk_size: 10, chunk_overlap: 5, format: :markdown]
chunks = TextChunker.split(text, opts)
Currently, we only implement one strategy choice: Recursive Chunk. This was reverse-engineered from LangChain, with plans to add more methods in the future.
You can use Recursive Chunk to split text up into any chunk size you wish, with or without overlap. It is important to note that this overlap is not guaranteed - rather, if the overlap makes sense, this is the max length for that overlap. Recursive Chunk prioritizes keeping the semantics intact (as defined by the separators derived from the input format). The overlap does not occur when such an overlap would break those semantics. See below for examples.
text = "This is a sample text. It will be split into properly-sized chunks using the TextChunker library."
iex(10)> TextChunker.split(text)
[
%TextChunker.Chunk{
start_byte: 0,
end_byte: 97,
text: "This is a sample text. It will be split into properly-sized chunks using the TextChunker library."
}
]
text = "This is a sample text. It will be split into properly-sized chunks using the TextChunker library."
opts = [chunk_size: 50, chunk_overlap: 5, format: :plaintext, strategy: TextChunker.Strategies.RecursiveChunk]
iex(10)> TextChunker.split(text, opts)
[
%TextChunker.Chunk{
start_byte: 0,
end_byte: 44,
text: "This is a sample text. It will be split into"
},
%TextChunker.Chunk{
start_byte: 39,
end_byte: 88,
text: " into properly-sized chunks using the TextChunker"
},
%TextChunker.Chunk{
start_byte: 88,
end_byte: 97,
text: " library."
}
]
Bug reports and pull requests are welcome on GitHub at https://github.com/revelrylabs/text_chunker_ex. Check out the contributing guidelines for more info.
Everyone is welcome to participate in the project. We expect contributors to adhere to the Contributor Covenant Code of Conduct.
See RELEASES.md for details about the release process.
Special thanks to the creators of Langchain for their initial approach to recursive text splitting, which inspired this library. See the NOTICE file for details.
TextChunker is released under the MIT License. See the LICENSE file for details.