FFmpeg
All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
vf_eq.h
Go to the documentation of this file.
1 /*
2  * Original MPlayer filters by Richard Felker, Hampa Hug, Daniel Moreno,
3  * and Michael Niedermeyer.
4  *
5  * Copyright (c) 2014 James Darnley <james.darnley@gmail.com>
6  * Copyright (c) 2015 Arwa Arif <arwaarif1994@gmail.com>
7  *
8  * This file is part of FFmpeg.
9  *
10  * FFmpeg is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation; either version 2 of the License, or
13  * (at your option) any later version.
14  *
15  * FFmpeg is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  * GNU General Public License for more details.
19  *
20  * You should have received a copy of the GNU General Public License along
21  * with FFmpeg; if not, write to the Free Software Foundation, Inc.,
22  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
23  */
24 
25 #ifndef AVFILTER_EQ_H
26 #define AVFILTER_EQ_H
27 
28 #include "avfilter.h"
29 #include "libavutil/eval.h"
30 
31 static const char *const var_names[] = {
32  "n", // frame count
33  "r", // frame rate
34  "t", // timestamp expressed in seconds
35  NULL
36 };
37 
38 enum var_name {
43 };
44 
45 typedef struct EQParameters {
46  void (*adjust)(struct EQParameters *eq, uint8_t *dst, int dst_stride,
47  const uint8_t *src, int src_stride, int w, int h);
48 
49  uint8_t lut[256];
50 
52  int lut_clean;
53 
54 } EQParameters;
55 
56 typedef struct EQContext {
57  const AVClass *class;
58 
60 
63  double contrast;
64 
67  double brightness;
68 
71  double saturation;
72 
73  char *gamma_expr;
75  double gamma;
76 
79  double gamma_weight;
80 
81  char *gamma_r_expr;
83  double gamma_r;
84 
85  char *gamma_g_expr;
87  double gamma_g;
88 
89  char *gamma_b_expr;
91  double gamma_b;
92 
93  double var_values[VAR_NB];
94 
95  void (*process)(struct EQParameters *par, uint8_t *dst, int dst_stride,
96  const uint8_t *src, int src_stride, int w, int h);
97 
99 } EQContext;
100 
101 static void process_c(EQParameters *param, uint8_t *dst, int dst_stride,
102  const uint8_t *src, int src_stride, int w, int h)
103 {
104  int contrast = (int) (param->contrast * 256 * 16);
105  int brightness = ((int) (100.0 * param->brightness + 100.0) * 511) / 200 - 128 - contrast / 32;
106 
107  for (int y = 0; y < h; y++) {
108  for (int x = 0; x < w; x++) {
109  int pel = ((src[y * src_stride + x] * contrast) >> 12) + brightness;
110 
111  if (pel & ~255)
112  pel = (-pel) >> 31;
113 
114  dst[y * dst_stride + x] = pel;
115  }
116  }
117 }
118 
120 
122 {
123  eq->process = process_c;
124 #if ARCH_X86
126 #endif
127 }
128 
129 #endif /* AVFILTER_EQ_H */
EQParameters::gamma_weight
double gamma_weight
Definition: vf_eq.h:51
EQContext::gamma_expr
char * gamma_expr
Definition: vf_eq.h:73
EQParameters::gamma
double gamma
Definition: vf_eq.h:51
var_name
var_name
Definition: noise.c:47
EQContext::gamma_pexpr
AVExpr * gamma_pexpr
Definition: vf_eq.h:74
av_unused
#define av_unused
Definition: attributes.h:131
w
uint8_t w
Definition: llviddspenc.c:38
EQContext::EvalMode
EvalMode
Definition: vf_eq.h:98
EQContext::gamma_weight
double gamma_weight
Definition: vf_eq.h:79
EQContext::param
EQParameters param[3]
Definition: vf_eq.h:59
ff_eq_init
static av_unused void ff_eq_init(EQContext *eq)
Definition: vf_eq.h:121
EQContext::brightness_expr
char * brightness_expr
Definition: vf_eq.h:65
eq
#define eq(A, B)
Definition: vf_xbr.c:92
VAR_NB
@ VAR_NB
Definition: vf_eq.h:42
VAR_R
@ VAR_R
Definition: vf_eq.h:40
EQContext::saturation_pexpr
AVExpr * saturation_pexpr
Definition: vf_eq.h:70
EQParameters
Definition: vf_eq.h:45
AVExpr
Definition: eval.c:158
EQContext::gamma_g_expr
char * gamma_g_expr
Definition: vf_eq.h:85
AVClass
Describe the class of an AVClass context structure.
Definition: log.h:75
EQContext::brightness
double brightness
Definition: vf_eq.h:67
EQContext::saturation
double saturation
Definition: vf_eq.h:71
NULL
#define NULL
Definition: coverity.c:32
ff_eq_init_x86
void ff_eq_init_x86(EQContext *eq)
Definition: vf_eq_init.c:47
EQContext::gamma_weight_expr
char * gamma_weight_expr
Definition: vf_eq.h:77
EQContext::gamma_weight_pexpr
AVExpr * gamma_weight_pexpr
Definition: vf_eq.h:78
EQContext::eval_mode
enum EQContext::EvalMode eval_mode
var_names
static const char *const var_names[]
Definition: vf_eq.h:31
VAR_N
@ VAR_N
Definition: vf_eq.h:39
EQContext::gamma_r
double gamma_r
Definition: vf_eq.h:83
eval.h
dst
uint8_t ptrdiff_t const uint8_t ptrdiff_t int intptr_t intptr_t int int16_t * dst
Definition: dsp.h:83
EQContext
Definition: vf_eq.h:56
EQParameters::contrast
double contrast
Definition: vf_eq.h:51
EQContext::saturation_expr
char * saturation_expr
Definition: vf_eq.h:69
EQContext::contrast
double contrast
Definition: vf_eq.h:63
EQContext::gamma_b_expr
char * gamma_b_expr
Definition: vf_eq.h:89
EQContext::contrast_pexpr
AVExpr * contrast_pexpr
Definition: vf_eq.h:62
VAR_T
@ VAR_T
Definition: vf_eq.h:41
EQParameters::adjust
void(* adjust)(struct EQParameters *eq, uint8_t *dst, int dst_stride, const uint8_t *src, int src_stride, int w, int h)
Definition: vf_eq.h:46
EQContext::EVAL_MODE_NB
@ EVAL_MODE_NB
Definition: vf_eq.h:98
EQContext::gamma_b
double gamma_b
Definition: vf_eq.h:91
EQParameters::brightness
double brightness
Definition: vf_eq.h:51
EQParameters::lut
uint8_t lut[256]
Definition: vf_eq.h:49
avfilter.h
EQContext::var_values
double var_values[VAR_NB]
Definition: vf_eq.h:93
EQContext::contrast_expr
char * contrast_expr
Definition: vf_eq.h:61
EQContext::brightness_pexpr
AVExpr * brightness_pexpr
Definition: vf_eq.h:66
EQContext::gamma_g
double gamma_g
Definition: vf_eq.h:87
EQContext::EVAL_MODE_FRAME
@ EVAL_MODE_FRAME
Definition: vf_eq.h:98
EQParameters::lut_clean
int lut_clean
Definition: vf_eq.h:52
process_c
static void process_c(EQParameters *param, uint8_t *dst, int dst_stride, const uint8_t *src, int src_stride, int w, int h)
Definition: vf_eq.h:101
EQContext::EVAL_MODE_INIT
@ EVAL_MODE_INIT
Definition: vf_eq.h:98
EQContext::gamma_g_pexpr
AVExpr * gamma_g_pexpr
Definition: vf_eq.h:86
EQContext::gamma_r_expr
char * gamma_r_expr
Definition: vf_eq.h:81
EQContext::gamma
double gamma
Definition: vf_eq.h:75
EQContext::gamma_b_pexpr
AVExpr * gamma_b_pexpr
Definition: vf_eq.h:90
EQContext::process
void(* process)(struct EQParameters *par, uint8_t *dst, int dst_stride, const uint8_t *src, int src_stride, int w, int h)
Definition: vf_eq.h:95
h
h
Definition: vp9dsp_template.c:2070
EQContext::gamma_r_pexpr
AVExpr * gamma_r_pexpr
Definition: vf_eq.h:82
src
#define src
Definition: vp8dsp.c:248