# superencoder trained on ideal simulator, 4 qubits, FractalDB
# try deeper MLP (with residual connection)

version: v0.0.8.0
device: cpu
seed: 42
n_epochs: 10
resume_from_ckpt: false
noise_factor: 0
noisy_probability: 0


state_generator:
    loss: DotProd
    loss_args:
        avg: true
        noisy: false
    aae_encoder:
        q_device: default.qubit
        n_qubits: 4
        n_encoder_layers: 8
        noisy: false
        AmplitudeDamping: 0.0
        DepolarizingChannel: 0.0

    super_encoder:
        arch: DeepMLP
        input_size: ${eval:"int(int(2**${..aae_encoder.n_qubits})**0.5)"}
        in_dim: ${eval:"${.input_size}*${.input_size}"}
        out_dim: ${eval:"${..aae_encoder.n_qubits} * ${..aae_encoder.n_encoder_layers}"}
        hidden_size: 256
        num_blocks: 3

dataset:
    root: ./FractalDB/fractaldb_cat60_ins1000
    transform: ToTensor


checkpoint:
    logs: ./logs/superencoder/${version}
    save_path: ./trained_models/superencoder_${version}_${state_generator.loss}.pt

dataloader:
    batch_size: 64
    num_workers: 0
    pin_memory: false



optimizer:
    name: Adam
    args:
        lr: 1.0e-4
    # momentum: 0.9
        weight_decay: 1.0e-6
