/r/proceduralgeneration

Photograph via snooOG

This subreddit is about everything procedurally generated (media, techniques, ...)

/r/proceduralgeneration

101,282 Subscribers

15

Spectral Valley [genart in p5js]

2 Comments
2024/09/10
09:48 UTC

6

Perlin noise with default lower frequency?

Hi. I'm making a procedural generated landscape and have ran into a problem. I'm feeding the noise function I'm using with world coordinates where 1 unit is one meter. This results in a very high frequency noise by default so I have to scale down the input coordinates a lot to get low frequency which can create accurate sized hills and mountains. This works well for the terrain geometry which have a minimal vertex spacing of 0.5 meters.

But I'm also generating textures and in the highest resolution (when closest to ground) I am dealing with sampling steps which are 0.03125 per sample point. Since I have to downscale the world coordinates by a factor of 10000 to get the frequency I require this results in floating point precision issues at those small increments. So one or more adjacent sample points can become the exact same position which in turn results in the exact same noise value. This is a problem becuase I need to efficiently calculate normals per texel for texture blending. And if I can't calculate a normal from the adjacent height values (because they are the same) it completely ruins everything.

I could of course take samples with a set minimum offset which would guarantee that all samples are different, but for performance requirments this is out of the question, I need to make use of the samples already calculated by adjacent threads in the compute shader to get anywhere near acceptable performance.

So I started to think that there must be some way to have the noise function be much lower frequency by default so I don't need to downscale the input coordinates at all and get into this precision issue. I can't use doubles either as that is massively murdering the performance on a GPU.

Unfortunately I don't really "get" how perlin noise works and my attempts to modify the function I'm using have failed spectacularly. So I was wondering if anyone knows this and how it's typically solved.

The perlin function I'm using is this one: https://github.com/BrianSharpe/Wombat/blob/master/Perlin2D_Deriv.glsl

Example of the problem I'm facing

Blending issue close up due to incorrect normals

Properly looking textures from a far

1 Comment
2024/09/10
07:03 UTC

7

How to weight procedural generation based on previous picks

The title is not worded well, sorry, but I couldn't think at anything different.

The jist of the thing is this: I want to write an NPC procedural generation routine that chooses a random number of personality traits, and in which each subsequent trait is informed by the previous ones to some degree (so that, for example, if it picks "lazy" as first choice, it doesn't picks "sporty" as the second one because it doesn't make too much sense).

I'm still learning, so this might be a very easy problem to solve, but as of now I have no idea how to tackle it without creating an angodly amount of lookup tables for each combination.

Can you help me with ideas and learning material? Thanks!

10 Comments
2024/09/08
13:31 UTC

40

pentaptych - python + gimp + imagemagick

0 Comments
2024/09/08
08:45 UTC

19

Glitchy spider

0 Comments
2024/09/08
01:04 UTC

0

Want to simulate a couple of scenes where a person is in danger or threat by another individual, how do I proceed with this in Unreal and possibly using Procedural Generation

So I have been working on a project where I need to detect a person is in danger by any physical means threatened by another individual or group of Individuals, I have some basic idea of Unreal for Game development but this simulation and procedural generation is totally new for me so any advice regarding the same will be appreciated

2 Comments
2024/09/07
18:01 UTC

37

Terrain generation using OpenSimplex and simple tectonic plate simulation(via a Voronoi diagram).

https://preview.redd.it/ds22tpu4qand1.png?width=1504&format=png&auto=webp&s=fb8147a2bf8fe9b79557ee2607a17031ac1ddb83

Seed I used while testing. Rivers where generated by picking random points above an elevation then following the slope of the elevation down, creating lakes whenever they flowed into valleys.

https://preview.redd.it/ry9sjez7qand1.png?width=1504&format=png&auto=webp&s=5c685ca6a709981da34d3c305abd9caa1ad5dc32

