# @package habitat.task

defaults:
  - /habitat/task: task_config_base
  - /habitat/task/actions:
    - arm_action
    - base_velocity
  - /habitat/task/measurements:
    - articulated_agent_force
    - force_terminate
    - articulated_agent_colls
    - robot_collisions_terminate
    - end_effector_to_rest_distance
    - end_effector_to_object_distance
    - did_pick_object
    - pick_distance_to_goal
    - pick_distance_to_goal_reward
    - pick_success
    - pick_reward
    - did_violate_hold_constraint
    - num_steps
  - /habitat/task/lab_sensors:
    - target_start_sensor
    - joint_sensor
    - joint_velocity_sensor
    - is_holding_sensor
    - end_effector_sensor
    - relative_resting_pos_sensor
    - object_category_sensor
    - object_segmentation_sensor
    - object_embedding_sensor
    - start_recep_segmentation_sensor
    - start_receptacle_sensor
  - _self_

type: RearrangePickTask-v0
base_angle_noise: 0.2618 # 15 degrees
constraint_violation_ends_episode: False
constraint_violation_drops_object: True
reward_measure: "pick_reward"
success_measure: "pick_success"
success_reward: 10.0
slack_reward: -0.005
end_on_success: True
desired_resting_position: [0.119, -0.383, 0.657]
spawn_reference: view_points
spawn_reference_sampling: uniform
spawn_max_dist_to_obj: 0.0
start_in_manip_mode: False
camera_tilt: -0.5236      # start in navigation mode
actions:
  arm_action:
    type: "ArmAction"
    arm_controller: "ArmRelPosKinematicReducedActionStretch"
    grip_controller: "GazeGraspAction"
    arm_joint_mask: [0,0,0,0,0,0,0,0,0,1]
    arm_joint_dimensionality: 1
    grasp_thresh_dist: 0.15
    disable_grip: False
    max_delta_pos: 0.1
    min_delta_pos: 0.02
    ee_ctrl_lim: 0.015
    gaze_distance_range: [0.1, 0.8]
    center_cone_angle_threshold: 90.0
    center_cone_vector: [0.0, 1.0, 0.0]
    grasp_threshold: 0.8
    gaze_distance_from: agent
    wrong_grasp_should_end: True
  base_velocity:
    type: "BaseWaypointTeleportAction"
    navmesh_offset: [[0.0, 0.0]]
measurements:
  force_terminate:
    max_accum_force: 10_000.0
    max_instant_force: 10_000.0
  pick_distance_to_goal:
    distance_to: EUCLIDEAN_POINT
    distance_from: END_EFFECTOR
    goals_attr: candidate_objects
  pick_success:
    object_goal: True
    ee_resting_success_threshold: 100.0
  pick_reward:
    object_goal: True
    angle_reward_min_dist: 0.0
    angle_reward_scale: 1.0
    navmesh_violate_pen: 0.3
lab_sensors:
  joint_sensor:
    dimensionality: 10
  joint_velocity_sensor:
    dimensionality: 10
  start_recep_segmentation_sensor:
    blank_out_prob: 0.5
  object_segmentation_sensor:
    blank_out_prob: 0.5
