:py:mod:`rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring`
=========================================================================

.. py:module:: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring

.. autodoc2-docstring:: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring
   :allowtitles:

Module Contents
---------------

Classes
~~~~~~~

.. list-table::
   :class: autosummary longtable
   :align: left

   * - :py:obj:`CURICoffeeStirringTask <rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.CURICoffeeStirringTask>`
     -

Functions
~~~~~~~~~

.. list-table::
   :class: autosummary longtable
   :align: left

   * - :py:obj:`compute_curi_reward <rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.compute_curi_reward>`
     - .. autodoc2-docstring:: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.compute_curi_reward
          :summary:
   * - :py:obj:`compute_grasp_transforms <rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.compute_grasp_transforms>`
     - .. autodoc2-docstring:: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.compute_grasp_transforms
          :summary:

API
~~~

.. py:class:: CURICoffeeStirringTask(cfg, rl_device, sim_device, graphics_device_id, headless, virtual_screen_capture, force_render)
   :canonical: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.CURICoffeeStirringTask

   Bases: :py:obj:`rofunc.learning.RofuncRL.tasks.isaacgymenv.base.vec_task.VecTask`

   .. py:method:: create_sim()
      :canonical: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.CURICoffeeStirringTask.create_sim

   .. py:method:: init_data()
      :canonical: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.CURICoffeeStirringTask.init_data

      .. autodoc2-docstring:: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.CURICoffeeStirringTask.init_data

   .. py:method:: compute_reward(actions)
      :canonical: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.CURICoffeeStirringTask.compute_reward

      .. autodoc2-docstring:: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.CURICoffeeStirringTask.compute_reward

   .. py:method:: compute_observations()
      :canonical: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.CURICoffeeStirringTask.compute_observations

      .. autodoc2-docstring:: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.CURICoffeeStirringTask.compute_observations

   .. py:method:: reset_idx(env_ids)
      :canonical: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.CURICoffeeStirringTask.reset_idx

   .. py:method:: pre_physics_step(actions)
      :canonical: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.CURICoffeeStirringTask.pre_physics_step

   .. py:method:: post_physics_step()
      :canonical: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.CURICoffeeStirringTask.post_physics_step

.. py:function:: compute_curi_reward(reset_buf: Tensor, progress_buf: Tensor, actions: Tensor, cabinet_dof_pos: Tensor, curi_grasp_pos: Tensor, drawer_grasp_pos: Tensor, curi_grasp_rot: Tensor, drawer_grasp_rot: Tensor, curi_lfinger_pos: Tensor, curi_rfinger_pos: Tensor, gripper_forward_axis: Tensor, drawer_inward_axis: Tensor, gripper_up_axis: Tensor, drawer_up_axis: Tensor, num_envs: int, dist_reward_scale: float, rot_reward_scale: float, around_handle_reward_scale: float, open_reward_scale: float, finger_dist_reward_scale: float, action_penalty_scale: float, distX_offset: float, max_episode_length: float) -> Tuple[Tensor, Tensor]
   :canonical: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.compute_curi_reward

   .. autodoc2-docstring:: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.compute_curi_reward

.. py:function:: compute_grasp_transforms(hand_rot: Tensor, hand_pos: Tensor, curi_local_grasp_rot: Tensor, curi_local_grasp_pos: Tensor, drawer_rot: Tensor, drawer_pos: Tensor, drawer_local_grasp_rot: Tensor, drawer_local_grasp_pos: Tensor) -> Tuple[Tensor, Tensor, Tensor, Tensor]
   :canonical: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.compute_grasp_transforms

   .. autodoc2-docstring:: rofunc.learning.RofuncRL.tasks.isaacgymenv.curi_coffee_stirring.compute_grasp_transforms