Tectonic plates layered on top of the terrain. They where generated using a Voronoi diagram then each plate was given a random velocity(green asterisks). Plate collisions where then determined using the plates vectors and positions. Boundary types are as follows: red, convergent; orange, divergent; and pink, transform. Convergent boundaries create mountain ranges/island chains and divergent boundaries create create rift valleys. The height of mountain ranges somewhat vary based on the intensity of the plate collisions. Please note: I am not a geologist so my understanding of how plate boundaries effect terrain is most likely incorrect.

https://preview.redd.it/76vf2x13rand1.png?width=1504&format=png&auto=webp&s=584bfd68ce529cfd90a2f39eeefc238ab7732ce8

Pure elevation map created with multiple arrays of OpenSimplex noise at different octaves added together in addition to the modifications made by the plate boundaries.

2 Comments
2024/09/07
02:27 UTC

54

Scalar Marble

Made in Blender using Geometry Nodes

3 Comments
2024/09/06
12:59 UTC

23

Procedural Planet Rendering

Space view

Another space view

Closer

Even closer

https://preview.redd.it/2kz8dq3bd5nd1.png?width=1919&format=png&auto=webp&s=da05d7ec1c2610213dc6bd605c8e691ebc0fcabf

Recently I have been working on a little opengl renderer for procedural planets, with the eventual goal of expanding to an entire universe. These are some screenshots I really enjoyed and wanted to show off. I have some videos of flight on my youtube channel: https://youtu.be/SaLLzhwu-J8?feature=shared

11 Comments
2024/09/06
08:19 UTC

12

Curvescape (genart in p5js)

0 Comments
2024/09/06
00:56 UTC

226

First try on 3D perlin noise

16 Comments
2024/09/05
20:27 UTC

0

Chat controls AI visuals, I play music

0 Comments
2024/09/04
18:12 UTC

4

QUESTION: need help identifying the kind of maths used to generate the forms seen in the YouTube video

https://www.youtube.com/watch?v=OmRL9ZBgwPQ&list=PLQBIOV-hHB3wUm_c-v2wa1pPpk-l6vBrZ&index=21

new programmer. Not very mathy

i'm sure what i'm looking for is related to fourier, lissajous, wave functions, periodic functions, dynamic functions, parametric, generate, kinetic, epicycles, chaos theory, uniformly rotating circles/compasses, maybe euler and maxwell equations....... but this is just alot of words to me in a google hole........... when i'm sure what im looking for is a simple field of maths or family of equations or algorithms or something.

