草庐IT

c++ - 将种子添加到 Perlin 噪声的最佳方法?

coder 2023-06-01 原文

我正在尝试在 C++ 中实现 2D Perlin 噪声生成,我发现一些实现根本不使用种子( hereherehere )。其他实现采用种子值来根据噪声值获得不同的噪声。

但是我发现 example code其中将种子值添加到计算每个 Octave 音阶的噪声值的函数参数中(请参阅链接代码中的 PerlinNoise::Total() )。另一个使用3D种子函数,将固定的种子值作为z值(刚才找不到例子)。其他文章建议使用其他噪声函数。

所以我的问题是,为 Perlin 噪声生成添加种子值的最佳方法是什么。给定相同的种子值,应该生成相同的噪声值。如果解决方案是使用自定义噪声函数,我会很感兴趣是否可以使用 Boost.Random(或 C++11 的标准 C++ 库类)来实现它。

编辑:用“最佳”方式回答我的意思:什么是给我 Perlin 噪音的最佳方式,就像它应该工作一样,例如梯度噪声函数。

最佳答案

由于没有人会从评论中写出答案,我正在尝试自己。正确时请点赞,错误时评论:)

有几个实现和示例代码(尝试)实现 Perlin 噪声。首先,有Improved Noise reference implementation来自肯·佩林本人。

案例 1:改进的噪声引用实现

noise 函数取三个 double 值并输出一个值。当使用 x 和 y 生成 2D 位图并保持 z 不变时,就会得到众所周知的 Perlin 噪声模式。当 z 在 0.0 和 1.0 之间变化时,噪声云似乎“变化”缓慢。因此,设置 z 的播种方法,例如z = 10.0 * seed,可以用于“播种”。

