guidedfilter: direct copy when no rescaling is needed, copied from ART

This commit is contained in:
Ingo Weyrich
2020-01-03 20:23:34 +01:00
parent 7c2aa2405b
commit cabbf8c229

View File

@@ -106,7 +106,18 @@ void guidedFilter(const array2D<float> &guide, const array2D<float> &src, array2
const auto f_subsample =
[multithread](array2D<float> &d, const array2D<float> &s) -> void
{
rescaleBilinear(s, d, multithread);
if (d.width() == s.width() && d.height() == s.height()) {
#ifdef _OPENMP
#pragma omp parallel for if (multithread)
#endif
for (int y = 0; y < s.height(); ++y) {
for (int x = 0; x < s.width(); ++x) {
d[y][x] = s[y][x];
}
}
} else {
rescaleBilinear(s, d, multithread);
}
};
const auto f_mean =