| #!/bin/bash |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
|
|
| <<comment |
| # Usage: |
| cd scripts/ |
| DIFFUSION=<absorbing_state|uniform> |
| PROP=<qed|ring_count> |
| sbatch \ |
| --export=ALL,DIFFUSION=${DIFFUSION},PROP=${PROP} \ |
| --job-name=train_qm9_classifier_${PROP}_${DIFFUSION} \ |
| train_qm9_classifier.sh |
| comment |
|
|
| |
| cd ../ || exit |
| source setup_env.sh |
| export NCCL_P2P_LEVEL=NVL |
| export HYDRA_FULL_ERROR=1 |
|
|
| |
| |
| |
| if [ -z "${DIFFUSION}" ]; then |
| echo "DIFFUSION is not set" |
| exit 1 |
| fi |
| if [ -z "${PROP}" ]; then |
| echo "PROP is not set" |
| exit 1 |
| fi |
| T=0 |
| RUN_NAME="${PROP}_${DIFFUSION}_T-${T}" |
|
|
| |
| srun python -u -m main \ |
| mode=train_classifier \ |
| diffusion=${DIFFUSION} \ |
| T=${T} \ |
| data=qm9 \ |
| data.label_col="${PROP}" \ |
| data.label_col_pctile=90 \ |
| data.num_classes=2 \ |
| loader.global_batch_size=2048 \ |
| loader.eval_global_batch_size=4096 \ |
| classifier_backbone=dit \ |
| classifier_model=tiny-classifier \ |
| model.length=32 \ |
| optim.lr=3e-4 \ |
| lr_scheduler=cosine_decay_warmup \ |
| lr_scheduler.warmup_t=1000 \ |
| lr_scheduler.lr_min=3e-6 \ |
| callbacks.checkpoint_every_n_steps.every_n_train_steps=5_000 \ |
| callbacks.checkpoint_monitor.monitor=val/cross_entropy \ |
| trainer.val_check_interval=1.0 \ |
| trainer.max_steps=25_000 \ |
| wandb.group=train_classifier \ |
| wandb.name="qm9-classifier_${RUN_NAME}" \ |
| hydra.run.dir="${PWD}/outputs/qm9/classifier/${RUN_NAME}" |