1*fb1b10abSAndroid Build Coastguard Worker /* 2*fb1b10abSAndroid Build Coastguard Worker * Copyright (c) 2012 The WebM project authors. All Rights Reserved. 3*fb1b10abSAndroid Build Coastguard Worker * 4*fb1b10abSAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license 5*fb1b10abSAndroid Build Coastguard Worker * that can be found in the LICENSE file in the root of the source 6*fb1b10abSAndroid Build Coastguard Worker * tree. An additional intellectual property rights grant can be found 7*fb1b10abSAndroid Build Coastguard Worker * in the file PATENTS. All contributing project authors may 8*fb1b10abSAndroid Build Coastguard Worker * be found in the AUTHORS file in the root of the source tree. 9*fb1b10abSAndroid Build Coastguard Worker */ 10*fb1b10abSAndroid Build Coastguard Worker 11*fb1b10abSAndroid Build Coastguard Worker #ifndef VPX_TEST_UTIL_H_ 12*fb1b10abSAndroid Build Coastguard Worker #define VPX_TEST_UTIL_H_ 13*fb1b10abSAndroid Build Coastguard Worker 14*fb1b10abSAndroid Build Coastguard Worker #include <stdio.h> 15*fb1b10abSAndroid Build Coastguard Worker #include <math.h> 16*fb1b10abSAndroid Build Coastguard Worker #include <tuple> 17*fb1b10abSAndroid Build Coastguard Worker 18*fb1b10abSAndroid Build Coastguard Worker #include "gtest/gtest.h" 19*fb1b10abSAndroid Build Coastguard Worker #include "vpx/vpx_image.h" 20*fb1b10abSAndroid Build Coastguard Worker 21*fb1b10abSAndroid Build Coastguard Worker // Macros 22*fb1b10abSAndroid Build Coastguard Worker #define GET_PARAM(k) std::get<k>(GetParam()) 23*fb1b10abSAndroid Build Coastguard Worker compute_psnr(const vpx_image_t * img1,const vpx_image_t * img2)24*fb1b10abSAndroid Build Coastguard Workerinline double compute_psnr(const vpx_image_t *img1, const vpx_image_t *img2) { 25*fb1b10abSAndroid Build Coastguard Worker assert((img1->fmt == img2->fmt) && (img1->d_w == img2->d_w) && 26*fb1b10abSAndroid Build Coastguard Worker (img1->d_h == img2->d_h)); 27*fb1b10abSAndroid Build Coastguard Worker 28*fb1b10abSAndroid Build Coastguard Worker const unsigned int width_y = img1->d_w; 29*fb1b10abSAndroid Build Coastguard Worker const unsigned int height_y = img1->d_h; 30*fb1b10abSAndroid Build Coastguard Worker unsigned int i, j; 31*fb1b10abSAndroid Build Coastguard Worker 32*fb1b10abSAndroid Build Coastguard Worker int64_t sqrerr = 0; 33*fb1b10abSAndroid Build Coastguard Worker for (i = 0; i < height_y; ++i) { 34*fb1b10abSAndroid Build Coastguard Worker for (j = 0; j < width_y; ++j) { 35*fb1b10abSAndroid Build Coastguard Worker int64_t d = img1->planes[VPX_PLANE_Y][i * img1->stride[VPX_PLANE_Y] + j] - 36*fb1b10abSAndroid Build Coastguard Worker img2->planes[VPX_PLANE_Y][i * img2->stride[VPX_PLANE_Y] + j]; 37*fb1b10abSAndroid Build Coastguard Worker sqrerr += d * d; 38*fb1b10abSAndroid Build Coastguard Worker } 39*fb1b10abSAndroid Build Coastguard Worker } 40*fb1b10abSAndroid Build Coastguard Worker double mse = static_cast<double>(sqrerr) / (width_y * height_y); 41*fb1b10abSAndroid Build Coastguard Worker double psnr = 100.0; 42*fb1b10abSAndroid Build Coastguard Worker if (mse > 0.0) { 43*fb1b10abSAndroid Build Coastguard Worker psnr = 10 * log10(255.0 * 255.0 / mse); 44*fb1b10abSAndroid Build Coastguard Worker } 45*fb1b10abSAndroid Build Coastguard Worker return psnr; 46*fb1b10abSAndroid Build Coastguard Worker } 47*fb1b10abSAndroid Build Coastguard Worker 48*fb1b10abSAndroid Build Coastguard Worker #endif // VPX_TEST_UTIL_H_ 49