defaults:
  - default
  - _self_

_target_: src.models.occupancy_autoencoder_particle.OccupancyAutoencoderParticleLitModule
num_classes: ${vars.num_classes}

model:
  _target_: src.models.occupancy_autoencoder_particle.OccupancyAutoencoderParticle
  _partial_: True
  encoder:
    _target_: src.models.components.encoders.upt_pool_transformer_perceiver.UptPoolTransformerPerceiver
    _partial_: True
    gnn_dim: 96
    enc_dim: 96
    perc_dim: ${vars.latent_dim}
    enc_depth: 4
    enc_num_attn_heads: 2
    perc_num_attn_heads: 3
    num_latent_tokens: 128
    condition_dim: 768
    supernode_pooling:
      _target_: src.modules.supernode_pooling.SupernodePooling
      supernodes_radius: 0.1
      supernodes_max_neighbours: 4
      net:
        _target_: src.modules.supernode_pooling.SupernodeGnn
        input_dim: ${vars.input_dim}
        hidden_dim: 96
        ndim: 2
        aggr:
          _target_: torch_geometric.nn.aggr.SumAggregation
        pos_embed:
          _target_: src.modules.positional_embeddings.ContinuousSincosEmbed
          _partial_: True
          pos_scale: ${vars.pos_scale}

  decoder:
    _target_: src.models.components.decoders.upt_transformer_perceiver_occupancy.UptTransformerPerceiverOccupancy
    _partial_: True
    dim: 192
    depth: 4
    num_attn_heads: 3
    input_dim: 192
    feat_dim: ${vars.output_dim}
    n_particle_types: ${vars.num_classes}
    condition_dim: 768
    ndim: 2
    pos_embed:
      _target_: src.modules.positional_embeddings.ContinuousSincosEmbed
      _partial_: True
      pos_scale: ${vars.pos_scale}

  conditioner:
    _target_: src.models.components.conditioners.upt_timestep_conditioner.UptTimestepConditioner
    _partial_: True
    dim: 192
    num_total_timesteps: ${vars.num_total_timesteps}
    condition_dim: 768

optimizer:
  _target_: torch.optim.AdamW
  _partial_: True
  lr: 0.0001
  weight_decay: 0.05