另一种设置噪声函数的方法是:如果你总是得到 [0.0; 范围内的噪声; 64.0[ 对于 x 和 y,可以通过在调用噪声函数时向 x、y 或两者添加偏移量来播种噪声:noise(x + 64.0*seed, y + 64.0*seed)。

案例 2:教程风格的 Perlin 噪声代码

然后有一个implementation Perlin 噪声(在许多其他 Perlin 噪声教程中改编和使用)具有这样的基本噪声函数(伪代码):

function Noise2(integer x, integer y)
    n = x + y * 57
    n = (n<<13) ^ n;
    return ( 1.0 - ( (n * (n * n * 15731 + 789221) + 1376312589)
       & 7fffffff) / 1073741824.0);    
end function

我的主要怀疑来自神奇的数字和这些页面作者的信任,即公式会导致均匀分布的噪声。其他作者在此公式的某处添加了种子值。

为这种类型的 Perlin 噪声实现添加种子的解决方案是编写一个函数,该函数为给定的 x 和 y 值均匀分布输出值(当然,通过为相同的 x 和 y 值返回相同的值) .这个函数可以用 Boost.Random 编写(代码未测试):

double Noise2(int x, int y)
{
   uint32_t seeds[3] = { uint32_t(x), uint32_t(y), seed };
   boost::mt19937 rng(seeds, seeds+3);
   boost::uniform_real<> dist(0.0, 1.0);
   boost::variate_generator<boost::mt19937&, boost::uniform_real<> >
      die(rng, dist);
   return die();
}

随机数生成器有一些 ctor,其中一个采用 uint32_t 的范围来确定 RNG 的初始状态。

还有一些库会产生相干噪声,例如 libnoise ,这可能会有所帮助。

单纯形噪声

我问的不是单纯形噪声,而是 implementation (from Stefan Gustavson)我发现使用了类似的技术(一些预先计算的表),比如 Ken Perlin 的引用实现,并且可以像上面的案例 1 一样播种。评论者 Robinson 在生成查找表时提到了播种,但我不知道这会如何工作。

关于c++ - 将种子添加到 Perlin 噪声的最佳方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7213469/

有关c++ - 将种子添加到 Perlin 噪声的最佳方法?的更多相关文章

  1. ruby - 如何使用 Nokogiri 的 xpath 和 at_xpath 方法 - 2

    我正在学习如何使用Nokogiri,根据这段代码我遇到了一些问题:require'rubygems'require'mechanize'post_agent=WWW::Mechanize.newpost_page=post_agent.get('http://www.vbulletin.org/forum/showthread.php?t=230708')puts"\nabsolutepathwithtbodygivesnil"putspost_page.parser.xpath('/html/body/div/div/div/div/div/table/tbody/tr/td/div

  2. ruby - 如何从 ruby​​ 中的字符串运行任意对象方法? - 2

    总的来说,我对ruby​​还比较陌生,我正在为我正在创建的对象编写一些rspec测试用例。许多测试用例都非常基础,我只是想确保正确填充和返回值。我想知道是否有办法使用循环结构来执行此操作。不必为我要测试的每个方法都设置一个assertEquals。例如:describeitem,"TestingtheItem"doit"willhaveanullvaluetostart"doitem=Item.new#HereIcoulddotheitem.name.shouldbe_nil#thenIcoulddoitem.category.shouldbe_nilendend但我想要一些方法来使用

  3. ruby - 为什么我可以在 Ruby 中使用 Object#send 访问私有(private)/ protected 方法? - 2

    类classAprivatedeffooputs:fooendpublicdefbarputs:barendprivatedefzimputs:zimendprotecteddefdibputs:dibendendA的实例a=A.new测试a.foorescueputs:faila.barrescueputs:faila.zimrescueputs:faila.dibrescueputs:faila.gazrescueputs:fail测试输出failbarfailfailfail.发送测试[:foo,:bar,:zim,:dib,:gaz].each{|m|a.send(m)resc

  4. ruby-on-rails - 使用 Ruby on Rails 进行自动化测试 - 最佳实践 - 2

    很好奇,就使用ruby​​onrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提

  5. ruby - Facter::Util::Uptime:Module 的未定义方法 get_uptime (NoMethodError) - 2

    我正在尝试设置一个puppet节点,但ruby​​gems似乎不正常。如果我通过它自己的二进制文件(/usr/lib/ruby/gems/1.8/gems/facter-1.5.8/bin/facter)在cli上运行facter,它工作正常,但如果我通过由ruby​​gems(/usr/bin/facter)安装的二进制文件,它抛出:/usr/lib/ruby/1.8/facter/uptime.rb:11:undefinedmethod`get_uptime'forFacter::Util::Uptime:Module(NoMethodError)from/usr/lib/ruby

  6. ruby - 我需要将 Bundler 本身添加到 Gemfile 中吗? - 2

    当我使用Bundler时,是否需要在我的Gemfile中将其列为依赖项?毕竟,我的代码中有些地方需要它。例如,当我进行Bundler设置时:require"bundler/setup" 最佳答案 没有。您可以尝试,但首先您必须用鞋带将自己抬离地面。 关于ruby-我需要将Bundler本身添加到Gemfile中吗?,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/4758609/

  7. Ruby 方法() 方法 - 2

    我想了解Ruby方法methods()是如何工作的。我尝试使用“ruby方法”在Google上搜索,但这不是我需要的。我也看过ruby​​-doc.org,但我没有找到这种方法。你能详细解释一下它是如何工作的或者给我一个链接吗?更新我用methods()方法做了实验,得到了这样的结果:'labrat'代码classFirstdeffirst_instance_mymethodenddefself.first_class_mymethodendendclassSecond使用类#returnsavailablemethodslistforclassandancestorsputsSeco

  8. ruby - 解析 RDFa、微数据等的最佳方式是什么,使用统一的模式/词汇(例如 schema.org)存储和显示信息 - 2

    我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i

  9. ruby - 将 Bootstrap Less 添加到 Sinatra - 2

    我有一个ModularSinatra应用程序,我正在尝试将Bootstrap添加到应用程序中。get'/bootstrap/application.css'doless:"bootstrap/bootstrap"end我在views/bootstrap中有所有less文件,包括bootstrap.less。我收到这个错误:Less::ParseErrorat/bootstrap/application.css'reset.less'wasn'tfound.Bootstrap.less的第一行是://CSSReset@import"reset.less";我尝试了所有不同的路径格式,但它

  10. ruby-on-rails - Rails 3.2.1 中 ActionMailer 中的未定义方法 'default_content_type=' - 2

    我在我的项目中添加了一个系统来重置用户密码并通过电子邮件将密码发送给他,以防他忘记密码。昨天它运行良好(当我实现它时)。当我今天尝试启动服务器时,出现以下错误。=>BootingWEBrick=>Rails3.2.1applicationstartingindevelopmentonhttp://0.0.0.0:3000=>Callwith-dtodetach=>Ctrl-CtoshutdownserverExiting/Users/vinayshenoy/.rvm/gems/ruby-1.9.3-p0/gems/actionmailer-3.2.1/lib/action_mailer

随机推荐