optimizer : {
  type: AdamW,
  kwargs: {
  lr : 0.0005,
  weight_decay : 0.05
}}

scheduler: {
  type: CosLR,
  kwargs: {
    epochs: 300,
    initial_epochs : 10
}}

dataset : {
  train : { _base_: cfgs/dataset_configs/ShapeNet-55.yaml,
            others: {subset: 'train', npoints: 1024}},
  val : { _base_: cfgs/dataset_configs/ShapeNet-55.yaml,
            others: {subset: 'test', npoints: 1024}},
  test : { _base_: cfgs/dataset_configs/ShapeNet-55.yaml,
            others: {subset: 'test', npoints: 1024}}}

model : {
  NAME: CSCon,
  group_size: 32,
  num_group: 64,
  loss: cdl2,
  T: 1.0,
  alpha_1: 1.0,
  alpha_2: 1.0,
  mlp_dim: 384,
  
  # parameters for predicting the centers
  pred_loss: l2, # l2 by default | l2, sml1, cos, l1
  ita: 0.1,  # 0.1 by default
  pred_pos_transformer_layer: 0,  # 0 by default
  add_detach: True,  # True by default 
  
  transformer_config: {
    mask_ratio: 0.6,  
    mask_type: 'rand',
    trans_dim: 384,
    encoder_dims: 384,
    depth: 12,
    drop_path_rate: 0.1,
    num_heads: 6,
    decoder_depth: 4,
    decoder_num_heads: 6,
  },
  }

npoints: 1024
total_bs : 128
step_per_update : 1
max_epoch : 300

# pretrain
# CUDA_VISIBLE_DEVICES=0 python main.py --config cfgs/pretrain/base.yaml --exp_name obj
# --resume

# # finetune scanobjectNN
# CUDA_VISIBLE_DEVICES=0 python main.py --config cfgs/linear/finetune_scan_hardest.yaml \
# --finetune_model --exp_name lr_6e-4 --ckpts experiments/base/pretrain/con_8/ckpt-epoch-300.pth


# CUDA_VISIBLE_DEVICES=1 python main.py --test --config cfgs/linear/finetune_scan_hardest.yaml \
# --exp_name lr_6e-4 --ckpts experiments/finetune_scan_hardest/linear/lr_6e-4/ckpt-best.pth


# # finetune_scan_objbg.yaml
# CUDA_VISIBLE_DEVICES=0 python main.py --config cfgs/linear/finetune_scan_objbg.yaml \
# --finetune_model --exp_name lr_8e-4 --ckpts experiments/base/pretrain/con_8/ckpt-epoch-300.pth

# CUDA_VISIBLE_DEVICES=0 python main.py --test --config cfgs/linear/finetune_scan_objbg.yaml \
# --exp_name lr_8e-4 --ckpts experiments/finetune_scan_objbg/linear/lr_8e-4/ckpt-best.pth


# # finetune_scan_objonly.yaml
# CUDA_VISIBLE_DEVICES=0 python main.py --config cfgs/finetune_scan_objonly.yaml \
# --finetune_model --exp_name con_8 --ckpts experiments/base/pretrain/con_8/ckpt-epoch-300.pth

# /////
# CUDA_VISIBLE_DEVICES=0 python main.py --config cfgs/linear/finetune_scan_objonly.yaml \
# --finetune_model --exp_name lr_8e-4 --ckpts experiments/base/pretrain/con_8/ckpt-epoch-300.pth



# CUDA_VISIBLE_DEVICES=0 python main.py --test --config cfgs/linear/finetune_scan_objonly.yaml \
# --exp_name lr_8e-4 --ckpts experiments/finetune_scan_objonly/linear/lr_8e-4/ckpt-best.pth


# /////


# CUDA_VISIBLE_DEVICES=0 python main.py --test --config cfgs/finetune_scan_objonly.yaml \
# --exp_name con_8 --ckpts experiments/finetune_scan_objonly/cfgs/con_8/ckpt-best.pth

# # S3DIS
# cd semantic_segmentation
# python main.py --ckpts ../experiments/base/pretrain/con_8/ckpt-epoch-300.pth \
# --root /root/autodl-tmp/PCP-MAE_ord/data/s3dis --learning_rate 0.00005 --epoch 60 --gpu 0 --log_dir seed1 --optimizer_part all --seed 1

