# **Installation** ( [Linux - Ubuntu 20.04](https://releases.ubuntu.com/focal/) )

It is advised to create a workspace in your home directory ( `/home/<YOU>/` ) that will contain all needed repository and data :

```powershell
cd /home/<YOU>/
mkdir -p workspace_continual
```

From now on, it is supposed we have such a workspace ( `/home/<YOU>/workspace_continual/` ).

As we use [Hydra](https://hydra.cc/docs/intro/) it is advised to verify (and to modify) the paths considered in the `.yaml` configurations files

It is also advised to install diverse apt-get requirements :

```bash
sudo apt-get update
sudo apt-get upgrade
sudo apt-get install -y apt-utils
sudo apt-get install -y software-properties-common
sudo add-apt-repository ppa:deadsnakes/ppa
sudo apt-get install -y gnupg2
sudo apt-get install -y wget
sudo apt-get install -y git
sudo apt-get install -y curl
sudo apt-get install -y libosmesa6-dev libgl1-mesa-glx libglfw3
sudo apt-get install -y patchelf
```

## **1. Python**

### **1.A. Python Installation**

Follow the instructions in the provided links to install the latest version of either [Anaconda](https://docs.anaconda.com/free/anaconda/install/windows/), [Miniconda](https://docs.anaconda.com/free/miniconda/index.html), or [Miniforge](https://github.com/conda-forge/miniforge).

Here is how to simply do it with **Miniforge** :

```bash
cd /home/<YOU>/
mkdir -p downloads
cd downloads/
wget https://github.com/conda-forge/miniforge/releases/latest/download/Miniforge3-Linux-x86_64.sh
chmod +x *
bash Miniforge3-Linux-x86_64.sh
```

The installation should be done after following the prompts and refreshing the terminal.

### **1.B. Conda Channels Setup**

Create a `.condarc` file in your home directory ( `/home/<YOU>/` ) and edit it with thie following content :

```text
channels:
    - conda-forge
```

Add additional channels for package installation :

```bash
conda config --env --add channels nvidia
conda config --env --add channels pytorch
```

And update conda :

```bash
conda update -n base -c conda-forge --override-channels conda
```

Here is a command to show the channels :

```bash
conda config --show channels
```

### **1.C. Conda Environment Setup**

It is advised to create a workspace containing all needed repository and data :

And to create a new environment :

```bash
conda create -n continual python=3.10 -y
conda activate continual
conda install -c conda-forge pip
conda install -c nvidia cuda-toolkit=12.1
conda install -c conda-forge --override-channels mesalib glew glfw
conda install -c conda-forge --override-channels libgcc -y
conda install -c conda-forge --override-channels patchelf
python -m pip install --upgrade pip
```

From now on, it is supposed we are working within such an environment (`continual`).

## **2. Required Packages & Libraries**

Preparations :

```bash
python -m pip install "cython<3"
```

### **2.A. MuJoCo [ For MuJoCo Environments ]**

#### *2.A.1. MuJoCo*

Download and unzip the MuJoCo 2.1.0 engine library (don't forget to replace `/home/<YOU>/` by your own home path) :

```bash
cd /home/<YOU>/downloads/
wget https://github.com/deepmind/mujoco/releases/download/2.1.0/mujoco210-linux-x86_64.tar.gz
cd ..
mkdir -p .mujoco
tar -xf ./downloads/mujoco210-linux-x86_64.tar.gz --directory .mujoco
```

Then add the following line to your `.bashrc` file and reload the terminal to make it effective :

```bash
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/<YOU>/.mujoco/mujoco210/bin
export MUJOCO_PY_MUJOCO_PATH=/home/<YOU>/.mujoco/mujoco210
```

#### *2.A.2. MuJoCo-Py*

Add the following line to your `.bashrc` and reload the terminal :

```bash
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/lib/nvidia
```

Then execute this command :

```bash
pip install mujoco_py
```

When it will be done you may encounter some rendering issues. In prevention, we invite you to modify the file `/home/<YOU>/miniforge3/envs/continual/lib/python3.10/site-packages/gymnasium/envs/mujoco/mujoco_rendering.py` at the line 593.

Replace :

```code
self.data.solver_iter
```

By :

```code
self.data.solver_niter
```

### **2.B. PyTorch**

Run this command :

```bash
python -m pip install torch torchvision
```

### **2.C. Godot Requirements**

Run these commands:

```bash
cd /home/<YOU>/workspace_continual/
cd /continual/python/envs/godot/executables/
chmod +x *
```

## **3. Main Repository**

### **3.A. Installation**

Copy this `CODE` folder within the workspace and follow these commands to install the main project :

```bash
cd /home/<YOU>/workspace_continual/CODE/python
python -m pip install -r requirements.txt
python -m pip install -e .
pip install "numpy==1.26.4"
pip install "dm_control<=1.0.20" "mujoco<=3.1.6"
```
