mode: train
amp: false
root_dir: ./log/ptnet2_fusion_0.01

# -------------------- Model --------------------
model:
  NAME: BaseSeg_Balance_MainDual
  hier_levels: 2                # coarse, fine
  num_classes_per_level: [4, 13]
  in_channels: 6
  use_prev_softmax_guidance: True
  cond_alpha: 1.0
  use_projection: False   # toggle projection MLPs in the single-branch head (true/false)
  beta: 0.999
  encoder_args: &enc_args
    NAME: PointNet2Encoder
    in_channels: 6
    mlps: [[[32,32,64]], [[64,64,128]], [[128,128,256]], [[256,256,512]]]
    strides: [4,4,4,4]
    layers: 3
    use_res: False
    radius: 0.1
    num_samples: 32
    sample_method: fps
    aggr_args: { NAME: convpool, feature_type: dp_fj, anisotropic: False, reduction: max }
    stem_conv: False
    group_args: { NAME: ballquery, use_xyz: True }
    conv_args: { order: conv-norm-act }
    act_args: { act: relu }
    norm_args: { norm: bn }
  decoder_args:
    NAME: PointNet2Decoder
    fp_mlps: [[128,128,128], [256,128], [256,256], [256,256]]
  cls_head_args:
    NAME: SegHead

hier_coarse_weight: 1.0   # weight for coarse ce loss (handled in train loop)

# -------------------- Prior Branch (levels 3-5) --------------------
prior_active: [0, 1]   # activate prior for levels 3,4,5 (0-based)

model_prior:
  NAME: BaseSeg_Balance_Prior
  in_channels: 6
  beta: 0.999
  encoder_args:
    NAME: PointNet2Encoder
    in_channels: 6
    mlps: [[[32,32,64]], [[64,64,128]], [[128,128,256]], [[256,256,512]]]
    strides: [4,4,4,4]
    layers: 3
    use_res: False
    radius: 0.1
    num_samples: 16
    sample_method: fps
    aggr_args: { NAME: convpool, feature_type: dp_fj_df, anisotropic: False, reduction: max }
    stem_conv: True
    group_args: { NAME: ballquery, use_xyz: True }
    conv_args: { order: conv-norm-act }
    act_args: { act: relu }
    norm_args: { norm: bn }

criterion_SupCon:
  NAME: SupConLoss
  temperature: 0.07

# Loss weights (keep default 1.0, adjust if needed)
loss_main_l1:       1.0
loss_prior:         1.0
loss_prior_supcon:  1.0
consistency_loss:
  enable: True
  matrices_file: /root/autodl-tmp/PointSegBase-main/configs/pointnet_urban_layer_all/data_list/matrix_file_list.yaml
  mode: inter
  weight: 1.0

# -------------------- Dataset --------------------
dataset:
  common:
    NAME: Urban3DSegBase
    cfg_dir: /root/autodl-tmp/PointSegBase-main/configs/pointnet_urban_layer_all
    set_name: TRAIN
  train:
    set_name: TRAIN
  val:
    set_name: VALIDATION
  test:
    set_name: TEST

dataloader:
  num_workers: 16

# -------------------- Transforms -----------------
datatransforms: {}

# -------------------- Training -------------------
epochs: 100
batch_size: 64
val_batch_size: 64

criterion:
  NAME: CrossEntropy
  label_smoothing: 0.2

optimizer:
  NAME: adamw
  weight_decay: 1e-4
lr: 0.01
sched: cosine
sched_on_epoch: true
min_lr: 1.0e-5

# -------------------- Misc -----------------------
num_classes: 13           # finest level classes
ignore_index: null   # do not ignore any label in confusion matrix to avoid NaN accuracy
val_freq: 1 
amp: False


