---
# Model type and architecture
model_mode: ae                    # Model to use. ae: Autoencoder
reconstruction: true              #
shallow_architecture: true        # If True, we use shallow encoder/decoder architecture with only one hidden layer for each
                                  # Else, 'dims' define the encoder architecture, and decoder is the symmetric version of encoder

# Architecture-related params
# The dimension of input features is added automatically, so it does not need to be defined here.
dims:                             # Autoencoder architecture - This is for Encoder - Decoder is symmetric to Encoder.
  - 16                           # Hidden. 
  - 16

isBatchNorm: true                # Set True to use BatchNorm layer
isDropout: true                  # Set True to use Dropout layer

# p-norm if z is normalised
normalize: true                   # If True, we do L2 normalization on latent variable
p_norm: 2                         # p-value used for normalization. p=2 for L2 norm, p=1 for L1 norm and so on.

# Parameters for training
dropout_rate: 0.1                 # Set dropout rate if Dropout is being used
learning_rate: 0.005              # Learning rate for training
# epochs: 5                        # Number of epochs to use for training
batch_size: 16                    # Set batch size
nth_epoch: 1                      # Compute validation loss in every nth_epoch
validate: false                   # Whether to compute validation loss

reduce_lr: false
scheduler: true                  # If True, turns on scheduler for learning rate.

validateScore: false            # if true either rmse or accuracy is used, loss otherwise
validation: false

# Options for subsetting
n_subsets: 2                      # Use at least 2 when using a single view. 
overlap: 0                     # A ratio [0,1) that defines how many features are overlapped between subsets. 
                                  
# Type of aggregation / pooling for latent variables of subsets
aggregation: mean                 # options:  mean (default), sum, max, min, and concat

# Noise-related options
add_noise: true                   # If True, it adds noise. The noise type is defined in "noise_type"
noise_type: gaussian_noise            # Type of noise to add to. Choices: swap_noise, gaussian_noise, zero_out
masking_ratio: [0.1,0.1]                # Percentage of the feature to add noise to binomial, all applied
noise_level: [0.1,0.1]                  # Stdev defined for Gaussian noise

# Data
n_classes: 10                     # Number of classes in the data 
training_data_ratio: 1          # Percentage of training set to be used as training - The rest will be used for test
validation_data_ratio : 0.3       # Percentage of validation set e.g. training_data_ratio[validation_data_ratio:]

# Losses to use
contrastive_loss: true            # If True, the contrastive loss is added to the total loss.
distance_loss: true               # If True, the distance loss is added to the total loss.

# Options for loss functions
tau: 0.1                          # Temperature parameter used in NTXentLoss
cosine_similarity: false          # If True, use cosine similarity in NTXentLoss. Else, use dot product.
reconstruct_subset: true         # If True, reconstructs subset of given input to encoder. 
                                  # Else, it reconstructs the complete tabular data.

ns : false                        # no pearson shuffle. if true no pearson shuffle applied to the loaded data
local : false