- bit[meta header]
- std[meta namespace]
- function template[meta id-type]
- cpp20[meta cpp]
namespace std {
template <class T>
constexpr int popcount(T x) noexcept;
}
立っているビットを数える。popcountは「population count」の略。
- 型
T
が符号なし整数型であること
値x
の、1ビットの数を返す。
投げない
- この関数は、ハードウェア機能として提供されている場合がある
- GCCの組み込み関数として
__builtin_popcount()
、__builtin_popcountl()
、__builtin_popcountll()
が定義されていた - popcountは少なくとも1961年のCPUアーキテクチャから存在している命令であり、NSA (アメリカ国家安全保障局) の要請によって暗号解析のためアーキテクチャに導入された。この命令は幅広い用途に使われる:
- 暗号解析
- エラー訂正 (ECC, Error Correction Code)。ハミング距離 (Hamming Distance) の計算に使用する
- チェスプログラム。チェスではビットでボード情報を保持することが多く、64ビットワードに1ボードの情報が収まる。popcountによって駒の変動計算などができる
- 分子の特徴ベクトル (Molecular Fingerprinting)。分子はなんらかの方法でハッシュ化され、それらがどれくらい似ているかをpopcountで判断する
- Hash Array Mapped Tries (HAMT) アルゴリズム
- ビット配列 (標準では
std::bitset
やstd::vector<bool>
)
#include <cassert>
#include <bit>
#include <cstdint>
int main()
{
auto i = static_cast<std::uint32_t>(0b1000'0000'0000'1010'0000'0000'0000'1000u);
int n = std::popcount(i);
assert(n == 4);
}
- std::popcount[color ff0000]
- std::uint32_t[link /reference/cstdint/uint32_t.md]
- C++20
- Clang: 9.0 [mark verified]
- GCC: 9.2 [mark verified]
- Visual C++: ??