File size: 2,864 Bytes
9c3a994
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
model:
  target: michelangelo.models.asl_diffusion.clip_asl_diffuser_pl_module.ClipASLDiffuser
  params:
    first_stage_config:
      target: michelangelo.models.tsal.asl_pl_module.AlignedShapeAsLatentPLModule
      params:
        shape_module_cfg:
          target: michelangelo.models.tsal.sal_perceiver.AlignedShapeLatentPerceiver
          params:
            num_latents: &num_latents 256
            embed_dim: &embed_dim 64
            point_feats: 3   # normal
            num_freqs: 8
            include_pi: false
            heads: 12
            width: 768
            num_encoder_layers: 8
            num_decoder_layers: 16
            use_ln_post: true
            init_scale: 0.25
            qkv_bias: false
            use_checkpoint: false
        aligned_module_cfg:
          target: michelangelo.models.tsal.clip_asl_module.CLIPAlignedShapeAsLatentModule
          params:
            clip_model_version: "./checkpoints/clip/clip-vit-large-patch14"

        loss_cfg:
          target: torch.nn.Identity

    cond_stage_config:
      target: michelangelo.models.conditional_encoders.encoder_factory.FrozenCLIPImageGridEmbedder
      params:
        version: "./checkpoints/clip/clip-vit-large-patch14"
        zero_embedding_radio: 0.1

    first_stage_key: "surface"
    cond_stage_key: "image"
    scale_by_std: false

    denoiser_cfg:
      target: michelangelo.models.asl_diffusion.asl_udt.ConditionalASLUDTDenoiser
      params:
        input_channels: *embed_dim
        output_channels: *embed_dim
        n_ctx: *num_latents
        width: 768
        layers: 6   # 2 * 6 + 1 = 13
        heads: 12
        context_dim: 1024
        init_scale: 1.0
        skip_ln: true
        use_checkpoint: true

    scheduler_cfg:
      guidance_scale: 7.5
      num_inference_steps: 50
      eta: 0.0

      noise:
        target: diffusers.schedulers.DDPMScheduler
        params:
          num_train_timesteps: 1000
          beta_start: 0.00085
          beta_end: 0.012
          beta_schedule: "scaled_linear"
          variance_type: "fixed_small"
          clip_sample: false
      denoise:
        target: diffusers.schedulers.DDIMScheduler
        params:
          num_train_timesteps: 1000
          beta_start: 0.00085
          beta_end: 0.012
          beta_schedule: "scaled_linear"
          clip_sample: false   # clip sample to -1~1
          set_alpha_to_one: false
          steps_offset: 1

    optimizer_cfg:
      optimizer:
        target: torch.optim.AdamW
        params:
          betas: [0.9, 0.99]
          eps: 1.e-6
          weight_decay: 1.e-2

      scheduler:
        target: michelangelo.utils.trainings.lr_scheduler.LambdaWarmUpCosineFactorScheduler
        params:
          warm_up_steps: 5000
          f_start: 1.e-6
          f_min: 1.e-3
          f_max: 1.0

    loss_cfg:
      loss_type: "mse"