# ################ We collect data using TS, and optimal 
# ################ action is the next action (lookahead)

# # # Collect data using TS
# CUDA_VISIBLE_DEVICES=0 python3 collect_data_lookahead.py --env linear_bandit_train_lookahead_pred_reward \
#     --envs 150000 \
#     --H 100 \
#     --dim 20 \
#     --var 0.3 \
#     --cov 0.0 \
#     --lin_d 5 \
#     --envs_eval 200 \
#     --data_type TS_pred_reward \
#     --pred_reward_type non_linear

# # # Train
# CUDA_VISIBLE_DEVICES=0 python3 train_new_wt.py --env linear_bandit_train_lookahead_pred_reward \
#     --envs 150000 \
#     --H 100 \
#     --dim 20 \
#     --lin_d 5 \
#     --var 0.3 \
#     --cov 0.0 \
#     --lr 0.00015 \
#     --layer 4 \
#     --head 4 \
#     --num_epochs 1000 \
#     --batch_size 1024 \
#     --seed 1 \
#     --pred_reward_type non_linear

# # # Evaluate, choose an appropriate epoch
# CUDA_VISIBLE_DEVICES=0 python3 eval_new.py --env linear_bandit_train_lookahead_pred_reward \
#     --envs 150000 \
#     --H 100 \
#     --dim 20 \
#     --lin_d 5 \
#     --var 0.3 \
#     --cov 0.0 \
#     --lr 0.00015 \
#     --layer 4 \
#     --head 4 \
#     --epoch 150 \
#     --n_eval 200 \
#     --seed 1 \
#     --pred_reward_type non_linear



# #######################################
# #######################################
# #######################################



# # # Collect data using TS
# CUDA_VISIBLE_DEVICES=0 python3 collect_data_lookahead.py --env linear_bandit_train_lookahead_pred_reward \
#     --envs 150000 \
#     --H 150 \
#     --dim 20 \
#     --var 0.3 \
#     --cov 0.0 \
#     --lin_d 5 \
#     --envs_eval 200 \
#     --data_type TS_pred_reward \
#     --pred_reward_type non_linear

# # # Train
# CUDA_VISIBLE_DEVICES=0 python3 train_new_wt.py --env linear_bandit_train_lookahead_pred_reward \
#     --envs 150000 \
#     --H 150 \
#     --dim 20 \
#     --lin_d 5 \
#     --var 0.3 \
#     --cov 0.0 \
#     --lr 0.00015 \
#     --layer 4 \
#     --head 4 \
#     --num_epochs 1000 \
#     --batch_size 1024 \
#     --seed 1 \
#     --pred_reward_type non_linear

# # # Evaluate, choose an appropriate epoch
# CUDA_VISIBLE_DEVICES=0 python3 eval_new.py --env linear_bandit_train_lookahead_pred_reward \
#     --envs 150000 \
#     --H 150 \
#     --dim 20 \
#     --lin_d 5 \
#     --var 0.3 \
#     --cov 0.0 \
#     --lr 0.00015 \
#     --layer 4 \
#     --head 4 \
#     --epoch 150 \
#     --n_eval 200 \
#     --seed 1 \
#     --pred_reward_type non_linear



# #######################################
# #######################################
# #######################################


# # # Collect data using TS
# CUDA_VISIBLE_DEVICES=0 python3 collect_data_lookahead.py --env linear_bandit_train_lookahead_pred_reward \
#     --envs 150000 \
#     --H 200 \
#     --dim 20 \
#     --var 0.3 \
#     --cov 0.0 \
#     --lin_d 5 \
#     --envs_eval 200 \
#     --data_type TS_pred_reward \
#     --pred_reward_type non_linear

