- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
Perlin Noise算法和Simplex Noise算法的随机性如何?
两者哪个算法的随机性更好?
与标准伪随机生成器相比,使用 Perlin/Simplex 作为随机数生成器是否有意义?
更新:我知道 Perlin/Simplex Noise 的用途。我只是对随机性属性感到好奇。
最佳答案
Perlin 噪声和单纯形噪声旨在生成有用的噪声,而不是完全随机的。这些算法通常用于创建程序生成的景观等。例如,它可以生成这样的地形(图片来自 here ):
在这张图片中,噪声生成了这样的 2D 高度图(图片来自 here ):
每个像素的颜色代表一个高度。生成高度图后,渲染器用于创建与图像“高度”(颜色)相匹配的地形。
因此,算法的结果实际上并不是“随机的”;如您所见,有许多易于辨别的模式。
Simplex 据说看起来有点“更好”,这意味着随机性较低,但其主要目的是它产生类似的噪声但更好地扩展到更高的维度。也就是说,如果一个人会产生 3D、4D、5D 噪声,则单纯形噪声会优于 Perlin 噪声,并产生相似的结果。
如果你想要一个通用的伪随机数生成器,请查看 Mersenne twister或 other prngs .请注意,关于密码学,prng 可能充满警告。
更新:
(对 OP 更新问题的回应)
至于这些噪声函数的随机属性,我知道柏林噪声使用(非常)穷人的 prng 作为输入,并在相邻的“随机”像素之间进行一些平滑/插值。输入随机性实际上只是伪随机索引到预先计算的随机向量中。
索引是使用一些简单的整数运算计算出来的,没什么特别的。例如,noise++ 项目使用预先计算的“randomVectors”(参见 here )来获取其源噪声,并在此向量的不同值之间进行插值。它通过一些简单的整数运算为这个向量生成一个“随机”索引,添加少量的伪随机性。这是一个片段:
int vIndex = (NOISE_X_FACTOR * ix + NOISE_Y_FACTOR * iy + NOISE_Z_FACTOR * iz + NOISE_SEED_FACTOR * seed) & 0xffffffff;
vIndex ^= (vIndex >> NOISE_SHIFT);
vIndex &= 0xff;
const Real xGradient = randomVectors3D[(vIndex<<2)];
...
然后,有些随机的噪声会被平滑并与相邻像素有效混合,从而产生图案。
perlin/simplex noise在产生初始噪声后,有了octave of noise的概念;也就是说,以不同的比例将噪声重新混合到自身中。这会产生更多的模式。因此,噪声的初始质量可能仅与预先计算的随机数组一样好,再加上伪随机索引的影响。但在柏林噪声对其产生影响之后,明显的随机性显着降低(我认为它实际上分布在更广阔的区域)。
关于algorithm - Perlin/Simplex Noise 算法的随机性质量如何?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12473434/
我使用透视滤镜在视频上放了一张图片。 示例 https://yadi.sk/i/MXtWUArJ3TyWBm 我怎样才能提高质量? 代码 ffmpeg -y -i bg.mp4 -loop 1 -i
我是 Matlab 的新手,虽然我知道一些其他的编程语言,所以如果这很简单,请原谅我。我无法在 StackOverflow 或其他地方找到任何答案。 我使用以下代码生成一个图形: figure(6)
我是 Matlab 的新手,虽然我知道一些其他的编程语言,所以如果这很简单,请原谅我。我无法在 StackOverflow 或其他地方找到任何答案。 我使用以下代码生成一个图形: figure(6)
在包含另一个类时,我总是需要写#include "headername.h"。是否可以在不编写其他类或使用“#include”包含多个类的情况下访问其他类? 最佳答案 什么 #include指令的作用
我有一个 .webm我想加速以延时拍摄的视频。我的原创.webm视频是 1280x720 并且质量非常好,但是当我用 FFMPEG 加速它时质量真的很差(即使分辨率保持不变)。这是我正在使用的命令:
我正在使用以下命令生成缩略图: mogrify -resize 128x128 -quality 75 "some thumb file" 对于示例文件: 如果我不指定质量 75,我会得到一个 40K
我想使用流体库的模型。谁能解释一下(我是建模/模拟的新手):质量/能量/动量平衡的公式:稳态、动态和初始猜测初始固定-->之间有什么区别以及对初始化时间/计算的影响是什么时间;我什么时候需要哪一个。
我通过解析“fmt 流映射”得到流 URL, 问题是如果我的视频时长不到 1 小时,我会得到这个: { "comment_count" = 1; description = ""; "dislikes
我试图根据用户的屏幕高度分辨率显示不同的视频分辨率,我有这段代码,但我不是 javascript 专家。它应该改变 src 属性,如果 res 低于 o 等于 360px 高度,等等。有什么建议吗?
我有播放 HLS 视频的 ExoPlayer,问题是我需要让用户能够更改视频质量(自动/1080/720/480)。 我发现使用 AdaptiveTrackSelection.Factory 确实可以
我的应用程序使用 phpmyadmin 连接到 mysql 中的数据库并将图像存储在数据库中,但我的问题是当我从数据库下载图像并将图像发布到 imageview 上时,图像的质量非常低颜色也受到影响。
大家好,我一直在使用 JavaFx 场景构建器来构建一个包含一些 png 图片的图形用户界面。 到目前为止,我一直在使用标签,然后将它们放大以适合图片(以便图片可见。但是这个解决方案并不令人满意,因为
我注意到,在显示比例为 1:1 的小图片时,它们通常看起来呈 block 状。我可以在使用 时解决问题通过使用更大比例的图像并使用 css 设置所需的大小来标记。 但是,我想用 background
我是自定义 CSS 的新手。我的老板希望我在 Qualtrics 中添加自定义 CSS(在外观/高级下)。在编辑预览窗口中,一切似乎都格式正确,但在实际调查页面上,许多元素的格式并未应用:图像是原始大
所以我尝试使用 CreateFont 尝试创建一种类似于我在 Photoshop 中使用的字体,但如果你仔细观察,Photoshop 中的质量要好得多。 这是我用来创建字体的代码: CreateFon
在自动去歪斜和裁剪之后我得到了下面的图像: 我需要对这张图片进行 OCR。现在 ABBYY Engine SDK 11 For Linux 产生的结果不是很好: IMerasers - www,rai
我目前在我的项目中使用 xorshift128+,我知道它通过了 Big Crush,并且被认为可以根据其速度生成相当高质量的随机数。但是,它会生成 64 位数字,而我需要的绝大多数随机数都是小整数(
我使用 python 以较小的质量保存 jpeg im = Image.open(file) im.save(cached_file, quality=80, optimize=True, progr
我在保存或使用 Gmagick PHP 扩展时找不到任何属性。 http://php.net/manual/en/book.gmagick.php 如何在 Gmagick 中更改 JPEG 质量? 最
youtube视频通常具有多种视频分辨率(质量),例如240p,360p,720p等,我如何检索youtube视频具有的视频分辨率(质量)是否有可以获取此信息的youtube api?Google.A
我是一名优秀的程序员,十分优秀!