#!/bin/bash

DEBUG=false

DATA_DIR=data/
DATASETS=(Ac-Ala3-NHMe AT-AT-CG-CG AT-AT stachyose DHA buckyball-catcher double-walled-nanotube)

PROJECT=softki4
GROUP=md22-hybrid-mat-cg
EPOCHS=200
DEVICE="cuda:0"
SEEDS=(6535 8830 92357)
NUM_WORKERS=8

if $DEBUG; then
    EPOCHS=1
    SEEDS=(6535)
    GROUP=test
    DATASETS=(double-walled-nanotube)
fi

pushd ..
    for seed in "${SEEDS[@]}"
    do
        for dataset in "${DATASETS[@]}"
        do
            python run.py \
                model=softki \
                gp.softki.model.num_inducing=512 \
                gp.softki.model.device=$DEVICE \
                gp.softki.model.use_qr=true \
                gp.softki.model.use_scale=true \
                gp.softki.model.T=1 \
                gp.softki.model.use_T=true \
                gp.softki.model.learn_T=true \
                gp.softki.model.learn_noise=true \
                gp.softki.model.use_ard=true \
                gp.softki.model.mll_approx=hutchinson_fallback \
                gp.softki.model.kernel._target_=MaternKernel \
                gp.softki.model.kernel.nu=1.5 \
                gp.softki.model.hutch_solver=cg \
                gp.softki.training.seed=$seed \
                gp.softki.training.epochs=$EPOCHS \
                gp.softki.training.learning_rate=0.01 \
                data_dir=$DATA_DIR \
                dataset.name=$dataset \
                dataset.train_frac=0.9 \
                dataset.val_frac=0 \
                dataset.num_workers=$NUM_WORKERS \
                wandb.project=$PROJECT \
                wandb.group=$GROUP \
                wandb.watch=true

            python run.py \
                model=svgp \
                gp.svgp.model.num_inducing=1024 \
                gp.svgp.model.device=$DEVICE \
                gp.svgp.model.learn_noise=true \
                gp.svgp.model.use_scale=true \
                gp.svgp.model.use_ard=true \
                gp.svgp.model.kernel._target_=MaternKernel \
                gp.svgp.model.kernel.nu=1.5 \
                gp.svgp.training.seed=$seed \
                gp.svgp.training.epochs=$EPOCHS \
                gp.svgp.training.learning_rate=0.01 \
                data_dir=$DATA_DIR \
                dataset.name=$dataset \
                dataset.train_frac=0.9 \
                dataset.val_frac=0 \
                dataset.num_workers=$NUM_WORKERS \
                wandb.project=$PROJECT \
                wandb.group=$GROUP \
                wandb.watch=true

            python run.py \
                model=sgpr \
                gp.sgpr.model.num_inducing=512 \
                gp.sgpr.model.device=$DEVICE \
                gp.sgpr.model.learn_noise=true \
                gp.sgpr.model.use_ard=true \
                gp.sgpr.model.use_scale=true \
                gp.sgpr.model.kernel._target_=MaternKernel \
                gp.sgpr.model.kernel.nu=1.5 \
                gp.sgpr.training.seed=$seed \
                gp.sgpr.training.epochs=$EPOCHS \
                gp.sgpr.training.learning_rate=.1 \
                data_dir=$DATA_DIR \
                dataset.name=$dataset \
                dataset.train_frac=0.9 \
                dataset.val_frac=0 \
                dataset.num_workers=$NUM_WORKERS \
                wandb.project=$PROJECT \
                wandb.group=$GROUP \
                wandb.watch=true
        done
    done
popd