-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSimplexNoise.h
83 lines (80 loc) · 3.3 KB
/
SimplexNoise.h
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
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
/**
* @file SimplexNoise.h
* @brief A Perlin Simplex Noise C++ Implementation (1D, 2D, 3D).
*
* Copyright (c) 2014-2018 Sebastien Rombauts ([email protected])
*
* Distributed under the MIT License (MIT) (See accompanying file LICENSE.txt
* or copy at http://opensource.org/licenses/MIT)
*/
#pragma once
#include <cstddef> // size_t
#include <random>
#include <functional>
#include <iostream>
#include <cmath>
#include <vector>
#define PI 3.14159265
//using namespace std;
/**
* @brief A Perlin Simplex Noise C++ Implementation (1D, 2D, 3D, 4D).
*/
class SimplexNoise {
public:
// 1D Perlin simplex noise
static float noise(float x);
// 2D Perlin simplex noise
static float noise(float x, float y);
// 3D Perlin simplex noise
static float noise(float x, float y, float z);
static float noise(float x, float y, float z, float w);
// Fractal/Fractional Brownian Motion (fBm) noise summation
float fractal(size_t octaves, float x) const;
float fractal(size_t octaves, float x, float y) const;
float fractal(size_t octaves, float x, float y, float z) const;
float TileableSimplex(float x, float y) {
double c = 2, a = 1; // torus parameters (controlling size)
double xt = (c + a * cos(2 * PI * y)) * cos(2 * PI * x);
double yt = (c + a * cos(2 * PI * y)) * sin(2 * PI * x);
double zt = a * sin(2 * PI * y);
double val = noise(xt, yt, zt);
return val;
}
float TileableSimplexS(float x, float y) {
double c = 2, a = 1; // torus parameters (controlling size)
double xt = c + a * cos(2 * PI * x);// +0.5;
double yt = c + a * sin(2 * PI * x);// +1;// +101.5;
double zt = a * 2 * PI * y;// +101.5;
double val = noise(xt, yt, zt);
return val;
}
float Simplex(float x, float y) {
double val = noise(x, y);
return val;
}
/**
* Constructor of to initialize a fractal noise summation
*
* @param[in] frequency Frequency ("width") of the first octave of noise (default to 1.0)
* @param[in] amplitude Amplitude ("height") of the first octave of noise (default to 1.0)
* @param[in] lacunarity Lacunarity specifies the frequency multiplier between successive octaves (default to 2.0).
* @param[in] persistence Persistence is the loss of amplitude between successive octaves (usually 1/lacunarity)
*/
explicit SimplexNoise(float frequency = 1.0f,
float amplitude = 1.0f,
float lacunarity = 2.0f,
float persistence = 0.5f) :
mFrequency(frequency),
mAmplitude(amplitude),
mLacunarity(lacunarity),
mPersistence(persistence) {
}
std::vector< std::vector<int>>* getNoise(int row, int columns, int edgeOptimization);
private:
// Parameters of Fractional Brownian Motion (fBm) : sum of N "octaves" of noise
float mFrequency; ///< Frequency ("width") of the first octave of noise (default to 1.0)
float mAmplitude; ///< Amplitude ("height") of the first octave of noise (default to 1.0)
float mLacunarity; ///< Lacunarity specifies the frequency multiplier between successive octaves (default to 2.0).
float mPersistence; ///< Persistence is the loss of amplitude between successive octaves (usually 1/lacunarity)
std::vector< std::vector<int>>* result;
};