<!-- Credit: adapted from Mujoco Menagerie -->
<mujoco model="panda">
  <compiler angle="radian" meshdir="franka_emika_panda/assets" autolimits="true"/>

  <option integrator="implicitfast" impratio="10"/>
    
  <default>
    <default class="panda">
      <joint armature="0.1" damping="5" axis="0 0 1" range="-2.8973 2.8973"/>
      <general dyntype="none" biastype="affine" ctrlrange="-2.8973 2.8973" forcerange="-87 87"/>
      <default class="finger">
        <joint axis="0 1 0" type="slide" range="0 0.05"/>
      </default>

      <default class="visual">
        <geom type="mesh" contype="0" conaffinity="0" group="2"/>
      </default>
      <default class="collision">
        <geom type="mesh" group="3"/>
        <default class="finger_collision">
          <geom type="box" size="0.015 0.005 0.04" pos="0 0.0055 0.035" friction="10 0.005 0.0001"/>
        </default>
      </default>
    </default>
  </default>

  <asset>
    <!-- Visual meshes -->
    <mesh file="link0_0.obj"/>
    <mesh file="link0_1.obj"/>
    <mesh file="link0_2.obj"/>
    <mesh file="link0_3.obj"/>
    <mesh file="link0_4.obj"/>
    <mesh file="link0_5.obj"/>
    <mesh file="link0_7.obj"/>
    <mesh file="link0_8.obj"/>
    <mesh file="link0_9.obj"/>
    <mesh file="link0_10.obj"/>
    <mesh file="link0_11.obj"/>
    <mesh file="link1.obj"/>
    <mesh file="link2.obj"/>
    <mesh file="link3_0.obj"/>
    <mesh file="link3_1.obj"/>
    <mesh file="link3_2.obj"/>
    <mesh file="link3_3.obj"/>
    <mesh file="link4_0.obj"/>
    <mesh file="link4_1.obj"/>
    <mesh file="link4_2.obj"/>
    <mesh file="link4_3.obj"/>
    <mesh file="link5_0.obj"/>
    <mesh file="link5_1.obj"/>
    <mesh file="link5_2.obj"/>
    <mesh file="link6_0.obj"/>
    <mesh file="link6_1.obj"/>
    <mesh file="link6_2.obj"/>
    <mesh file="link6_3.obj"/>
    <mesh file="link6_4.obj"/>
    <mesh file="link6_5.obj"/>
    <mesh file="link6_6.obj"/>
    <mesh file="link6_7.obj"/>
    <mesh file="link6_8.obj"/>
    <mesh file="link6_9.obj"/>
    <mesh file="link6_10.obj"/>
    <mesh file="link6_11.obj"/>
    <mesh file="link6_12.obj"/>
    <mesh file="link6_13.obj"/>
    <mesh file="link6_14.obj"/>
    <mesh file="link6_15.obj"/>
    <mesh file="link6_16.obj"/>
    <mesh file="link7_0.obj"/>
    <mesh file="link7_1.obj"/>
    <mesh file="link7_2.obj"/>
    <mesh file="link7_3.obj"/>
    <mesh file="link7_4.obj"/>
    <mesh file="link7_5.obj"/>
    <mesh file="link7_6.obj"/>
    <mesh file="link7_7.obj"/>
    <mesh file="hand_0.obj"/>
    <mesh file="hand_1.obj"/>
    <mesh file="hand_2.obj"/>
    <mesh file="hand_3.obj"/>
    <mesh file="hand_4.obj"/>
    <mesh file="finger_0.obj"/>
    <mesh file="finger_1.obj"/>
  </asset>

  <worldbody>
    <light name="top" pos="0 0 2" mode="trackcom"/>
    <body name="binA" pos="-0.17 0.6 0">
      <geom name="binA1" pos="0 -0.14 0.033" size="0.145 0.005 0.033" type="box" rgba="0 0.2 0.8 1" contype="0" conaffinity="0"/>
      <geom name="binA2" pos="0 0.14 0.033" size="0.145 0.005 0.033" type="box" rgba="0 0.2 0.8 1" contype="0" conaffinity="0"/>
      <geom name="binA3" pos="0.14 0 0.033" size="0.005 0.135 0.033" type="box" rgba="0 0.2 0.8 1" contype="0" conaffinity="0"/>
      <geom name="binA4" pos="-0.14 0 0.033" size="0.005 0.135 0.033" type="box" rgba="0 0.2 0.8 1" contype="0" conaffinity="0"/>
    </body>
    <body name="binB" pos="0.17 0.6 0">
      <geom name="binB1" pos="0 -0.14 0.033" size="0.145 0.005 0.033" type="box" rgba="0.8 0 0 1" contype="0" conaffinity="0"/>
      <geom name="binB2" pos="0 0.14 0.033" size="0.145 0.005 0.033" type="box" rgba="0.8 0 0 1" contype="0" conaffinity="0"/>
      <geom name="binB3" pos="0.14 0 0.033" size="0.005 0.135 0.033" type="box" rgba="0.8 0 0 1" contype="0" conaffinity="0"/>
      <geom name="binB4" pos="-0.14 0 0.033" size="0.005 0.135 0.033" type="box" rgba="0.8 0 0 1" contype="0" conaffinity="0"/>
    </body>
    
    <body name="cube" pos="-0.15 0.6 0.07">
      <freejoint/>
      <geom name="cube_geom" size="0.03 0.03 0.03" type="box" rgba="0 0.4 0 1" contype="0" conaffinity="0"/>
    </body>
      
    <body name="goal_marker" pos="0.15 0.6 0.07" gravcomp="1">
      <freejoint/>
      <geom name="goal_marker_geom" size="0.03 0.03 0.03" type="box" rgba="0.3 1 0.3 1" contype="0" conaffinity="0"/>
    </body>
      
    <body name="tablelink" pos="0 .2 0">
      <geom name="table_geom" group="4" pos="0.0 0.0 0.0" size="2.8 2.4 0.1" type="plane" mass="10" friction="0.2 0.005 0.0001" contype="0" conaffinity="0"/>
    </body>
      
    <body name="cube_walls" pos="0 0 0">
      <geom name="back_wall" pos="0 0.35 0.15" size="0.41 0.01 0.15" type="box" rgba="1 1 1 0" contype="0" conaffinity="0"/>
      <geom name="front_wall" pos="0 0.85 0.15" size="0.41 0.01 0.15" type="box" rgba="1 1 1 0" contype="0" conaffinity="0"/>
      <geom name="left_wall" pos="-0.4 0.6 0.15" size="0.01 0.24 0.15" type="box" rgba="1 1 1 0" contype="0" conaffinity="0"/>
      <geom name="right_wall" pos="0.4 0.6 0.15" size="0.01 0.24 0.15" type="box" rgba="1 1 1 0" contype="0" conaffinity="0"/>
    </body>
      
    <body name="hand" pos="0 0 0" quat="0 -1 1 0" gravcomp="1"> <!-- Need to rotate by 180 degrees on y-axis, then 90 degrees z-axis -->
      <joint name="hand_x" type="slide" pos="0 0 0" axis="0 -1 0" range="-0.4 0.4"/> <!-- Choose axes relative to hand so joint lengths correspond to the world position -->
      <joint name="hand_y" type="slide" pos="0 0 0" axis="-1 0 0" range="0.35 0.85"/>
      <joint name="hand_z" type="slide" pos="0 0 0" axis="0 0 -1" range="0 0.3"/>
      <geom name="hand_geom" rgba="1 1 1 1" type="capsule" size="0.04 0.06" pos="0 0 0.035" quat="1 1 0 0" contype="0" conaffinity="0"/>
      <body name="left_finger" pos="0 0 0.0584">
        <inertial mass="0.015" pos="0 0 0" diaginertia="2.375e-6 2.375e-6 7.5e-7"/>
        <joint name="finger_joint1" class="finger"/>
          <geom name="left_finger_geom" rgba="0.25 0.25 0.25 1" class="finger_collision" contype="0" conaffinity="0"/>
      </body>
      <body name="right_finger" pos="0 0 0.0584" quat="0 0 0 1">
        <inertial mass="0.015" pos="0 0 0" diaginertia="2.375e-6 2.375e-6 7.5e-7"/>
        <joint name="finger_joint2" class="finger"/>
          <geom name="right_finger_geom" rgba="0.25 0.25 0.25 1" class="finger_collision" contype="0" conaffinity="0"/>
      </body>
    </body>
  </worldbody>

  <equality>
    <joint joint1="finger_joint1" joint2="finger_joint2" solimp="0.95 0.99 0.001" solref="0.005 1"/>
  </equality>
    
  <contact>
    <pair geom1="cube_geom" geom2="table_geom"/>
    <pair geom1="cube_geom" geom2="binA1"/>
    <pair geom1="cube_geom" geom2="binA2"/>
    <pair geom1="cube_geom" geom2="binA3"/>
    <pair geom1="cube_geom" geom2="binA4"/>
    <pair geom1="cube_geom" geom2="binB1"/>
    <pair geom1="cube_geom" geom2="binB2"/>
    <pair geom1="cube_geom" geom2="binB3"/>
    <pair geom1="cube_geom" geom2="binB4"/>
    <pair geom1="cube_geom" geom2="hand_geom"/>
    <pair geom1="cube_geom" geom2="left_finger_geom"/>
    <pair geom1="cube_geom" geom2="right_finger_geom"/>
    <pair geom1="cube_geom" geom2="back_wall"/>
    <pair geom1="cube_geom" geom2="front_wall"/>
    <pair geom1="cube_geom" geom2="left_wall"/>
    <pair geom1="cube_geom" geom2="right_wall"/>
      
    <pair geom1="table_geom" geom2="hand_geom"/>
    <pair geom1="table_geom" geom2="left_finger_geom"/>
    <pair geom1="table_geom" geom2="right_finger_geom"/>
    
    <!-- The finger and bin collisions aren't being registered that well so fingers will ghost through the bin if enough force is applied and the fingers are fast enough. -->
    <pair geom1="left_finger_geom" geom2="binA1"/>
    <pair geom1="left_finger_geom" geom2="binA2"/>
    <pair geom1="left_finger_geom" geom2="binA3"/>
    <pair geom1="left_finger_geom" geom2="binA4"/>
    <pair geom1="left_finger_geom" geom2="binB1"/>
    <pair geom1="left_finger_geom" geom2="binB2"/>
    <pair geom1="left_finger_geom" geom2="binB3"/>
    <pair geom1="left_finger_geom" geom2="binB4"/>
    <pair geom1="right_finger_geom" geom2="binA1"/>
    <pair geom1="right_finger_geom" geom2="binA2"/>
    <pair geom1="right_finger_geom" geom2="binA3"/>
    <pair geom1="right_finger_geom" geom2="binA4"/>
    <pair geom1="right_finger_geom" geom2="binB1"/>
    <pair geom1="right_finger_geom" geom2="binB2"/>
    <pair geom1="right_finger_geom" geom2="binB3"/>
    <pair geom1="right_finger_geom" geom2="binB4"/>
    <pair geom1="hand_geom" geom2="binA1"/>
    <pair geom1="hand_geom" geom2="binA2"/>
    <pair geom1="hand_geom" geom2="binA3"/>
    <pair geom1="hand_geom" geom2="binA4"/>
    <pair geom1="hand_geom" geom2="binB1"/>
    <pair geom1="hand_geom" geom2="binB2"/>
    <pair geom1="hand_geom" geom2="binB3"/>
    <pair geom1="hand_geom" geom2="binB4"/>
      
    <pair geom1="left_finger_geom" geom2="right_finger_geom"/>
  </contact>

  <actuator>
    <general class="panda" name="actuator_hand_x" joint="hand_x" gainprm="1000" biasprm="0 -1000 -100"/>
    <general class="panda" name="actuator_hand_y" joint="hand_y" gainprm="1000" biasprm="0 -1000 -100"/>
    <general class="panda" name="actuator_hand_z" joint="hand_z" gainprm="1000" biasprm="0 -1000 -100"/>
    <!-- Remap original ctrlrange (0, 0.05) to (0, 255): 0.05 * 500 / 255 = 0.09804 -->
    <general class="panda" name="actuator8" joint="finger_joint1" forcerange="-500 500" ctrlrange="0 255"
      gainprm="0.09804 0 0" biasprm="0 -500 -50"/>
    <general class="panda" name="actuator9" joint="finger_joint2" forcerange="-500 500" ctrlrange="0 255"
      gainprm="0.09804 0 0" biasprm="0 -500 -50"/>
  </actuator>
</mujoco>
