xref: /aosp_15_r20/external/libavc/examples/svcenc/psnr.c (revision 495ae853bb871d1e5a258cb02c2cc13cde8ddb9a)
1*495ae853SAndroid Build Coastguard Worker /******************************************************************************
2*495ae853SAndroid Build Coastguard Worker  *
3*495ae853SAndroid Build Coastguard Worker  * Copyright (C) 2022 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 #include <stdio.h>
22*495ae853SAndroid Build Coastguard Worker #include <stdlib.h>
23*495ae853SAndroid Build Coastguard Worker #include <string.h>
24*495ae853SAndroid Build Coastguard Worker #include <math.h>
25*495ae853SAndroid Build Coastguard Worker 
26*495ae853SAndroid Build Coastguard Worker #include "ih264_typedefs.h"
27*495ae853SAndroid Build Coastguard Worker #include "iv2.h"
28*495ae853SAndroid Build Coastguard Worker #include "ive2.h"
29*495ae853SAndroid Build Coastguard Worker #include "isvce.h"
30*495ae853SAndroid Build Coastguard Worker #include "app.h"
31*495ae853SAndroid Build Coastguard Worker #include "psnr.h"
32*495ae853SAndroid Build Coastguard Worker 
33*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
34*495ae853SAndroid Build Coastguard Worker /*                                                                           */
35*495ae853SAndroid Build Coastguard Worker /*  Function Name : init_psnr                                                */
36*495ae853SAndroid Build Coastguard Worker /*                                                                           */
37*495ae853SAndroid Build Coastguard Worker /*  Description   : Initialize  PSNR for the Y, U, V component               */
38*495ae853SAndroid Build Coastguard Worker /*                                                                           */
39*495ae853SAndroid Build Coastguard Worker /*  Inputs        :                                                          */
40*495ae853SAndroid Build Coastguard Worker /*                                                                           */
41*495ae853SAndroid Build Coastguard Worker /*  Globals       :                                                          */
42*495ae853SAndroid Build Coastguard Worker /*                                                                           */
43*495ae853SAndroid Build Coastguard Worker /*  Processing    :                                                          */
44*495ae853SAndroid Build Coastguard Worker /*                                                                           */
45*495ae853SAndroid Build Coastguard Worker /*  Outputs       :                                                          */
46*495ae853SAndroid Build Coastguard Worker /*                                                                           */
47*495ae853SAndroid Build Coastguard Worker /*  Returns       :                                                          */
48*495ae853SAndroid Build Coastguard Worker /*                                                                           */
49*495ae853SAndroid Build Coastguard Worker /*  Issues        :                                                          */
50*495ae853SAndroid Build Coastguard Worker /*                                                                           */
51*495ae853SAndroid Build Coastguard Worker /*  Revision History:                                                        */
52*495ae853SAndroid Build Coastguard Worker /*                                                                           */
53*495ae853SAndroid Build Coastguard Worker /*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
54*495ae853SAndroid Build Coastguard Worker /*         28 12 2005   Ittiam          Draft                                */
55*495ae853SAndroid Build Coastguard Worker /*                                                                           */
56*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
init_psnr(app_ctxt_t * ps_app_ctxt)57*495ae853SAndroid Build Coastguard Worker void init_psnr(app_ctxt_t *ps_app_ctxt)
58*495ae853SAndroid Build Coastguard Worker {
59*495ae853SAndroid Build Coastguard Worker     ps_app_ctxt->adbl_psnr[0] = 0;
60*495ae853SAndroid Build Coastguard Worker     ps_app_ctxt->adbl_psnr[1] = 0;
61*495ae853SAndroid Build Coastguard Worker     ps_app_ctxt->adbl_psnr[2] = 0;
62*495ae853SAndroid Build Coastguard Worker     ps_app_ctxt->u4_psnr_cnt = 0;
63*495ae853SAndroid Build Coastguard Worker }
64*495ae853SAndroid Build Coastguard Worker 
65*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
66*495ae853SAndroid Build Coastguard Worker /*                                                                           */
67*495ae853SAndroid Build Coastguard Worker /*  Function Name : compute_psnr                                             */
68*495ae853SAndroid Build Coastguard Worker /*                                                                           */
69*495ae853SAndroid Build Coastguard Worker /*  Description   : Computes the PSNR for the Y, U, V component              */
70*495ae853SAndroid Build Coastguard Worker /*                                                                           */
71*495ae853SAndroid Build Coastguard Worker /*  Inputs        :                                                          */
72*495ae853SAndroid Build Coastguard Worker /*                                                                           */
73*495ae853SAndroid Build Coastguard Worker /*  Globals       :                                                          */
74*495ae853SAndroid Build Coastguard Worker /*                                                                           */
75*495ae853SAndroid Build Coastguard Worker /*  Processing    :                                                          */
76*495ae853SAndroid Build Coastguard Worker /*                                                                           */
77*495ae853SAndroid Build Coastguard Worker /*  Outputs       :                                                          */
78*495ae853SAndroid Build Coastguard Worker /*                                                                           */
79*495ae853SAndroid Build Coastguard Worker /*  Returns       :                                                          */
80*495ae853SAndroid Build Coastguard Worker /*                                                                           */
81*495ae853SAndroid Build Coastguard Worker /*  Issues        :                                                          */
82*495ae853SAndroid Build Coastguard Worker /*                                                                           */
83*495ae853SAndroid Build Coastguard Worker /*  Revision History:                                                        */
84*495ae853SAndroid Build Coastguard Worker /*                                                                           */
85*495ae853SAndroid Build Coastguard Worker /*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
86*495ae853SAndroid Build Coastguard Worker /*         28 12 2005   Ittiam          Draft                                */
87*495ae853SAndroid Build Coastguard Worker /*                                                                           */
88*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
compute_psnr(app_ctxt_t * ps_app_ctxt,iv_raw_buf_t * ps_buf1,iv_raw_buf_t * ps_buf2)89*495ae853SAndroid Build Coastguard Worker void compute_psnr(app_ctxt_t *ps_app_ctxt, iv_raw_buf_t *ps_buf1, iv_raw_buf_t *ps_buf2)
90*495ae853SAndroid Build Coastguard Worker {
91*495ae853SAndroid Build Coastguard Worker     WORD32 i, j;
92*495ae853SAndroid Build Coastguard Worker     WORD32 comp;
93*495ae853SAndroid Build Coastguard Worker     DOUBLE df_psnr[3];
94*495ae853SAndroid Build Coastguard Worker     WORD32 wd, ht, strd1, strd2;
95*495ae853SAndroid Build Coastguard Worker     UWORD8 *pu1_buf1, *pu1_buf2;
96*495ae853SAndroid Build Coastguard Worker     WORD32 incr1, incr2;
97*495ae853SAndroid Build Coastguard Worker 
98*495ae853SAndroid Build Coastguard Worker     printf("\nPicNum %4d\t ", ps_app_ctxt->u4_psnr_cnt);
99*495ae853SAndroid Build Coastguard Worker 
100*495ae853SAndroid Build Coastguard Worker     for(comp = 0; comp < 3; comp++)
101*495ae853SAndroid Build Coastguard Worker     {
102*495ae853SAndroid Build Coastguard Worker         df_psnr[comp] = 0;
103*495ae853SAndroid Build Coastguard Worker         pu1_buf1 = (UWORD8 *) ps_buf1->apv_bufs[comp];
104*495ae853SAndroid Build Coastguard Worker         pu1_buf2 = (UWORD8 *) ps_buf2->apv_bufs[comp];
105*495ae853SAndroid Build Coastguard Worker         wd = ps_buf1->au4_wd[comp];
106*495ae853SAndroid Build Coastguard Worker         ht = ps_buf1->au4_ht[comp];
107*495ae853SAndroid Build Coastguard Worker         strd1 = ps_buf1->au4_strd[comp] - ps_buf1->au4_wd[comp];
108*495ae853SAndroid Build Coastguard Worker         strd2 = ps_buf2->au4_strd[comp] - ps_buf2->au4_wd[comp];
109*495ae853SAndroid Build Coastguard Worker         incr1 = 1;
110*495ae853SAndroid Build Coastguard Worker         incr2 = 1;
111*495ae853SAndroid Build Coastguard Worker 
112*495ae853SAndroid Build Coastguard Worker         if((IV_YUV_420SP_UV == ps_buf1->e_color_fmt) || (IV_YUV_420SP_VU == ps_buf1->e_color_fmt))
113*495ae853SAndroid Build Coastguard Worker         {
114*495ae853SAndroid Build Coastguard Worker             switch(comp)
115*495ae853SAndroid Build Coastguard Worker             {
116*495ae853SAndroid Build Coastguard Worker                 case 0:
117*495ae853SAndroid Build Coastguard Worker                     pu1_buf1 = ps_buf1->apv_bufs[0];
118*495ae853SAndroid Build Coastguard Worker                     break;
119*495ae853SAndroid Build Coastguard Worker                 case 1:
120*495ae853SAndroid Build Coastguard Worker                     if(IV_YUV_420SP_UV == ps_buf1->e_color_fmt)
121*495ae853SAndroid Build Coastguard Worker                         pu1_buf1 = (UWORD8 *) ps_buf1->apv_bufs[1];
122*495ae853SAndroid Build Coastguard Worker                     else
123*495ae853SAndroid Build Coastguard Worker                         pu1_buf1 = (UWORD8 *) ps_buf1->apv_bufs[1] + 1;
124*495ae853SAndroid Build Coastguard Worker                     incr1 = 2;
125*495ae853SAndroid Build Coastguard Worker                     wd = ps_buf1->au4_wd[0] >> 1;
126*495ae853SAndroid Build Coastguard Worker                     ht = ps_buf1->au4_ht[0] >> 1;
127*495ae853SAndroid Build Coastguard Worker                     break;
128*495ae853SAndroid Build Coastguard Worker                 case 2:
129*495ae853SAndroid Build Coastguard Worker                     if(IV_YUV_420SP_UV == ps_buf1->e_color_fmt)
130*495ae853SAndroid Build Coastguard Worker                         pu1_buf1 = (UWORD8 *) ps_buf1->apv_bufs[1] + 1;
131*495ae853SAndroid Build Coastguard Worker                     else
132*495ae853SAndroid Build Coastguard Worker                         pu1_buf1 = ps_buf1->apv_bufs[1];
133*495ae853SAndroid Build Coastguard Worker                     incr1 = 2;
134*495ae853SAndroid Build Coastguard Worker                     wd = ps_buf1->au4_wd[0] >> 1;
135*495ae853SAndroid Build Coastguard Worker                     ht = ps_buf1->au4_ht[0] >> 1;
136*495ae853SAndroid Build Coastguard Worker                     strd1 = ps_buf1->au4_strd[1] - ps_buf1->au4_wd[1];
137*495ae853SAndroid Build Coastguard Worker                     break;
138*495ae853SAndroid Build Coastguard Worker             }
139*495ae853SAndroid Build Coastguard Worker         }
140*495ae853SAndroid Build Coastguard Worker         if((IV_YUV_420SP_UV == ps_buf2->e_color_fmt) || (IV_YUV_420SP_VU == ps_buf2->e_color_fmt))
141*495ae853SAndroid Build Coastguard Worker         {
142*495ae853SAndroid Build Coastguard Worker             switch(comp)
143*495ae853SAndroid Build Coastguard Worker             {
144*495ae853SAndroid Build Coastguard Worker                 case 0:
145*495ae853SAndroid Build Coastguard Worker                     pu1_buf2 = ps_buf2->apv_bufs[0];
146*495ae853SAndroid Build Coastguard Worker                     break;
147*495ae853SAndroid Build Coastguard Worker                 case 1:
148*495ae853SAndroid Build Coastguard Worker                     if(IV_YUV_420SP_UV == ps_buf2->e_color_fmt)
149*495ae853SAndroid Build Coastguard Worker                         pu1_buf2 = ps_buf2->apv_bufs[1];
150*495ae853SAndroid Build Coastguard Worker                     else
151*495ae853SAndroid Build Coastguard Worker                         pu1_buf2 = (UWORD8 *) ps_buf2->apv_bufs[1] + 1;
152*495ae853SAndroid Build Coastguard Worker                     incr2 = 2;
153*495ae853SAndroid Build Coastguard Worker                     wd = ps_buf2->au4_wd[0] >> 1;
154*495ae853SAndroid Build Coastguard Worker                     ht = ps_buf2->au4_ht[0] >> 1;
155*495ae853SAndroid Build Coastguard Worker 
156*495ae853SAndroid Build Coastguard Worker                     break;
157*495ae853SAndroid Build Coastguard Worker                 case 2:
158*495ae853SAndroid Build Coastguard Worker                     if(IV_YUV_420SP_UV == ps_buf2->e_color_fmt)
159*495ae853SAndroid Build Coastguard Worker                         pu1_buf2 = (UWORD8 *) ps_buf2->apv_bufs[1] + 1;
160*495ae853SAndroid Build Coastguard Worker                     else
161*495ae853SAndroid Build Coastguard Worker                         pu1_buf2 = ps_buf2->apv_bufs[1];
162*495ae853SAndroid Build Coastguard Worker                     incr2 = 2;
163*495ae853SAndroid Build Coastguard Worker                     wd = ps_buf2->au4_wd[0] >> 1;
164*495ae853SAndroid Build Coastguard Worker                     ht = ps_buf2->au4_ht[0] >> 1;
165*495ae853SAndroid Build Coastguard Worker                     strd2 = ps_buf2->au4_strd[1] - ps_buf2->au4_wd[1];
166*495ae853SAndroid Build Coastguard Worker 
167*495ae853SAndroid Build Coastguard Worker                     break;
168*495ae853SAndroid Build Coastguard Worker             }
169*495ae853SAndroid Build Coastguard Worker         }
170*495ae853SAndroid Build Coastguard Worker 
171*495ae853SAndroid Build Coastguard Worker         for(i = 0; i < ht; i++)
172*495ae853SAndroid Build Coastguard Worker         {
173*495ae853SAndroid Build Coastguard Worker             for(j = 0; j < wd; j++)
174*495ae853SAndroid Build Coastguard Worker             {
175*495ae853SAndroid Build Coastguard Worker                 WORD32 diff;
176*495ae853SAndroid Build Coastguard Worker                 diff = (*pu1_buf1 - *pu1_buf2);
177*495ae853SAndroid Build Coastguard Worker                 pu1_buf1 += incr1;
178*495ae853SAndroid Build Coastguard Worker                 pu1_buf2 += incr2;
179*495ae853SAndroid Build Coastguard Worker                 df_psnr[comp] += diff * diff;
180*495ae853SAndroid Build Coastguard Worker             }
181*495ae853SAndroid Build Coastguard Worker             pu1_buf1 += strd1;
182*495ae853SAndroid Build Coastguard Worker             pu1_buf2 += strd2;
183*495ae853SAndroid Build Coastguard Worker         }
184*495ae853SAndroid Build Coastguard Worker         df_psnr[comp] /= (wd * ht);
185*495ae853SAndroid Build Coastguard Worker         if(df_psnr[comp])
186*495ae853SAndroid Build Coastguard Worker             df_psnr[comp] = 20 * log10(255 / sqrt(df_psnr[comp]));
187*495ae853SAndroid Build Coastguard Worker         else
188*495ae853SAndroid Build Coastguard Worker             df_psnr[comp] = 100;
189*495ae853SAndroid Build Coastguard Worker 
190*495ae853SAndroid Build Coastguard Worker         ps_app_ctxt->adbl_psnr[comp] += df_psnr[comp];
191*495ae853SAndroid Build Coastguard Worker         switch(comp)
192*495ae853SAndroid Build Coastguard Worker         {
193*495ae853SAndroid Build Coastguard Worker             case 0:
194*495ae853SAndroid Build Coastguard Worker                 printf("Y :");
195*495ae853SAndroid Build Coastguard Worker                 break;
196*495ae853SAndroid Build Coastguard Worker             case 1:
197*495ae853SAndroid Build Coastguard Worker                 printf("U :");
198*495ae853SAndroid Build Coastguard Worker                 break;
199*495ae853SAndroid Build Coastguard Worker             case 2:
200*495ae853SAndroid Build Coastguard Worker                 printf("V :");
201*495ae853SAndroid Build Coastguard Worker                 break;
202*495ae853SAndroid Build Coastguard Worker             default:
203*495ae853SAndroid Build Coastguard Worker                 break;
204*495ae853SAndroid Build Coastguard Worker         }
205*495ae853SAndroid Build Coastguard Worker         printf("%2.2f\t", df_psnr[comp]);
206*495ae853SAndroid Build Coastguard Worker     }
207*495ae853SAndroid Build Coastguard Worker 
208*495ae853SAndroid Build Coastguard Worker     ps_app_ctxt->u4_psnr_cnt++;
209*495ae853SAndroid Build Coastguard Worker }
210*495ae853SAndroid Build Coastguard Worker 
211*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
212*495ae853SAndroid Build Coastguard Worker /*                                                                           */
213*495ae853SAndroid Build Coastguard Worker /*  Function Name : print_average_psnr                                       */
214*495ae853SAndroid Build Coastguard Worker /*                                                                           */
215*495ae853SAndroid Build Coastguard Worker /*  Description   : Computes the average PSNR for the Y, U, V component      */
216*495ae853SAndroid Build Coastguard Worker /*                                                                           */
217*495ae853SAndroid Build Coastguard Worker /*  Inputs        :                                                          */
218*495ae853SAndroid Build Coastguard Worker /*                                                                           */
219*495ae853SAndroid Build Coastguard Worker /*  Globals       :                                                          */
220*495ae853SAndroid Build Coastguard Worker /*                                                                           */
221*495ae853SAndroid Build Coastguard Worker /*  Processing    :                                                          */
222*495ae853SAndroid Build Coastguard Worker /*                                                                           */
223*495ae853SAndroid Build Coastguard Worker /*  Outputs       :                                                          */
224*495ae853SAndroid Build Coastguard Worker /*                                                                           */
225*495ae853SAndroid Build Coastguard Worker /*  Returns       :                                                          */
226*495ae853SAndroid Build Coastguard Worker /*                                                                           */
227*495ae853SAndroid Build Coastguard Worker /*  Issues        :                                                          */
228*495ae853SAndroid Build Coastguard Worker /*                                                                           */
229*495ae853SAndroid Build Coastguard Worker /*  Revision History:                                                        */
230*495ae853SAndroid Build Coastguard Worker /*                                                                           */
231*495ae853SAndroid Build Coastguard Worker /*         DD MM YYYY   Author(s)       Changes (Describe the changes made)  */
232*495ae853SAndroid Build Coastguard Worker /*         28 12 2005   Ittiam          Draft                                */
233*495ae853SAndroid Build Coastguard Worker /*                                                                           */
234*495ae853SAndroid Build Coastguard Worker /*****************************************************************************/
print_average_psnr(app_ctxt_t * ps_app_ctxt)235*495ae853SAndroid Build Coastguard Worker void print_average_psnr(app_ctxt_t *ps_app_ctxt)
236*495ae853SAndroid Build Coastguard Worker {
237*495ae853SAndroid Build Coastguard Worker     printf("\n");
238*495ae853SAndroid Build Coastguard Worker 
239*495ae853SAndroid Build Coastguard Worker     printf("Avg PSNR Y                      : %-2.2f\n",
240*495ae853SAndroid Build Coastguard Worker            (ps_app_ctxt->adbl_psnr[0] / ps_app_ctxt->u4_psnr_cnt));
241*495ae853SAndroid Build Coastguard Worker     printf("Avg PSNR U                      : %-2.2f\n",
242*495ae853SAndroid Build Coastguard Worker            (ps_app_ctxt->adbl_psnr[1] / ps_app_ctxt->u4_psnr_cnt));
243*495ae853SAndroid Build Coastguard Worker     printf("Avg PSNR V                      : %-2.2f\n",
244*495ae853SAndroid Build Coastguard Worker            (ps_app_ctxt->adbl_psnr[2] / ps_app_ctxt->u4_psnr_cnt));
245*495ae853SAndroid Build Coastguard Worker }
246