From 4232e522ea1524d25282bd1a5b2be991eee3a995 Mon Sep 17 00:00:00 2001 From: Kerollmops Date: Wed, 18 Dec 2024 17:11:26 +0100 Subject: [PATCH] Generate the dictionary only when necessary --- .../src/update/new/extract/documents/compression.rs | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/crates/milli/src/update/new/extract/documents/compression.rs b/crates/milli/src/update/new/extract/documents/compression.rs index 24bd5ee47..1e99b6e13 100644 --- a/crates/milli/src/update/new/extract/documents/compression.rs +++ b/crates/milli/src/update/new/extract/documents/compression.rs @@ -31,6 +31,8 @@ const DICTIONARY_MAX_SIZE: usize = 64_000; /// have not already been compressed in the database. If this threshold /// is reached, we do not generate a dictionary and continue as is. const COMPRESS_LIMIT: usize = 5_000_000; +/// This is 10KiB. +const TEN_KIB: usize = 10 * 1024; /// A function dedicated to use the existing or generate an appropriate /// document compression dictionay based on the documents available in @@ -115,6 +117,16 @@ where ); } + // We avoid generating a dictionary if most (> 1/3) of the sample sizes are + // smaller than 8 bytes, or if the sample data size is smaller than 10KiB. + // + // + if sample_sizes.iter().filter(|s| **s < 8).count() > sample_sizes.len() / 3 + || sample_data.len() < TEN_KIB + { + return Ok(None); + } + let dictionary = from_continuous(&sample_data, &sample_sizes, DICTIONARY_MAX_SIZE)?; index.put_document_compression_dictionary(wtxn, &dictionary)?; let encoder_dictionary = EncoderDictionary::copy(&dictionary, COMPRESSION_LEVEL);