|
template<typename Integer > |
std::size_t | ph::math::discrete_spatial_hash (Integer x, Integer y, Integer z, std::size_t hashTableSize) |
|
template<typename Integer > |
std::size_t | ph::math::discrete_spatial_hash (Integer x, Integer y, std::size_t hashTableSize) |
|
template<std::integral T> |
std::size_t | ph::math::discrete_spatial_hash (const TVector3< T > &point, std::size_t hashTableSize) |
|
template<std::floating_point T> |
std::size_t | ph::math::discrete_spatial_hash (const TVector3< T > &point, const TVector3< T > &cellSize, std::size_t hashTableSize) |
|
uint32 | ph::math::murmur3_bit_mix_32 (uint32 v) |
| MurmurHash3's bit mixer. 32-bit version.
|
|
uint64 | ph::math::murmur3_bit_mix_64 (uint64 v) |
| MurmurHash3's bit mixer. 64-bit version.
|
|
uint64 | ph::math::murmur3_v13_bit_mix_64 (uint64 v) |
| MurmurHash3's bit mixer. 64-bit version.
|
|
uint64 | ph::math::moremur_bit_mix_64 (uint64 v) |
| A MurmurHash3-style bit mixer that outperforms the original by quite some margin. 64-bit version.
|
|
template<typename T , typename BitMixerType = Murmur3BitMixer32> |
uint32 | ph::math::murmur3_32 (const T &data, uint32 seed) |
| Generate 32-bit hash values using MurmurHash3. Note that there are no collisions when T has <= 32 bits (two distinct inputs will not result in the same output). In general, if there is a way to reverse a function (reversing murmur3_32() is possible), it is guaranteed there cannot be any collisions. Otherwise, it would not be possible to revert.
|
|
template<typename T , typename BitMixerType > |
uint32 | ph::math::murmur3_32 (const T *data, std::size_t dataSize, BitMixerType &&bitMixer, uint32 seed) |
| Generate 32-bit hash values using MurmurHash3. This is a lower level variant of MurmurHash3 and can be useful for customizing its behavior, e.g., it can accept arbitrary BitMixerType without requiring it to be default constructible.
|
|
uint32 | ph::math::permuted_index (uint32 i, uint32 l, uint32 p) |
| Get the permuted index or value in O(1) space and O(1) time.
|
|