32template <ComputeData InputType = std::vector<Kakshya::DataVariant>, ComputeData OutputType = InputType>
85 const auto shift_hz = get_parameter_or<double>(
"shift_hz", 0.0);
86 const auto window_size = get_parameter_or<uint32_t>(
"window_size", 1024);
87 const auto hop_size = get_parameter_or<uint32_t>(
"hop_size", 512);
88 const auto sample_rate = get_parameter_or<double>(
"sample_rate", 48000.0);
89 const double lo = std::max(0.0, shift_hz);
90 const double hi = sample_rate / 2.0 + shift_hz;
93 [lo, hi, sample_rate, window_size, hop_size](std::span<double> ch) {
99 const auto pitch_ratio = get_parameter_or<double>(
"pitch_ratio", 1.0);
100 const auto window_size = get_parameter_or<uint32_t>(
"window_size", 2048);
101 const auto hop_size = get_parameter_or<uint32_t>(
"hop_size", 512);
102 const double semitones = 12.0 * std::log2(pitch_ratio);
105 [semitones, window_size, hop_size](std::span<double> ch) {
111 const auto lo_freq = get_parameter_or<double>(
"low_freq", 20.0);
112 const auto hi_freq = get_parameter_or<double>(
"high_freq", 20000.0);
113 const auto sample_rate = get_parameter_or<double>(
"sample_rate", 48000.0);
114 const auto window_size = get_parameter_or<uint32_t>(
"window_size", 1024);
115 const auto hop_size = get_parameter_or<uint32_t>(
"hop_size", 512);
118 [lo_freq, hi_freq, sample_rate, window_size, hop_size](std::span<double> ch) {
124 const auto factor = get_parameter_or<double>(
"enhancement_factor", 2.0);
125 const auto window_size = get_parameter_or<uint32_t>(
"window_size", 1024);
126 const auto hop_size = get_parameter_or<uint32_t>(
"hop_size", 512);
129 [factor, window_size, hop_size](std::span<double> ch) {
135 const auto threshold = get_parameter_or<double>(
"threshold", -40.0);
136 const auto window_size = get_parameter_or<uint32_t>(
"window_size", 1024);
137 const auto hop_size = get_parameter_or<uint32_t>(
"hop_size", 512);
140 [threshold, window_size, hop_size](std::span<double> ch) {
168 if (name ==
"operation") {
169 if (
auto r = safe_any_cast<SpectralOperation>(value)) {
173 if (
auto r = safe_any_cast<std::string>(value)) {
174 if (
auto e = Reflect::string_to_enum_case_insensitive<SpectralOperation>(*r.value)) {
197 template <
typename Func>
202 for (
size_t i = 0; i < channels.size(); ++i)
206 for (
size_t i = 0; i < channels.size(); ++i)
210 OperationHelper::reconstruct_from_double<InputType>(
m_working_buffer, structure_info));
240 template <
typename T>
244 if (!param.has_value())
245 return default_value;
247 auto result = safe_any_cast<T>(param);
248 return result.value_or(default_value);
262 if constexpr (std::is_same_v<InputType, OutputType>) {
Core::GlobalInputConfig input
Short-time Fourier domain primitives for MayaFlux::Kinesis.
output_type convert_result(std::vector< std::vector< double > > &result_data, DataStructureInfo &metadata)
Convert processed double data back to OutputType using metadata and optional callback.
static std::tuple< std::vector< std::span< double > >, DataStructureInfo > extract_structured_double(T &compute_data)
Extract structured double data from Datum container or direct ComputeData with automatic container ha...
std::vector< double > harmonic_enhance(std::span< const double > src, double enhancement_factor, uint32_t window_size, uint32_t hop_size)
Linear spectral tilt: scale each bin by a factor that rises linearly from 1 at bin 0 to enhancement_f...
std::vector< double > spectral_gate(std::span< const double > src, double threshold_db, uint32_t window_size, uint32_t hop_size)
Hard spectral gate: zero bins whose magnitude is below the threshold.
std::vector< double > spectral_filter(std::span< const double > src, double lo_hz, double hi_hz, double sample_rate, uint32_t window_size, uint32_t hop_size)
Hard bandpass filter: zero all bins outside [lo_hz, hi_hz].
std::vector< double > pitch_shift(std::span< const double > src, double semitones, uint32_t window_size, uint32_t analysis_hop)
Pitch-shift by resampling around a phase vocoder stretch.
constexpr std::string_view enum_to_string(EnumType value) noexcept
Universal enum to string converter using magic_enum (original case)
SpectralOperation
Spectral operations supported by SpectralTransformer.
@ SPECTRAL_FILTER
Hard bandpass filter.
@ SPECTRAL_GATE
Hard magnitude gate.
@ HARMONIC_ENHANCE
Linear spectral tilt.
@ PITCH_SHIFT
Phase-vocoder pitch shift, duration preserved.
@ FREQUENCY_SHIFT
Bandpass repositioning (approximate frequency shift)
TransformationType
Categories of transformation operations for discovery and organization.
@ SPECTRAL
Frequency domain transformations (pitch-shift, spectral filtering)
Input/Output container for computation pipeline data flow with structure preservation.