generators:
  train:
    _target_: dpconvcnp.data.gp.MixtureGPGenerator
    seed: ${params.generator_train_seed}
    dim: ${params.dim}
    kernel_types: 
      - eq
      - weakly_periodic
    min_log10_lengthscale: 0.1761
    max_log10_lengthscale: 0.1761
    noise_std: 0.2
    min_num_ctx: 1
    max_num_ctx: 512
    min_num_trg: 512
    max_num_trg: 512
    context_range: [[-2.0, 2.0]]
    target_range: [[-6.0, 6.0]]
    samples_per_epoch: 32768
    batch_size: 16
    min_epsilon: 3
    max_epsilon: 3
    min_log10_delta: -3
    max_log10_delta: -3
  valid:
    _target_: dpconvcnp.data.gp.MixtureGPGenerator
    seed: ${params.generator_valid_seed}
    dim: ${params.dim}
    kernel_types: 
      - eq
      - weakly_periodic
    min_log10_lengthscale: 0.1761
    max_log10_lengthscale: 0.1761
    noise_std: 0.2
    min_num_ctx: 1
    max_num_ctx: 512
    min_num_trg: 512
    max_num_trg: 512
    context_range: [[-2.0, 2.0]]
    target_range: [[-6.0, 6.0]]
    samples_per_epoch: 2048
    batch_size: 16
    min_epsilon: 3
    max_epsilon: 3
    min_log10_delta: -3
    max_log10_delta: -3
    reset_seed_at_epoch_end: true

model:
  _target_: dpconvcnp.model.dpconvcnp.DPConvCNP
  dpsetconv_encoder: ${dpsetconv}
  conv_net: ${conv_net}
  setconv_decoder: ${setconv}

dpsetconv:
  _target_: dpconvcnp.model.setconv.DPSetConvEncoder
  seed: ${params.dpsetconv_seed}
  points_per_unit: ${params.points_per_unit}
  dim: ${params.dim}
  margin: 2.0
  xmin: [-7.0]
  xmax: [7.0]
  lengthscale_init: 0.1
  y_bound_init: 2.0
  w_noise_init: 0.5
  lengthscale_trainable: true
  y_bound_trainable: true
  w_noise_trainable: true
  amortize_y_bound: false
  amortize_w_noise: false
  num_mlp_hidden_units: 32
  skip_density_noise: false
  skip_clip: false

conv_net:
  _target_: dpconvcnp.model.conv.UNet
  first_channels: 32
  last_channels: 2
  kernel_size: 5
  num_channels: [256, 256, 256, 256, 256, 256, 256]
  stride: 2
  dim: ${params.dim}
  seed: ${params.architecture_seed}

setconv:
  _target_: dpconvcnp.model.setconv.SetConvDecoder
  lengthscale_init: 0.1
  lengthscale_trainable: true
  scaling_factor: ${eval:'${params.points_per_unit} ** ${params.dim}'}
  dim: ${params.dim}
    
optimizer:
  _target_: tensorflow.keras.optimizers.Adam
  learning_rate: 3e-4

params:
  epochs: 200
  dim: 1
  points_per_unit: 32
  generator_train_seed: [1, 0]
  generator_valid_seed: [1, 10]
  architecture_seed: 20
  dpsetconv_seed: 30
  training_seed: [1, 40]
  validation_seed: [1, 50]

misc:
  results_root: _experiments
  experiment_name: null

plot_options:
  xlim: [-7.00, 7.00]
  ylim: [-3.00, 3.00]
