X-Git-Url: https://git.sesse.net/?p=stockfish;a=blobdiff_plain;f=src%2Fbitboard.h;h=1aefd8add5a623729652f70fc21a45076aacb5ee;hp=1140664838b47bfb875a4a4841b7c07f90c1e7e3;hb=c32904f0a049491585a043f95716f5b2c2678825;hpb=14c1fd4d27fa3bf9b4b68ffe3b088160ba6cbee4 diff --git a/src/bitboard.h b/src/bitboard.h index 11406648..1aefd8ad 100644 --- a/src/bitboard.h +++ b/src/bitboard.h @@ -395,23 +395,25 @@ inline int count_1s_max_15(Bitboard b) { inline int count_1s(Bitboard b) { unsigned w = unsigned(b >> 32), v = unsigned(b); - v = v - ((v >> 1) & 0x55555555); - w = w - ((w >> 1) & 0x55555555); - v += w; - v = (v & 0x33333333) + ((v >> 2) & 0x33333333); - v = (v + (v >> 4)) & 0x0F0F0F0F; - v = (v * 0x01010101) >> 24; // mul is fast on amd procs - return int(v); + v -= (v >> 1) & 0x55555555; // 0-2 in 2 bits + w -= (w >> 1) & 0x55555555; + v = ((v >> 2) & 0x33333333) + (v & 0x33333333); // 0-4 in 4 bits + w = ((w >> 2) & 0x33333333) + (w & 0x33333333); + v = ((v >> 4) + v) & 0x0F0F0F0F; // 0-8 in 8 bits + v += (((w >> 4) + w) & 0x0F0F0F0F); // 0-16 in 8 bits + v *= 0x01010101; // mul is fast on amd procs + return int(v >> 24); } inline int count_1s_max_15(Bitboard b) { unsigned w = unsigned(b >> 32), v = unsigned(b); - v = v - ((v >> 1) & 0x55555555); - w = w - ((w >> 1) & 0x55555555); - v += w; - v = (v & 0x33333333) + ((v >> 2) & 0x33333333); - v = (v * 0x11111111) >> 28; - return int(v); + v -= (v >> 1) & 0x55555555; // 0-2 in 2 bits + w -= (w >> 1) & 0x55555555; + v = ((v >> 2) & 0x33333333) + (v & 0x33333333); // 0-4 in 4 bits + w = ((w >> 2) & 0x33333333) + (w & 0x33333333); + v += w; // 0-8 in 4 bits + v *= 0x11111111; + return int(v >> 28); } #elif defined(BITCOUNT_SWAR_64)