Commit | Line | Data |
---|---|---|
3057fa66 | 1 | /* |
8aaac435 | 2 | Copyright (C) 2001-2002 Michael Niedermayer (michaelni@gmx.at) |
3057fa66 A |
3 | |
4 | This program is free software; you can redistribute it and/or modify | |
5 | it under the terms of the GNU General Public License as published by | |
6 | the Free Software Foundation; either version 2 of the License, or | |
7 | (at your option) any later version. | |
8 | ||
9 | This program is distributed in the hope that it will be useful, | |
10 | but WITHOUT ANY WARRANTY; without even the implied warranty of | |
11 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
12 | GNU General Public License for more details. | |
13 | ||
14 | You should have received a copy of the GNU General Public License | |
15 | along with this program; if not, write to the Free Software | |
16 | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | |
17 | */ | |
18 | ||
9f3328bc A |
19 | // POSTPROCESS_H is defined by opendivx's postprocess.h |
20 | #ifndef NEWPOSTPROCESS_H | |
21 | #define NEWPOSTPROCESS_H | |
3057fa66 A |
22 | |
23 | #define BLOCK_SIZE 8 | |
3057fa66 | 24 | #define TEMP_STRIDE 8 |
3b58b885 | 25 | //#define NUM_BLOCKS_AT_ONCE 16 //not used yet |
13e00528 A |
26 | |
27 | #define V_DEBLOCK 0x01 | |
28 | #define H_DEBLOCK 0x02 | |
29 | #define DERING 0x04 | |
d5a1a995 | 30 | #define LEVEL_FIX 0x08 /* Brightness & Contrast */ |
13e00528 | 31 | |
9f45d04d MN |
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 | |
cf76316a MN |
36 | #define LUM_DERING DERING // 4 |
37 | #define CHROM_DERING (DERING<<4) // 64 | |
9f45d04d | 38 | #define LUM_LEVEL_FIX LEVEL_FIX // 8 |
3b58b885 | 39 | #define CHROM_LEVEL_FIX (LEVEL_FIX<<4) // 128 (not implemented yet) |
13e00528 | 40 | |
9f45d04d MN |
41 | // Experimental vertical filters |
42 | #define V_RK1_FILTER 0x0100 // 256 | |
43 | #define V_X1_FILTER 0x0200 // 512 | |
13e00528 | 44 | |
9f45d04d | 45 | // Experimental horizontal filters |
cf76316a | 46 | #define H_RK1_FILTER 0x1000 // 4096 |
9f45d04d | 47 | #define H_X1_FILTER 0x2000 // 8192 |
d5a1a995 | 48 | |
911879d1 | 49 | // select between full y range (255-0) or standart one (234-16) |
658a85f2 MN |
50 | #define FULL_Y_RANGE 0x8000 // 32768 |
51 | ||
3b58b885 | 52 | //Deinterlacing Filters |
3b58b885 MN |
53 | #define LINEAR_IPOL_DEINT_FILTER 0x10000 // 65536 |
54 | #define LINEAR_BLEND_DEINT_FILTER 0x20000 // 131072 | |
acced553 MN |
55 | #define CUBIC_BLEND_DEINT_FILTER 0x8000 // (not implemented yet) |
56 | #define CUBIC_IPOL_DEINT_FILTER 0x40000 // 262144 | |
a6be8111 | 57 | #define MEDIAN_DEINT_FILTER 0x80000 // 524288 |
3b58b885 | 58 | |
117e45b0 | 59 | #define TEMP_NOISE_FILTER 0x100000 |
8aaac435 | 60 | #define FORCE_QUANT 0x200000 |
117e45b0 | 61 | |
3b58b885 | 62 | |
e939e1c3 | 63 | #define GET_PP_QUALITY_MAX 6 |
13e00528 | 64 | |
a0e8aca3 | 65 | //must be defined if stride%8 != 0 |
311832de | 66 | //#define PP_FUNNY_STRIDE |
a0e8aca3 | 67 | |
a6be8111 MN |
68 | //#define TIMING |
69 | //#define MORE_TIMING | |
3057fa66 | 70 | |
06c4804a MN |
71 | //use if u want a faster postprocessing code |
72 | //cant differentiate between chroma & luma filters (both on or both off) | |
73 | //obviosly the -pp option at the commandline has no effect except turning the here selected | |
74 | //filters on | |
75 | //#define COMPILE_TIME_MODE 0x77 | |
76 | ||
3057fa66 A |
77 | #define QP_STORE_T int |
78 | ||
911879d1 MN |
79 | struct PPMode{ |
80 | int lumMode; //acivates filters for luminance | |
81 | int chromMode; //acivates filters for chrominance | |
82 | int oldMode; // will be passed to odivx | |
83 | int error; // non zero on error | |
84 | ||
117e45b0 MN |
85 | int minAllowedY; // for brigtness correction |
86 | int maxAllowedY; // for brihtness correction | |
87 | ||
88 | int maxTmpNoise[3]; // for Temporal Noise Reducing filter (Maximal sum of abs differences) | |
07f8991b MN |
89 | |
90 | int maxDcDiff; // max abs diff between pixels to be considered flat | |
8aaac435 | 91 | int forcedQuant; // quantizer if FORCE_QUANT is used |
911879d1 MN |
92 | }; |
93 | ||
94 | struct PPFilter{ | |
95 | char *shortName; | |
96 | char *longName; | |
117e45b0 MN |
97 | int chromDefault; // is chrominance filtering on by default if this filter is manually activated |
98 | int minLumQuality; // minimum quality to turn luminance filtering on | |
99 | int minChromQuality; // minimum quality to turn chrominance filtering on | |
100 | int mask; // Bitmask to turn this filter on | |
911879d1 MN |
101 | }; |
102 | ||
117e45b0 | 103 | /* Obsolete, dont use it, use postprocess2() instead */ |
3057fa66 A |
104 | void postprocess(unsigned char * src[], int src_stride, |
105 | unsigned char * dst[], int dst_stride, | |
106 | int horizontal_size, int vertical_size, | |
9f3328bc | 107 | QP_STORE_T *QP_store, int QP_stride, int mode); |
e939e1c3 | 108 | |
911879d1 MN |
109 | void postprocess2(unsigned char * src[], int src_stride, |
110 | unsigned char * dst[], int dst_stride, | |
111 | int horizontal_size, int vertical_size, | |
112 | QP_STORE_T *QP_store, int QP_stride, struct PPMode *mode); | |
113 | ||
114 | ||
117e45b0 | 115 | /* Obsolete, dont use it, use getPpModeByNameAndQuality() instead */ |
9f3328bc | 116 | int getPpModeForQuality(int quality); |
e939e1c3 | 117 | |
117e45b0 | 118 | // name is the stuff after "-pp" on the command line |
096172d4 | 119 | struct PPMode getPPModeByNameAndQuality(char *name, int quality); |
911879d1 | 120 | |
45b4f285 MN |
121 | int readPPOpt(void *conf, char *arg); |
122 | ||
3057fa66 | 123 | #endif |