#pragma once

#include <cstdint>
#include <ATen/ATen.h>


namespace sfrp {
namespace bernoulli {
namespace sparse {


///////////////////////////////////////////////////////////////////////////////
// Random projections
// 
// layouts = row_major, must be contiguous, must have same dtype.
// mat.shape = [n_vecs, d_og]
// out.shape = [n_vecs, d_proj]

void rp_v1_xorwow_alg3(at::Tensor mat, uint32_t seed, uint64_t sparse_region_size, at::Tensor out);

void rp_v2_xorwow_alg1(at::Tensor mat, uint32_t seed, uint64_t sparse_region_size, at::Tensor out);


///////////////////////////////////////////////////////////////////////////////
// Multiplications with the transposed projection matrix.
// 
// layouts = row_major, must be contiguous, must have same dtype.
// mat.shape = [n_vecs, d_proj]
// out.shape = [n_vecs, d_og]

void trp_rp_v2_xorwow_alg1(at::Tensor mat, uint32_t seed, uint64_t sparse_region_size, at::Tensor out);




}  // sparse
}  // bernoulli
}  // sfrp
