Module: BitsCount::Primitive
- Defined in:
- lib/bits_count/primitive.rb
Constant Summary collapse
- UNPACK_PATTERN =
"B*"- WORDBITS =
Hash[0.upto(2**16-1).map{|i| [i, population_count_int32(i)] }].freeze
Class Method Summary collapse
- .population_count_int32(i) ⇒ Object
- .population_count_map(i) ⇒ Object
- .population_count_str(s) ⇒ Object
Class Method Details
.population_count_int32(i) ⇒ Object
8 9 10 11 12 13 14 15 |
# File 'lib/bits_count/primitive.rb', line 8 def population_count_int32(i) i = i - ((i >> 1) & 0x55555555) i = (i & 0x33333333) + ((i >> 2) & 0x33333333) i = (i + (i >> 4)) & 0x0F0F0F0F i = i + (i >> 8) i = i + (i >> 16) i & 0x0000003F end |
.population_count_map(i) ⇒ Object
22 23 24 |
# File 'lib/bits_count/primitive.rb', line 22 def population_count_map(i) WORDBITS[i&0xFFFF] + WORDBITS[i>>16] end |
.population_count_str(s) ⇒ Object
18 19 20 |
# File 'lib/bits_count/primitive.rb', line 18 def population_count_str(s) s.unpack(UNPACK_PATTERN).first.count(?1) end |