# config.yaml - training configuration
data:
  train_dir:
  val_dir:
  num_workers: 4
  pin_memory: true

train:
  epochs: 100
  batch_size: 4
  seed: 42
  device: auto
  grad_clip: 1.0
  eval_interval: 1
  checkpoint_dir: ./checkpoints
  log_dir: ./logs
  save_every_n_epochs: 10

optim:
  name: AdamW
  lr: 0.0001
  weight_decay: 0.01
  betas: [0.9, 0.999]

scheduler:
  name: CosineAnnealingLR           # or StepLR
  T_max: 100
  eta_min: 0.000001
  # for StepLR:
  # step_size: 30
  # gamma: 0.1

amp:
  enabled: true

dataloader:
  batch_size: 4

model:
  model_path: ./model.py           # path to model definition if needed for import
  embedding_mode: complex          # complex | binder

  node_encoder:
    include_heavy_atom_coords: true
    activation: silu
    dropout: 0.0

    chem_hidden: 32
    angle_hidden: 32
    rho_hidden: 32
    heavy_hidden: 64
    ss_hidden: 32

    fuse_hidden: 128
    node_embed_dim: 64
    ss_embed_dim: 64
    use_layernorm: true

  chain_edge_encoder:
    activation: silu
    use_layernorm: true
    dropout: 0.0

    seq_dist_cut: 32
    rbf_dim: 15
    ori_dim: 12
    edge_seq_hidden: 32
    edge_contact_hidden: 16
    edge_rbf_hidden: 64
    edge_ori_hidden: 64
    edge_fuse_hidden: 128
    edge_embed_dim: 64

  interface_edge_encoder:
    activation: silu
    use_layernorm: true
    dropout: 0.0
    
    if_edge_rbf_hidden: 64
    if_edge_ori_hidden: 64
    if_edge_chem_bin_hidden: 16
    if_edge_chem_cont_hidden: 16
    if_edge_inter_hidden: 32
    if_edge_fuse_hidden: 128
    if_edge_embed_dim: 64
  
  diffusion:
    num_steps: 500
    noise_type: blosum         # uniform | blosum
    position_mean: [0.0, 0.0, 0.0]
    position_scale: [10.0]
    embedding_mode: complex          # complex | binder
    design_mode: codesign            # folding | folding | inverse_folding

    graph_encoder:
      embedding_dim: 64
      num_layers: 6



logging:
  csv_log: true

misc:
  save_best_only: true
  resume_from: ""
