X-Git-Url: https://git.sesse.net/?p=pitch;a=blobdiff_plain;f=pitch.cpp;h=97238f5f05b1a99113837029199f44434b1f220e;hp=13efaf8a5660f9b955c7d9d29cf15e9e9ba03c0c;hb=f4906bf100acb8c5875196b7c2306effdd6a091d;hpb=2921b00f987d93f2ccc8c918da196158c2f90906;ds=sidebyside diff --git a/pitch.cpp b/pitch.cpp index 13efaf8..97238f5 100644 --- a/pitch.cpp +++ b/pitch.cpp @@ -234,6 +234,9 @@ std::pair find_peak(double *in, unsigned num_samples) } } + if (best_bin == 0 || best_bin == num_samples / 2) { + return std::make_pair(-1.0, 0.0); + } std::pair peak = interpolate_peak(in[best_bin - 1], in[best_bin], @@ -248,6 +251,8 @@ std::pair find_peak(double *in, unsigned num_samples) std::pair adjust_for_overtones(std::pair base, double *in, unsigned num_samples) { double mu = base.first, var = 1.0 / (base.second * base.second); + + //printf("Base at %.2f (amp=%5.2fdB)\n", base.first, base.second); for (unsigned i = 2; i < 10; ++i) { unsigned middle = unsigned(floor(freq_to_bin(base.first, num_samples) * i + 0.5));