annotate postproc/postprocess.h @ 6652:f5942acbb873

sync
author nexus
date Sat, 06 Jul 2002 08:00:14 +0000
parents ac6e2ce386fa
children f483ab704252
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
2158
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
1 /*
3964
4911e2fc554b -npp fq:<quantizer>
michael
parents: 3832
diff changeset
2 Copyright (C) 2001-2002 Michael Niedermayer (michaelni@gmx.at)
2158
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
3
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
4 This program is free software; you can redistribute it and/or modify
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
5 it under the terms of the GNU General Public License as published by
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
6 the Free Software Foundation; either version 2 of the License, or
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
7 (at your option) any later version.
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
8
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
9 This program is distributed in the hope that it will be useful,
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
12 GNU General Public License for more details.
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
13
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
14 You should have received a copy of the GNU General Public License
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
15 along with this program; if not, write to the Free Software
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
16 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
17 */
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
18
2186
491d4fc9b6f2 small changes for mplayer integration:
arpi
parents: 2179
diff changeset
19 // POSTPROCESS_H is defined by opendivx's postprocess.h
491d4fc9b6f2 small changes for mplayer integration:
arpi
parents: 2179
diff changeset
20 #ifndef NEWPOSTPROCESS_H
491d4fc9b6f2 small changes for mplayer integration:
arpi
parents: 2179
diff changeset
21 #define NEWPOSTPROCESS_H
2158
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
22
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
23 #define BLOCK_SIZE 8
2159
795f3d022657 fixed a bug in the horizontal default filter
arpi
parents: 2158
diff changeset
24 #define TEMP_STRIDE 8
2203
f90b6e259dc8 rewrote the horizontal lowpass filter to fix a bug which caused a blocky look
michael
parents: 2189
diff changeset
25 //#define NUM_BLOCKS_AT_ONCE 16 //not used yet
2158
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
26
2159
795f3d022657 fixed a bug in the horizontal default filter
arpi
parents: 2158
diff changeset
27 #define V_DEBLOCK 0x01
795f3d022657 fixed a bug in the horizontal default filter
arpi
parents: 2158
diff changeset
28 #define H_DEBLOCK 0x02
795f3d022657 fixed a bug in the horizontal default filter
arpi
parents: 2158
diff changeset
29 #define DERING 0x04
2168
21a8f158d19f bugfixes: last 3 lines not brightness/contrast corrected
michael
parents: 2159
diff changeset
30 #define LEVEL_FIX 0x08 /* Brightness & Contrast */
2159
795f3d022657 fixed a bug in the horizontal default filter
arpi
parents: 2158
diff changeset
31
2179
2d8d14b882cc fixed a rounding bug thing in the X1 Filter
michael
parents: 2169
diff changeset
32 #define LUM_V_DEBLOCK V_DEBLOCK // 1
2d8d14b882cc fixed a rounding bug thing in the X1 Filter
michael
parents: 2169
diff changeset
33 #define LUM_H_DEBLOCK H_DEBLOCK // 2
2d8d14b882cc fixed a rounding bug thing in the X1 Filter
michael
parents: 2169
diff changeset
34 #define CHROM_V_DEBLOCK (V_DEBLOCK<<4) // 16
2d8d14b882cc fixed a rounding bug thing in the X1 Filter
michael
parents: 2169
diff changeset
35 #define CHROM_H_DEBLOCK (H_DEBLOCK<<4) // 32
2474
2e9442544447 just a few "not implemented yet" removed
michael
parents: 2389
diff changeset
36 #define LUM_DERING DERING // 4
2e9442544447 just a few "not implemented yet" removed
michael
parents: 2389
diff changeset
37 #define CHROM_DERING (DERING<<4) // 64
2179
2d8d14b882cc fixed a rounding bug thing in the X1 Filter
michael
parents: 2169
diff changeset
38 #define LUM_LEVEL_FIX LEVEL_FIX // 8
2203
f90b6e259dc8 rewrote the horizontal lowpass filter to fix a bug which caused a blocky look
michael
parents: 2189
diff changeset
39 #define CHROM_LEVEL_FIX (LEVEL_FIX<<4) // 128 (not implemented yet)
2159
795f3d022657 fixed a bug in the horizontal default filter
arpi
parents: 2158
diff changeset
40
2179
2d8d14b882cc fixed a rounding bug thing in the X1 Filter
michael
parents: 2169
diff changeset
41 // Experimental vertical filters
2d8d14b882cc fixed a rounding bug thing in the X1 Filter
michael
parents: 2169
diff changeset
42 #define V_RK1_FILTER 0x0100 // 256
2d8d14b882cc fixed a rounding bug thing in the X1 Filter
michael
parents: 2169
diff changeset
43 #define V_X1_FILTER 0x0200 // 512
2159
795f3d022657 fixed a bug in the horizontal default filter
arpi
parents: 2158
diff changeset
44
2179
2d8d14b882cc fixed a rounding bug thing in the X1 Filter
michael
parents: 2169
diff changeset
45 // Experimental horizontal filters
2474
2e9442544447 just a few "not implemented yet" removed
michael
parents: 2389
diff changeset
46 #define H_RK1_FILTER 0x1000 // 4096
2179
2d8d14b882cc fixed a rounding bug thing in the X1 Filter
michael
parents: 2169
diff changeset
47 #define H_X1_FILTER 0x2000 // 8192
2168
21a8f158d19f bugfixes: last 3 lines not brightness/contrast corrected
michael
parents: 2159
diff changeset
48
2389
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
49 // select between full y range (255-0) or standart one (234-16)
2285
4840e356d0d3 fixed a bug in the tmp buffer
michael
parents: 2246
diff changeset
50 #define FULL_Y_RANGE 0x8000 // 32768
4840e356d0d3 fixed a bug in the tmp buffer
michael
parents: 2246
diff changeset
51
2203
f90b6e259dc8 rewrote the horizontal lowpass filter to fix a bug which caused a blocky look
michael
parents: 2189
diff changeset
52 //Deinterlacing Filters
f90b6e259dc8 rewrote the horizontal lowpass filter to fix a bug which caused a blocky look
michael
parents: 2189
diff changeset
53 #define LINEAR_IPOL_DEINT_FILTER 0x10000 // 65536
f90b6e259dc8 rewrote the horizontal lowpass filter to fix a bug which caused a blocky look
michael
parents: 2189
diff changeset
54 #define LINEAR_BLEND_DEINT_FILTER 0x20000 // 131072
2246
f7c1485b33be fixed the height%8!=0 bug
michael
parents: 2221
diff changeset
55 #define CUBIC_BLEND_DEINT_FILTER 0x8000 // (not implemented yet)
f7c1485b33be fixed the height%8!=0 bug
michael
parents: 2221
diff changeset
56 #define CUBIC_IPOL_DEINT_FILTER 0x40000 // 262144
2221
9fd911c931cd minor cleanups
michael
parents: 2203
diff changeset
57 #define MEDIAN_DEINT_FILTER 0x80000 // 524288
2203
f90b6e259dc8 rewrote the horizontal lowpass filter to fix a bug which caused a blocky look
michael
parents: 2189
diff changeset
58
2860
08b833fb875a temporal noise reducer in C (-pp 0x100000)
michael
parents: 2474
diff changeset
59 #define TEMP_NOISE_FILTER 0x100000
3964
4911e2fc554b -npp fq:<quantizer>
michael
parents: 3832
diff changeset
60 #define FORCE_QUANT 0x200000
2860
08b833fb875a temporal noise reducer in C (-pp 0x100000)
michael
parents: 2474
diff changeset
61
2203
f90b6e259dc8 rewrote the horizontal lowpass filter to fix a bug which caused a blocky look
michael
parents: 2189
diff changeset
62
2189
82556b3a1228 Cleanup:
arpi
parents: 2186
diff changeset
63 #define GET_PP_QUALITY_MAX 6
2158
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
64
2286
58b3f908201d added compiletime option to turn width%8==0 on
michael
parents: 2285
diff changeset
65 //must be defined if stride%8 != 0
2292
d57280ca1db9 PP_FUNNY_STRIDE disabled
arpi
parents: 2286
diff changeset
66 //#define PP_FUNNY_STRIDE
2286
58b3f908201d added compiletime option to turn width%8==0 on
michael
parents: 2285
diff changeset
67
2221
9fd911c931cd minor cleanups
michael
parents: 2203
diff changeset
68 //#define TIMING
9fd911c931cd minor cleanups
michael
parents: 2203
diff changeset
69 //#define MORE_TIMING
2158
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
70
3154
b2e24fec97bc compiletime pp-mode support (luminance = chrominance filters though) 1-2% faster with -benchmark -vo null -nosound
michael
parents: 2860
diff changeset
71 //use if u want a faster postprocessing code
b2e24fec97bc compiletime pp-mode support (luminance = chrominance filters though) 1-2% faster with -benchmark -vo null -nosound
michael
parents: 2860
diff changeset
72 //cant differentiate between chroma & luma filters (both on or both off)
b2e24fec97bc compiletime pp-mode support (luminance = chrominance filters though) 1-2% faster with -benchmark -vo null -nosound
michael
parents: 2860
diff changeset
73 //obviosly the -pp option at the commandline has no effect except turning the here selected
b2e24fec97bc compiletime pp-mode support (luminance = chrominance filters though) 1-2% faster with -benchmark -vo null -nosound
michael
parents: 2860
diff changeset
74 //filters on
b2e24fec97bc compiletime pp-mode support (luminance = chrominance filters though) 1-2% faster with -benchmark -vo null -nosound
michael
parents: 2860
diff changeset
75 //#define COMPILE_TIME_MODE 0x77
b2e24fec97bc compiletime pp-mode support (luminance = chrominance filters though) 1-2% faster with -benchmark -vo null -nosound
michael
parents: 2860
diff changeset
76
2158
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
77 #define QP_STORE_T int
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
78
2389
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
79 struct PPMode{
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
80 int lumMode; //acivates filters for luminance
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
81 int chromMode; //acivates filters for chrominance
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
82 int oldMode; // will be passed to odivx
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
83 int error; // non zero on error
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
84
2860
08b833fb875a temporal noise reducer in C (-pp 0x100000)
michael
parents: 2474
diff changeset
85 int minAllowedY; // for brigtness correction
08b833fb875a temporal noise reducer in C (-pp 0x100000)
michael
parents: 2474
diff changeset
86 int maxAllowedY; // for brihtness correction
08b833fb875a temporal noise reducer in C (-pp 0x100000)
michael
parents: 2474
diff changeset
87
08b833fb875a temporal noise reducer in C (-pp 0x100000)
michael
parents: 2474
diff changeset
88 int maxTmpNoise[3]; // for Temporal Noise Reducing filter (Maximal sum of abs differences)
3832
d05cfaf5f0f2 minor brightness/contrast bugfix / moved some global vars into ppMode
michael
parents: 3771
diff changeset
89
d05cfaf5f0f2 minor brightness/contrast bugfix / moved some global vars into ppMode
michael
parents: 3771
diff changeset
90 int maxDcDiff; // max abs diff between pixels to be considered flat
3964
4911e2fc554b -npp fq:<quantizer>
michael
parents: 3832
diff changeset
91 int forcedQuant; // quantizer if FORCE_QUANT is used
2389
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
92 };
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
93
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
94 struct PPFilter{
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
95 char *shortName;
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
96 char *longName;
2860
08b833fb875a temporal noise reducer in C (-pp 0x100000)
michael
parents: 2474
diff changeset
97 int chromDefault; // is chrominance filtering on by default if this filter is manually activated
08b833fb875a temporal noise reducer in C (-pp 0x100000)
michael
parents: 2474
diff changeset
98 int minLumQuality; // minimum quality to turn luminance filtering on
08b833fb875a temporal noise reducer in C (-pp 0x100000)
michael
parents: 2474
diff changeset
99 int minChromQuality; // minimum quality to turn chrominance filtering on
08b833fb875a temporal noise reducer in C (-pp 0x100000)
michael
parents: 2474
diff changeset
100 int mask; // Bitmask to turn this filter on
2389
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
101 };
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
102
2860
08b833fb875a temporal noise reducer in C (-pp 0x100000)
michael
parents: 2474
diff changeset
103 /* Obsolete, dont use it, use postprocess2() instead */
2158
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
104 void postprocess(unsigned char * src[], int src_stride,
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
105 unsigned char * dst[], int dst_stride,
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
106 int horizontal_size, int vertical_size,
2186
491d4fc9b6f2 small changes for mplayer integration:
arpi
parents: 2179
diff changeset
107 QP_STORE_T *QP_store, int QP_stride, int mode);
2189
82556b3a1228 Cleanup:
arpi
parents: 2186
diff changeset
108
2389
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
109 void postprocess2(unsigned char * src[], int src_stride,
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
110 unsigned char * dst[], int dst_stride,
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
111 int horizontal_size, int vertical_size,
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
112 QP_STORE_T *QP_store, int QP_stride, struct PPMode *mode);
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
113
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
114
2860
08b833fb875a temporal noise reducer in C (-pp 0x100000)
michael
parents: 2474
diff changeset
115 /* Obsolete, dont use it, use getPpModeByNameAndQuality() instead */
2186
491d4fc9b6f2 small changes for mplayer integration:
arpi
parents: 2179
diff changeset
116 int getPpModeForQuality(int quality);
2189
82556b3a1228 Cleanup:
arpi
parents: 2186
diff changeset
117
2860
08b833fb875a temporal noise reducer in C (-pp 0x100000)
michael
parents: 2474
diff changeset
118 // name is the stuff after "-pp" on the command line
5576
ac6e2ce386fa fix typo found by Milan Cutka <cutka@szm.sk>
michael
parents: 3964
diff changeset
119 struct PPMode getPPModeByNameAndQuality(char *name, int quality);
2389
bd3f33e7dd26 auto brightness/ contrast bugfix
michael
parents: 2292
diff changeset
120
3771
a14b3a600b81 new -pp options stuff (-npp ...)
michael
parents: 3154
diff changeset
121 int readPPOpt(void *conf, char *arg);
a14b3a600b81 new -pp options stuff (-npp ...)
michael
parents: 3154
diff changeset
122
2158
508468a75be0 new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff changeset
123 #endif