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 // apdated from org.apache.lucene.util.BitUtil // whcih 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 }