[解決済み] boost::hash_combine のマジックナンバー
2022-12-08 22:42:53
質問
質問
boost::hash_combine
テンプレート関数は、ハッシュへの参照(
seed
と呼ばれる)とオブジェクト
v
. によると
ドキュメントによると
によると、それは
seed
のハッシュと
v
によって
seed ^= hash_value(v) + 0x9e3779b9 + (seed << 6) + (seed >> 2);
これが決定論的であることがわかります。XORが使われる理由もわかります。
足し算は似たような値を大きく離してマッピングするのに役立つので、ハッシュテーブルのプロービングが破綻しないのは確かですが、魔法の定数が何なのか、誰か説明してくれませんか?
どのように解決するのですか?
マジックナンバーは32のランダムなビットで、それぞれが0か1である可能性が等しく、ビット間に単純な相関がないものとされています。このようなビットの文字列を見つける一般的な方法は、無理数の 2 進展開を使用することで、この場合、その数は黄金比の逆数となります。
phi = (1 + sqrt(5)) / 2
2^32 / phi = 0x9e3779b9
つまり、この数字を含めると、シードの各ビットがランダムに変更されます。古い種をシフトしたものを含めることで、仮に
hash_value()
がかなり小さな値の範囲であったとしても、違いはすぐにすべてのビットに広がります。
関連
-
[解決済み】C++ クラスヘッダが含まれているときに「不明な型」があるのはなぜですか?重複
-
[解決済み】リンカーエラーです。"リンカ入力ファイルはリンクが行われていないため未使用"、そのファイル内の関数への未定義参照
-
[解決済み】エラー。引数リストに一致するコンストラクタのインスタンスがない
-
[解決済み] UbuntuにBoostをインストールする方法
-
[解決済み] 簡単な面接問題が難しくなった:1~100の数字が与えられたとき、ちょうどk個の数字が欠けていることを見つけなさい。
-
[解決済み] 32ビット整数のセットビットの数を数えるには?
-
[解決済み] ある数字が2の累乗かどうかを確認する方法
-
[解決済み] 23,148,855,308,184,500は魔法の数字なのか、それとも単なる偶然なのか?
-
[解決済み】Visual Studio 2010でBoostを使用する方法
-
[解決済み】スマートポインタ(boost)の説明
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
[解決済み】 unsigned int vs. size_t
-
[解決済み] クラスにデフォルトコンストラクタが存在しない。
-
[解決済み】C++エラー:の初期化に一致するコンストラクタがありません。
-
[解決済み】浮動小数点例外エラーが発生する: 8
-
[解決済み】ファイルから整数を読み込んで配列に格納する C++ 【クローズド
-
[解決済み】システムが指定されたファイルを見つけられませんでした。
-
[解決済み】警告 - 符号付き整数式と符号なし整数式の比較
-
[解決済み] スタックアロケーションにより初期化されていない値が作成された
-
[解決済み] C++ - ハッシュ値を結合するのにboost::hash_combineが最適なのはなぜですか?
-
[解決済み】コレクションのhashCodeメソッドの最適な実装について