- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在使用菱形方 block 算法生成随机地形。它工作正常,除了我得到这些大圆锥形状或者伸出或插入地形。问题似乎是时不时会有一个点设置得太高或太低。
这是问题的图片
当我将平滑度设置得非常高时可以更好地看到它
这是我的代码-
private void CreateHeights()
{
if (cbUseLand.Checked == false)
return;
int
Size = Convert.ToInt32(System.Math.Pow(2, int.Parse(tbDetail.Text)) + 1),
SideLength = Size - 1,
d = 1025 / (Size - 1),
HalfSide;
Heights = new Point3D[Size, Size];
float
r = float.Parse(tbHeight.Text),
Roughness = float.Parse(RoughnessBox.Text);
//seeding all the points
for (int x = 0; x < Size; x++)
for (int y = 0; y < Size; y++)
Heights[x, y] = Make3DPoint(x * d, 740, y * d);
while (SideLength >= 2)
{
HalfSide = SideLength / 2;
for (int x = 0; x < Size - 1; x = x + SideLength)
{
for (int y = 0; y < Size - 1; y = y + SideLength)
{
Heights[x + HalfSide, y + HalfSide].y =
(Heights[x, y].y +
Heights[x + SideLength, y].y +
Heights[x, y + SideLength].y +
Heights[x + SideLength, y + SideLength].y) / 4 - r + ((float)(random.NextDouble() * r) * 2);
}
}
for (int x = 0; x < Size - 1; x = x + SideLength)
{
for (int y = 0; y < Size - 1; y = y + SideLength)
{
if (y != 0)
Heights[x + HalfSide, y].y = (Heights[x, y].y + Heights[x + SideLength, y].y + Heights[x + HalfSide, y + HalfSide].y + Heights[x + HalfSide, y - HalfSide].y) / 4 - r + ((float)(random.NextDouble() * r) * 2);
if (x != 0)
Heights[x, y + HalfSide].y = (Heights[x, y].y + Heights[x, y + SideLength].y + Heights[x + HalfSide, y + HalfSide].y + Heights[x - HalfSide, y + HalfSide].y) / 4 - r + ((float)(random.NextDouble() * r) * 2);
}
}
SideLength = SideLength / 2;
r = r / Roughness;
}
}
最佳答案
Gavin S. P. Miller 在 SIGGRAPH '86 上发表了演讲,讲述了 Fournier、Fussel 和 Carpenter 的原始算法是如何存在根本性缺陷的。因此,您所看到的对于 Diamond Square 算法的任何简单实现都是正常的。您将需要一种单独的平滑方法,要么发布每个 Diamond-Square 复合步骤,要么作为所有 diamond-square 迭代(或两者)的后处理。米勒解决了这个问题。加权和框或高斯滤波是一种选择;将初始数组播种到比最初的 4 个点更大的程度(即,手动或使用某些内置智能复制 diamond-square 前几步的结果集,但提供无偏值);在使用 diamond-square 增加细节之前为数组提供的初始信息越多,结果就越好。
原因似乎在于 Square 步骤的执行方式。在菱形步骤中,我们取正方形四个角的平均值来生成该正方形的中心。然后,在随后的 Square 步骤中,我们取四个正交相邻邻居的平均值,其中一个是我们刚刚生成的正方形的中心点。你能看出问题所在吗?那些原始角高度值对随后的菱形正方形迭代贡献太大,因为它们通过它们自己的影响和它们创建的中点做出贡献。这会导致尖顶(突出和侵入),因为局部派生的点更倾向于那些早期的点......并且因为(通常是 3 个)其他点也这样做,这会在你迭代时围绕这些点产生“循环”影响使用 Diamond-Square 到更高的深度。所以这些“别名”问题只有在数组的初始状态未指定时才会出现;事实上,出现的伪影可以看作是仅使用 4 个点开始的直接几何结果。
您可以执行以下操作之一:
关于algorithm - Diamond-Square 算法的平滑问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7549883/
我想使用与此按钮相同的边框: (参见:https://graphicdesign.stackexchange.com/)。是否可以使用 radius XML 属性(borderLeftTopRadiu
我有四个带有列的表格: TABLE1: id TABLE2: id, t4_ref, t1_ref TABLE3: id, t4_ref, t1_ref TABLE4: id, type 我想要做的是
我正在尝试让我的 for 循环在给定用户特定最大值和最小值的情况下输出菱形,即使输入也是不允许的。任何想法,将不胜感激。练习并不像我想象的那么顺利。 #include #include using
我想谈谈有向无环图中从节点节点到另一个节点有多条路径的地方。这不是“循环”,我应该怎么称呼它?我正在使用术语“钻石”,但这意味着只有四个节点,这是不对的。 最佳答案 正如你所说,正确的术语不太可能是菱
我对一个Java项目有疑问: public class example { public Data getData() { List users = usersService.f
我对一个Java项目有疑问: public class example { public Data getData() { List users = usersService.f
我遇到了一个问题,我的代码在 NetBeans 中编译并运行良好,但是当我尝试使用 javac 通过命令行进行编译时,出现未经检查的警告错误,并且失败。当我使用 -Xlint:unchecked 进行
我有以下代码: class Base { public: virtual void doSomething() = 0; }; class BaseImpl : public
几年前,当 Java7 已经发布一年左右时,我从 C# 回到了 Java - java 泛型在某些方面对我来说似乎很奇怪。 有一个我会一遍又一遍地回来,看到这两个答案的受欢迎程度...... Diff
这个问题在这里已经有了答案: C++ virtual inheritance initializer list (2 个答案) 关闭 9 年前。 假设我们有一个菱形继承,其中 D 从 B1 和 B2
当我编译这个时: LinkedBlockingDeque q = new LinkedBlockingDeque<>(); 在 Eclipse Java EE Kepler 版本中,一切正常,但是一旦
Ruby 的版本是这样的: % ruby -v ruby 2.5.0p0 (2017-12-25 revision 61468) [x86_64-darwin17] 我想到了如果我们在 Ruby 中以
这是讨论的后续问题: Why doesn't the diamond operator work within a addAll() call in Java 7? 来自 Java 教程, http:
我正在使用菱形方 block 算法生成随机地形。它工作正常,除了我得到这些大圆锥形状或者伸出或插入地形。问题似乎是时不时会有一个点设置得太高或太低。 这是问题的图片 当我将平滑度设置得非常高时可以更好
假设,我想创建一个如下所示的类并且不使用虚拟继承。从“下层”实例访问“上层”类成员的语法是什么?已经为左和右计算了一些方法,但不确定哪个是“规范”正确的。以及如何访问成员下---上层的方式? /*
我刚刚开始从事一个 Java 项目,并使用 IntelliJ 从 GitHub 下载了源代码——我以前从未使用过 IntelliJ,但听说这是一个比 Eclipse 好得多的 IDE(这就是我上次进行
考虑以下代码片段: class A { }; class B:public virtual A { }; class C:public virtual A { }; class D:public B,
假设我有一个应用程序有多个类(使用继承)现在有一天,我必须向我的应用程序添加新规范,这将需要我使用多重继承。 例如这段代码: class A{}; class B : public A{}; clas
我的项目暂时使用等距透视图,我在它们上方以网格格式显示坐标以进行调试。但是,当涉及到播放器的碰撞/网格锁定时,我遇到了一个问题。 由于 sprite 绘图的性质,我的数学计算在纹理的“三角形”角空白区
当一个类继承自同一基类派生的 2 个类时,我无法理解为什么虚拟继承在我们没有遇到类似于菱形继承(钻石问题)的问题的情况下有用。 当它仍然有用(或什至需要)时,有人能给我一个例子或解释吗? 谢谢:) 最
我是一名优秀的程序员,十分优秀!