X-Git-Url: https://git.sesse.net/?p=movit;a=blobdiff_plain;f=resample_effect.cpp;h=54eec864fe7a6c272fa68e3476dfcdf52b31c8a7;hp=aa3a4033ee8e5dec5b2f9826de529dfb98c22567;hb=1400c353ad03f4d31f665be0d02e8e360f69ef5c;hpb=6be20704cdc7b64e37cc886b7872df58ef66eb1f diff --git a/resample_effect.cpp b/resample_effect.cpp index aa3a403..54eec86 100644 --- a/resample_effect.cpp +++ b/resample_effect.cpp @@ -63,7 +63,22 @@ unsigned gcd(unsigned a, unsigned b) template unsigned combine_samples(const Tap *src, Tap *dst, unsigned src_size, unsigned num_src_samples, unsigned max_samples_saved) { + // Cut off near-zero values at both sides. unsigned num_samples_saved = 0; + while (num_samples_saved < max_samples_saved && + num_src_samples > 0 && + fabs(src[0].weight) < 1e-6) { + ++src; + --num_src_samples; + ++num_samples_saved; + } + while (num_samples_saved < max_samples_saved && + num_src_samples > 0 && + fabs(src[num_src_samples - 1].weight) < 1e-6) { + --num_src_samples; + ++num_samples_saved; + } + for (unsigned i = 0, j = 0; i < num_src_samples; ++i, ++j) { // Copy the sample directly; it will be overwritten later if we can combine. if (dst != NULL) { @@ -183,7 +198,7 @@ double compute_sum_sq_error(const Tap* weights, unsigned num_weights, int lower_pos = int(floor(to_fp64(bilinear_weights[0].pos) * size - 0.5)); int upper_pos = int(ceil(to_fp64(bilinear_weights[num_bilinear_weights - 1].pos) * size - 0.5)) + 2; lower_pos = min(lower_pos, lrintf(weights[0].pos * size - 0.5)); - upper_pos = max(upper_pos, lrintf(weights[num_weights - 1].pos * size - 0.5)); + upper_pos = max(upper_pos, lrintf(weights[num_weights - 1].pos * size - 0.5) + 1); float* effective_weights = new float[upper_pos - lower_pos]; for (int i = 0; i < upper_pos - lower_pos; ++i) {