data_module:
  _target_: data_module.concatenated_eeg_data_module.ConcatenatedEEGDataModule
  name: emg
  cfg:
    num_workers: ${num_workers}
    batch_size: ${batch_size}
  train: ${datasets}
  val: null
  test: null
task:
  _target_: tasks.wave_reconstruction.MaskedWaveletPretrainingTask
scheduler:
  _target_: schedulers.cosine_lr.CosineLRSchedulerWrapper
  trainer: ${trainer}
  warmup_epochs: 10
  min_lr: 2.5e-07
  warmup_lr_init: 2.5e-07
  t_in_epochs: false
model:
  _target_: models.waveMiM.ChannelVisionTransformer
  in_ch: 16
  max_level: 3
  wave_kernel_size: 16
  timesteps: 1000
  patch_kernel:
  - 1
  - 50
  patch_stride:
  - 1
  - 50
  embed_dim: 512
  depth: 12
  num_heads: 8
  mlp_ratio: 4.0
  drop_path: 0.1
  attention_type: alternating
  masking_ratio: 0.7
model_head:
  _target_: models.model_heads.wavelet_decoder.MAEDecoder
  decoder_output_dim: 50
  embed_dim: 512
  decoder_embed_dim: 512
  decoder_num_heads: 8
  decoder_depth: 8
  mlp_ratio: 4.0
  attention_type: default
  drop_path: 0.0
  H_out: 64
  W_out: 20
  num_patches: 1280
criterion:
  _target_: criterion.reconstruction_norm.ReconstructionNorm
  patch_size:
  - 1
  - 50
  alpha: 0.1
  loss_type: smooth_l1
  using_spectrogram: false
tag: mar_25
gpus: 4
num_nodes: 1
num_workers: 8
batch_size: 32
seed: 42
resume: false
pretrained_checkpoint: null
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_work/CNHPC_1526560/yanlchen/EMG_Pretrain/waveletMiM_pretraining/checkpoints/
    filename: ${experiment_name}-loss${criterion.loss_type}_alpha${criterion.alpha}_attention${model.attention_type}-{epoch:02d}-{val_loss:.4f}
    monitor: val_loss
    mode: min
    save_top_k: 1
    save_last: false
    every_n_epochs: 1
io:
  base_output_path: /leonardo_work/CNHPC_1526560/yanlchen/EMG_Pretrain/waveMiM_pretraining/tensorboard_logs
  version: ${experiment_name}-loss${criterion.loss_type}_alpha${criterion.alpha}_attention${model.attention_type}
trainer:
  num_nodes: ${num_nodes}
  devices: -1
  strategy: ddp
  max_epochs: 6
  max_steps: 500000
  benchmark: true
  check_val_every_n_epoch: 3
  num_sanity_val_steps: 2
  accelerator: gpu
  accumulate_grad_batches: 32
optimizer:
  optim: AdamW
  lr: 0.00125
  betas:
  - 0.9
  - 0.98
  weight_decay: 0.05
experiment_name: waveMiM_pretraining
final_test: false
datasets:
  db6:
    _target_: datasets.emg_pretrain_dataset.EMGPretrainDataset
    data_path: /leonardo_work/CNHPC_1526560/yanlchen/EMG_Pretrain/DB6
    transform: true
  db7:
    _target_: datasets.emg_pretrain_dataset.EMGPretrainDataset
    data_path: /leonardo_work/CNHPC_1526560/yanlchen/EMG_Pretrain/DB7
    transform: true
  db8:
    _target_: datasets.emg_pretrain_dataset.EMGPretrainDataset
    data_path: /leonardo_work/CNHPC_1526560/yanlchen/EMG_Pretrain/DB8
    transform: true
