#pragma once

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


namespace sfrp {
namespace bernoulli {
namespace dense {


///////////////////////////////////////////////////////////////////////////////
// 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_v2_alg3(at::Tensor mat, uint32_t seed, at::Tensor out);

void rp_v3_xorwow_alg3(at::Tensor mat, uint32_t seed, at::Tensor out);
// void rp_v3_mrg32k3a_alg3(at::Tensor mat, uint32_t seed, 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_v3_xorwow_alg1(at::Tensor mat, uint32_t seed, at::Tensor out);



}  // dense
}  // bernoulli
}  // sfrp