really just looking for simple ways to implement the kind of forms seen in the video in a plotter like matplotlib (i'll look into p5 later) that I can add live updating of parameters to and other simple-ish things like algorithms for floatiness, parallax motion, and simple noise.

not looking for complex shaders or advanced stuff. just nice, varied geometry plots that, with parameters, can be animated to move between very ordered and mandala-esque, to random chaotic squigglies.

pointers in the right direction greatly appreciated!

4 Comments
2024/09/04
16:35 UTC

273

hunt-and-kill maze algorithm

it's satisfying for me.

16 Comments
2024/09/03
10:01 UTC

56

Generating an endless, persistent, non-Euclidean maze NOW IN 3D

5 Comments
2024/09/02
01:59 UTC

16

I'm skeptical that this is proper implementation of Wilson's algorithm

https://i.redd.it/depgpr9tv5md1.gif

It takes quite a while for the random walk to reach the first white cell, but if you are patient and watch it through to the end, the gif will eventually terminate with a completed maze.

It looks like always converging and terminating in finite time, but when i increase the maze size, the consuming time drastically increases due to its stochastic nature. how to fix it? at the first place, did i properly implement the algorithm?

I know there are many other algorithms for generating mazes other than Wilson's. But this question focuses on Wilson only.

I share my Python source code below. it's a bit dirty and not well-organized, so feel free to ask me if you are wondering the code.

def random_step(r, c, R, C):
    dir = [(0, 1), (1, 0), (0, -1), (-1, 0)]
    neighbors = []
    for dr, dc in dir:
        nr, nc = r + dr, c + dc
        if 0 <= nr < R and 0 <= nc < C:
            neighbors.append((nr, nc))
    return random.choice(neighbors)

from PIL import Image, ImageDraw

def draw_maze(maze, path, nonust, uniform_scale):
    R, C = len(maze), len(maze[0])
    img_size = (C * uniform_scale, R * uniform_scale)
    img = Image.new("RGB", img_size, "black")
    drawer = ImageDraw.Draw(img)
    for r in range(R):
        for c in range(C):
            x0, y0 = c * uniform_scale, r * uniform_scale
            x1, y1 = x0 + uniform_scale, y0 + uniform_scale
            if (r, c) not in nonust:
                drawer.rectangle([x0, y0, x1, y1], fill="white")
            elif (r, c) in path:
                drawer.rectangle([x0, y0, x1, y1], fill="gray")
            # elif maze[r][c] == (True, True, True, True):
            #     drawer.rectangle([x0, y0, x1, y1], fill="white")
            else:
                drawer.rectangle([x0, y0, x1, y1], fill="pink")
            if maze[r][c][0]:
                drawer.line([x0, y0, x1, y0], fill="brown", width=2)
            if maze[r][c][1]:
                drawer.line([x1, y0, x1, y1], fill="brown", width=2)
            if maze[r][c][2]:
                drawer.line([x0, y1, x1, y1], fill="brown", width=2)
            if maze[r][c][3]:
                drawer.line([x0, y0, x0, y1], fill="brown", width=2)
    return img

def Wilson(R, C, uniform_scale):
    maze = [[[True, True, True, True] for _ in range(C)] for _ in range(R)]
    frames = []
    nonust = {(i, j) for j in range(C) for i in range(R)}
    r0, c0 = random.randint(0, R - 1), random.randint(0, C - 1)
    nonust.discard((r0, c0))
    maze[r0][c0] = [True, True, True, True]
    while len(nonust) > 0:
        startr, startc = random.choice(list(nonust))
        path = [(startr, startc)]
        while path[-1] in nonust:
            r, c = path[-1]
            nr, nc = random_step(r, c, R, C)
            if (nr, nc) in path:
                path = path[: path.index((nr, nc)) + 1]
            else:
                path.append((nr, nc))
            frames.append(draw_maze(maze, path, nonust, uniform_scale))
        for i in range(len(path) - 1):
            r, c = path[i]
            nr, nc = path[i + 1]
            if nr == r - 1:
                maze[r][c][0] = False
                maze[nr][nc][2] = False
            elif nr == r + 1:
                maze[r][c][2] = False
                maze[nr][nc][0] = False
            elif nc == c - 1:
                maze[r][c][3] = False
                maze[nr][nc][1] = False
            elif nc == c + 1:
                maze[r][c][1] = False
                maze[nr][nc][3] = False
            nonust.discard((r, c))
            frames.append(draw_maze(maze, path, nonust, uniform_scale))
    frames[0].save(
        "Wilson.gif",
        save_all=True,
        append_images=frames[1:],
        duration=0.5,
        loop=0,
    )
6 Comments
2024/09/01
08:57 UTC

91

moody rainscape - python + c

3 Comments
2024/09/01
05:19 UTC

7

Some progress updates and previews of regional map generation on my fully procgen'd RPG in the making.

1 Comment
2024/08/31
20:05 UTC

198

My talk about extending Wave Function Collapse is now online. I presented this at Everything Procedural 2024.

16 Comments
2024/08/31
16:36 UTC

35

Glowy hairs system

2 Comments
2024/08/31
13:41 UTC

220

Persistent, non-Euclidean maze that generates at runtime as you explore

28 Comments
2024/08/31
02:01 UTC

Back To Top