Closed sakthiprasasd closed 5 years ago
Hello Sakthiprasasd, For cartesian control please refer to this link : https://github.com/Kinovarobotics/kinova-ros#cartesian-position-control Sincerely,
Hi Nassif, Tool coordinate control is different from cartesian. We did the Cartesian control, but no provision is there to control the arm in tool coordinate system. Please refer to the image to get a better idea
Hello Sakthiprasasd,
My name is Sylvain Brisebois, a colleague of Martine and Nassif.
I think I understand what you want and here is an implementation that Martine gave me to perform a tool motion control on the Jaco.
This example is intended to apply a transformation to a joystick command to control the translation in the gripper frame instead of the base frame.
// Gripper frame control CartesianPosition pose;
// Get actual gripper pose (Position & orientation)
lApiErr = m_RobotAPI.fGetCartesianCommand(pose);
KeDelay::SleepMs(5);
if(lApiErr != NO_ERROR_KINOVA)
{
LOG(LOG_ERR, "Robot API SendJoystickCommand Error: %d",lApiErr);
m_ConsecutiveCommErrors++;
}
else
{
//the transformation matrix between end-effector and base frame is given by the end-effector orientation
Eigen::Matrix3f orientation_robot;
orientation_robot = Eigen::AngleAxisf(pose.Coordinates.ThetaX, Eigen::Vector3f::UnitX())
* Eigen::AngleAxisf(pose.Coordinates.ThetaY, Eigen::Vector3f::UnitY())
* Eigen::AngleAxisf(pose.Coordinates.ThetaZ, Eigen::Vector3f::UnitZ());
//translation vector in end-effector frame
Eigen::Vector3f translation_vector_ee_frame(lthreadJoystickCommand.InclineLeftRight,
-lthreadJoystickCommand.InclineForwardBackward,
lthreadJoystickCommand.Rotate);
//translation vector in base frame
Eigen::Vector3f translation_vector_base_frame = orientation_robot * translation_vector_ee_frame;
//update the x-y-z part of the command
lthreadJoystickCommand.InclineLeftRight = translation_vector_base_frame(0); // X
lthreadJoystickCommand.InclineForwardBackward = translation_vector_base_frame(1); // Y
lthreadJoystickCommand.Rotate = translation_vector_base_frame(2); // Z
}
This algo will need some modification for your situation, but the idea is there. The orientation still need to be adapted if you want it to be controlled in position, but in velocity it's already in the gripper frame.
Let me know if you need assistance for that too.
Hi Sylvain Brisebois, Thank you so much for your reply. We need some more support from your side. The first time we are using visual studio and Kinova codes. We don't know where we need to modify or which file we need to change to get tool coordinate control. In windows, Example_cartesian mode control - 3 header files and one source code are there in that the c++ source code eigon vector, frame details, and DH parameters are not there. We cant able to find the details of functions mentioned in that program. From where we get those details? Through SDK we can able to run examples but not able to run through the visual studio. Is there any additional thing we need to do to get the arm movement??
Hi Sylvain Brisebois, If we modify the urdf, we can find the solution for this issue? using SolidWorks it's very difficult to do the modification of urdf. what software did you use to do the urdf?
Kinovarobotics/matlab_Kinovaapi_wrapper is there to integrating Kinova with Matlab. Through Matlab, we can achieve tool coordinate control ?? Is there any example in Matlab which is helpful for us?
Hi sakthiprasasd,
Yess the Kinovarobotics/matlab_Kinovaapi_wrapper is there to integrating Kinova with Matlab. The following codes will help you to achieve your goal.
tool_pose.txt EulerXYZtoRot.txt
This code is ready to use with the matlab wrapper from kinova just rename them as matlab files. This code, make the arm move in hand effector frame, but only in transaltion. Fortunately, when you control the arm in cartesian velocity for rotation, it already move in end effector frame. This means that you only can use the sendCartesianVelocityCommand as is for End effector rotation.
Sincerely,
Hi Sylvain Brisebois, Thank you so much for your support. Currently, we are working in Matlab. We can able to control the arm. Tool coordinate control is not completely working we are trying to solve the issues.
Is there any method to disable the singularity avoidance method?
To disable the singularity avoidance, you have to control the arm with the low-level API. This API is not supported in Matlab.
For tool control, which issues are you facing? Is it about the code I provide you?
Hi Sylvain Brisebois, Thank you so much for your support. Tool coordinate is working with Matlab. But we are doing everything in ROS platform, so can you give the ROS package for tool coordinate control?
Hi sakthiprasasd,
We do not have a package ROS for tool coordinate control, but the logic behind the Matlab code is the same that the one you have to implement in ROS. You have to create your own node which passes the translation command through the transformation matrix, given in Matlab code, before sending it to the arm. For rotation, you only have to send velocity command. To summarize, your node will be an intermediate between the user and the Kinova ROS package. It will take tool coordinate command in input from the user and will output base coordinate command that will be sent directly to the arm via the API.
I will try to create a simple node to do this today. Let me know if I can do something else.
One Thing I can suggest you is to modify the pose_action_client.py. This node already calls each function of the API that you'll need to control the arm in tool coordinate.
Hi Sylvain Brisebois, Thank you so much for your support. Now we can able to control the arm in 'tool coordinate system' with the help of the commands.
Hi, Anyone can suggest a method or tutorial for tool coordinate control of Kinova arm J2S6S300??