微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

算法 – 包裹2D perlin噪声

我正在使用Perlin Noise进行高度图生成算法,我想让它包围边缘,以便它被视为连续的.有没有一个简单的方法或技巧呢?我想我需要像球面噪音那样的水平和垂直的包裹.我也会快乐只有1个包装轴,但两个会更好.

现在我使用经典的算法,您可以在其中设置要添加多少个八度音阶,以及用于在每个连续八度音阶之间改变波形的幅度和频率的乘法器.

提前致谢!

解决方法

获得Perlin噪声作为波形总和.通过内插随机值获得波形,较高的八度波形具有较小的缩放因子,而内插的随机值彼此更接近.为了使其环绕,您只需要以通常的环形方式正确地插入y轴和x轴,即,如果X轴从x_min跨越到x_max,最左边的随机点(正被插值)是在x0处和最右侧的x1(x_min 一个进行伪代码.这假设一个256×256矩阵,其中perlin噪声网格大小是两个像素的强度…只是为了使其可读.想象一下大小="=" 16:="" <="">
wrappable_perlin_octave(grid,size):
   for (x=0;x<256;x+=size):
     for (y=0;y<256;y+=size):
       grid[x][y] = random()
   for (x=0;x<256;x+=size):
     for (y=0;y<256;y+=size):
       if (x % size != 0 || y % size != 0): # interpolate
         ax = x - x % size
         bx = (ax + size) % 256 # wrap-around
         ay = y - y % size
         by = (ay + size) % 256 # wrap-around
         h = (x % size) / size # horizontal balance,floating-point calculation
         v = (y % size) / size # vertical balance,floating-point calculation
         grid[x][y] = grid[ax][ay] * (1-h) * (1-v) +
                      grid[bx][ay] * h * (1-v) +
                      grid[ax][by] * (1-h) * v +
                      grid[bx][by] * h * v

原文地址:https://www.jb51.cc/Perl/171532.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