MayaFlux 0.4.0
Digital-First Multimedia Processing Framework
Loading...
Searching...
No Matches

◆ estimate_pitch() [2/2]

MAYAFLUX_API double MayaFlux::estimate_pitch ( const std::vector< double > &  data,
double  sample_rate = 48000.0,
double  min_freq = 80.0,
double  max_freq = 2000.0 
)

Estimate fundamental frequency using autocorrelation for single-channel data.

Parameters
dataInput signal data
sample_rateSample rate (default: 48000 Hz)
min_freqMinimum expected frequency (default: 80 Hz)
max_freqMaximum expected frequency (default: 2000 Hz)
Returns
Estimated F0 in Hz (0 if not detected)

Definition at line 729 of file Yantra.cpp.

730{
731 auto a = std::make_shared<Yantra::StandardEnergyAnalyzer>();
732 a->set_energy_method(Yantra::EnergyMethod::HARMONIC);
733 a->set_parameter("sample_rate", sample_rate);
734 a->set_parameter("min_freq", min_freq);
735 a->set_parameter("max_freq", max_freq);
736 auto result = a->analyze_energy({ Kakshya::DataVariant(data) });
737 return result.channels.empty() ? 0.0 : result.channels[0].mean_energy * sample_rate / 1000.0;
738}
size_t a
std::variant< std::vector< double >, std::vector< float >, std::vector< uint8_t >, std::vector< uint16_t >, std::vector< uint32_t >, std::vector< std::complex< float > >, std::vector< std::complex< double > >, std::vector< glm::vec2 >, std::vector< glm::vec3 >, std::vector< glm::vec4 >, std::vector< glm::mat4 > > DataVariant
Multi-type data storage for different precision needs.
Definition NDData.hpp:76

References a, and MayaFlux::Yantra::HARMONIC.