Class BestCandidateSampling.Cube

java.lang.Object
org.joml.sampling.BestCandidateSampling.Cube
Enclosing class:
BestCandidateSampling

public static class BestCandidateSampling.Cube extends Object
Generates Best Candidate samples inside a unit cube.
Author:
Kai Burjack
  • Constructor Details

    • Cube

      public Cube()
      Create a new instance of BestCandidateSampling.Cube to configure and generate 'best candidate' sample positions on the unit cube with each sample tried numCandidates number of times, and call the given callback for each sample generate.
  • Method Details

    • seed

      public BestCandidateSampling.Cube seed(long seed)
      Set the seed to initialize the pseudo-random number generator with.
      Parameters:
      seed - the seed value
      Returns:
      this
    • numSamples

      public BestCandidateSampling.Cube numSamples(int numSamples)
      Set the number of samples to generate.
      Parameters:
      numSamples - the number of samples
      Returns:
      this
    • numCandidates

      public BestCandidateSampling.Cube numCandidates(int numCandidates)
      Set the number of candidates to try for each generated sample.
      Parameters:
      numCandidates - the number of candidates to try
      Returns:
      this
    • generate

      public BestCandidateSampling.Cube generate(float[] xyzs)
      Generate 'best candidate' sample positions and store the coordinates of all generated samples into the given xyzs float array.

      This method performs heap allocations, so should be used sparingly.

      Parameters:
      xyzs - will hold the x, y and z coordinates of all samples in the order XYZXYZXYZ.... This array must have a length of at least numSamples
      Returns:
      this
    • generate

      public BestCandidateSampling.Cube generate(FloatBuffer xyzs)
      Generate 'best candidate' sample positions and store the coordinates of all generated samples into the given xyzs FloatBuffer.

      The samples will be written starting at the current position of the FloatBuffer. The position of the FloatBuffer will not be modified.

      This method performs heap allocations, so should be used sparingly.

      Parameters:
      xyzs - will hold the x, y and z coordinates of all samples in the order XYZXYZXYZ.... This FloatBuffer must have at least numSamples remaining elements. The position of the buffer will not be modified by this method
      Returns:
      this
    • generate

      public BestCandidateSampling.Cube generate(Callback3d callback)
      Generate 'best candidate' sample positions and call the given callback for each generated sample.

      This method performs heap allocations, so should be used sparingly.

      Parameters:
      callback - will be called with the coordinates of each generated sample position
      Returns:
      this