# Automatic Reward Shaping from Multi-Objective Human Heuristics
This is the official implementation fo MORSE: Multi-Objective Reward Shaping with Exploration.
We support two types of environments. For MuJoCo tasks, refer to `Stable-Baselines3`. For Isaac Sim tasks, use `rsl_rl` and `IsaacLab`. 

## MuJoCo Environment
### Environment Setup
```bash
conda create --name morse python=3.10
conda activate morse

pip install -e .
pip install wandb
pip install gymnasium[mujoco]
pip install pybullet
pip install tqdm rich tensorboard gpustat
```

### Launching Experiments
The code for Sec. 6.1, Preliminary Validation of MORSE Exploration, can be found in `Stable-Baselines3/outer_loop/_test.py`.

We provide integrated scripts in `Stable-Baselines3/run.bash` to fully reproduce the main results and the ablation results within MuJoCo environments presented in the paper. 

We present our task definition and environment setup in `stable_baselines3/envs`. To setup new tasks, please refer to the examples. 

## Isaac Sim Environment
### Environment Setup
```bash
conda create -n env python=3.10
conda activate env

# download isaac sim
mkdir isaacsim
cd isaacsim
wget https://download.isaacsim.omniverse.nvidia.com/isaac-sim-standalone%404.5.0-rc.36%2Brelease.19112.f59b3005.gl.linux-x86_64.release.zip
unzip 


# add the following lines to ~/.bashrc
# Isaac Sim root directory
export ISAACSIM_PATH="/path/to/isaacsim"
# Isaac Sim python executable
export ISAACSIM_PYTHON_EXE="${ISAACSIM_PATH}/python.sh"
export PYTHONPATH=/path/to/rsl_rl:$PYTHONPATH

# check if python path is set correctly
${ISAACSIM_PYTHON_EXE} -c "print('Isaac Sim configuration is now complete.')"
# check if Isaac Sim can be launched from python
${ISAACSIM_PYTHON_EXE} ${ISAACSIM_PATH}/standalone_examples/api/isaacsim.core.api/add_cubes.py

cd IsaacLab
# create a symbolic link
ln -s /path/to/isaacsim _isaac_sim
cp -r conda_setup/etc $CONDA_PREFIX

./isaaclab.sh --install
./isaaclab.sh --install rsl_rl

pip install -e .
pip install wandb
pip install gymnasium[mujoco]
pip install pybullet
pip install tqdm rich tensorboard gpustat

```

### Launching Experiments
We provide integrated scripts in `IsaacLab/run.bash` to fully reproduce the main resultswithin Isaac Sim environments presented in the paper. 