speech-prep 0.1.1

Speech-focused audio preprocessing — VAD, format detection, decoding, noise reduction, chunking
Documentation
//! # speech-prep
//!
//! Speech-focused audio preprocessing for Rust.
//!
//! - Voice activity detection (dual-metric: energy + spectral flux)
//! - Multi-format decoding (WAV/MP3/FLAC/OGG/M4A/Opus → 16kHz mono PCM)
//! - Preprocessing (DC removal, high-pass filter, noise reduction, normalization)
//! - Speech-aligned chunking with overlap handling
//! - Quality assessment metrics
//!
//! ## Usage
//!
//! ```rust
//! use speech_prep::VadConfig;
//!
//! let config = VadConfig::default();
//! assert!(config.base_threshold > 0.0);
//! ```

#![cfg_attr(test, allow(clippy::unwrap_used))]
#![cfg_attr(test, allow(clippy::expect_used))]
#![cfg_attr(test, allow(clippy::panic))]
#![cfg_attr(test, allow(clippy::indexing_slicing))]
#![cfg_attr(test, allow(clippy::print_stdout))]
#![cfg_attr(test, allow(clippy::float_cmp))]

pub mod buffer;
pub mod chunker;
pub mod converter;
pub mod decoder;
pub mod error;
#[cfg(any(test, feature = "fixtures"))]
pub mod fixtures;
pub mod format;
pub mod monitoring;
pub mod pipeline;
pub mod preprocessing;
pub mod time;
pub mod types;
pub mod vad;

pub use buffer::{AudioBuffer, AudioMetadata};
pub use chunker::{ChunkBoundary, Chunker, ChunkerConfig, ProcessedChunk};
pub use error::{Error, Result};
pub use monitoring::VADStats;
pub use pipeline::{AudioPipelineCoordinator, ProcessingResult, StageLatencies};
pub use preprocessing::{
    DcHighPassFilter, HighpassOrder, NoiseReducer, NoiseReductionConfig, PreprocessingConfig,
    VadContext,
};
pub use time::{AudioDuration, AudioInstant, AudioTimestamp};
pub use types::AudioChunk;
pub use vad::{NoopVadMetricsCollector, SpeechChunk, VadConfig, VadDetector, VadMetricsCollector};