log_level = 'info'
sweep_mode = false

[inputs]
n_workers = +1
n_threads = +6
device = 'cpu'
in_directory = './data/inputs/'
dataset = 'cambridge_work_commuter_lsoas_to_msoas'
load_experiment = ''

[inputs.data]
    origin_demand = 'origin_demand_sum_normalised.txt'
      destination_attraction_ts='destination_attraction_time_series_sum_normalised.txt'
    cost_matrix = """cost_matrices/clustered_facilities_sample_20x20_20_01_2023_\
    sample_20x20_clustered_facilities_ripleys_k_500_euclidean_points%_\
    prob_origin_destination_adjusted_normalised_boundary_only_\
    edge_corrected_cost_matrix_max_normalised.txt"""
    ground_truth_table = 'table_lsoas_to_msoas.txt'
    total_cost_by_origin = 'lsoas_total_distance_to_work.txt'

[spatial_interaction_model]
  # sim_type = 'ProductionConstrained','TotallyConstrained'
  name = 'TotallyConstrained'
  grand_total = +33704
  [spatial_interaction_model.parameters]
    bmax = +1.0
    alpha = +1.0
    beta = 0.0
  
[harris_wilson_model]
  dt = +0.001
  [harris_wilson_model.parameters]
    noise_percentage = +0.01
    epsilon = 1.0
    sigma = 0.01414213562

[training]
  N = +10000 # number of epochs or mcmc samples
  num_steps = +1
  batch_size = +1
  to_learn = ['alpha', 'beta']
  intensity_model = 'spatial_interaction_model'
  physics_model = 'harris_wilson_model'

[hyperparameter_optimisation]
  n_trials = 100
  timeout = nan
  metric_minimise = true
  metric_evaluation = "MathUtils.srmse(prediction=prediction,ground_truth=ground_truth_table,mask=mask)"
  
[mcmc]
  disable_tqdm = true
  mcmc_workers = 1
  [mcmc.parameters]
    theta_steps = 1
    step_size = 1.0
    covariance = [[0.0149674,0.00182529],[0.00182529,0.0109968]]

  [mcmc.destination_attraction]
    log_destination_attraction_steps = 1
    leapfrog_steps = 3#10
    leapfrog_step_size = 0.01 #0.02
    ais_leapfrog_steps = 3#10
    ais_leapfrog_step_size = 0.2#0.1
    ais_samples = 10
    n_bridging_distributions = 50

[neural_network]
  disable_tqdm = true
  [neural_network.loss_function] 
    loss_name = 'mseloss'
  [neural_network.hyperparameters]
    num_hidden_layers = +1
    optimizer = 'Adam'
    learning_rate = +0.002
    [neural_network.hyperparameters.biases]
      default = [+0.0, +4.0]
      [neural_network.hyperparameters.biases.layer_specific]
    [neural_network.hyperparameters.nodes_per_layer]
      default = +20
      [neural_network.hyperparameters.nodes_per_layer.layer_specific]
    [neural_network.hyperparameters.activation_funcs]
      default = 'linear'
      [neural_network.hyperparameters.activation_funcs.layer_specific]
        1 = 'abs'

[[experiments]]
  type = 'SIM_NN'
  comment = 'Spatial Interaction Model parameter learning using Neural Networks'
  disable_tqdm = false
  export_samples = true
  export_metadata = true
  overwrite = true
  validate_samples = false

[[experiments]]
  type = 'SIM_MCMC'
  comment = 'Spatial Interaction Model parameter learning using Markov Chain Monte Carlo'
  disable_tqdm = false
  export_samples = true
  export_metadata = true
  overwrite = true
  validate_samples = false

[outputs]
    write_start = +1
    write_every = +1
    out_directory = './data/outputs/'
    out_group = 'exp5'
    title = ''