-
On Ubuntu install C++ tools,
sudo apt-get install build-essential libssl-dev
-
Install CMAKE,
sudo snap install cmake -classic
-
Install JDK 11. If not installed, download "Oracle Java 11 JDK".
-
Make sure that
JAVA_HOME
is set to the JDK 11 directory. -
Make sure your alternatives for java and javac point to the Oracle Java 11 JDK.
-
Add
$JAVA_HOME/bin
to yourPATH
in.bashrc
,export PATH = ${PATH}:$JAVA_HOME/bin
-
Add the following environmental variables:
export JAVA_INCLUDE_PATH=$JAVA_HOME/include/
export JAVA_INCLUDE_PATH2=$JAVA_HOME/include/linux/
export JAVA_AWT_INCLUDE_PATH=$JAVA_HOME/include/
-
Update your environment,
source .bashrc
-
Install IntelliJ IDEA,
a) install Python plugin,
b) install Kotlin plugin,
c) install Kotlin Notebook plugin,
d) configure Kotlin Notebook plugin.
-
Install CUDA 11.? from NVIDIA (should work with the most current version, if not 11.1),
https://developer.nvidia.com/cuda-downloads
-
Install cuDNN from NVDIA,
https://developer.nvidia.com/rdp/cudnn-download
-
Install OpenBlas,
sudo apt-get install libopenblas-dev
-
Create a github account if you do not have one.
-
Setup your github account to use ssh.
-
Setup your github account to use a token.
-
Install github tools,
sudo apt-get install gh
-
Install the token into github tools.
-
Fork facebookresearch/diffkt to you github account.
-
Clone the fork to your local computer.
gh repo clone {github-id}/diffkt
-
Check your local DiffKt project to see if the original facebookresearch/diffkt.git is upstream,
cd {your git projects}/diffkt
git remote -v
You should see
origin [email protected]:{gethub id}/diffkt.git (fetch)
origin [email protected]:{gethub id}/diffkt.git (push)
upstream [email protected]:facebookresearch/diffkt.git (fetch)
upstream [email protected]:facebookresearch/diffkt.git (push)
If you are missing upstream, execute the following.
git remote add upstream [email protected]:facebookresearch/diffkt.git
-
Read the github docs for merging your local repository with upstream,
https://docs.github.com/en/pull-requests/collaborating-with-pull-requests/working-with-forks/syncing-a-fork
-
In general, pull from upstream and merge, but checkin to origin (your fork) and do a pull request to merge with upstream,
-
cd {you project}/diffkt/cpp/ops
-
Read the README.md,
-
Install OpenMP,
sudo apt install libomp-dev
and/or
sudo apt-get install libgomp1
-
Install Eigen,
sudo apt-get install libeigen3-dev
-
Install the Intel oneAPI Base Toolkit.
-
Add the proper oneAPI libraries to link. DiffKt uses version 2.1.0, which is different from the Base Toolkit,
cd {your projects}diffkt/cpp/ops
wget $(fwdproxy-config wget) https://github.com/oneapi-src/oneDNN/releases/download/v2.1/dnnl_lnx_2.1.0_cpu_gomp.tgz
tar -zxvf dnnl_lnx_2.1.0_cpu_gomp.tgz
mv dnnl_lnx_2.1.0_cpu_gomp dnnl
-
mkdir build
-
cd build
-
cmake ..
-
make VERBOSE=1
-
If make completed without error, then the ops directory should be built and installed as the following:
{your projects}/diffkt/kotlin/api/src/main/resources/libdnnlops_jni.so
{your projects}/diffkt/kotlin/api/src/main/resources/libops_jni.so
{your projects}/diffkt/kotlin/api/src/main/resources/libsparseops_jni.so
-
cd {your projects}/diffkt/cpp/gpuops
-
Read the README.md.
-
source /opt/intel/oneapi/setvars.sh
Note: You may have link issues with the Intel libraries. For a quick work around, create a symbolic link in /usr/lib to the library that is not linking.
-
Install libtorch in the gpuops directory. .gitignore is set to ignore the directory,
wget $(fwdproxy-config wget) https://download.pytorch.org/libtorch/lts/1.8/cu111/libtorch-cxx11-abi-shared-with-deps-1.8.2%2Bcu111.zip
unzip libtorch-cxx11-abi-shared-with-deps-1.8.2%2Bcu111.zip
rm libtorch-cxx11-abi-shared-with-deps-1.8.2%2Bcu111.zip
-
mkdir build
-
cd build
-
cmake ..
-
make VERBOSE=1 -j
-
If make completed without error, then the gpuops directory should be built and installed as the following,
{your projects}/diffkt/kotlin/api/src/main/resources/libgnuops_jni.so
-
Make sure your default shell is bash and that sh links to bash.
-
cd {your projects}/diffkt/kotlin
-
Read the README.md.
-
At GitHub make sure your token has "read:packages" scope.
-
Create the file
github.env
with the following in it,GITHUB_ACTOR={your username}
GITHUB_TOKEN={your access token with the read:packages permission}
-
Start intellij.
-
Open {you projects}/diffkt/kotlin
-
Using Gradle, build the project.