1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
// Copyright (c) 2025 SynaDB Contributors
// Licensed under the SynaDB License. See LICENSE file for details.
//! Compression utilities for Syna database.
//!
//! This module provides two compression strategies:
//!
//! 1. **LZ4 compression** - General-purpose compression for large values
//! 2. **Delta encoding** - Specialized compression for float sequences
//!
//! Both can be enabled via [`DbConfig`](crate::DbConfig).
use crate;
/// Compresses data using LZ4.
///
/// Uses `lz4_flex` with size prepended for self-describing decompression.
///
/// # Arguments
///
/// * `data` - The raw bytes to compress
///
/// # Returns
///
/// Compressed bytes with the original size prepended (4 bytes).
/// Decompresses LZ4 compressed data.
///
/// # Arguments
///
/// * `data` - Compressed bytes (with size prepended)
///
/// # Returns
///
/// * `Ok(Vec<u8>)` - Decompressed data
/// * `Err(SynaError::DecompressionFailed)` - If decompression fails
/// Returns `true` if the data is large enough to benefit from compression.
///
/// Small values (≤64 bytes) may actually grow when compressed due to
/// LZ4 overhead, so we skip compression for them.
/// Encodes a float value as a delta from the previous value.
///
/// Delta encoding stores the difference between consecutive values,
/// which is typically smaller for time-series data with gradual changes.
///
/// # Arguments
///
/// * `current` - The current value to encode
/// * `previous` - The previous value in the sequence
///
/// # Returns
///
/// The delta: `current - previous`
///
/// # Example
///
/// ```rust
/// use synadb::compression::{encode_delta, decode_delta};
///
/// let prev = 100.0;
/// let curr = 100.5;
/// let delta = encode_delta(curr, prev);
/// assert_eq!(delta, 0.5);
/// assert_eq!(decode_delta(delta, prev), curr);
/// ```
/// Decodes a delta-encoded float value.
///
/// # Arguments
///
/// * `delta` - The delta value (difference from previous)
/// * `previous` - The previous value in the sequence
///
/// # Returns
///
/// The reconstructed value: `previous + delta`