#include <cstdint>

#include <torch/extension.h>


// // Dimension of random projection, seed for random projection.
// void cuda_rand_proj_hypercubic_v01(torch::Tensor out, torch::Tensor x, uint64_t seed);


// TODO: As first pass, have something that constructs the projection matrices explicitly.
//  - Useful for testing/benchmarking.
//  - Can examine the random projection matrices and see if they are good or have any problems with them.



// out.shape = [d_proj, d_og], layout = row_major, must be contiguous.
void cuda_make_rand_proj_hypercubic_mat_v01(torch::Tensor out, uint32_t seed);


// layouts = row_major, must be contiguous, must have same dtype.
// mat.shape = [n_vecs, d_og]
// out.shape = [n_vecs, d_proj]
void cuda_rand_proj_hypercubic_v01_alg01(torch::Tensor mat, uint32_t seed, torch::Tensor out);
void cuda_rand_proj_hypercubic_v01_alg02(torch::Tensor mat, uint32_t seed, torch::Tensor out);
void cuda_rand_proj_hypercubic_v01_alg03(torch::Tensor mat, uint32_t seed, torch::Tensor out);

void cuda_rand_proj_hypercubic_v02_alg03(torch::Tensor mat, uint32_t seed, torch::Tensor out);


