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

◆ estimate_pitch_per_channel()

MAYAFLUX_API std::vector< double > MayaFlux::estimate_pitch_per_channel ( const std::vector< Kakshya::DataVariant > &  channels,
double  sample_rate = 48000.0,
double  min_freq = 80.0,
double  max_freq = 2000.0 
)

Estimate fundamental frequency per channel for multi-channel data.

Parameters
channelsVector of channel data
sample_rateSample rate (default: 48000 Hz)
min_freqMinimum expected frequency (default: 80 Hz)
max_freqMaximum expected frequency (default: 2000 Hz)
Returns
Vector of estimated F0 values in Hz, one per channel (0 if not detected)

Definition at line 781 of file Yantra.cpp.

782{
783 auto energy_analyzer = std::make_shared<Yantra::StandardEnergyAnalyzer>();
784 energy_analyzer->set_energy_method(Yantra::EnergyMethod::HARMONIC);
785 energy_analyzer->set_parameter("sample_rate", sample_rate);
786 energy_analyzer->set_parameter("min_freq", min_freq);
787 energy_analyzer->set_parameter("max_freq", max_freq);
788 auto result = energy_analyzer->analyze_energy(channels);
789
790 std::vector<double> pitches;
791 for (const auto& channel : result.channels) {
792 double pitch = channel.mean_energy * sample_rate / 1000.0;
793 pitches.push_back(pitch);
794 }
795 return pitches;
796}

References MayaFlux::Yantra::HARMONIC.