#pragma once

#include <cstdint>
#include <cuda/util/editor_hack.h>


namespace sfrp {
namespace hashing {

///////////////////////////////////////////////////////////////////////////////

// __device__ __forceinline__ uint64_t fast_hash64(uint64_t x);
// __device__ __forceinline__ uint32_t fast_hash32(uint32_t x);
// __device__ __forceinline__ uint32_t fast_seeded_hash(uint32_t seed, uint64_t x);

// https://stackoverflow.com/a/12996028
__device__ __forceinline__ uint64_t fast_hash64(uint64_t x) {
    x = (x ^ (x >> 30)) * UINT64_C(0xbf58476d1ce4e5b9);
    x = (x ^ (x >> 27)) * UINT64_C(0x94d049bb133111eb);
    x = x ^ (x >> 31);
    return x;
}

// https://stackoverflow.com/a/12996028
__device__ __forceinline__ uint32_t fast_hash32(uint32_t x) {
    x = ((x >> 16) ^ x) * 0x45d9f3b;
    x = ((x >> 16) ^ x) * 0x45d9f3b;
    x = (x >> 16) ^ x;
    return x;
}


// I just made this up, IDK if it works OK.
__device__ __forceinline__ uint32_t fast_seeded_hash(uint32_t seed, uint64_t x) {
    return fast_hash32(((uint32_t) fast_hash64(x)) ^ seed);
}

///////////////////////////////////////////////////////////////////////////////

}  // hashing
}  // sfrp
