2-D PSRDnoise tutorial

Page 1  2  3  4  5  6  7  8  9  10  11  12  13  14  15  16  17  18  19  20  21

Frame rate: FPS

17: Warping a fractal sum

This shader is summing four noise terms, with each successive term being warped by the gradient of previous terms, with successively smaller impact on the total warping from each term as the sum progresses. Like before, the amount of warping increases towards the bottom of the image.

Now, we can clearly see the "billowing" and "swirling" effects that Perlin and Neyret talked about in their article. Towards the bottom of this image, the look and feel of the pattern is clearly that of billowing clouds or smoke.

This is still a 2-D pattern, created with a very reasonable number of noise values (four). Adding more terms increases the detail, but because of the texture warping, there is already some fine detail in the "crinkles" at the most strongly warped part of the pattern. Ordinary fractal sums of noise, like the rather blurry pattern at the top of the image, require more terms to generate enough detail.

Let's generate the nice pattern at the bottom for the entire canvas, and add just one more term for some more fine-grain detail!

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
varying vec2 st;
uniform float time;
 
void main(void) {
 
    const float nscale = 4.0;
    vec2 v = nscale * (st-0.5);
    const vec2 p = vec2(0.0, 0.0);
    float alpha = time;
    vec2 g, gsum;
 
    float warp = 0.13*clamp(1.1-st.t*1.2, 0.0, 1.0);
 
    float n = 0.5;
    n += 0.4 * psrdnoise(v, p, alpha, g);
    gsum = g;
    vec2 warped_v = v*2.0 + warp*gsum;
    n += 0.2 * psrdnoise(warped_v, p, alpha*2.0, g);
    gsum += 0.5*g;
    warped_v = v*4.0 + warp*gsum;
    n += 0.1 * psrdnoise(warped_v, p, alpha*4.0, g);
    gsum += 0.25*g;
    warped_v = v*8.0 + warp*gsum;
    n += 0.05 * psrdnoise(warped_v, p, alpha*8.0, g);
 
    vec3 noisecolor = vec3(n);
     
    gl_FragColor = vec4(noisecolor, 1.0);
}