Advertisement
raphael76280

Untitled

Apr 13th, 2019
125
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 3.78 KB | None | 0 0
  1.  
  2. perlin = {}
  3. perlin.p = {}
  4.  
  5.  
  6. local permutation = {151,160,137,91,90,15,
  7. 131,13,201,95,96,53,194,233,7,225,140,36,103,30,69,142,8,99,37,240,21,10,23,
  8. 190, 6,148,247,120,234,75,0,26,197,62,94,252,219,203,117,35,11,32,57,177,33,
  9. 88,237,149,56,87,174,20,125,136,171,168, 68,175,74,165,71,134,139,48,27,166,
  10. 77,146,158,231,83,111,229,122,60,211,133,230,220,105,92,41,55,46,245,40,244,
  11. 102,143,54, 65,25,63,161, 1,216,80,73,209,76,132,187,208, 89,18,169,200,196,
  12. 135,130,116,188,159,86,164,100,109,198,173,186, 3,64,52,217,226,250,124,123,
  13. 5,202,38,147,118,126,255,82,85,212,207,206,59,227,47,16,58,17,182,189,28,42,
  14. 223,183,170,213,119,248,152, 2,44,154,163, 70,221,153,101,155,167, 43,172,9,
  15. 129,22,39,253, 19,98,108,110,79,113,224,232,178,185, 112,104,218,246,97,228,
  16. 251,34,242,193,238,210,144,12,191,179,162,241, 81,51,145,235,249,14,239,107,
  17. 49,192,214, 31,181,199,106,157,184, 84,204,176,115,121,50,45,127, 4,150,254,
  18. 138,236,205,93,222,114,67,29,24,72,243,141,128,195,78,66,215,61,156,180
  19. }
  20.  
  21. for i=0,255 do
  22. perlin.p[i] = permutation[i+1]
  23. perlin.p[i+256] = permutation[i+1]
  24. end
  25.  
  26. perlin.dot_product = {
  27. [0x0]=function(x,y,z) return x + y end,
  28. [0x1]=function(x,y,z) return -x + y end,
  29. [0x2]=function(x,y,z) return x - y end,
  30. [0x3]=function(x,y,z) return -x - y end,
  31. [0x4]=function(x,y,z) return x + z end,
  32. [0x5]=function(x,y,z) return -x + z end,
  33. [0x6]=function(x,y,z) return x - z end,
  34. [0x7]=function(x,y,z) return -x - z end,
  35. [0x8]=function(x,y,z) return y + z end,
  36. [0x9]=function(x,y,z) return -y + z end,
  37. [0xA]=function(x,y,z) return y - z end,
  38. [0xB]=function(x,y,z) return -y - z end,
  39. [0xC]=function(x,y,z) return y + x end,
  40. [0xD]=function(x,y,z) return -y + z end,
  41. [0xE]=function(x,y,z) return y - x end,
  42. [0xF]=function(x,y,z) return -y - z end
  43. }
  44. function perlin:grad(hash, x, y, z)
  45. return self.dot_product[bit32.band(hash,0xF)](x,y,z)
  46. end
  47.  
  48. -- Fade function is used to smooth final output
  49. function perlin.fade(t)
  50. return t * t * t * (t * (t * 6 - 15) + 10)
  51. end
  52.  
  53. function perlin.lerp(t, a, b)
  54. return a + t * (b - a)
  55. end
  56.  
  57. function perlin:noise(x, y, z)
  58. local self = perlin
  59.  
  60. y = y or 0
  61. z = z or 0
  62.  
  63. local xi = bit32.band(math.floor(x),255)
  64. local yi = bit32.band(math.floor(y),255)
  65. local zi = bit32.band(math.floor(z),255)
  66.  
  67. x = x - math.floor(x)
  68. y = y - math.floor(y)
  69. z = z - math.floor(z)
  70.  
  71. local u = self.fade(x)
  72. local v = self.fade(y)
  73. local w = self.fade(z)
  74.  
  75. -- Hash all 8 unit cube coordinates surrounding input coordinate
  76. local p = self.p
  77. local A, AA, AB, AAA, ABA, AAB, ABB, B, BA, BB, BAA, BBA, BAB, BBB
  78. A = p[xi ] + yi
  79. AA = p[A ] + zi
  80. AB = p[A+1 ] + zi
  81. AAA = p[ AA ]
  82. ABA = p[ AB ]
  83. AAB = p[ AA+1 ]
  84. ABB = p[ AB+1 ]
  85.  
  86. B = p[xi+1] + yi
  87. BA = p[B ] + zi
  88. BB = p[B+1 ] + zi
  89. BAA = p[ BA ]
  90. BBA = p[ BB ]
  91. BAB = p[ BA+1 ]
  92. BBB = p[ BB+1 ]
  93.  
  94. -- Take the weighted average between all 8 unit cube coordinates
  95. return self.lerp(w,
  96. self.lerp(v,
  97. self.lerp(u,
  98. self:grad(AAA,x,y,z),
  99. self:grad(BAA,x-1,y,z)
  100. ),
  101. self.lerp(u,
  102. self:grad(ABA,x,y-1,z),
  103. self:grad(BBA,x-1,y-1,z)
  104. )
  105. ),
  106. self.lerp(v,
  107. self.lerp(u,
  108. self:grad(AAB,x,y,z-1), self:grad(BAB,x-1,y,z-1)
  109. ),
  110. self.lerp(u,
  111. self:grad(ABB,x,y-1,z-1), self:grad(BBB,x-1,y-1,z-1)
  112. )
  113. )
  114. )
  115. end
  116.  
  117. -- Gradient function finds dot product between pseudorandom gradient vector
  118. -- and the vector from input coordinate to a unit cube vertex
  119.  
  120.  
  121. return perlin
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement