# superencoder trained on ideal simulator, 8 qubits, FractalDB
# try deeper MLP (with residual connection)
# increase hidden_size to 512, num_blocks to 8


version: v0.0.8.2
device: cuda
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: 8
        n_encoder_layers: 40
        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: 512
        num_blocks: 8

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: 3.0e-5
    # momentum: 0.9
        weight_decay: 1.0e-7
