/PerlinNoise

Simple codes to generate Perlin Noise

Primary LanguagePythonMIT LicenseMIT

Perlin Noise

This note is about Perlin noise and accelerating Python codes using C dynamic library. My knowledge of Perlin noise mostly comes from pvigier's GitHub site, Adrian's blog, Wikipedia, and this marvelous post. Anyone who wants to learn Perlin noise is strongly recommended to take a look at those references. There are several ways to accelerate Python codes. I learn one way from this post. Some explanations about the codes are in my Chinese post.

My original motivation is to study how to generate a smooth noise, not a white noise. Perlin noise is definitely a good choice. I like to use Python. However, Python does not have the speed to do this in a fast way. If multiples of for loops are unavoided, the performance of Python is horrible! One of the options to accelerate Python is taking the advantage of numpy, if one has the superior numpy skill like Pvigier did in this post. Building such skills require fluency about numpy. An alternative way is accerlateing Python by using C dynamic library.

To build the C dynamic library, use the following codes in the terminal.

$ mkdir build
$ cd build
$ cmake ..
$ make
$ mv ./lib/libperlinNoise.dylib ../python # Move library to the python folder.
$ cd ../python
$ python cppnoise.py # Use the library as an example in the cppnoise.py code

It generates a dynamic library libperlinNoise.dylib in the folder ./build/lib. To illustrate the usage of the dynamic library, just move it to the python folder and execute either cppnoise.py or caltime.py.

Speed Comparison

To see the power of C code, let us compare the speed between the numpy and C code.

$ python caltime.py
2D noise, numpy time consuming:  0.08261830806732177
3D noise, numpy time consuming:  4.525643992424011
2D noise, cpp time consuming:  0.007184123992919922
3D noise, cpp time consuming:  0.1645211935043335

Let me remind that there is no single for loop in Pvigier's numpy code. Numpy's vectorized features are fully taken advantaged of. Needlessly to say, C code still can do this more than 10 times faster than numpy!

Images

noise2d