gimpmath.h 2.95 KB
Newer Older
1
/* LIBGIMP - The GIMP Library
2 3 4
 * Copyright (C) 1995-1997 Peter Mattis and Spencer Kimball
 *
 * gimpmath.h
Tor Lillqvist's avatar
Tor Lillqvist committed
5
 *
6
 * This library is free software: you can redistribute it and/or
Marc Lehmann's avatar
Marc Lehmann committed
7
 * modify it under the terms of the GNU Lesser General Public
Tor Lillqvist's avatar
Tor Lillqvist committed
8
 * License as published by the Free Software Foundation; either
9
 * version 3 of the License, or (at your option) any later version.
Tor Lillqvist's avatar
Tor Lillqvist committed
10 11 12 13
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14
 * Lesser General Public License for more details.
Tor Lillqvist's avatar
Tor Lillqvist committed
15
 *
Marc Lehmann's avatar
Marc Lehmann committed
16
 * You should have received a copy of the GNU Lesser General Public
17 18
 * License along with this library.  If not, see
 * <http://www.gnu.org/licenses/>.
Tor Lillqvist's avatar
Tor Lillqvist committed
19
 */
20

21 22
#ifndef __GIMP_MATH_H__
#define __GIMP_MATH_H__
Tor Lillqvist's avatar
Tor Lillqvist committed
23

24

Tor Lillqvist's avatar
Tor Lillqvist committed
25
#include <math.h>
David Neary's avatar
David Neary committed
26 27 28 29

#ifdef HAVE_IEEEFP_H
#include <ieeefp.h>
#endif
Tor Lillqvist's avatar
Tor Lillqvist committed
30

31 32 33 34
#ifdef G_OS_WIN32
#include <float.h>
#endif

35 36
#define __GIMP_MATH_H_INSIDE__

37 38 39
#include <libgimpmath/gimpmathtypes.h>

#include <libgimpmath/gimpmatrix.h>
40
#include <libgimpmath/gimpmd5.h>
41 42
#include <libgimpmath/gimpvector.h>

43 44 45
#undef __GIMP_MATH_H_INSIDE__


46
G_BEGIN_DECLS
47

48 49 50 51 52

/**
 * SECTION: gimpmath
 * @title: GimpMath
 * @short_description: Mathematical definitions and macros.
Tor Lillqvist's avatar
Tor Lillqvist committed
53
 *
54 55
 * Mathematical definitions and macros for use both by the GIMP
 * application and plug-ins. These macros should be used rather than
56
 * the ones from &lt;math.h&gt; for enhanced portability.
57 58
 **/

Tor Lillqvist's avatar
Tor Lillqvist committed
59

60 61 62 63 64 65 66
/**
 * RINT:
 * @x: the value to be rounded
 *
 * This macro rounds its argument @x to an integer value in floating
 * point format. Use RINT() instead of rint().
 **/
Tor Lillqvist's avatar
Tor Lillqvist committed
67 68 69 70 71 72
#ifdef HAVE_RINT
#define RINT(x) rint(x)
#else
#define RINT(x) floor ((x) + 0.5)
#endif

73 74 75 76
/**
 * ROUND:
 * @x: the value to be rounded.
 *
77
 * This macro rounds its positive argument @x to the nearest integer.
78
 **/
Tor Lillqvist's avatar
Tor Lillqvist committed
79 80
#define ROUND(x) ((int) ((x) + 0.5))

81 82 83 84 85 86 87 88
/**
 * SIGNED_ROUND:
 * @x: the value to be rounded.
 *
 * This macro rounds its argument @x to the nearest integer.
 **/
#define SIGNED_ROUND(x) ((int) ((((x) < 0) ? (x) - 0.5 : (x) + 0.5)))

89 90 91 92 93 94
/**
 * SQR:
 * @x: the value to be squared.
 *
 * This macro squares its argument @x.
 **/
Tor Lillqvist's avatar
Tor Lillqvist committed
95 96
#define SQR(x) ((x) * (x))

97 98 99 100 101 102
/**
 * MAX255:
 * @a: the value to be limited.
 *
 * This macro limits it argument @a, an (0-511) int, to 255.
 **/
Tor Lillqvist's avatar
Tor Lillqvist committed
103 104
#define MAX255(a)  ((a) | (((a) & 256) - (((a) & 256) >> 8)))

105 106 107 108 109 110 111
/**
 * CLAMP0255:
 * @a: the value to be clamped.
 *
 * This macro clamps its argument @a, an int32-range int, between 0
 * and 255 inclusive.
 **/
Tor Lillqvist's avatar
Tor Lillqvist committed
112 113
#define CLAMP0255(a)  CLAMP(a,0,255)

114 115 116 117 118 119
/**
 * gimp_deg_to_rad:
 * @angle: the angle to be converted.
 *
 * This macro converts its argument @angle from degree to radian.
 **/
120
#define gimp_deg_to_rad(angle) ((angle) * (2.0 * G_PI) / 360.0)
121 122 123 124 125 126 127

/**
 * gimp_rad_to_deg:
 * @angle: the angle to be converted.
 *
 * This macro converts its argument @angle from radian to degree.
 **/
128 129
#define gimp_rad_to_deg(angle) ((angle) * 360.0 / (2.0 * G_PI))

130 131

G_END_DECLS
Tor Lillqvist's avatar
Tor Lillqvist committed
132

133
#endif /* __GIMP_MATH_H__ */