data_module:
  _target_: data_module.finetune_data_module.FinetuneModule
  name: ecg
  cfg:
    num_workers: ${num_workers}
    batch_size: ${batch_size}
  train:
    _target_: datasets.emg_finetune_dataset.FinetuneDataset
    file_path: /leonardo_scratch/large/userexternal/ychen003/ECG_Finetune/shaoxing/train.h5
    transform: false
  val:
    _target_: datasets.emg_finetune_dataset.FinetuneDataset
    file_path: /leonardo_scratch/large/userexternal/ychen003/ECG_Finetune/shaoxing/val.h5
    transform: false
  test:
    _target_: datasets.emg_finetune_dataset.FinetuneDataset
    file_path: /leonardo_scratch/large/userexternal/ychen003/ECG_Finetune/shaoxing/test.h5
    transform: false
task:
  _target_: tasks.classification_task.ClassificationTask
  freeze_backbone: false
  layerwise_lr_decay: 1.0
  freq_mask_param: 0
  time_mask_param: 0
  noise_level: 0.0
  augment_prob: 0.0
  transform: null
scheduler:
  _target_: schedulers.cosine_lr.CosineLRSchedulerWrapper
  trainer: ${trainer}
  warmup_epochs: 5
  min_lr: 5.0e-06
  warmup_lr_init: 5.0e-07
  t_in_epochs: false
model:
  _target_: models.waveecg.ChannelVisionTransformer
  in_ch: 12
  max_level: 4
  wave_kernel_size: 24
  wavelet_names:
  - sym4
  - sym5
  - db6
  - coif3
  - bior4.4
  use_separate_channel: true
  ffn_ratio: 4.0
  ffn_kernel_size: 5
  ffn_drop: 0.1
  hw_square_kernel: 3
  hw_band_kernel: 15
  reduced_dim: 24
  timesteps: 1024
  patch_size:
  - 1
  - 64
  embed_dim: 512
  depth: 12
  num_heads: 16
  mlp_ratio: 4.0
  drop_path: 0.1
  attention_type: wavelet_enhanced
  masking_ratio: 0.65
  importance_ratio: 0.7
  use_masking: false
  max_seq_len: 2048
model_head:
  _target_: models.model_heads.cls_classification_head.CLSClassificationHead
  embed_dim: ${model.embed_dim}
  hidden_layers:
  - 128
  - 64
  num_classes: 37
  drop: 0.0
  use_layernorm: true
  use_batchnorm: false
criterion:
  _target_: criterion.ce_criterion.CrossEntropyWrapper
  label_smoothing: 0.1
tag: apr_28
gpus: 4
num_nodes: 1
num_workers: 8
batch_size: 32
seed: 42
resume: false
pretrained_checkpoint: /leonardo_work/CNHPC_1526560/yanlchen/ECG_checkpoints/ECG_large.ckpt
load_state_dict: false
training: true
print_model: true
find_unused_parameters: true
final_validate: true
finetune_pretrained: false
finetune_pretrained_path: null
freeze_decoder: false
model_checkpoint:
  save_last: true
  save_top_k: 1
  monitor: val_psnr
  mode: max
callbacks:
  lr_monitor:
    _target_: pytorch_lightning.callbacks.LearningRateMonitor
    logging_interval: step
  progress_bar:
    _target_: pytorch_lightning.callbacks.TQDMProgressBar
    refresh_rate: 10
  model_checkpoint:
    _target_: pytorch_lightning.callbacks.ModelCheckpoint
    dirpath: /leonardo_scratch/large/userexternal/ychen003/ECG_Finetune/checkpoints/${experiment_name}
    filename: ${experiment_name}-{epoch:02d}-{val_loss:.4f}
    every_n_epochs: 1
    save_top_k: 5
    monitor: val_loss
    save_last: true
io:
  base_output_path: /leonardo_work/CNHPC_1526560/yanlchen/ECG_Finetune_large/logs_shaoxing
  version: ${experiment_name}
trainer:
  num_nodes: ${num_nodes}
  devices: -1
  strategy: ddp
  max_epochs: 30
  max_steps: 500000
  benchmark: true
  check_val_every_n_epoch: 1
  num_sanity_val_steps: 2
  accelerator: gpu
  accumulate_grad_batches: 1
optimizer:
  optim: AdamW
  lr: 0.0005
  betas:
  - 0.9
  - 0.98
  weight_decay: 0.01
experiment_name: waveECG_fintune_shaoxing
final_test: true
