name: "control4d-static"
tag: "${basename:${data.dataroot}}_${rmspace:${system.prompt_processor.prompt},_}"
exp_root_dir: "outputs"
seed: 0

data_type: "multiview-camera-datamodule"
data:
  train_downsample_resolution: 2
  eval_downsample_resolution: 2
  dataroot: ???

system_type: "control4d-multiview-system"
system:
  start_editing_step: 2000

  geometry_type: "implicit-volume"
  geometry:
    radius: 2.
    n_feature_dims: 11
    normal_type: analytic
    pos_encoding_config:
      otype: HashGrid
      n_levels: 16
      n_features_per_level: 2
      log2_hashmap_size: 19
      base_resolution: 16
      per_level_scale: 1.4472692374403782 # max resolution 4096
    density_bias: "blob_magic3d"
    density_activation: softplus
    density_blob_scale: 10.
    density_blob_std: 0.5
    isosurface_resolution: 128
    isosurface_threshold: auto
    isosurface_coarse_to_fine: true

  material_type: "hybrid-rgb-latent-material"
  material:
    n_output_dims: 11
    requires_normal: true

  background_type: "solid-color-background"
  background:
    n_output_dims: 11
    color: [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]

  renderer_type: "gan-volume-renderer"
  renderer:
    base_renderer_type: "nerf-volume-renderer"
    base_renderer:
      radius: ${system.geometry.radius}
      num_samples_per_ray: 512

  guidance_type: "stable-diffusion-controlnet-guidance"
  guidance:
    control_type: "normal"
    min_step_percent: 0.05
    max_step_percent: 0.8
    condition_scale: 1.0

  prompt_processor_type: "stable-diffusion-prompt-processor"
  prompt_processor:
    pretrained_model_name_or_path: "runwayml/stable-diffusion-v1-5"

  loggers:
    wandb:
      enable: false
      project: 'threestudio'

  loss:
    lambda_sds: 0.
    lambda_orient: [0, 10.0, 1000., 5000.0]
    lambda_sparsity: 1.0
    lambda_opaque: 1.0
    lambda_l1: 10.
    lambda_p: 10.
    lambda_kl: 0.000001
    lambda_G: 0.01
    lambda_D: 1.
  optimizer:
    name: Adam
    args:
      lr: 0.01
      betas: [0.9, 0.99]
      eps: 1.e-15
    params:
      geometry:
        lr: 0.01
      background:
        lr: 0.001
      renderer.generator:
        lr: 0.0001
      renderer.local_encoder:
        lr: 0.0001
      renderer.global_encoder:
        lr: 0.0001
    optimizer_dis:
      name: Adam
      args:
        lr: 0.01
        betas: [0.9, 0.99]
        eps: 1.e-15
      params:
        renderer.discriminator:
          lr: 0.00001

trainer:
  max_steps: 50000
  log_every_n_steps: 1
  num_sanity_val_steps: 0
  val_check_interval: 200
  enable_progress_bar: true
  precision: 16-mixed

checkpoint:
  save_last: true
  save_top_k: -1
  every_n_train_steps: ${trainer.max_steps}
