annotate libmpcodecs/vf_qp.c @ 32527:babddccb9312

use x264_picture_init. this currently has no effect, but it always should have been done this way, and it will be required for some future x264 version.
author lorenm
date Wed, 10 Nov 2010 08:32:54 +0000
parents 0d03e9c53d26
children 8fa2f43cb760
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
1 /*
26727
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
2 * Copyright (C) 2004 Michael Niedermayer <michaelni@gmx.at>
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
3 *
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
4 * This file is part of MPlayer.
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
5 *
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
6 * MPlayer is free software; you can redistribute it and/or modify
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
7 * it under the terms of the GNU General Public License as published by
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
8 * the Free Software Foundation; either version 2 of the License, or
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
9 * (at your option) any later version.
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
10 *
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
11 * MPlayer is distributed in the hope that it will be useful,
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
14 * GNU General Public License for more details.
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
15 *
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
16 * You should have received a copy of the GNU General Public License along
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
17 * with MPlayer; if not, write to the Free Software Foundation, Inc.,
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
18 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
82601a38e2a7 Use standard license headers.
diego
parents: 25221
diff changeset
19 */
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
20
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
21 #include <stdio.h>
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
22 #include <stdlib.h>
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
23 #include <string.h>
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
24 #include <math.h>
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
25 #include <inttypes.h>
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
26
17012
6ff3379a0862 Unify include path handling, -I.. is in CFLAGS.
diego
parents: 16677
diff changeset
27 #include "mp_msg.h"
6ff3379a0862 Unify include path handling, -I.. is in CFLAGS.
diego
parents: 16677
diff changeset
28 #include "cpudetect.h"
24974
6f05850b5fd1 Rearrange headers to get rid of an #undef and remove unnecessary headers.
diego
parents: 24972
diff changeset
29 #include "img_format.h"
6f05850b5fd1 Rearrange headers to get rid of an #undef and remove unnecessary headers.
diego
parents: 24972
diff changeset
30 #include "mp_image.h"
6f05850b5fd1 Rearrange headers to get rid of an #undef and remove unnecessary headers.
diego
parents: 24972
diff changeset
31 #include "vf.h"
6f05850b5fd1 Rearrange headers to get rid of an #undef and remove unnecessary headers.
diego
parents: 24972
diff changeset
32 #include "libvo/fastmemcpy.h"
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
33
17012
6ff3379a0862 Unify include path handling, -I.. is in CFLAGS.
diego
parents: 16677
diff changeset
34 #include "libavcodec/avcodec.h"
31256
0d03e9c53d26 Fix compilation after FFmpeg r23485.
cehoyos
parents: 31233
diff changeset
35 #include "libavutil/eval.h"
16677
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
36
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
37
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
38 struct vf_priv_s {
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
39 char eq[200];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
40 int8_t *qp;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
41 int8_t lut[257];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
42 int qp_stride;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
43 };
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
44
30642
a972c1a4a012 cosmetics: Rename struct vf_instance_s --> vf_instance.
diego
parents: 30638
diff changeset
45 static int config(struct vf_instance *vf,
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
46 int width, int height, int d_width, int d_height,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
47 unsigned int flags, unsigned int outfmt){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
48 int h= (height+15)>>4;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
49 int i;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
50
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
51 vf->priv->qp_stride= (width+15)>>4;
16677
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
52 vf->priv->qp= av_malloc(vf->priv->qp_stride*h*sizeof(int8_t));
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 29087
diff changeset
53
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
54 for(i=-129; i<128; i++){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
55 double const_values[]={
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
56 M_PI,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
57 M_E,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
58 i != -129,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
59 i,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
60 0
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
61 };
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
62 static const char *const_names[]={
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
63 "PI",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
64 "E",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
65 "known",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
66 "qp",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
67 NULL
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
68 };
31130
d1f5069bef25 Fix compilation broken by FFmpeg-r23201 that changed the api of error logging.
iive
parents: 30989
diff changeset
69 double temp_val;
31233
01fdbb0aaa5c Fix compilation after FFmpeg r23402.
cehoyos
parents: 31130
diff changeset
70 int res;
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
71
31256
0d03e9c53d26 Fix compilation after FFmpeg r23485.
cehoyos
parents: 31233
diff changeset
72 res= av_parse_and_eval_expr(&temp_val, vf->priv->eq, const_names, const_values, NULL, NULL, NULL, NULL, NULL, 0, NULL);
31130
d1f5069bef25 Fix compilation broken by FFmpeg-r23201 that changed the api of error logging.
iive
parents: 30989
diff changeset
73
31233
01fdbb0aaa5c Fix compilation after FFmpeg r23402.
cehoyos
parents: 31130
diff changeset
74 if (res < 0){
31130
d1f5069bef25 Fix compilation broken by FFmpeg-r23201 that changed the api of error logging.
iive
parents: 30989
diff changeset
75 mp_msg(MSGT_VFILTER, MSGL_ERR, "qp: Error evaluating \"%s\" \n", vf->priv->eq);
d1f5069bef25 Fix compilation broken by FFmpeg-r23201 that changed the api of error logging.
iive
parents: 30989
diff changeset
76 return 0;
d1f5069bef25 Fix compilation broken by FFmpeg-r23201 that changed the api of error logging.
iive
parents: 30989
diff changeset
77 }
d1f5069bef25 Fix compilation broken by FFmpeg-r23201 that changed the api of error logging.
iive
parents: 30989
diff changeset
78 vf->priv->lut[i+129]= lrintf(temp_val);
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
79 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
80
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
81 return vf_next_config(vf,width,height,d_width,d_height,flags,outfmt);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
82 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
83
30642
a972c1a4a012 cosmetics: Rename struct vf_instance_s --> vf_instance.
diego
parents: 30638
diff changeset
84 static void get_image(struct vf_instance *vf, mp_image_t *mpi){
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
85 if(mpi->flags&MP_IMGFLAG_PRESERVE) return; // don't change
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
86 // ok, we can do pp in-place (or pp disabled):
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
87 vf->dmpi=vf_get_image(vf->next,mpi->imgfmt,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
88 mpi->type, mpi->flags, mpi->w, mpi->h);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
89 mpi->planes[0]=vf->dmpi->planes[0];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
90 mpi->stride[0]=vf->dmpi->stride[0];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
91 mpi->width=vf->dmpi->width;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
92 if(mpi->flags&MP_IMGFLAG_PLANAR){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
93 mpi->planes[1]=vf->dmpi->planes[1];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
94 mpi->planes[2]=vf->dmpi->planes[2];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
95 mpi->stride[1]=vf->dmpi->stride[1];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
96 mpi->stride[2]=vf->dmpi->stride[2];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
97 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
98 mpi->flags|=MP_IMGFLAG_DIRECT;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
99 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
100
30642
a972c1a4a012 cosmetics: Rename struct vf_instance_s --> vf_instance.
diego
parents: 30638
diff changeset
101 static int put_image(struct vf_instance *vf, mp_image_t *mpi, double pts){
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
102 mp_image_t *dmpi;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
103 int x,y;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
104
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
105 if(!(mpi->flags&MP_IMGFLAG_DIRECT)){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
106 // no DR, so get a new image! hope we'll get DR buffer:
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
107 vf->dmpi=vf_get_image(vf->next,mpi->imgfmt,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
108 MP_IMGTYPE_TEMP, MP_IMGFLAG_ACCEPT_STRIDE|MP_IMGFLAG_PREFER_ALIGNED_STRIDE,
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
109 mpi->w,mpi->h);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
110 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
111
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
112 dmpi= vf->dmpi;
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 29087
diff changeset
113
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
114 if(!(mpi->flags&MP_IMGFLAG_DIRECT)){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
115 memcpy_pic(dmpi->planes[0], mpi->planes[0], mpi->w, mpi->h, dmpi->stride[0], mpi->stride[0]);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
116 if(mpi->flags&MP_IMGFLAG_PLANAR){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
117 memcpy_pic(dmpi->planes[1], mpi->planes[1], mpi->w>>mpi->chroma_x_shift, mpi->h>>mpi->chroma_y_shift, dmpi->stride[1], mpi->stride[1]);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
118 memcpy_pic(dmpi->planes[2], mpi->planes[2], mpi->w>>mpi->chroma_x_shift, mpi->h>>mpi->chroma_y_shift, dmpi->stride[2], mpi->stride[2]);
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
119 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
120 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
121 vf_clone_mpi_attributes(dmpi, mpi);
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 29087
diff changeset
122
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
123 dmpi->qscale = vf->priv->qp;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
124 dmpi->qstride= vf->priv->qp_stride;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
125 if(mpi->qscale){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
126 for(y=0; y<((dmpi->h+15)>>4); y++){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
127 for(x=0; x<vf->priv->qp_stride; x++){
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 29087
diff changeset
128 dmpi->qscale[x + dmpi->qstride*y]=
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
129 vf->priv->lut[ 129 + ((int8_t)mpi->qscale[x + mpi->qstride*y]) ];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
130 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
131 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
132 }else{
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
133 int qp= vf->priv->lut[0];
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
134 for(y=0; y<((dmpi->h+15)>>4); y++){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
135 for(x=0; x<vf->priv->qp_stride; x++){
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
136 dmpi->qscale[x + dmpi->qstride*y]= qp;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
137 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
138 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
139 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
140
17906
20aca9baf5d8 passing pts through the filter layer (lets see if pts or cola comes out at the end)
michael
parents: 17523
diff changeset
141 return vf_next_put_image(vf,dmpi, pts);
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
142 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
143
30642
a972c1a4a012 cosmetics: Rename struct vf_instance_s --> vf_instance.
diego
parents: 30638
diff changeset
144 static void uninit(struct vf_instance *vf){
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
145 if(!vf->priv) return;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
146
16677
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
147 if(vf->priv->qp) av_free(vf->priv->qp);
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
148 vf->priv->qp= NULL;
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 29087
diff changeset
149
16677
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
150 av_free(vf->priv);
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
151 vf->priv=NULL;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
152 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
153
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
154 //===========================================================================//
30638
a7b908875c14 Rename open() vf initialization function to vf_open().
diego
parents: 29263
diff changeset
155 static int vf_open(vf_instance_t *vf, char *args){
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
156 vf->config=config;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
157 vf->put_image=put_image;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
158 vf->get_image=get_image;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
159 vf->uninit=uninit;
16677
044b85964c05 Compilation fix for systems lacking lrintf like e.g. NetBSD.
diego
parents: 11923
diff changeset
160 vf->priv=av_malloc(sizeof(struct vf_priv_s));
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
161 memset(vf->priv, 0, sizeof(struct vf_priv_s));
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 29087
diff changeset
162
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
163 // avcodec_init();
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
164
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
165 if (args) strncpy(vf->priv->eq, args, 199);
29263
0f1b5b68af32 whitespace cosmetics: Remove all trailing whitespace.
diego
parents: 29087
diff changeset
166
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
167 return 1;
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
168 }
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
169
25221
00fff9a3b735 Make all vf_info_t structs const
reimar
parents: 24974
diff changeset
170 const vf_info_t vf_info_qp = {
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
171 "QP changer",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
172 "qp",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
173 "Michael Niedermayer",
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
174 "",
30638
a7b908875c14 Rename open() vf initialization function to vf_open().
diego
parents: 29263
diff changeset
175 vf_open,
11921
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
176 NULL
dd3ac91a86b5 qp change filter
michael
parents:
diff changeset
177 };