blob: dd9672a256d01a622e2f8d49b969d5e4910881ae (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
|
/*
* This file is part of mpv.
*
* This file can be distributed under the 3-clause license ("New BSD License").
*
* You can alternatively redistribute the non-Glumpy parts of this file and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*/
#ifndef MPLAYER_FILTER_KERNELS_H
#define MPLAYER_FILTER_KERNELS_H
#include <stdbool.h>
struct filter_window {
const char *name;
double radius; // Preferred radius, should only be changed if resizable
double (*weight)(struct filter_window *k, double x);
bool resizable; // Filter supports any given radius
double params[2]; // User-defined custom filter parameters. Not used by
// all filters
double blur; // Blur coefficient (sharpens or widens the filter)
double taper; // Taper coefficient (flattens the filter's center)
};
struct filter_kernel {
struct filter_window f; // the kernel itself
struct filter_window w; // window storage
double clamp; // clamping factor, affects negative weights
double value_cutoff; // discard all contributions below this value (polar)
// Constant values
const char *window; // default window
bool polar; // whether or not the filter uses polar coordinates
// The following values are set by mp_init_filter() at runtime.
int size; // number of coefficients (may depend on radius)
double filter_scale; // Factor to convert the mathematical filter
// function radius to the possibly wider
// (in the case of downsampling) filter sample
// radius.
double radius_cutoff; // the true radius at which we can cut off the filter
};
extern const struct filter_window mp_filter_windows[];
extern const struct filter_kernel mp_filter_kernels[];
const struct filter_window *mp_find_filter_window(const char *name);
const struct filter_kernel *mp_find_filter_kernel(const char *name);
bool mp_init_filter(struct filter_kernel *filter, const int *sizes,
double scale);
void mp_compute_lut(struct filter_kernel *filter, int count, int stride,
float *out_array);
#endif /* MPLAYER_FILTER_KERNELS_H */
|