# Storage-Free Random Projections

*NOTE: Not all the random projections here might actually be storage-free.*


This code will focus on my current use-case for random projections.
This means the data matrix having few rows (typically between 1 and 100) and many columns (usually in the tens to hundreds of millions and up to maybe billions).
I haven't dialed in exactly what the dimensions of typical projections will be, but I'm thinking of usually between a thousand and a few thousand with a wider range of between around a hundred to around ten thousand.


To build with cmake
```bash
# cmake -DCMAKE_BUILD_TYPE=RelWithDebInfo -DCMAKE_PREFIX_PATH=`python -c 'import torch;print(torch.utils.cmake_prefix_path)'` -GNinja ..


cmake -DSET_TRUE_WHEN_ACTUALLY_BUILDING=ON \
    -DCMAKE_PREFIX_PATH=`python -c 'import torch;print(torch.utils.cmake_prefix_path)'` \
    -DPYTHON_EXECUTABLE=$(python -c "import sys; print(sys.executable)") \
    -S . -B build



cmake --build build -j 24


```

Since my editor currently doesn't have good features for cuda files, I've put all of the files that need to be
compiled with `nvcc` in the `src/cuda` directory. Header files that end with `.cc.h` can be included in C++
files. All other header files in the `src/cuda` directory are assumed to not work with C++.