# # # few-shot
# CUDA_VISIBLE_DEVICES=0 python main.py --config cfgs/fewshot.yaml --finetune_model \
# --ckpts experiments/base/pretrain/con_8/ckpt-epoch-300.pth --exp_name way_10_shot_20_flod_2 --way 10 --shot 20 --fold 2


# # test
# # CUDA_VISIBLE_DEVICES=0 python main.py --test --config cfgs/finetune_scan_hardest.yaml \
# # --exp_name con_9 --ckpts experiments/finetune_scan_hardest/cfgs/con_9/ckpt-best.pth

# # 三次前传 86.4
# # 分开进行三次前传 87.0
# # con_4 相同mask+pos_pre 86.89
# # con_5 mask不同修改mask对齐后 89.90
# # con_6 相同mask并对齐 90.01
# # con_8 只保留loss3 90.67
# # con_9 rec center+neighbor 90.49
# # con_10 con_9+no_detach() 90.49

# # ModelNet50
# CUDA_VISIBLE_DEVICES=0 python main.py --config cfgs/linear/finetune_modelnet.yaml \
# --finetune_model --exp_name lr_ --ckpts experiments/base/pretrain/con_8/ckpt-epoch-300.pth

# # no——vote
# CUDA_VISIBLE_DEVICES=0 python main.py --test --config cfgs/linear/finetune_modelnet.yaml \
# --exp_name lr_5e-5_no --ckpts experiments/finetune_modelnet/linear/lr_5e-5/ckpt-best.pth

# # vote
# CUDA_VISIBLE_DEVICES=0 python main.py --test --config cfgs/linear/finetune_modelnet.yaml \
# --exp_name lr_5e-5 --ckpts experiments/finetune_modelnet/linear/lr_5e-5/ckpt-best.pth --vote



# # ModelNet50
# CUDA_VISIBLE_DEVICES=0 python main.py --config cfgs/linear/finetune_modelnet.yaml \
# --finetune_model --exp_name lr_ --ckpts experiments/base/pretrain/con_8/ckpt-epoch-300.pth

# # no——vote
# CUDA_VISIBLE_DEVICES=0 python main.py --test --config cfgs/linear/finetune_modelnet.yaml \
# --exp_name lr_8e-4_no --ckpts experiments/finetune_modelnet/linear/lr_8e-4/ckpt-best.pth

# # vote
# CUDA_VISIBLE_DEVICES=0 python main.py --test --config cfgs/linear/finetune_modelnet.yaml \
# --exp_name lr_2e-4 --ckpts experiments/finetune_modelnet/linear/lr_2e-4/ckpt-best.pth --vote



# #point mae
# # 1.finetune_scan_objbg.yaml
# CUDA_VISIBLE_DEVICES=0 python main.py --config cfgs/linear/finetune_scan_objbg.yaml \
# --finetune_model --exp_name pointmae --ckpts /root/autodl-tmp/Point-MAE/experiments/pretrain/pretrain.pth

# CUDA_VISIBLE_DEVICES=0 python main.py --test --config cfgs/linear/finetune_scan_objbg.yaml \
# --exp_name pointmae --ckpts experiments/finetune_scan_objbg/linear/pointmae/ckpt-best.pth

# # 2.finetune_scan_objonly.yaml

# CUDA_VISIBLE_DEVICES=0 python main.py --config cfgs/linear/finetune_scan_objonly.yaml \
# --finetune_model --exp_name pointmae --ckpts /root/autodl-tmp/Point-MAE/experiments/pretrain/pretrain.pth

# CUDA_VISIBLE_DEVICES=0 python main.py --test --config cfgs/linear/finetune_scan_objonly.yaml \
# --exp_name pointmae --ckpts experiments/finetune_scan_objonly/linear/pointmae/ckpt-best.pth

# # 3.finetune scanobjectNN
# CUDA_VISIBLE_DEVICES=0 python main.py --config cfgs/linear/finetune_scan_hardest.yaml \
# --finetune_model --exp_name pointmae --ckpts /root/autodl-tmp/Point-MAE/experiments/pretrain/pretrain.pth


# CUDA_VISIBLE_DEVICES=1 python main.py --test --config cfgs/linear/finetune_scan_hardest.yaml \
# --exp_name lr_2e-4 --ckpts experiments/finetune_scan_hardest/linear/lr_2e-4/ckpt-best.pth



# /root/autodl-tmp/Point-MAE/experiments/pretrain/pretrain.pth