{
    "name": "ppmi",
    "phase": "train", // always set to train in the config
    "gpu_ids": [
        0
    ],
    "path": { //set the path
        "log": "logs",
        "tb_logger": "tb_logger",
        "results": "results",
        "checkpoint": "checkpoint",
        "resume_state": null // UPDATE THIS FOR RESUMING TRAINING
    },
    "datasets": {
        "train": {
            "name": "ppmi",
            "dataroot": null,  // **UPDATE THIS TO THE PATH OF THE FILE** e.g. ".../data/HARDI193.nii.gz"
            "valid_mask": [0,64],
            "phase": "train",
            "padding": 3,
            "val_volume_idx": 40,
            "val_slice_idx": 40, 
            "batch_size": 8,
            "in_channel": 1,
            "num_workers": 4,
            "use_shuffle": true,
            "noise2noise":false// dont change
        },
        "val": {
            "name": "ppmi",
            "dataroot": null,  // **UPDATE THIS TO THE PATH OF THE FILE** e.g. ".../data/HARDI193.nii.gz"
            "valid_mask": [0,64],
            "phase": "val",
            "padding": 3,
            "val_volume_idx": 40,
            "val_slice_idx": 40,
            "batch_size": 1,
            "in_channel": 1,
            "num_workers": 4,
            "noise2noise":false// dont change
        }
    },
    "model": {
        "which_model_G": "mri", // use the ddpm or sr3 network structure
        "finetune_norm": false,
        "drop_rate": 0.0,
        "unet": {
            "in_channel": 1,
            "out_channel": 1,
            "inner_channel": 32,
            "norm_groups": 32,
            "channel_multiplier": [
                1,
                2,
                4,
                8,
                8
            ],
            "attn_res": [
                16
            ],
            "res_blocks": 2,
            "dropout": 0.0,
            "version": "v1"
        },
        "beta_schedule": { // use munual beta_schedule for acceleration
            "train": {
                "schedule": "rev_warmup70",
                "n_timestep": 1000,
                "linear_start": 5e-5,
                "linear_end": 1e-2
            },
            "val": {
                "schedule": "rev_warmup70",
                "n_timestep": 1000,
                "linear_start": 5e-5,
                "linear_end": 1e-2
            }
        },
        "diffusion": {
            "image_size": 128,
            "channels": 3, //sample channel
            "conditional": true // not used for DDM2
        }
    },
    "train": {
        "n_iter": 100000,
        "val_freq": 1e3,
        "save_checkpoint_freq": 1e4,
        "print_freq": 1e2,
        "optimizer": {
            "type": "adam",
            "lr": 1e-4
        },
        "ema_scheduler": { // not used now
            "step_start_ema": 5000,
            "update_ema_every": 1,
            "ema_decay": 0.9999
        }
    },
   // for NOISE2NOISE,NEI2NEI,NOISIER2NOISE,DIP we dont use it Di-Fusion
    "noise_model": {
        "resume_state": null, // **UPDATE THIS TO THE PATH OF PHASE1 TRAINED NOISE MODEL** e.g. ".../experiments/1_noisemodel/checkpoint/latest"
        "drop_rate": 0.0,
        "unet": {
            "in_channel": 1,
            "out_channel": 1,
            "inner_channel": 32,
            "norm_groups": 32,
            "channel_multiplier": [
                1,
                2,
                4,
                8,
                8
            ],
            "attn_res": [
                16
            ],
            "res_blocks": 2,
            "dropout": 0.0,
            "version": "v1"
        },
        "beta_schedule": { // use munual beta_schedule for accelerationß
            "linear_start": 5e-5,
            "linear_end": 1e-2
        },
        "n_iter": 100000,
        "val_freq": 2e3,
        "save_checkpoint_freq": 1e4,
        "print_freq": 1e3,
        "optimizer": {
            "type": "adam",
            "lr": 1e-4
        }
    }
}