37 lines
461 B
Go
37 lines
461 B
Go
// +build !go1.9
|
|
|
|
package roaring
|
|
|
|
// LeadingZeroBits returns the number of consecutive most significant zero
|
|
// bits of x.
|
|
func countLeadingZeros(i uint64) int {
|
|
if i == 0 {
|
|
return 64
|
|
}
|
|
n := 1
|
|
x := uint32(i >> 32)
|
|
if x == 0 {
|
|
n += 32
|
|
x = uint32(i)
|
|
}
|
|
if (x >> 16) == 0 {
|
|
n += 16
|
|
x <<= 16
|
|
}
|
|
if (x >> 24) == 0 {
|
|
n += 8
|
|
x <<= 8
|
|
}
|
|
if x>>28 == 0 {
|
|
n += 4
|
|
x <<= 4
|
|
}
|
|
if x>>30 == 0 {
|
|
n += 2
|
|
x <<= 2
|
|
|
|
}
|
|
n -= int(x >> 31)
|
|
return n
|
|
}
|