- Nathaniel Goldfarb (nagoldfarb@wpi.edu)
- Shreyas Chandra Sekhar (cshreyastech@gmail.com) This package contains the RBDL server and Controller server for
controlling robotic model in AMBF. The purpose is to provide a framework to build model based controller for simulated robotic systems in the AMBF frame work. AMBF can be found here. The frameworks uses ROS servervices message to communicate between you custom application and the servers. This allows
The
The follow need to be installed. Please follow their respected install instructions
The ambf_control_package needs to be installed in a catkin_ws
A server object can be created using the following code
#include "ros/ros.h"
#include "rbdl_server/RBDLServer.h"
int main(int argc, char **argv)
{
ros::init(argc, argv, "Dynamic_Server");
ros::NodeHandle n;
RBDLServer my_server(&n);
ros::spin();
return 0;
}
And can be communicated with using the following code. The RBDL model first has to be created using the AMBF model file. The dynamics can then be calculated. IT is important to note that joint order matters a great deal and the joint order will not match.
"""
use the RBDL server to create the model
"""
import rospy
from rbdl_server.srv import RBDLModel, RBDLModelAlignment
from rbdl_server.srv import RBDLInverseDynamics
RBDL = "path to Yaml model file"
name = "name of model" # This can be anything you want, by assaining spesific names muiple models can be controlled.
try:
print("making model")
model_srv = rospy.ServiceProxy('CreateModel', RBDLModel)
resp1 = model_srv(name, model_path)
except rospy.ServiceException as e:
print("Service call failed: %s"%e)
"""
Then the dynamics can be calculated using the following
"""
tau = np.asarray([0.0] * joint_num)
rospy.wait_for_service("InverseDynamics")
try:
dyn_srv = rospy.ServiceProxy('InverseDynamics', RBDLInverseDynamics)
resp1 = dyn_srv(model_name, q, qd, qdd)
tau = resp1.tau
except rospy.ServiceException as e:
print("Service call failed: %s"%e)
Below is an example of how to convert between RBDL model and the AMBF model.
def ambf_to_rbdl(self, q):
"""
make the order of the joints for the dynamics
"""
names = self._selected_joint_names # A list of the joints names you want
ambf_joints_names = self.handle.get_joint_names()
joints_aligned = [0.0]*len(names)
q_new = [0.0]*len(names)
for ii, name in enumerate(names):
if(len(names) > len(ambf_joints_names)):
index = self._joint_map_selected[name]
else:
index = self._joint_map[name] - 1
joints_aligned[index] = q[ii]
return joints_aligned
def rbdl_to_ambf(self, q):
"""
reverse the order of the AMBF
"""
names = self._selected_joint_names
ambf_joints_names = self.handle.get_joint_names()
q_new = [0.0]*len(names)
for ii, name in enumerate(names):
if(len(names) > len(ambf_joints_names)):
index = self._joint_map_selected[name]
else:
index = self._joint_map[name] - 1
q_new[ii] = q[index]
return q_new