X-Git-Url: https://git.sesse.net/?p=movit;a=blobdiff_plain;f=resample_effect.cpp;h=1b74a965c6f60654967f5960fe3e69384256a78f;hp=79d5f21c45543a936f81e33a4ead19ca32d5a74f;hb=8bb071c7d0f0b03ffd15b3919f4e6afded57d1ea;hpb=1bd97eb70a6fcb913bf954e369bc1a90ba17f74e diff --git a/resample_effect.cpp b/resample_effect.cpp index 79d5f21..1b74a96 100644 --- a/resample_effect.cpp +++ b/resample_effect.cpp @@ -161,14 +161,15 @@ unsigned combine_many_samples(const Tap *weights, unsigned src_size, unsi { float num_subtexels = src_size / movit_texel_subpixel_precision; float inv_num_subtexels = movit_texel_subpixel_precision / src_size; - int src_bilinear_samples = 0; - for (unsigned y = 0; y < dst_samples; ++y) { - unsigned num_samples_saved = combine_samples(weights + y * src_samples, NULL, num_subtexels, inv_num_subtexels, src_samples, UINT_MAX); - src_bilinear_samples = max(src_bilinear_samples, src_samples - num_samples_saved); + unsigned max_samples_saved = UINT_MAX; + for (unsigned y = 0; y < dst_samples && max_samples_saved > 0; ++y) { + unsigned num_samples_saved = combine_samples(weights + y * src_samples, NULL, num_subtexels, inv_num_subtexels, src_samples, max_samples_saved); + max_samples_saved = min(max_samples_saved, num_samples_saved); } // Now that we know the right width, actually combine the samples. + unsigned src_bilinear_samples = src_samples - max_samples_saved; *bilinear_weights = new Tap[dst_samples * src_bilinear_samples]; for (unsigned y = 0; y < dst_samples; ++y) { Tap *bilinear_weights_ptr = *bilinear_weights + y * src_bilinear_samples; @@ -178,8 +179,8 @@ unsigned combine_many_samples(const Tap *weights, unsigned src_size, unsi num_subtexels, inv_num_subtexels, src_samples, - src_samples - src_bilinear_samples); - assert(int(src_samples) - int(num_samples_saved) == src_bilinear_samples); + max_samples_saved); + assert(num_samples_saved == max_samples_saved); normalize_sum(bilinear_weights_ptr, src_bilinear_samples); } return src_bilinear_samples;