mirror of
				https://github.com/GayPizzaSpecifications/voxelotl-engine.git
				synced 2025-11-04 02:59:37 +00:00 
			
		
		
		
	simpler range mask calculation
This commit is contained in:
		@ -65,21 +65,9 @@ public extension RandomProvider where Output: UnsignedInteger {
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  mutating func nextModless(in bound: Output) -> Output {
 | 
			
		||||
    func pow2MaskFrom(range num: Output) -> Output {
 | 
			
		||||
      if num & (num - 1) == 0 {
 | 
			
		||||
        return num - 1
 | 
			
		||||
      }
 | 
			
		||||
      var result: Output = 1
 | 
			
		||||
      for _ in 0..<Output.bitWidth {
 | 
			
		||||
        if result >= num {
 | 
			
		||||
          return result - 1
 | 
			
		||||
        }
 | 
			
		||||
        result <<= 1
 | 
			
		||||
      }
 | 
			
		||||
      return .max
 | 
			
		||||
    }
 | 
			
		||||
    let shift = bound.leadingZeroBitCount
 | 
			
		||||
    let mask = Output.max &>> shift
 | 
			
		||||
 | 
			
		||||
    let mask = pow2MaskFrom(range: bound)
 | 
			
		||||
    var result: Output
 | 
			
		||||
    repeat {
 | 
			
		||||
      result = next() & mask
 | 
			
		||||
 | 
			
		||||
		Reference in New Issue
	
	Block a user