mirror of
				https://github.com/go-gitea/gitea
				synced 2025-09-28 03:28:13 +00:00 
			
		
		
		
	* update bleve to master b17287a86f6cac923a5d886e10618df994eeb54b6724eac2e3b8dde89cfbe3a2 * remove unused pkg from dep file * change bleve from master to recent revision
		
			
				
	
	
		
			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
 | |
| // apdated 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
 | |
| }
 |