1 |
|
#include <stdio.h> |
2 |
|
|
3 |
#include "../xvid.h" |
#include "../xvid.h" |
4 |
#include "../image/image.h" |
#include "../image/image.h" |
5 |
|
|
11 |
case XVID_PLG_INFO : |
case XVID_PLG_INFO : |
12 |
{ |
{ |
13 |
xvid_plg_info_t * info = (xvid_plg_info_t*)param1; |
xvid_plg_info_t * info = (xvid_plg_info_t*)param1; |
14 |
info->flags = XVID_REQORIGINAL; |
info->flags = XVID_REQPSNR; |
15 |
return 0; |
return 0; |
16 |
} |
} |
17 |
|
|
24 |
{ |
{ |
25 |
xvid_plg_data_t * data = (xvid_plg_data_t*)param1; |
xvid_plg_data_t * data = (xvid_plg_data_t*)param1; |
26 |
|
|
|
long sse_y = plane_sse(data->original.plane[0], data->current.plane[0], |
|
|
data->current.stride[0], data->width, data->height); |
|
|
|
|
|
long sse_u = plane_sse(data->original.plane[1], data->current.plane[1], |
|
|
data->current.stride[1], data->width/2, data->height/2); |
|
|
|
|
|
long sse_v = plane_sse(data->original.plane[2], data->current.plane[2], |
|
|
data->current.stride[2], data->width/2, data->height/2); |
|
|
|
|
27 |
printf("y_psnr=%2.2f u_psnr=%2.2f v_psnr=%2.2f\n", |
printf("y_psnr=%2.2f u_psnr=%2.2f v_psnr=%2.2f\n", |
28 |
sse_to_PSNR(sse_y, data->width*data->height), |
sse_to_PSNR(data->sse_y, data->width*data->height), |
29 |
sse_to_PSNR(sse_u, data->width*data->height/4), |
sse_to_PSNR(data->sse_u, data->width*data->height/4), |
30 |
sse_to_PSNR(sse_v, data->width*data->height/4)); |
sse_to_PSNR(data->sse_v, data->width*data->height/4)); |
|
|
|
|
{ |
|
|
IMAGE img; |
|
|
char tmp[100]; |
|
|
img.y = data->original.plane[0]; |
|
|
img.u = data->original.plane[1]; |
|
|
img.v = data->original.plane[2]; |
|
|
sprintf(tmp, "ori-%03i.pgm", data->frame_num); |
|
|
image_dump_yuvpgm(&img, data->original.stride[0], data->width, data->height, tmp); |
|
|
|
|
|
img.y = data->current.plane[0]; |
|
|
img.u = data->current.plane[1]; |
|
|
img.v = data->current.plane[2]; |
|
|
sprintf(tmp, "enc-%03i.pgm", data->frame_num); |
|
|
image_dump_yuvpgm(&img, data->reference.stride[0], data->width, data->height, tmp); |
|
|
} |
|
31 |
|
|
32 |
return 0; |
return 0; |
33 |
} |
} |