From 996c81ef01b1df3c22b1b0350ff54f8b33b80f6e Mon Sep 17 00:00:00 2001 From: Pavel Krajcevski Date: Sat, 12 Oct 2013 16:32:09 -0400 Subject: [PATCH] Specialize the FilterValid routine to not consider the pixels as pixels but rather as values. This seems somewhat inelegant but it's fine in terms of a quick fix. --- Base/src/Image.cpp | 45 ++++++++++++++++++++++++++++++++++----------- 1 file changed, 34 insertions(+), 11 deletions(-) diff --git a/Base/src/Image.cpp b/Base/src/Image.cpp index 5dea2f9..74a9fe7 100644 --- a/Base/src/Image.cpp +++ b/Base/src/Image.cpp @@ -218,19 +218,42 @@ double Image::ComputePSNR(Image *other) { return 10 * log10(maxi/mse); } -template -static Image FilterValid(const Image &img, uint32 size, double sigma) { +static Image FilterValid(const Image &img, uint32 size, double sigma) { assert(size % 2); Image gaussian(size, size); GenerateGaussianKernel(gaussian, size, sigma); - Image tmp = img; - tmp.Filter(gaussian); - Image out(tmp.GetWidth() - size + 1, tmp.GetHeight() - size + 1); - uint32 halfSz = size >> 1; - for(uint32 j = halfSz; j < img.GetHeight()-halfSz; j++) { - for(uint32 i = halfSz; i < img.GetWidth()-halfSz; i++) { - out(i-halfSz, j-halfSz) = tmp(i, j); + double sum = 0.0; + for(uint32 j = 0; j < size; j++) { + for(uint32 i = 0; i < size; i++) { + sum += static_cast(gaussian(i, j)); + } + } + + for(uint32 j = 0; j < size; j++) { + for(uint32 i = 0; i < size; i++) { + double v = static_cast(gaussian(i, j)); + gaussian(i, j) = static_cast(v / sum); + } + } + + int32 h = static_cast(img.GetHeight()); + int32 w = static_cast(img.GetWidth()); + + Image out(img.GetWidth() - size + 1, img.GetHeight() - size + 1); + int32 halfSz = static_cast(size) >> 1; + for(int32 j = halfSz; j < h-halfSz; j++) { + for(int32 i = halfSz; i < w-halfSz; i++) { + int32 xoffset = -halfSz; + int32 yoffset = -halfSz; + + double result = 0; + for(int32 y = 0; y < static_cast(size); y++) + for(int32 x = 0; x < static_cast(size); x++) { + double s = static_cast(gaussian(x, y)); + result += s * static_cast(img(i+xoffset+x, j+yoffset+y)); + } + out(i+xoffset, j+yoffset) = static_cast(result); } } @@ -262,8 +285,8 @@ double Image::ComputeSSIM(Image *other, double *mssim) { for(uint32 j = 0; j < GetHeight(); j++) { for(uint32 i = 0; i < GetWidth(); i++) { - img1(i, j) = 255.0f * static_cast(img1(i, j)); - img2(i, j) = 255.0f * static_cast(img2(i, j)); + img1(i, j) = 255.0 * static_cast(img1(i, j)); + img2(i, j) = 255.0 * static_cast(img2(i, j)); } }