import robosuite.controllers.base_controller as base_controller_module
import robosuite.models.grippers.panda_gripper as panda_gripper_module
import robosuite.environments.base as base_module

# used for high speed libero

def patched_scale_action(self, action):
    if self.action_scale is None:
        self.action_scale = abs(self.output_max - self.output_min) / abs(self.input_max - self.input_min)
        self.action_output_transform = (self.output_max + self.output_min) / 2.0
        self.action_input_transform = (self.input_max + self.input_min) / 2.0
    # 注意：这里没有 clip 操作
    transformed_action = (action - self.action_input_transform) * self.action_scale + self.action_output_transform
    return transformed_action

def step(self, action):
    self.timestep += 1
    policy_step = True
    for i in range(int(self.control_timestep / self.model_timestep)):
        self.sim.forward()
        self._pre_action(action, policy_step)
        self.sim.step()
        self._update_observables()
        policy_step = False
    self.cur_time += self.control_timestep
    reward, done, info = self._post_action(action)
    if self.viewer is not None and self.renderer != "mujoco":
        self.viewer.update()
    observations = self.viewer._get_observations() if self.viewer_get_obs else self._get_observations()
    return observations, reward, done, info

def patched_speed_property(self):
    return 0.02

def apply_patches():
    base_controller_module.Controller.scale_action = patched_scale_action
    panda_gripper_module.PandaGripper.speed = property(patched_speed_property)
    base_module.MujocoEnv.step = step


