# Algorithm Configuration
algo: "bp"  # Algorithm type: 'bp' for backpropagation
problem: "vision"  # Problem domain, e.g., 'vision' for image-related tasks
seed: 24  # Seed for reproducibility
gpu: "5"  # GPU identifier
fairness: false # log class accuracy
cpu_batching: true
# Task Configuration
n_rounds: 500  # Number of training rounds
dataset: "fashion_mnist"  # Dataset name
dist: "NON-IID"  # Data distribution type: 'IID', 'NON-IID', 'ONE', 'TWO'
pholder: [1, 28, 28, 1]  # Placeholder dimensions for input data
num_classes: 10  # Number of classes in the dataset
n_clients: 5  # Number of clients for federated learning
client_epoch: 0  # Number of epochs per client
n_shards_per_client: 2  # Number of data shards per client
use_max_padding: False  # Use maximum padding for data

# Training Configuration
batch_size: 512  # Batch size for training
opt_name: "sgd"  # Optimizer name, e.g., 'sgd' for stochastic gradient descent
lr: 0.1 #0.187310371216762  # Learning rate
momentum: 0.9074430532989942  # Momentum factor for optimizer
l1_reg: 0.000  # L1 regularization factor
l2_reg: 0.0001  # L2 regularization factor

# Network Configuration
network_name: "CNN"  # Name of the neural network architecture
network_config:  # Detailed network configuration
  depth_1: 1
  depth_2: 1
  features_1: 8
  features_2: 16
  kernel_1: 5
  kernel_2: 5
  strides_1: 1
  strides_2: 1
  num_linear_layers: 0
  num_output_units: 10

# Sparsity Configuration
sparsify: false  # Enable/disable sparsity
percentage: 0.995  # Sparsity percentage

# Quantization Configuration
quantize: false  # Enable/disable quantization
n_bits: 4  # Number of bits for quantization

# Linear Regression Configuration
linear: false  # Enable/disable linear regression
reg_lr: 0.8  # Learning rate for regression
reg_iter: 25  # Number of iterations for regression

# Projection as Fitness
projection: false  # Enable/disable projection as fitness


# Evolutionary Federated Learning Configuration
evofed: false  # Enable/disable evolutionary federated learning
strategy: "OpenES"  # Evolutionary strategy
pop_size: 64  # Population size
sigma_init: 0.35  # Initial value for sigma
sigma_decay: 1  # Decay rate for sigma
sigma_limit: 0.27  # Limit for sigma decay
init_min: 0.0  # Minimum initial value for parameters
init_max: 0.0  # Maximum initial value for parameters
clip_min: -100  # Minimum clipping value for parameters
clip_max: 100  # Maximum clipping value for parameters
momentum_es: 0.9 #0.9  # Momentum for evolutionary strategy
lrate_init: 0.01265945973415419  # Initial learning rate for evolutionary strategy
lrate_decay: 0.999  # Decay rate for learning rate in evolutionary strategy
lrate_limit: 0.001  # Limit for learning rate decay
beta_1: 0.99  # Beta_1 parameter for optimizer in evolutionary strategy
beta_2: 0.999  # Beta_2 parameter for optimizer in evolutionary strategy
eps: 1e-8  # Epsilon value for numerical stability in evolutionary strategy
sigma_lrate: 0.2  # Learning rate for sigma updates
sigma_max_change: 0.2  # Maximum change for sigma per update

# Fitness Evaluation Configuration
maximize: True  # Whether to maximize the fitness function
centered_rank: True  # Use centered rank for fitness evaluation
z_score: False  # Use z-score normalization for fitness
w_decay: 0.01519011431032822  # Weight decay factor for fitness

# Data Partitioning Configuration
parts: 1  # Number of data partitions

# Evaluation Configuration
eval_every: 1  # Frequency of evaluation

# Model Saving Configuration
save_model: True  # Enable/disable model saving
save_dir: "saved_models"  # Directory to save models

# Noise Configuration
noise: False  # Enable/disable noise addition
uniform_noise: False  # Use uniform noise distribution
noise_std: 0.08  # Standard deviation for noise

# Log Histogram Errors
log_histogram: True  # Enable/disable logging history errors
bins: 50  # Number of bins for histogram


# Recycle Gradient
recycle: False  # Enable/disable gradient recycling


# Momentum Gain
momentum_gain: false  # Enable/disable momentum gain
