Blob Blame Raw
#pragma once

/*-------------------------------------------------------------
 iwa_noise1234.h
 Identical to a public domain code "noise1234.h" by Stefan Gustavson.
 Just changed file name for handling of files.
-------------------------------------------------------------*/
/*-- The original code starts here --*/

// Noise1234
// Author: Stefan Gustavson (stegu@itn.liu.se)
//
// This library is public domain software, released by the author
// into the public domain in February 2011. You may do anything
// you like with it. You may even remove all attributions,
// but of course I'd appreciate it if you kept my name somewhere.
//
// 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
// General Public License for more details.

/** \file
		\brief Declares the Noise1234 class for producing Perlin noise.
		\author Stefan Gustavson (stegu@itn.liu.se)
*/

/*
 * This is a clean, fast, modern and free Perlin noise class in C++.
 * Being a stand-alone class with no external dependencies, it is
 * highly reusable without source code modifications.
 *
 * Note:
 * Replacing the "float" type with "double" can actually make this run faster
 * on some platforms. A templatized version of Noise1234 could be useful.
 */

class Noise1234
{

public:
	Noise1234() {}
	~Noise1234() {}

	/** 1D, 2D, 3D and 4D float Perlin noise, SL "noise()"
 */
	static float noise(float x);
	static float noise(float x, float y);
	static float noise(float x, float y, float z);
	static float noise(float x, float y, float z, float w);

	/** 1D, 2D, 3D and 4D float Perlin periodic noise, SL "pnoise()"
 */
	static float pnoise(float x, int px);
	static float pnoise(float x, float y, int px, int py);
	static float pnoise(float x, float y, float z, int px, int py, int pz);
	static float pnoise(float x, float y, float z, float w,
						int px, int py, int pz, int pw);

private:
	static unsigned char perm[];
	static float grad(int hash, float x);
	static float grad(int hash, float x, float y);
	static float grad(int hash, float x, float y, float z);
	static float grad(int hash, float x, float y, float z, float t);
};