merged an old head into main branch
[oweals/minetest.git] / src / noise.h
1 /*
2 Minetest-c55
3 Copyright (C) 2010-2011 celeron55, Perttu Ahola <celeron55@gmail.com>
4
5 This program is free software; you can redistribute it and/or modify
6 it under the terms of the GNU General Public License as published by
7 the Free Software Foundation; either version 2 of the License, or
8 (at your option) any later version.
9
10 This program is distributed in the hope that it will be useful,
11 but WITHOUT ANY WARRANTY; without even the implied warranty of
12 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13 GNU General Public License for more details.
14
15 You should have received a copy of the GNU General Public License along
16 with this program; if not, write to the Free Software Foundation, Inc.,
17 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18 */
19
20 #ifndef NOISE_HEADER
21 #define NOISE_HEADER
22
23 double easeCurve(double t);
24  
25 // Return value: -1 ... 1
26 double noise2d(int x, int y, int seed);
27 double noise3d(int x, int y, int z, int seed);
28
29 double noise2d_gradient(double x, double y, int seed);
30 double noise3d_gradient(double x, double y, double z, int seed);
31
32 double noise2d_perlin(double x, double y, int seed,
33                 int octaves, double persistence);
34
35 double noise2d_perlin_abs(double x, double y, int seed,
36                 int octaves, double persistence);
37
38 double noise3d_perlin(double x, double y, double z, int seed,
39                 int octaves, double persistence);
40
41 double noise3d_perlin_abs(double x, double y, double z, int seed,
42                 int octaves, double persistence);
43
44 class NoiseBuffer
45 {
46 public:
47         NoiseBuffer();
48         ~NoiseBuffer();
49         
50         void clear();
51         void create(int seed, int octaves, double persistence,
52                         double pos_scale,
53                         double first_x, double first_y, double first_z,
54                         double last_x, double last_y, double last_z,
55                         double samplelength_x, double samplelength_y, double samplelength_z);
56
57         void intSet(int x, int y, int z, double d);
58         double intGet(int x, int y, int z);
59         double get(double x, double y, double z);
60
61 private:
62         double *m_data;
63         double m_start_x, m_start_y, m_start_z;
64         double m_samplelength_x, m_samplelength_y, m_samplelength_z;
65         int m_size_x, m_size_y, m_size_z;
66 };
67
68 #endif
69