#!/bin/bash

bash run_sweep_fk.sh

source ~/.bashrc
job_slot_to_gpu=(-1 1)


# Preflight
# env_parallel --eta -j 1 --colsep , --header : CUDA_VISIBLE_DEVICES='${job_slot_to_gpu[{%}]}' 'python src/userfm/main.py -c job +experiment=Steer{dynamical_system} steering=SourceParallelTempering steering.chain_count={chain_count} steering.update_count={update_count} steering.tilt={tilt} steering.penalization_power={penalization_power} model.conf={model_alt_id}' ::: $(duckdb runs.sqlite -c "copy (select * from SweepTrainedModel cross join SweepSPTUpdateCount cross join SweepSPTChainCount cross join SweepPenalizationPower order by dynamical_system desc) to '/dev/stdout'")
# env_parallel --eta -j 1 --colsep , --header : CUDA_VISIBLE_DEVICES='${job_slot_to_gpu[{%}]}' 'python src/userfm/main.py -c job +experiment=Steer{dynamical_system} steering=SourceParallelTempering steering.chain_count={chain_count} steering.update_count={update_count} steering.tilt={tilt} steering.penalization_power=0 model.conf={model_alt_id}' ::: $(duckdb runs.sqlite -c "copy (select * exclude tilt, SweepTilt.tilt from SweepTrainedModel natural join BestSPTParameter cross join SweepTilt where penalization_power = 0 order by dynamical_system desc, SweepTilt.tilt) to '/dev/stdout'")
# Go
# env_parallel --delay 120 --eta -j $((${#job_slot_to_gpu[@]} - 1)) --colsep , --header : CUDA_VISIBLE_DEVICES='${job_slot_to_gpu[{%}]}' 'python src/userfm/main.py +experiment=Steer{dynamical_system} steering=SourceParallelTempering steering.chain_count={chain_count} steering.update_count={update_count} steering.tilt={tilt} steering.penalization_power={penalization_power} model.conf={model_alt_id}' ::: $(duckdb runs.sqlite -c "copy (select * from SweepTrainedModel cross join SweepSPTUpdateCount cross join SweepSPTChainCount cross join SweepPenalizationPower order by dynamical_system desc) to '/dev/stdout'")
# env_parallel --delay 30 --eta -j $((${#job_slot_to_gpu[@]} - 1)) --colsep , --header : CUDA_VISIBLE_DEVICES='${job_slot_to_gpu[{%}]}' 'python src/userfm/main.py +experiment=Steer{dynamical_system} steering=SourceParallelTempering steering.chain_count={chain_count} steering.update_count={update_count} steering.tilt={tilt} steering.penalization_power=0 model.conf={model_alt_id}' ::: $(duckdb runs.sqlite -c "copy (select * exclude tilt, SweepTilt.tilt from SweepTrainedModel natural join BestSPTParameter cross join SweepTilt where penalization_power = 0 order by dynamical_system desc, SweepTilt.tilt) to '/dev/stdout'")
env_parallel --eta --line-buffer -j $((${#job_slot_to_gpu[@]} - 1)) --colsep , --header : CUDA_VISIBLE_DEVICES='${job_slot_to_gpu[{%}]}' 'python src/userfm/main.py -c job +experiment=Steer{dynamical_system} steering=SourceParallelTempering steering.chain_count={chain_count} steering.update_count={update_count} steering.tilt={tilt} steering.penalization_power=0 model.conf={model_alt_id} dataset.time_step_count={time_step_count} log_constraint_values=true' ::: $(duckdb runs.sqlite -c "copy (select Conf.alt_id as model_alt_id, SweepTrajectoryLength.time_step_count, SweepModelTrained.tilt, BestSPTParameter.* from Conf join TrainingAndEvaluation on Conf.id = TrainingAndEvaluation.id join Dataset on TrainingAndEvaluation.Dataset = Dataset.id join DynamicalSystem on Dataset.id = DynamicalSystem.id join SweepTrajectoryLength on (Dataset.sa_inheritance = SweepTrajectoryLength.dynamical_system and DynamicalSystem.time_step_count = SweepTrajectoryLength.time_step_count) join SweepModelTrained on (SweepTrajectoryLength.dynamical_system = SweepModelTrained.dynamical_system) join BestSPTParameter on BestSPTParameter.dynamical_system = SweepTrajectoryLength.dynamical_system where fit and penalization_power = 0) to '/dev/stdout'")