# # # Train
# CUDA_VISIBLE_DEVICES=0 python3 train_new_wt.py --env linear_bandit_train_lookahead_pred_reward \
#     --envs 150000 \
#     --H 200 \
#     --dim 20 \
#     --lin_d 5 \
#     --var 0.3 \
#     --cov 0.0 \
#     --lr 0.00015 \
#     --layer 4 \
#     --head 4 \
#     --num_epochs 1000 \
#     --batch_size 1024 \
#     --seed 1 \
#     --pred_reward_type non_linear

# # # Evaluate, choose an appropriate epoch
# CUDA_VISIBLE_DEVICES=0 python3 eval_new.py --env linear_bandit_train_lookahead_pred_reward \
#     --envs 150000 \
#     --H 200 \
#     --dim 20 \
#     --lin_d 5 \
#     --var 0.3 \
#     --cov 0.0 \
#     --lr 0.00015 \
#     --layer 4 \
#     --head 4 \
#     --epoch 150 \
#     --n_eval 200 \
#     --seed 1 \
#     --pred_reward_type non_linear


# #######################################
# #######################################
# #######################################


# # # Collect data using TS
# CUDA_VISIBLE_DEVICES=0 python3 collect_data_lookahead.py --env linear_bandit_train_lookahead_pred_reward \
#     --envs 150000 \
#     --H 250 \
#     --dim 20 \
#     --var 0.3 \
#     --cov 0.0 \
#     --lin_d 5 \
#     --envs_eval 200 \
#     --data_type TS_pred_reward \
#     --pred_reward_type non_linear

# # # Train
# CUDA_VISIBLE_DEVICES=0 python3 train_new_wt.py --env linear_bandit_train_lookahead_pred_reward \
#     --envs 150000 \
#     --H 250 \
#     --dim 20 \
#     --lin_d 5 \
#     --var 0.3 \
#     --cov 0.0 \
#     --lr 0.00015 \
#     --layer 4 \
#     --head 4 \
#     --num_epochs 1000 \
#     --batch_size 1024 \
#     --seed 1 \
#     --pred_reward_type non_linear

# # # Evaluate, choose an appropriate epoch
# CUDA_VISIBLE_DEVICES=0 python3 eval_new.py --env linear_bandit_train_lookahead_pred_reward \
#     --envs 150000 \
#     --H 250 \
#     --dim 20 \
#     --lin_d 5 \
#     --var 0.3 \
#     --cov 0.0 \
#     --lr 0.00015 \
#     --layer 4 \
#     --head 4 \
#     --epoch 150 \
#     --n_eval 200 \
#     --seed 1 \
#     --pred_reward_type non_linear




# #######################################
# #######################################
# #######################################


# # Collect data using TS
CUDA_VISIBLE_DEVICES=0 python3 collect_data_lookahead.py --env linear_bandit_train_lookahead_pred_reward \
    --envs 200000 \
    --H 300 \
    --dim 20 \
    --var 0.3 \
    --cov 0.0 \
    --lin_d 5 \
    --envs_eval 200 \
    --data_type TS_pred_reward \
    --pred_reward_type linear

# # Train
CUDA_VISIBLE_DEVICES=0 python3 train_new_wt.py --env linear_bandit_train_lookahead_pred_reward \
    --envs 200000 \
    --H 300 \
    --dim 20 \
    --lin_d 5 \
    --var 0.3 \
    --cov 0.0 \
    --lr 0.00015 \
    --layer 4 \
    --head 4 \
    --num_epochs 1000 \
    --batch_size 512 \
    --seed 1 \
    --pred_reward_type linear

# # Evaluate, choose an appropriate epoch
CUDA_VISIBLE_DEVICES=0 python3 eval_new.py --env linear_bandit_train_lookahead_pred_reward \
    --envs 200000 \
    --H 300 \
    --dim 20 \
    --lin_d 5 \
    --var 0.3 \
    --cov 0.0 \
    --lr 0.00015 \
    --layer 4 \
    --head 4 \
    --epoch 150 \
    --n_eval 200 \
    --seed 1 \
    --pred_reward_type linear