Mercurial > libavcodec.hg
annotate libpostproc/postprocess.h @ 156:c09459686be3 libavcodec
temporal noise reducer in C (-pp 0x100000)
setting the thresholds from the commandline requires postprocess2() / getPpModeByNameAndQuality() (someone could perhaps modify mplayer so that they are beiing used, iam too lazy for it ;)
author | michael |
---|---|
date | Tue, 13 Nov 2001 02:40:56 +0000 |
parents | f91bb7527628 |
children | a0efaf471d6b |
rev | line source |
---|---|
95
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
1 /* |
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
2 Copyright (C) 2001 Michael Niedermayer (michaelni@gmx.at) |
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
3 |
8bce253b537c
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 |
8bce253b537c
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 |
8bce253b537c
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 |
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
7 (at your option) any later version. |
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
8 |
8bce253b537c
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, |
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
10 but WITHOUT ANY WARRANTY; without even the implied warranty of |
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
12 GNU General Public License for more details. |
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
13 |
8bce253b537c
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 |
8bce253b537c
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 |
8bce253b537c
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 |
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
17 */ |
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
18 |
103 | 19 // POSTPROCESS_H is defined by opendivx's postprocess.h |
20 #ifndef NEWPOSTPROCESS_H | |
21 #define NEWPOSTPROCESS_H | |
95
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
22 |
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
23 #define BLOCK_SIZE 8 |
96 | 24 #define TEMP_STRIDE 8 |
106
389391a6d0bf
rewrote the horizontal lowpass filter to fix a bug which caused a blocky look
michael
parents:
104
diff
changeset
|
25 //#define NUM_BLOCKS_AT_ONCE 16 //not used yet |
95
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
26 |
96 | 27 #define V_DEBLOCK 0x01 |
28 #define H_DEBLOCK 0x02 | |
29 #define DERING 0x04 | |
97
e57b1d38d71f
bugfixes: last 3 lines not brightness/contrast corrected
michael
parents:
96
diff
changeset
|
30 #define LEVEL_FIX 0x08 /* Brightness & Contrast */ |
96 | 31 |
99 | 32 #define LUM_V_DEBLOCK V_DEBLOCK // 1 |
33 #define LUM_H_DEBLOCK H_DEBLOCK // 2 | |
34 #define CHROM_V_DEBLOCK (V_DEBLOCK<<4) // 16 | |
35 #define CHROM_H_DEBLOCK (H_DEBLOCK<<4) // 32 | |
131 | 36 #define LUM_DERING DERING // 4 |
37 #define CHROM_DERING (DERING<<4) // 64 | |
99 | 38 #define LUM_LEVEL_FIX LEVEL_FIX // 8 |
106
389391a6d0bf
rewrote the horizontal lowpass filter to fix a bug which caused a blocky look
michael
parents:
104
diff
changeset
|
39 #define CHROM_LEVEL_FIX (LEVEL_FIX<<4) // 128 (not implemented yet) |
96 | 40 |
99 | 41 // Experimental vertical filters |
42 #define V_RK1_FILTER 0x0100 // 256 | |
43 #define V_X1_FILTER 0x0200 // 512 | |
96 | 44 |
99 | 45 // Experimental horizontal filters |
131 | 46 #define H_RK1_FILTER 0x1000 // 4096 |
99 | 47 #define H_X1_FILTER 0x2000 // 8192 |
97
e57b1d38d71f
bugfixes: last 3 lines not brightness/contrast corrected
michael
parents:
96
diff
changeset
|
48 |
116 | 49 // select between full y range (255-0) or standart one (234-16) |
112 | 50 #define FULL_Y_RANGE 0x8000 // 32768 |
51 | |
106
389391a6d0bf
rewrote the horizontal lowpass filter to fix a bug which caused a blocky look
michael
parents:
104
diff
changeset
|
52 //Deinterlacing Filters |
389391a6d0bf
rewrote the horizontal lowpass filter to fix a bug which caused a blocky look
michael
parents:
104
diff
changeset
|
53 #define LINEAR_IPOL_DEINT_FILTER 0x10000 // 65536 |
389391a6d0bf
rewrote the horizontal lowpass filter to fix a bug which caused a blocky look
michael
parents:
104
diff
changeset
|
54 #define LINEAR_BLEND_DEINT_FILTER 0x20000 // 131072 |
111 | 55 #define CUBIC_BLEND_DEINT_FILTER 0x8000 // (not implemented yet) |
56 #define CUBIC_IPOL_DEINT_FILTER 0x40000 // 262144 | |
107 | 57 #define MEDIAN_DEINT_FILTER 0x80000 // 524288 |
106
389391a6d0bf
rewrote the horizontal lowpass filter to fix a bug which caused a blocky look
michael
parents:
104
diff
changeset
|
58 |
156 | 59 #define TEMP_NOISE_FILTER 0x100000 |
60 | |
106
389391a6d0bf
rewrote the horizontal lowpass filter to fix a bug which caused a blocky look
michael
parents:
104
diff
changeset
|
61 |
104 | 62 #define GET_PP_QUALITY_MAX 6 |
95
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
63 |
113 | 64 //must be defined if stride%8 != 0 |
114 | 65 //#define PP_FUNNY_STRIDE |
113 | 66 |
107 | 67 //#define TIMING |
68 //#define MORE_TIMING | |
95
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
69 |
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
70 #define QP_STORE_T int |
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
71 |
116 | 72 struct PPMode{ |
73 int lumMode; //acivates filters for luminance | |
74 int chromMode; //acivates filters for chrominance | |
75 int oldMode; // will be passed to odivx | |
76 int error; // non zero on error | |
77 | |
156 | 78 int minAllowedY; // for brigtness correction |
79 int maxAllowedY; // for brihtness correction | |
80 | |
81 int maxTmpNoise[3]; // for Temporal Noise Reducing filter (Maximal sum of abs differences) | |
116 | 82 }; |
83 | |
84 struct PPFilter{ | |
85 char *shortName; | |
86 char *longName; | |
156 | 87 int chromDefault; // is chrominance filtering on by default if this filter is manually activated |
88 int minLumQuality; // minimum quality to turn luminance filtering on | |
89 int minChromQuality; // minimum quality to turn chrominance filtering on | |
90 int mask; // Bitmask to turn this filter on | |
116 | 91 }; |
92 | |
156 | 93 /* Obsolete, dont use it, use postprocess2() instead */ |
95
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
94 void postprocess(unsigned char * src[], int src_stride, |
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
95 unsigned char * dst[], int dst_stride, |
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
96 int horizontal_size, int vertical_size, |
103 | 97 QP_STORE_T *QP_store, int QP_stride, int mode); |
104 | 98 |
116 | 99 void postprocess2(unsigned char * src[], int src_stride, |
100 unsigned char * dst[], int dst_stride, | |
101 int horizontal_size, int vertical_size, | |
102 QP_STORE_T *QP_store, int QP_stride, struct PPMode *mode); | |
103 | |
104 | |
156 | 105 /* Obsolete, dont use it, use getPpModeByNameAndQuality() instead */ |
103 | 106 int getPpModeForQuality(int quality); |
104 | 107 |
156 | 108 // name is the stuff after "-pp" on the command line |
116 | 109 struct PPMode getPpModeByNameAndQuality(char *name, int quality); |
110 | |
95
8bce253b537c
new postprocess code by Michael Niedermayer (michaelni@gmx.at)
arpi
parents:
diff
changeset
|
111 #endif |