title = "Configuration file used for scaling network width and number of message passes"

# For enoder and network widths
enc_widths              = [8, 16, 32, 64]
network_widths          = [128, 256, 512]

# For message passing ablation study
n_msg_passes            = [1, 2, 3, 4, 5, 6]
local_poolings          = ["sum", "avg"]

n_obj                   = [8]
dof                     = 2
dtype                   = "double"            # choices: 'float', 'double'
auto_diff_mode          = "forward"           # choices: 'forward' or 'reverse', only affects the SWIM models when computing the dense layer output gradient w.r.t. inputs q and p to construct the linear system
device                  = "cpu"               # choices: 'cpu' or 'cuda'

[data]
n_points                = 4_000               # number of data points
train_test_split        = 0.5
mass                    = 1.0                 # should be positive
spring_constant         = 1.0                 # should be positive
x_min                   = -1.0                # should be less than x_max
x_max                   = +1.0                # should be greater than x_min
meshing                 = "rectangular"       # choices: 'rectangular', 'diagonal', 'cross'
data_seed               = 5194756             # random state for the data generation

[model]
direct                  = false               # assume directed graph or not, only affects GNN
enc_width               = 64
network_width           = 512
local_pooling           = "sum"
global_pooling          = "sum"
activ_str               = "softplus"          # choices: 'tanh', 'relu', 'silu', 'gelu', 'elu', 'mish', 'softplus', 'softsign'
init_method             = "relu"              # only affects gradient-descent based training, specifies init method for the biases of the network, choices are 'relu' for relu-like and 'tanh' for tanh-like activation functions
model_seed              = 29529475            # random state for the model initialization, only affects adam-training

[train]
param_sampler           = "relu"              # choices: 'relu', 'tanh', use relu for relu-like activs, 'tanh' for tanh-like
resample_duplicates     = true                # whether to resample duplicate weights to avoid redundant parameters
driver                  = "gels"             # driver to use for the linear solver, choices: QR based 'gels' or 'gelsy', SVD based 'gelsd', 'gelss'
rcond                   = 1e-06               # regularization for the linear solver
sampling_seed           = 5194756             # random state for the sampling of dense layer parameters
