# @package env_mods
# Configuration for environment modifications

use_mods: false  # Master switch for all modifications

# Observation noise configuration
observation_noise:
  enabled: false
  type: "gaussian"  # Options: gaussian, uniform, saltpepper, adversarial
  level: 0.1  # Noise magnitude
  frequency: 1.0  # Frequency of applying noise (1.0 = every step)

# Action perturbation configuration
action_perturb:
  enabled: false
  type: "noise"  # Options: drop, noise, delay, stuck
  probability: 1.0  # Probability of perturbation
  level: 0.1  # Magnitude of perturbation

# Reward shift configuration
reward_shift:
  enabled: false
  type: "scale"  # Options: scale, delay, noise, sparse, sign_flip
  param: 0.9  # Parameter for the specific shift type
  noise_level: 0.1  # Standard deviation of noise (for 'noise' type)

# Transition dynamics perturbation
transition_perturb:
  enabled: false
  type: "teleport"  # Options: teleport, random_force, friction
  probability: 0.05  # Probability of applying the perturbation
  level: 0.1  # Magnitude of the perturbation

# Parameter shift configuration (for supported environments)
param_shift:
  enabled: false
  train_apply: false
  eval_apply: true
  # For Pendulum:
  gravity_factor: 1.0  # Gravity factor
  mass_factor: 1.0  # Mass factor
  length_factor: 1.0  # Length factor
  # For Cartpole:
  # Share gravity_factor:1.0, length_factor:1.0, mass_factor:1.0
  force_mag_factor: 1.0
  # For LunarLander:
  # Share gravity_factor:1.0
  wind_power: 0.0  # Constant wind force
  turbulence_power: 1.5  # Random turbulence
  engine_factor: 1.0 # Main and side engine power factor
  # For Halfcheetah
  back_stiff: 1.0
  front_stiff: 1.0
  back_damping: 1.0
  front_damping: 1.0
  act_ctrlrange: 1.0
  # For Reacher
  joint0_stiff: 0.0
  joint1_stiff: 0.0
  joint0_damping: 1.0
  joint1_damping: 1.0

# Evaluation environment configuration
eval:
  use_modified: true  # Whether to use modified env for evaluation
  include_observation_perturb: true  # Include action perturbations in eval
  include_action_perturb: true  # Include action perturbations in eval
  include_reward_shift: true  # Include reward shifts in eval
  include_transition_perturb: true  # Include transition perturbations in eval