|  | /* | 
|  | * Copyright (c) 2016, Alliance for Open Media. All rights reserved. | 
|  | * | 
|  | * This source code is subject to the terms of the BSD 2 Clause License and | 
|  | * the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License | 
|  | * was not distributed with this source code in the LICENSE file, you can | 
|  | * obtain it at www.aomedia.org/license/software. 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 www.aomedia.org/license/patent. | 
|  | */ | 
|  |  | 
|  | #ifndef AOM_AOM_DSP_SSIM_H_ | 
|  | #define AOM_AOM_DSP_SSIM_H_ | 
|  |  | 
|  | #ifdef __cplusplus | 
|  | extern "C" { | 
|  | #endif | 
|  |  | 
|  | #include "config/aom_config.h" | 
|  |  | 
|  | #if CONFIG_INTERNAL_STATS | 
|  | #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_get_ssim_metrics(uint8_t *img1, int img1_pitch, uint8_t *img2, | 
|  | int img2_pitch, int width, int height, Ssimv *sv2, | 
|  | Metrics *m, int do_inconsistency); | 
|  |  | 
|  | void aom_lowbd_calc_ssim(const YV12_BUFFER_CONFIG *source, | 
|  | const YV12_BUFFER_CONFIG *dest, double *weight, | 
|  | double *fast_ssim); | 
|  |  | 
|  | 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); | 
|  |  | 
|  | #if CONFIG_AV1_HIGHBITDEPTH | 
|  | void aom_highbd_calc_ssim(const YV12_BUFFER_CONFIG *source, | 
|  | const YV12_BUFFER_CONFIG *dest, double *weight, | 
|  | uint32_t bd, uint32_t in_bd, double *fast_ssim); | 
|  | #endif  // CONFIG_AV1_HIGHBITDEPTH | 
|  |  | 
|  | void aom_calc_ssim(const YV12_BUFFER_CONFIG *orig, | 
|  | const YV12_BUFFER_CONFIG *recon, const uint32_t bit_depth, | 
|  | const uint32_t in_bit_depth, int is_hbd, double *weight, | 
|  | double *frame_ssim2); | 
|  | #endif  // CONFIG_INTERNAL_STATS | 
|  |  | 
|  | double aom_ssim2(const uint8_t *img1, const uint8_t *img2, int stride_img1, | 
|  | int stride_img2, int width, int height); | 
|  |  | 
|  | #if CONFIG_AV1_HIGHBITDEPTH | 
|  | double aom_highbd_ssim2(const uint8_t *img1, const uint8_t *img2, | 
|  | int stride_img1, int stride_img2, int width, int height, | 
|  | uint32_t bd, uint32_t shift); | 
|  | #endif  // CONFIG_AV1_HIGHBITDEPTH | 
|  |  | 
|  | #ifdef __cplusplus | 
|  | }  // extern "C" | 
|  | #endif | 
|  |  | 
|  | #endif  // AOM_AOM_DSP_SSIM_H_ |