Added optional threshold
This commit is contained in:
		
							parent
							
								
									c04ac3b4d4
								
							
						
					
					
						commit
						e6ec8aeafa
					
				@ -10,10 +10,12 @@ namespace FastRng.Double
 | 
			
		||||
        private readonly double[] samples;
 | 
			
		||||
        private readonly IRandom rng;
 | 
			
		||||
        private readonly ushort sampleSize;
 | 
			
		||||
        private readonly double threshold;
 | 
			
		||||
        
 | 
			
		||||
        public ShapeFitter(Func<double, double> shapeFunction, IRandom rng, ushort sampleSize = 100)
 | 
			
		||||
        public ShapeFitter(Func<double, double> shapeFunction, IRandom rng, ushort sampleSize = 100, double threshold = 0.99)
 | 
			
		||||
        {
 | 
			
		||||
            this.rng = rng;
 | 
			
		||||
            this.threshold = threshold;
 | 
			
		||||
            this.sampleSize = sampleSize;
 | 
			
		||||
            this.samples = new double[sampleSize];
 | 
			
		||||
            this.probabilities = new double[sampleSize];
 | 
			
		||||
@ -35,7 +37,7 @@ namespace FastRng.Double
 | 
			
		||||
                var nextBucket = (int)Math.Floor(nextNumber * this.sampleSize);
 | 
			
		||||
                this.samples[nextBucket] += this.probabilities[nextBucket];
 | 
			
		||||
 | 
			
		||||
                if (this.samples[nextBucket] >= 1.0)
 | 
			
		||||
                if (this.samples[nextBucket] >= this.threshold)
 | 
			
		||||
                {
 | 
			
		||||
                    this.samples[nextBucket] = 0.0;
 | 
			
		||||
                    return nextNumber;
 | 
			
		||||
 | 
			
		||||
		Loading…
	
		Reference in New Issue
	
	Block a user