|  | /* | 
|  | * Copyright (c) 2021, Alliance for Open Media. All rights reserved | 
|  | * | 
|  | * This source code is subject to the terms of the BSD 3-Clause Clear License | 
|  | * and the Alliance for Open Media Patent License 1.0. If the BSD 3-Clause Clear | 
|  | * License was not distributed with this source code in the LICENSE file, you | 
|  | * can obtain it at aomedia.org/license/software-license/bsd-3-c-c/.  If the | 
|  | * Alliance for Open Media Patent License 1.0 was not distributed with this | 
|  | * source code in the PATENTS file, you can obtain it at | 
|  | * aomedia.org/license/patent-license/. | 
|  | */ | 
|  |  | 
|  | #ifndef AOM_AOM_DSP_SSIM_H_ | 
|  | #define AOM_AOM_DSP_SSIM_H_ | 
|  |  | 
|  | #define MAX_SSIM_DB 100.0; | 
|  |  | 
|  | #ifdef __cplusplus | 
|  | extern "C" { | 
|  | #endif | 
|  |  | 
|  | #include "config/aom_config.h" | 
|  |  | 
|  | #include "aom_scale/yv12config.h" | 
|  |  | 
|  | // metrics used for calculating ssim, ssim2, dssim, and ssimc | 
|  | typedef struct { | 
|  | // source sum ( over 8x8 region ) | 
|  | uint32_t sum_s; | 
|  |  | 
|  | // reference sum (over 8x8 region ) | 
|  | uint32_t sum_r; | 
|  |  | 
|  | // source sum squared ( over 8x8 region ) | 
|  | uint32_t sum_sq_s; | 
|  |  | 
|  | // reference sum squared (over 8x8 region ) | 
|  | uint32_t sum_sq_r; | 
|  |  | 
|  | // sum of source times reference (over 8x8 region) | 
|  | uint32_t sum_sxr; | 
|  |  | 
|  | // calculated ssim score between source and reference | 
|  | double ssim; | 
|  | } Ssimv; | 
|  |  | 
|  | // metrics collected on a frame basis | 
|  | typedef struct { | 
|  | // ssim consistency error metric ( see code for explanation ) | 
|  | double ssimc; | 
|  |  | 
|  | // standard ssim | 
|  | double ssim; | 
|  |  | 
|  | // revised ssim ( see code for explanation) | 
|  | double ssim2; | 
|  |  | 
|  | // ssim restated as an error metric like sse | 
|  | double dssim; | 
|  |  | 
|  | // dssim converted to decibels | 
|  | double dssimd; | 
|  |  | 
|  | // ssimc converted to decibels | 
|  | double ssimcd; | 
|  | } Metrics; | 
|  |  | 
|  | double aom_calc_fastssim(const YV12_BUFFER_CONFIG *source, | 
|  | const YV12_BUFFER_CONFIG *dest, double *ssim_y, | 
|  | double *ssim_u, double *ssim_v, uint32_t bd, | 
|  | uint32_t in_bd); | 
|  |  | 
|  | double aom_highbd_calc_ssim(const YV12_BUFFER_CONFIG *source, | 
|  | const YV12_BUFFER_CONFIG *dest, double *weight, | 
|  | uint32_t bd, uint32_t in_bd); | 
|  |  | 
|  | #ifdef __cplusplus | 
|  | }  // extern "C" | 
|  | #endif | 
|  |  | 
|  | #endif  // AOM_AOM_DSP_SSIM_H_ |