mirror of
https://github.com/opencloud-eu/opencloud.git
synced 2026-01-04 12:10:21 -05:00
Bumps [github.com/blevesearch/bleve/v2](https://github.com/blevesearch/bleve) from 2.5.3 to 2.5.4. - [Release notes](https://github.com/blevesearch/bleve/releases) - [Commits](https://github.com/blevesearch/bleve/compare/v2.5.3...v2.5.4) --- updated-dependencies: - dependency-name: github.com/blevesearch/bleve/v2 dependency-version: 2.5.4 dependency-type: direct:production update-type: version-update:semver-patch ... Signed-off-by: dependabot[bot] <support@github.com>
44 lines
1.5 KiB
Go
44 lines
1.5 KiB
Go
package numeric
|
|
|
|
var interleaveMagic = []uint64{
|
|
0x5555555555555555,
|
|
0x3333333333333333,
|
|
0x0F0F0F0F0F0F0F0F,
|
|
0x00FF00FF00FF00FF,
|
|
0x0000FFFF0000FFFF,
|
|
0x00000000FFFFFFFF,
|
|
0xAAAAAAAAAAAAAAAA,
|
|
}
|
|
|
|
var interleaveShift = []uint{1, 2, 4, 8, 16}
|
|
|
|
// Interleave the first 32 bits of each uint64
|
|
// adapted from org.apache.lucene.util.BitUtil
|
|
// which was adapted from:
|
|
// http://graphics.stanford.edu/~seander/bithacks.html#InterleaveBMN
|
|
func Interleave(v1, v2 uint64) uint64 {
|
|
v1 = (v1 | (v1 << interleaveShift[4])) & interleaveMagic[4]
|
|
v1 = (v1 | (v1 << interleaveShift[3])) & interleaveMagic[3]
|
|
v1 = (v1 | (v1 << interleaveShift[2])) & interleaveMagic[2]
|
|
v1 = (v1 | (v1 << interleaveShift[1])) & interleaveMagic[1]
|
|
v1 = (v1 | (v1 << interleaveShift[0])) & interleaveMagic[0]
|
|
v2 = (v2 | (v2 << interleaveShift[4])) & interleaveMagic[4]
|
|
v2 = (v2 | (v2 << interleaveShift[3])) & interleaveMagic[3]
|
|
v2 = (v2 | (v2 << interleaveShift[2])) & interleaveMagic[2]
|
|
v2 = (v2 | (v2 << interleaveShift[1])) & interleaveMagic[1]
|
|
v2 = (v2 | (v2 << interleaveShift[0])) & interleaveMagic[0]
|
|
return (v2 << 1) | v1
|
|
}
|
|
|
|
// Deinterleave the 32-bit value starting at position 0
|
|
// to get the other 32-bit value, shift it by 1 first
|
|
func Deinterleave(b uint64) uint64 {
|
|
b &= interleaveMagic[0]
|
|
b = (b ^ (b >> interleaveShift[0])) & interleaveMagic[1]
|
|
b = (b ^ (b >> interleaveShift[1])) & interleaveMagic[2]
|
|
b = (b ^ (b >> interleaveShift[2])) & interleaveMagic[3]
|
|
b = (b ^ (b >> interleaveShift[3])) & interleaveMagic[4]
|
|
b = (b ^ (b >> interleaveShift[4])) & interleaveMagic[5]
|
|
return b
|
|
}
|