annotate postproc/postprocess_internal.h @ 8763:19e96e60a3d0

Speed optimizations (runs twise as fast) and bugfix (wrong cutoff frequency buffer over run noise and garbeled output when wrong input format)
author anders
date Sat, 04 Jan 2003 06:19:25 +0000
parents 11888c95481b
children e547ce712577
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
8038
fe30880576dc cleanup
michael
parents:
diff changeset
1 /*
fe30880576dc cleanup
michael
parents:
diff changeset
2 Copyright (C) 2001-2002 Michael Niedermayer (michaelni@gmx.at)
fe30880576dc cleanup
michael
parents:
diff changeset
3
fe30880576dc cleanup
michael
parents:
diff changeset
4 This program is free software; you can redistribute it and/or modify
fe30880576dc cleanup
michael
parents:
diff changeset
5 it under the terms of the GNU General Public License as published by
fe30880576dc cleanup
michael
parents:
diff changeset
6 the Free Software Foundation; either version 2 of the License, or
fe30880576dc cleanup
michael
parents:
diff changeset
7 (at your option) any later version.
fe30880576dc cleanup
michael
parents:
diff changeset
8
fe30880576dc cleanup
michael
parents:
diff changeset
9 This program is distributed in the hope that it will be useful,
fe30880576dc cleanup
michael
parents:
diff changeset
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
fe30880576dc cleanup
michael
parents:
diff changeset
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
fe30880576dc cleanup
michael
parents:
diff changeset
12 GNU General Public License for more details.
fe30880576dc cleanup
michael
parents:
diff changeset
13
fe30880576dc cleanup
michael
parents:
diff changeset
14 You should have received a copy of the GNU General Public License
fe30880576dc cleanup
michael
parents:
diff changeset
15 along with this program; if not, write to the Free Software
fe30880576dc cleanup
michael
parents:
diff changeset
16 Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
fe30880576dc cleanup
michael
parents:
diff changeset
17 */
fe30880576dc cleanup
michael
parents:
diff changeset
18
fe30880576dc cleanup
michael
parents:
diff changeset
19 #define V_DEBLOCK 0x01
fe30880576dc cleanup
michael
parents:
diff changeset
20 #define H_DEBLOCK 0x02
fe30880576dc cleanup
michael
parents:
diff changeset
21 #define DERING 0x04
fe30880576dc cleanup
michael
parents:
diff changeset
22 #define LEVEL_FIX 0x08 /* Brightness & Contrast */
fe30880576dc cleanup
michael
parents:
diff changeset
23
fe30880576dc cleanup
michael
parents:
diff changeset
24 #define LUM_V_DEBLOCK V_DEBLOCK // 1
fe30880576dc cleanup
michael
parents:
diff changeset
25 #define LUM_H_DEBLOCK H_DEBLOCK // 2
fe30880576dc cleanup
michael
parents:
diff changeset
26 #define CHROM_V_DEBLOCK (V_DEBLOCK<<4) // 16
fe30880576dc cleanup
michael
parents:
diff changeset
27 #define CHROM_H_DEBLOCK (H_DEBLOCK<<4) // 32
fe30880576dc cleanup
michael
parents:
diff changeset
28 #define LUM_DERING DERING // 4
fe30880576dc cleanup
michael
parents:
diff changeset
29 #define CHROM_DERING (DERING<<4) // 64
fe30880576dc cleanup
michael
parents:
diff changeset
30 #define LUM_LEVEL_FIX LEVEL_FIX // 8
fe30880576dc cleanup
michael
parents:
diff changeset
31 #define CHROM_LEVEL_FIX (LEVEL_FIX<<4) // 128 (not implemented yet)
fe30880576dc cleanup
michael
parents:
diff changeset
32
fe30880576dc cleanup
michael
parents:
diff changeset
33 // Experimental vertical filters
fe30880576dc cleanup
michael
parents:
diff changeset
34 #define V_X1_FILTER 0x0200 // 512
fe30880576dc cleanup
michael
parents:
diff changeset
35
fe30880576dc cleanup
michael
parents:
diff changeset
36 // Experimental horizontal filters
fe30880576dc cleanup
michael
parents:
diff changeset
37 #define H_X1_FILTER 0x2000 // 8192
fe30880576dc cleanup
michael
parents:
diff changeset
38
fe30880576dc cleanup
michael
parents:
diff changeset
39 // select between full y range (255-0) or standart one (234-16)
fe30880576dc cleanup
michael
parents:
diff changeset
40 #define FULL_Y_RANGE 0x8000 // 32768
fe30880576dc cleanup
michael
parents:
diff changeset
41
fe30880576dc cleanup
michael
parents:
diff changeset
42 //Deinterlacing Filters
fe30880576dc cleanup
michael
parents:
diff changeset
43 #define LINEAR_IPOL_DEINT_FILTER 0x10000 // 65536
fe30880576dc cleanup
michael
parents:
diff changeset
44 #define LINEAR_BLEND_DEINT_FILTER 0x20000 // 131072
fe30880576dc cleanup
michael
parents:
diff changeset
45 #define CUBIC_BLEND_DEINT_FILTER 0x8000 // (not implemented yet)
fe30880576dc cleanup
michael
parents:
diff changeset
46 #define CUBIC_IPOL_DEINT_FILTER 0x40000 // 262144
fe30880576dc cleanup
michael
parents:
diff changeset
47 #define MEDIAN_DEINT_FILTER 0x80000 // 524288
fe30880576dc cleanup
michael
parents:
diff changeset
48 #define FFMPEG_DEINT_FILTER 0x400000
fe30880576dc cleanup
michael
parents:
diff changeset
49
fe30880576dc cleanup
michael
parents:
diff changeset
50 #define TEMP_NOISE_FILTER 0x100000
fe30880576dc cleanup
michael
parents:
diff changeset
51 #define FORCE_QUANT 0x200000
fe30880576dc cleanup
michael
parents:
diff changeset
52
fe30880576dc cleanup
michael
parents:
diff changeset
53 //use if u want a faster postprocessing code
fe30880576dc cleanup
michael
parents:
diff changeset
54 //cant differentiate between chroma & luma filters (both on or both off)
fe30880576dc cleanup
michael
parents:
diff changeset
55 //obviosly the -pp option at the commandline has no effect except turning the here selected
fe30880576dc cleanup
michael
parents:
diff changeset
56 //filters on
fe30880576dc cleanup
michael
parents:
diff changeset
57 //#define COMPILE_TIME_MODE 0x77
fe30880576dc cleanup
michael
parents:
diff changeset
58
fe30880576dc cleanup
michael
parents:
diff changeset
59 struct PPFilter{
fe30880576dc cleanup
michael
parents:
diff changeset
60 char *shortName;
fe30880576dc cleanup
michael
parents:
diff changeset
61 char *longName;
fe30880576dc cleanup
michael
parents:
diff changeset
62 int chromDefault; // is chrominance filtering on by default if this filter is manually activated
fe30880576dc cleanup
michael
parents:
diff changeset
63 int minLumQuality; // minimum quality to turn luminance filtering on
fe30880576dc cleanup
michael
parents:
diff changeset
64 int minChromQuality; // minimum quality to turn chrominance filtering on
fe30880576dc cleanup
michael
parents:
diff changeset
65 int mask; // Bitmask to turn this filter on
fe30880576dc cleanup
michael
parents:
diff changeset
66 };
fe30880576dc cleanup
michael
parents:
diff changeset
67
fe30880576dc cleanup
michael
parents:
diff changeset
68 typedef struct PPMode{
fe30880576dc cleanup
michael
parents:
diff changeset
69 int lumMode; // acivates filters for luminance
fe30880576dc cleanup
michael
parents:
diff changeset
70 int chromMode; // acivates filters for chrominance
fe30880576dc cleanup
michael
parents:
diff changeset
71 int error; // non zero on error
fe30880576dc cleanup
michael
parents:
diff changeset
72
fe30880576dc cleanup
michael
parents:
diff changeset
73 int minAllowedY; // for brigtness correction
fe30880576dc cleanup
michael
parents:
diff changeset
74 int maxAllowedY; // for brihtness correction
fe30880576dc cleanup
michael
parents:
diff changeset
75 float maxClippedThreshold; // amount of "black" u r willing to loose to get a brightness corrected picture
fe30880576dc cleanup
michael
parents:
diff changeset
76
fe30880576dc cleanup
michael
parents:
diff changeset
77 int maxTmpNoise[3]; // for Temporal Noise Reducing filter (Maximal sum of abs differences)
fe30880576dc cleanup
michael
parents:
diff changeset
78
fe30880576dc cleanup
michael
parents:
diff changeset
79 int baseDcDiff;
fe30880576dc cleanup
michael
parents:
diff changeset
80 int flatnessThreshold;
fe30880576dc cleanup
michael
parents:
diff changeset
81
fe30880576dc cleanup
michael
parents:
diff changeset
82 int forcedQuant; // quantizer if FORCE_QUANT is used
fe30880576dc cleanup
michael
parents:
diff changeset
83 } PPMode;
fe30880576dc cleanup
michael
parents:
diff changeset
84
fe30880576dc cleanup
michael
parents:
diff changeset
85 typedef struct PPContext{
fe30880576dc cleanup
michael
parents:
diff changeset
86 uint8_t *tempBlocks; //used for the horizontal code
fe30880576dc cleanup
michael
parents:
diff changeset
87
fe30880576dc cleanup
michael
parents:
diff changeset
88 /* we need 64bit here otherwise weŽll going to have a problem
fe30880576dc cleanup
michael
parents:
diff changeset
89 after watching a black picture for 5 hours*/
fe30880576dc cleanup
michael
parents:
diff changeset
90 uint64_t *yHistogram;
fe30880576dc cleanup
michael
parents:
diff changeset
91
fe30880576dc cleanup
michael
parents:
diff changeset
92 uint64_t __attribute__((aligned(8))) packedYOffset;
fe30880576dc cleanup
michael
parents:
diff changeset
93 uint64_t __attribute__((aligned(8))) packedYScale;
fe30880576dc cleanup
michael
parents:
diff changeset
94
fe30880576dc cleanup
michael
parents:
diff changeset
95 /* Temporal noise reducing buffers */
fe30880576dc cleanup
michael
parents:
diff changeset
96 uint8_t *tempBlured[3];
fe30880576dc cleanup
michael
parents:
diff changeset
97 int32_t *tempBluredPast[3];
fe30880576dc cleanup
michael
parents:
diff changeset
98
fe30880576dc cleanup
michael
parents:
diff changeset
99 /* Temporary buffers for handling the last row(s) */
fe30880576dc cleanup
michael
parents:
diff changeset
100 uint8_t *tempDst;
fe30880576dc cleanup
michael
parents:
diff changeset
101 uint8_t *tempSrc;
fe30880576dc cleanup
michael
parents:
diff changeset
102
fe30880576dc cleanup
michael
parents:
diff changeset
103 uint8_t *deintTemp;
fe30880576dc cleanup
michael
parents:
diff changeset
104
fe30880576dc cleanup
michael
parents:
diff changeset
105 uint64_t __attribute__((aligned(8))) pQPb;
fe30880576dc cleanup
michael
parents:
diff changeset
106 uint64_t __attribute__((aligned(8))) pQPb2;
fe30880576dc cleanup
michael
parents:
diff changeset
107
fe30880576dc cleanup
michael
parents:
diff changeset
108 uint64_t __attribute__((aligned(8))) mmxDcOffset[32];
fe30880576dc cleanup
michael
parents:
diff changeset
109 uint64_t __attribute__((aligned(8))) mmxDcThreshold[32];
8630
11888c95481b buffer alloc cleanup / 10l
michael
parents: 8038
diff changeset
110
8038
fe30880576dc cleanup
michael
parents:
diff changeset
111 QP_STORE_T *nonBQPTable;
8630
11888c95481b buffer alloc cleanup / 10l
michael
parents: 8038
diff changeset
112 QP_STORE_T *forcedQPTable;
11888c95481b buffer alloc cleanup / 10l
michael
parents: 8038
diff changeset
113
8038
fe30880576dc cleanup
michael
parents:
diff changeset
114 int QP;
fe30880576dc cleanup
michael
parents:
diff changeset
115 int nonBQP;
fe30880576dc cleanup
michael
parents:
diff changeset
116
fe30880576dc cleanup
michael
parents:
diff changeset
117 int frameNum;
fe30880576dc cleanup
michael
parents:
diff changeset
118
fe30880576dc cleanup
michael
parents:
diff changeset
119 int cpuCaps;
8630
11888c95481b buffer alloc cleanup / 10l
michael
parents: 8038
diff changeset
120
11888c95481b buffer alloc cleanup / 10l
michael
parents: 8038
diff changeset
121 int stride; //size of some buffers (needed to realloc them if needed)
8038
fe30880576dc cleanup
michael
parents:
diff changeset
122
fe30880576dc cleanup
michael
parents:
diff changeset
123 PPMode ppMode;
fe30880576dc cleanup
michael
parents:
diff changeset
124 } PPContext;
fe30880576dc cleanup
michael
parents:
diff changeset
125