加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

算法 – 包裹2D perlin噪声

发布时间:2020-12-15 22:02:02 所属栏目:大数据 来源:网络整理
导读:我正在使用Perlin Noise进行高度图生成算法,我想让它包围边缘,以便它被视为连续的.有没有一个简单的方法或技巧呢?我想我需要像球面噪音那样的水平和垂直的包裹.我也会快乐只有1个包装轴,但两个会更好. 现在我使用经典的算法,您可以在其中设置要添加多少个八
我正在使用Perlin Noise进行高度图生成算法,我想让它包围边缘,以便它被视为连续的.有没有一个简单的方法或技巧呢?我想我需要像球面噪音那样的水平和垂直的包裹.我也会快乐只有1个包装轴,但两个会更好.

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

提前致谢!

解决方法

获得Perlin噪声作为波形总和.通过内插随机值获得波形,较高的八度波形具有较小的缩放因子,而内插的随机值彼此更接近.为了使其环绕,您只需要以通常的环形方式正确地插入y轴和x轴,即,如果X轴从x_min跨越到x_max,最左边的随机点(正被插值)是在x0处和最右侧的x1(x_min
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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读