Skip to content

Latest commit

 

History

History
123 lines (91 loc) · 3.75 KB

File metadata and controls

123 lines (91 loc) · 3.75 KB

Compliant Control and Application

It contains the compliant control algorithms in robotic arm, and the chosen robot is universal robot which is popular collaborate robot in the world.

Compile

mkdir catkin_ws/src && cd catkin_ws/src
git clone https://github.com/MingshanHe/Compliant-Control-and-Application.git
catkin build (or cd .. && catkin_make)

If there is come up with some errors during compile process, you might need to install some ros packages for support this project, I recommend you to run following command or search the compile error in Google or Baidu and so on.

rosdep install -i --from-path src --rosdistro noetic --ignore-src -r -y

Check

using the following command to check the self-defined controller. Like:cartesian_velocity_controller

rospack plugins --attrib=plugin controller_interface

Run

Notice: In this repository, I have used ur5e robot and its urdf file need to be changed in different situation, like need or not a force/torque sensor in the end effector. Please check the urdf file seriously and run the algorithm, Thanks.

1. Admittance

roslaunch ur_gazebo ur5e_bringup.launch transmission_hw_interface:=hardware_interface/PositionJointInterface specified_controller:=cartesian_velocity_controller
roslaunch admittance Admittance.launch

After the robot has moved to the desired pose, run the following commands to generate fake wrench signal

roslaunch admittance Wrench_Fake.launch

2. Impedance

roslaunch ur_gazebo ur5e_bringup.launch transmission_hw_interface:=hardware_interface/EffortJointInterface specified_controller:=joint_torque_controller
roslaunch impedance Impedance.launch

3. Application (Hybrid Admittance Control)

roslaunch mir_gazebo mir_ur5e.launch tf_prefix:=robot1
roslaunch admittance HybridAdmittance.launch tf_prefix:=robot1

4. Hybrid Position Force Control

roslaunch ur_gazebo ur5e_bringup.launch transmission_hw_interface:=hardware_interface/PositionJointInterface specified_controller:=cartesian_velocity_controller environment:=polish
roslaunch hybrid_position_force_control hybrid_position_force_control.launch

And then it needs to use the topic publish command in the terminal. It is recommended to move to the pose [-0.1, 0.3, 0.3, 0.707, -0.707, 0.0, 0.0].

rostopic pub /desired_carteisan_pose_cmd geometry_msgs/Pose "position: x: -0.10 y: 0.30 z: 0.30 orientation: x: 0.707 y: -0.707 z: 0.0 w: 0.0" 

5. Mobile Robot

roslaunch mir_gazebo mir.launch

There are some pre-settings that will be needed to run in this project. Three mode is provided to be tested.

  1. Mobile Robot(mir robot)
  2. Mobile Robot(mir robot) with a Robotic Arm(UR5E)
  3. Mobile Robot(mir robot) with a Robotic Arm(UR5E) and a Gripper(Robotiq)

For change amoung them, this project have provided the setting params in the mir.launch file. And you also need to change the start controller for the robotic arm in mir_gazebo_common.launch

roslaunch mir_navigation move_base.xml with_virtual_walls:=false

Mapping

roslaunch mir_navigation hector_mapping.launch
rviz -d $(rospack find mir_navigation)/rviz/navigation.rviz

Navigation

roslaunch mir_navigation start_planner.launch \
    map_file:=$(rospack find mir_gazebo)/maps/maze.yaml \
    virtual_walls_map_file:=$(rospack find mir_gazebo)/maps/maze_virtual_walls.yaml
rviz -d $(rospack find mir_navigation)/rviz/navigation.rviz

Performance

1. Admittance

1

2. Hybrid Admittance Control

2

3. Hybrid Position Force Control

3

123