32template <ComputeData InputType = std::vector<Kakshya::DataVariant>, ComputeData OutputType = InputType>
81 const auto ir = get_parameter_or<std::vector<double>>(
82 "impulse_response", std::vector<double> { 1.0 });
89 const auto tmpl = get_parameter_or<std::vector<double>>(
90 "template_signal", std::vector<double> { 1.0 });
91 const auto norm = get_parameter_or<bool>(
"normalize",
true);
98 const auto ref = get_parameter_or<std::vector<double>>(
99 "reference_signal", std::vector<double> { 1.0 });
106 const auto ir = get_parameter_or<std::vector<double>>(
107 "impulse_response", std::vector<double> { 1.0 });
108 const auto reg = get_parameter_or<double>(
"regularization", 1e-6);
115 const auto norm = get_parameter_or<bool>(
"normalize",
true);
143 if (name ==
"operation") {
144 if (
auto r = safe_any_cast<ConvolutionOperation>(value)) {
148 if (
auto r = safe_any_cast<std::string>(value)) {
149 if (
auto e = Reflect::string_to_enum_case_insensitive<ConvolutionOperation>(*r.value)) {
171 template <
typename Func>
176 for (
size_t i = 0; i < channels.size(); ++i) {
177 if constexpr (std::is_void_v<std::invoke_result_t<Func, std::span<double>>>) {
185 for (
size_t i = 0; i < channels.size(); ++i)
188 OperationHelper::reconstruct_from_double<InputType>(
m_working_buffer, structure_info));
200 this->
set_parameter(
"impulse_response", std::vector<double> { 1.0 });
201 this->
set_parameter(
"template_signal", std::vector<double> { 1.0 });
202 this->
set_parameter(
"reference_signal", std::vector<double> { 1.0 });
214 template <
typename T>
218 if (!param.has_value())
219 return default_value;
221 auto result = safe_any_cast<T>(param);
222 return result.value_or(default_value);
236 if constexpr (std::is_same_v<InputType, OutputType>) {
Core::GlobalInputConfig input
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 > convolve(std::span< const double > src, std::span< const double > ir)
Linear FFT convolution.
std::vector< double > cross_correlate(std::span< const double > src, std::span< const double > tmpl, bool normalize)
Cross-correlation via FFT.
std::vector< double > auto_correlate(std::span< const double > src, bool normalize)
Auto-correlation via FFT.
std::vector< double > deconvolve(std::span< const double > src, std::span< const double > ir, double regularization)
Frequency-domain deconvolution with Tikhonov regularisation.
std::vector< double > matched_filter(std::span< const double > src, std::span< const double > reference)
Matched filter (normalised cross-correlation)
constexpr std::string_view enum_to_string(EnumType value) noexcept
Universal enum to string converter using magic_enum (original case)
ConvolutionOperation
Specific convolution operations supported.
@ DECONVOLUTION
Deconvolution.
@ DIRECT_CONVOLUTION
Standard convolution.
@ AUTO_CORRELATION
Auto-correlation.
@ CROSS_CORRELATION
Cross-correlation.
@ MATCHED_FILTER
Matched filtering.
TransformationType
Categories of transformation operations for discovery and organization.
@ CONVOLUTION
Convolution-based transformations (impulse response, filters)
Input/Output container for computation pipeline data flow with structure preservation.