defaults:
  - ovmm@config: ovmm_eval
  - env@config: hssd_eval
  - agent/config@config.AGENT: heuristic_agent
  - agent/config/options@config.AGENT: [default, debug]
  - habitat_baselines/rl/policy/hierarchical_policy/defined_skills@config.habitat_baselines.rl.policy.hierarchical_policy.defined_skills: nn_skills
  - _self_
  - agent: base
  - evaluator: helios_evaluator

output_dir: ./evaluate/${hydra:runtime.choices.agent/gaze}-${start_episode}_${num_episodes}${eval:'"-gt_semantics" if ${config.GROUND_TRUTH_SEMANTICS} else ""'}
evaluation_type: local
start_episode: 0 # start episode
end_episode: null # end episode. this overrides num_episodes
num_episodes: ${eval:'None if ${end_episode} is None else ${end_episode}-${start_episode}'} # number of episodes
max_episode_steps: 1250 # max number of steps per episode. 1250: default
visualize: True # visualize ovmm and nav
# pixels_per_meter: 20
# map_size: 1000 # in pixels
pixels_per_meter: 40
map_size: 2000 # in pixels
planning_window_size: ${eval:'${map_size} // 2'} # size of planning window
gt_semantics: False # use ground truth semantics
save_rep: False # save gaussian splats
keep_exploring: True # keep exploring after depletion of frontiers
catch_exceptions: ${eval:'${num_episodes} >= 100'} # catch exceptions in agent.act() and terminate episode
visualize_3dgs: False
visualize_eig: False

alpha_uncertainty: 1
alpha_d: 0.001

thresh_sr_wu: 0.4
thresh_go_wu: 0.5
thresh_er_wu: 0.6

thresh_sr_g: 0.4
thresh_go_g: 0.3
thresh_er_g: 0.4

thresh_sr: 0.5
thresh_go: 0.4
thresh_er: 0.4

allow_multiple_visits_sr: False
allow_multiple_visits_go: False
allow_multiple_visits_er: False

use_our_pick: True
use_our_place: True

rl_place: False

use_2dgs: False

detection_module: detic #choices: 'detic', 'grounded_sam'
detection_conf_threshold: 0.45
semantic_threshold_for_er: 0.55
semantic_threshold_for_sr: 0.45

concentration_param_scaling_factor: 3
concentration_param_opacity_scaling_factor: 1

use_global_objective: True

stop_on_collision: True

use_dist_scale: False

habitat:
  environment:
    max_episode_steps: ${max_episode_steps}
    iterator_options:
      shuffle: True
      max_scene_repeat_episodes: 10
      max_scene_repeat_steps: -1

config:
  habitat: ${habitat}
  DUMP_LOCATION: ${output_dir}
  habitat_baselines:
    image_dir: ${output_dir}/images
    video_dir: ${output_dir}/videos
    video_fps: 4
  AGENT:
    detection_module: ${detection_module} # the detector to use for perception in case ground_truth_semantics are turned off
    VISION:
      confidence_threshold: ${detection_conf_threshold} # detic object detection confidence threshold
    SEMANTIC_MAP:
      map_size_cm: 5000
    fall_wait_steps: 200 #${eval:'1 if ${gt_semantics} else 0'}
    PLACE:
      type: ${eval:'"rl" if ${rl_place} else "heuristic"'} # "rl" or "heuristic" or "hardcoded"
  GROUND_TRUTH_SEMANTICS: ${eval:'1 if ${gt_semantics} else 0'}
  EXP_NAME: ''
  PRINT_IMAGES: ${visualize}
  EVAL_VECTORIZED:
    metrics_save_freq: 1

hydra:
  run:
    dir: ${output_dir}

platform: sim