改进的噪音版本保持返回0

时间:2011-07-06 02:00:14

标签: c# random xna noise perlin-noise

我正在尝试在我的XNA游戏中实现改进的噪音,但我的改进的噪音功能保持返回0.0f。它与Ken Perlin(http://mrl.nyu.edu/~perlin/noise/)的代码完全相同,只是移植到C#。

我尝试重写该类,甚至直接从站点复制和粘贴(当然然后移植到C#),但它不会输出任何值而是0。

这是我正在使用的代码:

public class PerlinNoise 
    { 
        private int[] permutations = new int[512]; 

    private Random random; 

    public PerlinNoise() 
        : this(Environment.TickCount) 
    { } 

    public PerlinNoise(int seed) 
    { 
        random = new Random(seed); 

        for (int i = 0; i < 256; i++) 
        { 
            permutations[i] = i; 
        } 

        for (int i = 0; i < 256; i++) 
        { 
            int k = random.Next(256 - i) + i; 

            int l = permutations[i]; 

            permutations[i] = permutations[k]; 
            permutations[k] = l; 
            permutations[i + 256] = permutations[i]; 
        } 
    } 

    private int fastfloor(float x) 
    { 
        return x > 0 ? (int)x : (int)x - 1; 
    } 

    private float fade(float t) 
    { 
        return t * t * t * (t * (t * 6 - 15) + 10); 
    } 

    private float lerp(float t, float a, float b) 
    { 
        return a + t * (b - a); 
    } 

    public float grad(int hash, float x, float y, float z) 
    { 
        int h = hash & 15; 

        float u = h < 8 ? x : y, 
            v = h < 4 ? y : h == 12 || h == 14 ? x : z; 

        return ((h & 1) == 0 ? u : -u) + ((h & 2) == 0 ? v : -v); 
    } 

    public float noise3d(float x, float y, float z) 
    { 
        int X = fastfloor(x) & 0xff, 
            Y = fastfloor(y) & 0xff, 
            Z = fastfloor(z) & 0xff; 

        x -= fastfloor(x); 
        y -= fastfloor(y); 
        z -= fastfloor(z); 

        float u = fade(x); 
        float v = fade(y); 
        float w = fade(z); 

        int A = permutations[X] + Y, AA = permutations[A] + Z, AB = permutations[A + 1] + Z, 
            B = permutations[X + 1] + Y, BA = permutations[B] + Z, BB = permutations[B + 1] + Z; 

        return lerp(w, lerp(v, lerp(u, grad(permutations[AA], x, y, z), 
                                 grad(permutations[BA], x - 1, y, z)), 
                         lerp(u, grad(permutations[AB], x, y - 1, z), 
                                 grad(permutations[BB], x - 1, y - 1, z))), 

                         lerp(v, lerp(u, grad(permutations[AA + 1], x, y, z - 1), 
                                 grad(permutations[BA + 1], x - 1, y, z - 1)), 
                         lerp(u, grad(permutations[AB + 1], x, y - 1, z - 1), 
                                 grad(permutations[BB + 1], x - 1, y - 1, z - 1)))); 
    } 

    public float noise2d(float x, float y) 
    { 
        return noise3d(x, y, 0f); 
    } 
} `

为了测试它,我只是做了:

string[] args = Console.ReadLine().Split(' '); 

PerlinNoise noise = new PerlinNoise(); 

int x = args[0]; 
int y = args[1]; 
int z = args[2]; 

Console.WriteLine(noise.noise3d(x, y, z));

正如我上面所说,它总是输出0。

2 个答案:

答案 0 :(得分:1)

如果所有参数都是整数,似乎输出0.0f。将测试代码更改为

var input = Console.ReadLine()
                    .Split(' ')
                    .Select(s => float.Parse(s,
                        System.Globalization.CultureInfo.InvariantCulture))
                    .ToArray();

并尝试输入,例如4234.2123 3123.12312 423.2434

我不太确定这是否是所希望的行为,但是

        x -= Math.Floor(x);                                // FIND RELATIVE X,Y,Z
        y -= Math.Floor(y);                                // OF POINT IN CUBE.
        z -= Math.Floor(z);

始终会xy&amp;如果它们是整数,则z = 0; fade(0.0f)也始终为零。

答案 1 :(得分:1)

在输入的情况下将输入乘以(1 / MAX_VALUE),只需乘以1/256左右,并且永远不要给它大于此值。在游戏中使用时,将输入乘以(1 / MAXIMUM_CHOORD_VALUE)