1*495ae853SAndroid Build Coastguard Worker /******************************************************************************
2*495ae853SAndroid Build Coastguard Worker *
3*495ae853SAndroid Build Coastguard Worker * Copyright (C) 2015 The Android Open Source Project
4*495ae853SAndroid Build Coastguard Worker *
5*495ae853SAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License");
6*495ae853SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License.
7*495ae853SAndroid Build Coastguard Worker * You may obtain a copy of the License at:
8*495ae853SAndroid Build Coastguard Worker *
9*495ae853SAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0
10*495ae853SAndroid Build Coastguard Worker *
11*495ae853SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software
12*495ae853SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS,
13*495ae853SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*495ae853SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and
15*495ae853SAndroid Build Coastguard Worker * limitations under the License.
16*495ae853SAndroid Build Coastguard Worker *
17*495ae853SAndroid Build Coastguard Worker *****************************************************************************
18*495ae853SAndroid Build Coastguard Worker * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
19*495ae853SAndroid Build Coastguard Worker */
20*495ae853SAndroid Build Coastguard Worker
21*495ae853SAndroid Build Coastguard Worker /**
22*495ae853SAndroid Build Coastguard Worker *******************************************************************************
23*495ae853SAndroid Build Coastguard Worker * @file
24*495ae853SAndroid Build Coastguard Worker * psnr.c
25*495ae853SAndroid Build Coastguard Worker *
26*495ae853SAndroid Build Coastguard Worker * @brief
27*495ae853SAndroid Build Coastguard Worker * Contains functions necessary for computing psnr
28*495ae853SAndroid Build Coastguard Worker *
29*495ae853SAndroid Build Coastguard Worker * @author
30*495ae853SAndroid Build Coastguard Worker * ittiam
31*495ae853SAndroid Build Coastguard Worker *
32*495ae853SAndroid Build Coastguard Worker * @remarks
33*495ae853SAndroid Build Coastguard Worker * none
34*495ae853SAndroid Build Coastguard Worker *
35*495ae853SAndroid Build Coastguard Worker *******************************************************************************
36*495ae853SAndroid Build Coastguard Worker */
37*495ae853SAndroid Build Coastguard Worker
38*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
39*495ae853SAndroid Build Coastguard Worker /* File Includes */
40*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
41*495ae853SAndroid Build Coastguard Worker /* System include files */
42*495ae853SAndroid Build Coastguard Worker #include <stdio.h>
43*495ae853SAndroid Build Coastguard Worker #include <stdlib.h>
44*495ae853SAndroid Build Coastguard Worker #include <string.h>
45*495ae853SAndroid Build Coastguard Worker #include <math.h>
46*495ae853SAndroid Build Coastguard Worker
47*495ae853SAndroid Build Coastguard Worker /* User include files */
48*495ae853SAndroid Build Coastguard Worker #include "ih264_typedefs.h"
49*495ae853SAndroid Build Coastguard Worker #include "iv2.h"
50*495ae853SAndroid Build Coastguard Worker #include "ive2.h"
51*495ae853SAndroid Build Coastguard Worker #include "ih264e.h"
52*495ae853SAndroid Build Coastguard Worker #include "app.h"
53*495ae853SAndroid Build Coastguard Worker #include "psnr.h"
54*495ae853SAndroid Build Coastguard Worker
55*495ae853SAndroid Build Coastguard Worker
56*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
57*495ae853SAndroid Build Coastguard Worker /* Function Definition */
58*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
59*495ae853SAndroid Build Coastguard Worker
60*495ae853SAndroid Build Coastguard Worker /**
61*495ae853SAndroid Build Coastguard Worker **************************************************************************
62*495ae853SAndroid Build Coastguard Worker * @brief Initialize PSNR for the Y, U, V component
63*495ae853SAndroid Build Coastguard Worker **************************************************************************
64*495ae853SAndroid Build Coastguard Worker */
init_psnr(app_ctxt_t * ps_app_ctxt)65*495ae853SAndroid Build Coastguard Worker void init_psnr(app_ctxt_t *ps_app_ctxt)
66*495ae853SAndroid Build Coastguard Worker {
67*495ae853SAndroid Build Coastguard Worker ps_app_ctxt->adbl_psnr[0] = 0;
68*495ae853SAndroid Build Coastguard Worker ps_app_ctxt->adbl_psnr[1] = 0;
69*495ae853SAndroid Build Coastguard Worker ps_app_ctxt->adbl_psnr[2] = 0;
70*495ae853SAndroid Build Coastguard Worker ps_app_ctxt->u4_psnr_cnt = 0;
71*495ae853SAndroid Build Coastguard Worker }
72*495ae853SAndroid Build Coastguard Worker
73*495ae853SAndroid Build Coastguard Worker /**
74*495ae853SAndroid Build Coastguard Worker **************************************************************************
75*495ae853SAndroid Build Coastguard Worker * @brief Computes PSNR for the Y, U, V component
76*495ae853SAndroid Build Coastguard Worker **************************************************************************
77*495ae853SAndroid Build Coastguard Worker */
compute_psnr(app_ctxt_t * ps_app_ctxt,iv_raw_buf_t * ps_buf1,iv_raw_buf_t * ps_buf2)78*495ae853SAndroid Build Coastguard Worker void compute_psnr(app_ctxt_t *ps_app_ctxt,
79*495ae853SAndroid Build Coastguard Worker iv_raw_buf_t *ps_buf1,
80*495ae853SAndroid Build Coastguard Worker iv_raw_buf_t *ps_buf2)
81*495ae853SAndroid Build Coastguard Worker {
82*495ae853SAndroid Build Coastguard Worker WORD32 i, j;
83*495ae853SAndroid Build Coastguard Worker WORD32 comp;
84*495ae853SAndroid Build Coastguard Worker DOUBLE df_psnr[3];
85*495ae853SAndroid Build Coastguard Worker WORD32 wd, ht, strd1, strd2;
86*495ae853SAndroid Build Coastguard Worker UWORD8 *pu1_buf1, *pu1_buf2;
87*495ae853SAndroid Build Coastguard Worker WORD32 incr1, incr2;
88*495ae853SAndroid Build Coastguard Worker
89*495ae853SAndroid Build Coastguard Worker printf("\nPicNum %4d\t ", ps_app_ctxt->u4_psnr_cnt);
90*495ae853SAndroid Build Coastguard Worker
91*495ae853SAndroid Build Coastguard Worker for(comp = 0; comp < 3; comp++)
92*495ae853SAndroid Build Coastguard Worker {
93*495ae853SAndroid Build Coastguard Worker df_psnr[comp] = 0;
94*495ae853SAndroid Build Coastguard Worker pu1_buf1 = (UWORD8 *)ps_buf1->apv_bufs[comp];
95*495ae853SAndroid Build Coastguard Worker pu1_buf2 = (UWORD8 *)ps_buf2->apv_bufs[comp];
96*495ae853SAndroid Build Coastguard Worker wd = ps_buf1->au4_wd[comp];
97*495ae853SAndroid Build Coastguard Worker ht = ps_buf1->au4_ht[comp];
98*495ae853SAndroid Build Coastguard Worker strd1 = ps_buf1->au4_strd[comp] - ps_buf1->au4_wd[comp];
99*495ae853SAndroid Build Coastguard Worker strd2 = ps_buf2->au4_strd[comp] - ps_buf2->au4_wd[comp];
100*495ae853SAndroid Build Coastguard Worker incr1 = 1;
101*495ae853SAndroid Build Coastguard Worker incr2 = 1;
102*495ae853SAndroid Build Coastguard Worker
103*495ae853SAndroid Build Coastguard Worker if((IV_YUV_420SP_UV == ps_buf1->e_color_fmt)
104*495ae853SAndroid Build Coastguard Worker || (IV_YUV_420SP_VU == ps_buf1->e_color_fmt))
105*495ae853SAndroid Build Coastguard Worker {
106*495ae853SAndroid Build Coastguard Worker switch(comp)
107*495ae853SAndroid Build Coastguard Worker {
108*495ae853SAndroid Build Coastguard Worker case 0:
109*495ae853SAndroid Build Coastguard Worker pu1_buf1 = ps_buf1->apv_bufs[0];
110*495ae853SAndroid Build Coastguard Worker break;
111*495ae853SAndroid Build Coastguard Worker case 1:
112*495ae853SAndroid Build Coastguard Worker if(IV_YUV_420SP_UV == ps_buf1->e_color_fmt)
113*495ae853SAndroid Build Coastguard Worker pu1_buf1 = (UWORD8 *)ps_buf1->apv_bufs[1];
114*495ae853SAndroid Build Coastguard Worker else
115*495ae853SAndroid Build Coastguard Worker pu1_buf1 = (UWORD8 *)ps_buf1->apv_bufs[1] + 1;
116*495ae853SAndroid Build Coastguard Worker incr1 = 2;
117*495ae853SAndroid Build Coastguard Worker wd = ps_buf1->au4_wd[0] >> 1;
118*495ae853SAndroid Build Coastguard Worker ht = ps_buf1->au4_ht[0] >> 1;
119*495ae853SAndroid Build Coastguard Worker break;
120*495ae853SAndroid Build Coastguard Worker case 2:
121*495ae853SAndroid Build Coastguard Worker if(IV_YUV_420SP_UV == ps_buf1->e_color_fmt)
122*495ae853SAndroid Build Coastguard Worker pu1_buf1 = (UWORD8 *)ps_buf1->apv_bufs[1] + 1;
123*495ae853SAndroid Build Coastguard Worker else
124*495ae853SAndroid Build Coastguard Worker pu1_buf1 = ps_buf1->apv_bufs[1];
125*495ae853SAndroid Build Coastguard Worker incr1 = 2;
126*495ae853SAndroid Build Coastguard Worker wd = ps_buf1->au4_wd[0] >> 1;
127*495ae853SAndroid Build Coastguard Worker ht = ps_buf1->au4_ht[0] >> 1;
128*495ae853SAndroid Build Coastguard Worker strd1 = ps_buf1->au4_strd[1] - ps_buf1->au4_wd[1];
129*495ae853SAndroid Build Coastguard Worker break;
130*495ae853SAndroid Build Coastguard Worker }
131*495ae853SAndroid Build Coastguard Worker }
132*495ae853SAndroid Build Coastguard Worker if((IV_YUV_420SP_UV == ps_buf2->e_color_fmt)
133*495ae853SAndroid Build Coastguard Worker || (IV_YUV_420SP_VU == ps_buf2->e_color_fmt))
134*495ae853SAndroid Build Coastguard Worker {
135*495ae853SAndroid Build Coastguard Worker switch(comp)
136*495ae853SAndroid Build Coastguard Worker {
137*495ae853SAndroid Build Coastguard Worker case 0:
138*495ae853SAndroid Build Coastguard Worker pu1_buf2 = ps_buf2->apv_bufs[0];
139*495ae853SAndroid Build Coastguard Worker break;
140*495ae853SAndroid Build Coastguard Worker case 1:
141*495ae853SAndroid Build Coastguard Worker if(IV_YUV_420SP_UV == ps_buf2->e_color_fmt)
142*495ae853SAndroid Build Coastguard Worker pu1_buf2 = ps_buf2->apv_bufs[1];
143*495ae853SAndroid Build Coastguard Worker else
144*495ae853SAndroid Build Coastguard Worker pu1_buf2 = (UWORD8 *)ps_buf2->apv_bufs[1] + 1;
145*495ae853SAndroid Build Coastguard Worker incr2 = 2;
146*495ae853SAndroid Build Coastguard Worker wd = ps_buf1->au4_wd[0] >> 1;
147*495ae853SAndroid Build Coastguard Worker ht = ps_buf1->au4_ht[0] >> 1;
148*495ae853SAndroid Build Coastguard Worker
149*495ae853SAndroid Build Coastguard Worker break;
150*495ae853SAndroid Build Coastguard Worker case 2:
151*495ae853SAndroid Build Coastguard Worker if(IV_YUV_420SP_UV == ps_buf2->e_color_fmt)
152*495ae853SAndroid Build Coastguard Worker pu1_buf2 = (UWORD8 *)ps_buf2->apv_bufs[1] + 1;
153*495ae853SAndroid Build Coastguard Worker else
154*495ae853SAndroid Build Coastguard Worker pu1_buf2 = ps_buf2->apv_bufs[1];
155*495ae853SAndroid Build Coastguard Worker incr2 = 2;
156*495ae853SAndroid Build Coastguard Worker wd = ps_buf1->au4_wd[0] >> 1;
157*495ae853SAndroid Build Coastguard Worker ht = ps_buf1->au4_ht[0] >> 1;
158*495ae853SAndroid Build Coastguard Worker strd2 = ps_buf2->au4_strd[1] - ps_buf2->au4_wd[1];
159*495ae853SAndroid Build Coastguard Worker
160*495ae853SAndroid Build Coastguard Worker break;
161*495ae853SAndroid Build Coastguard Worker }
162*495ae853SAndroid Build Coastguard Worker }
163*495ae853SAndroid Build Coastguard Worker
164*495ae853SAndroid Build Coastguard Worker for(i = 0; i < ht; i++)
165*495ae853SAndroid Build Coastguard Worker {
166*495ae853SAndroid Build Coastguard Worker for(j = 0; j < wd; j++)
167*495ae853SAndroid Build Coastguard Worker {
168*495ae853SAndroid Build Coastguard Worker WORD32 diff;
169*495ae853SAndroid Build Coastguard Worker diff = (*pu1_buf1 - *pu1_buf2);
170*495ae853SAndroid Build Coastguard Worker pu1_buf1 += incr1;
171*495ae853SAndroid Build Coastguard Worker pu1_buf2 += incr2;
172*495ae853SAndroid Build Coastguard Worker df_psnr[comp] += diff * diff;
173*495ae853SAndroid Build Coastguard Worker }
174*495ae853SAndroid Build Coastguard Worker pu1_buf1 += strd1;
175*495ae853SAndroid Build Coastguard Worker pu1_buf2 += strd2;
176*495ae853SAndroid Build Coastguard Worker }
177*495ae853SAndroid Build Coastguard Worker df_psnr[comp] /= (wd * ht);
178*495ae853SAndroid Build Coastguard Worker if(df_psnr[comp])
179*495ae853SAndroid Build Coastguard Worker df_psnr[comp] = 20 * log10(255 / sqrt(df_psnr[comp]));
180*495ae853SAndroid Build Coastguard Worker else
181*495ae853SAndroid Build Coastguard Worker df_psnr[comp] = 100;
182*495ae853SAndroid Build Coastguard Worker
183*495ae853SAndroid Build Coastguard Worker ps_app_ctxt->adbl_psnr[comp] += df_psnr[comp];
184*495ae853SAndroid Build Coastguard Worker switch(comp)
185*495ae853SAndroid Build Coastguard Worker {
186*495ae853SAndroid Build Coastguard Worker case 0:
187*495ae853SAndroid Build Coastguard Worker printf("Y :");
188*495ae853SAndroid Build Coastguard Worker break;
189*495ae853SAndroid Build Coastguard Worker case 1:
190*495ae853SAndroid Build Coastguard Worker printf("U :");
191*495ae853SAndroid Build Coastguard Worker break;
192*495ae853SAndroid Build Coastguard Worker case 2:
193*495ae853SAndroid Build Coastguard Worker printf("V :");
194*495ae853SAndroid Build Coastguard Worker break;
195*495ae853SAndroid Build Coastguard Worker default:
196*495ae853SAndroid Build Coastguard Worker break;
197*495ae853SAndroid Build Coastguard Worker }
198*495ae853SAndroid Build Coastguard Worker printf("%2.2f\t", df_psnr[comp]);
199*495ae853SAndroid Build Coastguard Worker }
200*495ae853SAndroid Build Coastguard Worker
201*495ae853SAndroid Build Coastguard Worker ps_app_ctxt->u4_psnr_cnt++;
202*495ae853SAndroid Build Coastguard Worker }
203*495ae853SAndroid Build Coastguard Worker
204*495ae853SAndroid Build Coastguard Worker /**
205*495ae853SAndroid Build Coastguard Worker **************************************************************************
206*495ae853SAndroid Build Coastguard Worker * @brief Prints PSNR for the Y, U, V component
207*495ae853SAndroid Build Coastguard Worker **************************************************************************
208*495ae853SAndroid Build Coastguard Worker */
print_average_psnr(app_ctxt_t * ps_app_ctxt)209*495ae853SAndroid Build Coastguard Worker void print_average_psnr(app_ctxt_t *ps_app_ctxt)
210*495ae853SAndroid Build Coastguard Worker {
211*495ae853SAndroid Build Coastguard Worker printf("\n");
212*495ae853SAndroid Build Coastguard Worker
213*495ae853SAndroid Build Coastguard Worker printf("Avg PSNR Y : %-2.2f\n",
214*495ae853SAndroid Build Coastguard Worker (ps_app_ctxt->adbl_psnr[0] / ps_app_ctxt->u4_psnr_cnt));
215*495ae853SAndroid Build Coastguard Worker printf("Avg PSNR U : %-2.2f\n",
216*495ae853SAndroid Build Coastguard Worker (ps_app_ctxt->adbl_psnr[1] / ps_app_ctxt->u4_psnr_cnt));
217*495ae853SAndroid Build Coastguard Worker printf("Avg PSNR V : %-2.2f\n",
218*495ae853SAndroid Build Coastguard Worker (ps_app_ctxt->adbl_psnr[2] / ps_app_ctxt->u4_psnr_cnt));
219*495ae853SAndroid Build Coastguard Worker }
220*495ae853SAndroid Build Coastguard Worker
221