mirror of
https://github.com/yuzu-emu/FasTC.git
synced 2025-01-23 19:51:19 +00:00
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.
This commit is contained in:
parent
5af29c87d0
commit
996c81ef01
|
@ -218,19 +218,42 @@ double Image<PixelType>::ComputePSNR(Image<PixelType> *other) {
|
||||||
return 10 * log10(maxi/mse);
|
return 10 * log10(maxi/mse);
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename PixelType>
|
static Image<IPixel> FilterValid(const Image<IPixel> &img, uint32 size, double sigma) {
|
||||||
static Image<PixelType> FilterValid(const Image<PixelType> &img, uint32 size, double sigma) {
|
|
||||||
assert(size % 2);
|
assert(size % 2);
|
||||||
Image<IPixel> gaussian(size, size);
|
Image<IPixel> gaussian(size, size);
|
||||||
GenerateGaussianKernel(gaussian, size, sigma);
|
GenerateGaussianKernel(gaussian, size, sigma);
|
||||||
Image<PixelType> tmp = img;
|
|
||||||
tmp.Filter(gaussian);
|
|
||||||
|
|
||||||
Image<PixelType> out(tmp.GetWidth() - size + 1, tmp.GetHeight() - size + 1);
|
double sum = 0.0;
|
||||||
uint32 halfSz = size >> 1;
|
for(uint32 j = 0; j < size; j++) {
|
||||||
for(uint32 j = halfSz; j < img.GetHeight()-halfSz; j++) {
|
for(uint32 i = 0; i < size; i++) {
|
||||||
for(uint32 i = halfSz; i < img.GetWidth()-halfSz; i++) {
|
sum += static_cast<float>(gaussian(i, j));
|
||||||
out(i-halfSz, j-halfSz) = tmp(i, j);
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for(uint32 j = 0; j < size; j++) {
|
||||||
|
for(uint32 i = 0; i < size; i++) {
|
||||||
|
double v = static_cast<float>(gaussian(i, j));
|
||||||
|
gaussian(i, j) = static_cast<float>(v / sum);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int32 h = static_cast<int32>(img.GetHeight());
|
||||||
|
int32 w = static_cast<int32>(img.GetWidth());
|
||||||
|
|
||||||
|
Image<IPixel> out(img.GetWidth() - size + 1, img.GetHeight() - size + 1);
|
||||||
|
int32 halfSz = static_cast<int32>(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<int32>(size); y++)
|
||||||
|
for(int32 x = 0; x < static_cast<int32>(size); x++) {
|
||||||
|
double s = static_cast<float>(gaussian(x, y));
|
||||||
|
result += s * static_cast<float>(img(i+xoffset+x, j+yoffset+y));
|
||||||
|
}
|
||||||
|
out(i+xoffset, j+yoffset) = static_cast<float>(result);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -262,8 +285,8 @@ double Image<PixelType>::ComputeSSIM(Image<PixelType> *other, double *mssim) {
|
||||||
|
|
||||||
for(uint32 j = 0; j < GetHeight(); j++) {
|
for(uint32 j = 0; j < GetHeight(); j++) {
|
||||||
for(uint32 i = 0; i < GetWidth(); i++) {
|
for(uint32 i = 0; i < GetWidth(); i++) {
|
||||||
img1(i, j) = 255.0f * static_cast<float>(img1(i, j));
|
img1(i, j) = 255.0 * static_cast<float>(img1(i, j));
|
||||||
img2(i, j) = 255.0f * static_cast<float>(img2(i, j));
|
img2(i, j) = 255.0 * static_cast<float>(img2(i, j));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue