Skip to content

Baselines for Model-Based Optimization installation fixes and compatible with newer AMPERE+ GPUs (e.g. 3090)

License

Notifications You must be signed in to change notification settings

kaist-silab/design-baselines-fixes

Repository files navigation

Design-Baselines-Fix

Baselines for Model-Based Optimization installation guide and fixes to make it compatible with AMPERE and newever GPUs (e.g. 3090 etc.)

Tested on the following configurations:

  • Ubuntu 22.04, 1x3090, CUDA 12.1
  • Ubuntu 18.04, 8x3090, CUDA 11.4

Original repository: https://github.com/brandontrabucco/design-baselines

Fixes

We make several installation fixes. Our goal is to make the benchmark work for GPUs with Ampere (e.g. Nvidia 3090) and more recent architectures. We also fix some issues with the installation process.

Changes:

  • Make Mujoco installation optional
  • Fixed super().__init__() for some nets
  • Fixed requirements.txt to include new TF and more
  • Updated environment.yml for latest cudnn and cudatoolkit
  • Updated design-bench to avoid importing error with gym
  • Installation described below

Quick installation

After installing conda, you may run the following script to install the benchmark:

bash install.sh

you may also choose whether to install Mujoco or not via the script.

Full guide

Before installing the main Conda enviroment, make sure to install the following as well as Conda.

Conda environment

Create a new conda environment:

conda create -f environment.yml

Mujoco (Optional)

  1. Download mujoco200 from here https://www.roboti.us/download.html, and extract it to .mujoco/mujoco200 (rename it to mujoco200).
  2. Then I have to install the license from here https://www.roboti.us/file/mjkey.txt to .mujoco/mjkey.txt.
  3. Update the environment export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/home/$USER/.mujoco/mujoco200/bin
  4. Install with
pip install mujoco-py==2.0.2.3

Remember to install the following packages required by design-baselines:

 pip install Cython==0.29.21  robel==0.1.2 morphing-agents==1.5.1 design-bench[all]==2.0.20

TensorRT

First:

pip install nvidia-pyindex nvidia-tensorrt

After installing TensorRT, we need to link libnvinfer.so.8 to libnvinfer.so.7 as well as its plugin.

find / -name libnvinfer.so.8

this will give e.g. $PATH/site-packages/tensorrt/libnvinfer.so.8 (where $PATH is the path to your conda environment)

then:

sudo ln -s $PATH/site-packages/tensorrt/libnvinfer.so.8 $PATH/site-packages/tensorrt/libnvinfer.so.7
sudo ln -s $PATH/site-packages/tensorrt/libnvinfer_plugin.so.8 $PATH/site-packages/tensorrt/libnvinfer_plugin.so.7

Finally, add the following to your .bashrc:

export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$PATH/site-packages/tensorrt/

Set environment variables

Set the environment variables as follows:

conda env config vars set LD_LIBRARY_PATH=$CONDA_PREFIX/lib:$(dirname $(dirname $(which python)))/lib:$(dirname $(find "$(dirname $(dirname $(which python)))" -name "*libnvinfer.so.8")):~/.mujoco/mujoco200/bin
conda env config vars set XLA_FLAGS=--xla_gpu_cuda_data_dir=/usr/lib/cuda

Finally, reactivate the environment:

conda activate design-baselines

It should work now. If you get an error, try to install the packages manually.

Test if it works

python -c 'import tensorflow as tf;  tf.test.is_gpu_available(cuda_only=False)' 

If you get some errors, try manually installing the packages or ask ChatGPT / Google. You can also submit an issue here, but I am not sure if I can help you.

Finally, you may try running

bash test.sh

by first subsituting in the file NUM_CPUS=20 and NUM_GPUS=1 with the number of CPUs and GPUs you have. This will run the benchmark command in the description below.

Feedback

If you have any feedback or would like to improve the installation process, please submit a pull request or an issue ;)


Original Package README

Design-Baselines is a set of baseline algorithms for solving automatic design problems that involve choosing an input that maximizes a black-box function. This type of optimization is used across scientific and engineering disciplines in ways such as designing proteins and DNA sequences with particular functions, chemical formulas and molecule substructures, the morphology and controllers of robots, and many more applications.

These applications have significant potential to accelerate research in biochemistry, chemical engineering, materials science, robotics and many other disciplines. We hope this set of baselines serves as a robust platform to drive these applications and create widespread excitement for model-based optimization.

COMs Website: link | COMs Paper: arXiv

If these applications interest you, consider using our benchmark: design-bench, which you may install to python and automatically download benchmark data using pip install design-bench==2.0.12.

Offline Model-Based Optimization

Offline Model-Based Optimization

The goal of model-based optimization is to find an input x that maximizes an unknown black-box function f. This function is frequently difficulty or costly to evaluate---such as requiring wet-lab experiments in the case of protein design. In these cases, f is described by a set of function evaluations: D = {(x_0, y_0), (x_1, y_1), ... (x_n, y_n)}, and optimization is performed without querying f on new data points.

Installation

Design-Baselines can be downloaded from github and installed using anaconda.

git clone [email protected]:brandontrabucco/design-baselines.git
conda create -f design-baselines/environment.yml

Performance Of Baselines

We benchmark a set of 9 methods for solving offline model-based optimization problems. Performance is reported in normalized form, where the 100th percentile score of 128 candidate designs is evaluated and normalized such that a 1.0 corresponds to performance equivalent to the best performing design in the full unobserved dataset assoctated with each model-based optimization task. A 0.0 corresponds to performance equivalent to the worst performing design in the full unobserved dataset. In circumstances where an exact oracle is not available, this full unobserved dataset is used for training the approximate oracle that is used for evaluation of candidate designs proposed by each method. The symbol ± indicates the empirical standard deviation of reported performance across 8 trials.

