filters: Make the linear covolutions general.
[gfxprim.git] / libs / filters / GP_Cubic.h
blob5d3c0e6a057b1818e7d4cfc5ad50387daf6dad17
1 /*****************************************************************************
2 * This file is part of gfxprim library. *
3 * *
4 * Gfxprim is free software; you can redistribute it and/or *
5 * modify it under the terms of the GNU Lesser General Public *
6 * License as published by the Free Software Foundation; either *
7 * version 2.1 of the License, or (at your option) any later version. *
8 * *
9 * Gfxprim 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 GNU *
12 * Lesser General Public License for more details. *
13 * *
14 * You should have received a copy of the GNU Lesser General Public *
15 * License along with gfxprim; if not, write to the Free Software *
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, *
17 * Boston, MA 02110-1301 USA *
18 * *
19 * Copyright (C) 2009-2012 Cyril Hrubis <metan@ucw.cz> *
20 * *
21 *****************************************************************************/
25 This header contains cubic resampling function aproximation.
29 #ifndef FILTERS_GP_CUBIC_H
30 #define FILTERS_GP_CUBIC_H
32 #define Ap 0.5
34 static inline float cubic_float(float x)
36 if (x < 0)
37 x = -x;
39 if (x < 1)
40 return (2 - Ap)*x*x*x + (Ap - 3)*x*x + 1;
42 if (x < 2)
43 return -Ap*x*x*x + 5*Ap*x*x - 8*Ap*x + 4*Ap;
45 return 0;
48 #include <stdint.h>
50 /* Defined in GP_Cubic.gen.c */
51 extern int16_t GP_CubicTable[];
54 * Fixed point version of above.
56 * The input and output are expected in 24.8 fixed point format
58 static inline int cubic_int(int x)
60 if (x < 0)
61 x = -x;
63 if (x >= 2048)
64 return 0;
66 return GP_CubicTable[x];
69 #endif /* FILTERS_GP_CUBIC_H */