task: vlsa
cuda_id: 1
seed: 42

wandb_dir: /home/user/repo/VLSA
wandb_prj: VLSA-IFMLE-ZeroShot
save_path: ./result/exp-ifmle-zeroshot/{0}-MIZero-CONCH
save_prediction: True
eval_training_loader_per_epoch: False
ckpt_for_eval: last # last / best
num_shot: 0 # active if num_shot >= 0

# data loading
dataset_name: ['tcga_brca']
path_patch: /{1}/ExpData/{0}/tiles-20x-s448/feats-CONCH-vl-proj/pt_files
path_coord: /{1}/ExpData/{0}/tiles-20x-s448/patches
path_table: ./data_split/5foldcv/{0}/mahmoodlab_{0}_survival.csv
data_mode: patch
path_cluster: null
path_graph: null
feat_format: pt
time_format: interval # 'origin', 'ratio', 'quantile', 'interval'
time_bins: 4 # equals to the number of prompts for survival prediction
data_split_path: ./data_split/5foldcv/{0}/splits_{2}.csv
data_split_seed: [0, 1, 2, 3, 4]

# network architecture
arch: VLSA
path_clip_model: /NAS02/Others/pretrained-models
init_wt: False
net_output_converter: softmax # use to convert prediction
model_saver_module_filter: prompt_encoder # filter this module when saving the model

# API dependency
vlsa_api: CONCH # HF (HuggingFace) / CLIP (github.com/openai/clip) / CONCH (mahmoodlab/CONCH)

# logit_scale
vlsa_frozen_logit_scale: True

# [Vision] MIL encoder
vlsa_img_encoder_name: FeatMIL # FeatMIL (designed for zero-shot pred) does not involve any learnable parameters
vlsa_img_encoder_frozen: True # frozen it in zero-shot evaluation 
vlsa_img_encoder_dim_in: 512
vlsa_img_encoder_dim_hid: 256
vlsa_img_encoder_num_cls: 512
vlsa_img_encoder_use_feat_proj: False
vlsa_img_encoder_drop_rate: 0.25
# in Zero-Shot prediction, it should be one of max / mean / logit_max / logit_mean / logit_top10
# logit_xxx indicates that pooling / aggregation is applied to logits, rather than instance features.
vlsa_img_encoder_pooling: ['logit_top10', 'logit_max', 'logit_mean']  

# [Text] Text encoder
vlsa_txt_encoder_name: mahmoodlab/conch # 'vinid/plip', 'openai/clip-vit-base-patch32', 'mahmoodlab/conch'
vlsa_txt_encoder_frozen: True # frozen it in zero-shot evaluation 

# [Text] Prompt Learning
vlsa_pmt_learner_name: CoOp # CoOp / Adapter 
vlsa_pmt_learner_pretrained: False # if use the text prompts pretrained by CoOp

# [Text] CoOp-based prompt learning
vlsa_pmt_learner_coop_ckpt: null # null if not pretrained
vlsa_pmt_learner_coop_method: 'plain' # plain / rank
vlsa_pmt_learner_coop_num_ranks: 4
vlsa_pmt_learner_coop_num_base_ranks: 4
vlsa_pmt_learner_coop_num_tokens_per_rank: 4
vlsa_pmt_learner_coop_num_context_tokens: 8
vlsa_pmt_learner_coop_rank_tokens_position: tail # "tail", "front", "middle"
vlsa_pmt_learner_coop_init_prompt_path: 'tools/survival_prompts.json' # null / 'tools/survival_prompts.json'
vlsa_pmt_learner_coop_init_prompt_rank_idx: 0 # the index of rank names in `init_prompt_path`
vlsa_pmt_learner_coop_init_prompt_context_idx: 4 # the index of context in `init_prompt_path`
vlsa_pmt_learner_coop_rank_specific_context: False # True / False
vlsa_pmt_learner_coop_frozen_context_embeds: True # frozen it in zero-shot evaluation 
vlsa_pmt_learner_coop_frozen_rank_embeds: True # frozen it in zero-shot evaluation 

# [Text] Adapter-based prompt learning
vlsa_pmt_learner_adapter_method: default # default / Adapter / TaskRes
vlsa_pmt_learner_adapter_num_ranks: null # equals to time_bins, aotumatically filled
vlsa_pmt_learner_adapter_res_ratio: 0.5 # active for TaskRes
vlsa_pmt_learner_adapter_dim_reduction: 4 # active for Adapter
vlsa_pmt_learner_adapter_keep_ratio: 0.8 # active for Adapter
vlsa_pmt_learner_adapter_init_prompt_path: 'tools/survival_template_prompts.json' # null / 'tools/survival_template_prompts.json'
vlsa_pmt_learner_adapter_init_prompt_rank_idx: 0 # the index of rank names in `init_prompt_path`
vlsa_pmt_learner_adapter_init_prompt_context_idx: 0 # the index of context in `init_prompt_path`

# training loss
loss_type: SurvIFMLE # use XXX-XXX-XXX to configure multi-loss
loss_survifmle_weight: 1.0

# evaluator
evaluator: VL-IF # Reg / NLL / Cox / VL

# optimizer
opt_name: adam
opt_lr: 0.0002
opt_weight_decay: 0.00001

#training
epochs: 10
batch_size: 1
bp_every_batch: 32
num_workers: 4

# Early Stopping
es: False
es_patience: 20
es_warmup: 0
es_verbose: True
es_start_epoch: 0
monitor_metrics: loss # loss / c_index

# LR Scheduler
lrs: False
lrs_factor: 0.5
lrs_patience: 10

# In a test mode
test: False