Performance On Continuous Tasks

Method \ Task Superconductor Ant Morphology D'Kitty Morphology Hopper Controller
D (best) 0.399 0.565 0.884 1.0
Auto. CbAS 0.421 ± 0.045 0.884 ± 0.046 0.906 ± 0.006 0.137 ± 0.005
CbAS 0.503 ± 0.069 0.879 ± 0.032 0.892 ± 0.008 0.141 ± 0.012
BO-qEI 0.402 ± 0.034 0.820 ± 0.000 0.896 ± 0.000 0.550 ± 0.118
CMA-ES 0.465 ± 0.024 1.219 ± 0.738 0.724 ± 0.001 0.604 ± 0.215
Grad. 0.518 ± 0.024 0.291 ± 0.023 0.874 ± 0.022 1.035 ± 0.482
Grad. Min 0.506 ± 0.009 0.478 ± 0.064 0.889 ± 0.011 1.391 ± 0.589
Grad. Mean 0.499 ± 0.017 0.444 ± 0.081 0.892 ± 0.011 1.586 ± 0.454
MINs 0.469 ± 0.023 0.916 ± 0.036 0.945 ± 0.012 0.424 ± 0.166
REINFORCE 0.481 ± 0.013 0.263 ± 0.032 0.562 ± 0.196 -0.020 ± 0.067
COMs (Ours) 0.439 ± 0.033 0.944 ± 0.016 0.949 ± 0.015 2.056 ± 0.314

Performance On Discrete Tasks

Method \ Task GFP TF Bind 8 UTR
D (best) 0.789 0.439 0.593
Auto. CbAS 0.865 ± 0.000 0.910 ± 0.044 0.691 ± 0.012
CbAS 0.865 ± 0.000 0.927 ± 0.051 0.694 ± 0.010
BO-qEI 0.254 ± 0.352 0.798 ± 0.083 0.684 ± 0.000
CMA-ES 0.054 ± 0.002 0.953 ± 0.022 0.707 ± 0.014
Grad. 0.864 ± 0.001 0.977 ± 0.025 0.695 ± 0.013
Grad. Min 0.864 ± 0.000 0.984 ± 0.012 0.696 ± 0.009
Grad. Mean 0.864 ± 0.000 0.986 ± 0.012 0.693 ± 0.010
MINs 0.865 ± 0.001 0.905 ± 0.052 0.697 ± 0.010
REINFORCE 0.865 ± 0.000 0.948 ± 0.028 0.688 ± 0.010
COMs (Ours) 0.864 ± 0.000 0.945 ± 0.033 0.699 ± 0.011

Reproducing Baseline Performance

To reproduce the performance of baseline algorithms reported in our work, you may then run the following series of commands in a bash terminal using the command-line interface exposed in design-baselines. Also, please ensure that the conda environment design-baselines is activated in the bash session that you run these commands from in order to access the design-baselines command-line interface.

# set up machine parameters
NUM_CPUS=32
NUM_GPUS=8

for TASK_NAME in \
    superconductor \
    ant \
    dkitty \
    hopper \
    gfp \
    tf-bind-8 \
    utr; do
    
  for ALGORITHM_NAME in \
      autofocused-cbas \
      cbas \
      bo-qei \
      cma-es \
      gradient-ascent \
      gradient-ascent-min-ensemble \
      gradient-ascent-mean-ensemble \
      mins \
      reinforce; do
  
    # launch several model-based optimization algorithms using the command line interface
    # for example: 
    # (design-baselines) name@computer:~/$ cbas gfp \
    #                                        --local-dir ~/db-results/cbas-gfp \
    #                                        --cpus 32 \
    #                                        --gpus 8 \
    #                                        --num-parallel 8 \
    #                                        --num-samples 8
    $ALGORITHM_NAME $TASK_NAME \
      --local-dir ~/db-results/$ALGORITHM_NAME-$TASK_NAME \
      --cpus $NUM_CPUS \
      --gpus $NUM_GPUS \
      --num-parallel 8 \
      --num-samples 8
    
  done
  
done

# generate the main performance table of the paper
design-baselines make-table --dir ~/db-results/ --percentile 100th

# generate the performance tables in the appendix
design-baselines make-table --dir ~/db-results/ --percentile 50th
design-baselines make-table --dir ~/db-results/ --percentile 100th --no-normalize

These commands will run several model-based optimization algorithms (such as CbAS) contained in design-baselines on all tasks released with the design-bench benchmark, and will then generate three performance tables from those results, and print a latex rendition of these performance tables to stdout.

Running COMs

You may run COMs using the design-baselines command line interface in a bash session where the design-baselines anaconda environments is activated and the design-baselines pip package is installed. Below is an example command that will run COMs on the task HopperController-Exact-v0 from design-bench.

coms --logging-dir ./coms-hopper \
     --not-fast \
     --task HopperController-Exact-v0 \
     --no-task-relabel \
     --normalize-ys \
     --normalize-xs \
     --particle-lr 0.05 \
     --particle-train-gradient-steps 50 \
     --particle-evaluate-gradient-steps 50 \
     --particle-entropy-coefficient 0.0 \
     --forward-model-activations relu \
     --forward-model-activations relu \
     --forward-model-hidden-size 2048 \
     --forward-model-lr 0.0003 \
     --forward-model-alpha 0.1 \
     --forward-model-alpha-lr 0.01 \
     --forward-model-overestimation-limit 0.5 \
     --forward-model-noise-std 0.0 \
     --forward-model-batch-size 128 \
     --forward-model-val-size 500 \
     --forward-model-epochs 50 \
     --evaluation-samples 128

About

Baselines for Model-Based Optimization installation fixes and compatible with newer AMPERE+ GPUs (e.g. 3090)

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published