/* * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * Copyright 2015 Danny Robson */ #ifndef __UTIL_HASH_FASTHASH_HPP #define __UTIL_HASH_FASTHASH_HPP #include "../view.hpp" #include #include // Zilong Tan's FastHash, via George Marsaglia's "Xorshift RNGs" namespace util::hash { template struct fasthash { using digest_t = ValueT; static constexpr uint64_t mix (uint64_t v) { v ^= v >> 23; v *= 0x2127599bf4325c37; v ^= v >> 47; return v; } digest_t operator() (uint64_t seed, util::view) const; }; } #endif