#pragma once
// Common utilities for the bernoulli style of random projections.

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


namespace sfrp {
namespace bernoulli {

// // Returns -1 if even and 1 if odd.
// __device__ __forceinline__ float parity_as_pm1(uint32_t x);


// // Returns -1 if the bit_index-th bit is even and 1 if it is odd.
// __device__ __forceinline__ float bit_parity_as_pm1(uint32_t x, uint8_t bit_index);


__device__ __forceinline__ float parity_as_pm1(uint32_t x) {
    return (float) (2 * (int) (x % 2) - 1);
}

__device__ __forceinline__ float bit_parity_as_pm1(uint32_t x, uint8_t bit_index) {
    return parity_as_pm1(x >> bit_index);
}


}  // bernoulli
}  // sfrp
