model: pydgn.model.dgn.cgmm.CGMM
experiment: pydgn.experiment.cgmm_classifier_task.ClassifierCGMMTask
higher_results_are_better: True
dataset_getter: pydgn.data.provider.IncrementalDataProvider
log_every: 1
num_dataloader_workers: 0  # > 0 only with --debug option and GPU device
pin_memory: False  # True only with --debug option and GPU device
device: cpu
grid:
  layer_config:
    embeddings_folder: [YOUR FOLDER]
      - 200
    shuffle:
      - False
    previous_layers_to_use:
      - "1"  # multiple layers: "1,2,4"
    concatenate_on_axis: 1  # must be > 0
    max_layers: 20
    layers:
      - 1
      - 2
      - 3
      - 4
      - 5
      - 6
      - 7
      - 8
      - 9
      - 10
      - 11
      - 12
      - 13
      - 14
      - 15
      - 16
      - 17
      - 18
      - 19
      - 20
    C:
      - 20
    A: 1
    predictor:
      - pydgn.model.predictor.node_predictor.UnsupervisedProbabilisticNodeReadout
    emission:
      - pydgn.model.distribution.emission.Categorical
    unibigram:
      - True
    aggregation:
      - sum
    infer_with_posterior:
      - False
    epochs:
      - 10
    wrapper:
      - pydgn.training.engine.IncrementalTrainingEngine
    loss:
      - pydgn.training.callback.loss.CGMMLoss
    optimizer:
      - pydgn.training.callback.optimizer.CGMMOptimizer
    scorer:
      - class_name: pydgn.training.callback.score.MultiScore
        args:
          # used at model selection time. Should be the one on which to perform early stopping
          main_scorer: pydgn.training.callback.score.CGMMCompleteLikelihoodScore
          true_likelihood: pydgn.training.callback.score.CGMMTrueLikelihoodScore
    plotter:
    arbitrary_function_config: # Define the information for the arbitrary function
      shuffle: True
      batch_size:
        - 32
      checkpoint: True
      log_every: 1
      num_dataloader_workers: 0  # > 0 only with --debug option and GPU device
      pin_memory: False  # True only with --debug option and GPU device
      device: cpu
      epochs:
        - 2000
      hidden_units:
        - 32
      optimizer:
        - class_name: pydgn.training.callback.optimizer.Optimizer
          args:
            optimizer_class_name: torch.optim.Adam
            lr:
              - 0.001
            weight_decay:
              - 0.
      loss:
        - pydgn.training.callback.loss.MulticlassClassificationLoss
      scorer:
        - pydgn.training.callback.score.MulticlassAccuracyScore
      predictor:
        - pydgn.model.predictor.graph_predictor.SimpleMLPGraphPredictor
      wrapper:
        - pydgn.training.engine.TrainingEngine
      early_stopper:
        - class_name:
            - pydgn.training.callback.early_stopping.PatienceEarlyStopper
          args:
            patience:
              - 300
            monitor: validation_Multiclass Accuracy # (train_,validation_)[name_of_the_scorer_or_loss_to_monitor]
            mode: max
            checkpoint: True
      plotter:
        - pydgn.training.callback.plotter.Plotter
