RandNoise.cpp 798 B

1234567891011121314151617181920212223242526272829303132333435363738
  1. #include "RandNoise.h"
  2. #include <Random.h>
  3. #include <stdlib.h>
  4. #include "Constants.h"
  5. #include "FastNoiseLite.h"
  6. #include "FastNoiseWrapper.h"
  7. RandNoise::RandNoise(int seed)
  8. : Noise(),
  9. seed(seed)
  10. {
  11. srand(seed);
  12. table = new short[RandNoiseTableSize];
  13. for (int i = 0; i < RandNoiseTableSize; i++)
  14. table[i] = (short)rand();
  15. }
  16. RandNoise::~RandNoise()
  17. {
  18. delete[] table;
  19. }
  20. int RandNoise::getSeed() const
  21. {
  22. return seed;
  23. }
  24. double RandNoise::getNoise(double x, double y, double z)
  25. {
  26. int index = seed % RandNoiseTableSize;
  27. index = abs(table[index] + (int)x) % RandNoiseTableSize;
  28. index = abs(table[index] + (int)y) % RandNoiseTableSize;
  29. index = abs(table[index] + (int)z) % RandNoiseTableSize;
  30. return (double)table[index]
  31. / RAND_MAX;
  32. }