-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmoveit_collision_checker_py.cpp
128 lines (106 loc) · 3.46 KB
/
moveit_collision_checker_py.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
#include <vector>
#include <ros/ros.h>
#include <boost/thread.hpp>
#include <boost/python.hpp>
#include <boost/python/stl_iterator.hpp>
#include <boost/algorithm/string.hpp>
#include <moveit_collision_checker/moveit_collision_checker.h>
using namespace boost::python;
using namespace moveit_collision_checker;
template<typename T>
static void python_to_vector(boost::python::object o, std::vector<T> &v) {
stl_input_iterator<T> begin(o);
stl_input_iterator<T> end;
v.clear();
v.insert(v.end(), begin, end);
}
template<class T>
static list vector_to_list(const std::vector<T>& v)
{
object get_iter = iterator<std::vector<T> >();
object iter = get_iter(v);
list l(iter);
return l;
}
static int argc;
static char **argv;
static bool keep_running;
static boost::shared_ptr<boost::thread> spin_thread;
static void spin() {
ros::NodeHandle nh;
ros::Rate r(50);
while(keep_running) {
ros::spinOnce();
r.sleep();
}
}
static void init_roscpp() {
keep_running = true;
if(not ros::isInitialized()) {
object sys_module = import("sys");
list py_argv = extract<list>(sys_module.attr("argv"));
argc = 0;
argv = new char*[argc];
for(int i=0; i<len(py_argv); i++) {
std::string arg = extract<std::string>(py_argv[i]);
if(arg.compare(0, 8, "__name:=") != 0) {
argv[argc] = extract<char*>(py_argv[i]);
argc++;
}
}
object rospy_module = import("rospy");
object get_name = rospy_module.attr("get_name");
std::string name = extract<std::string>(get_name());
std::vector<std::string> strs;
boost::split(strs, name, boost::is_any_of("/"));
std::cerr<<"Initializing roscpp with ROS name: \""<<strs.back()+"_cpp"<<"\""<<std::endl;
ros::init(argc, argv, strs.back()+"_cpp",
ros::init_options::NoSigintHandler);
//spin_thread = boost::make_shared<boost::thread>(spin);
std::cerr<<"Initialized."<<std::endl;
}
}
static void shutdown_roscpp() {
keep_running = false;
//spin_thread->join();
ros::shutdown();
delete[] argv;
argc = 0;
}
class CheckerWrapper : public Checker {
public:
CheckerWrapper(
std::string robot_description_param,
std::string root_link,
std::string planning_scene_topic) : Checker(robot_description_param, root_link, planning_scene_topic) { }
CheckerWrapper(const CheckerWrapper &other) : Checker(other) { }
list get_joint_names() {
std::vector<std::string> joint_names;
getJointNames(joint_names);
list names;
for(auto joint_name : joint_names) {
names.append(joint_name);
}
return names;
}
bool check_state(object position_obj, object orientation_obj, object joint_positions_obj, object ignore_obj) {
std::vector<double> position, orientation, joint_positions;
std::vector<std::string> ignore;
python_to_vector(position_obj, position);
python_to_vector(orientation_obj, orientation);
python_to_vector(joint_positions_obj, joint_positions);
python_to_vector(ignore_obj, ignore);
return checkState(position, orientation, joint_positions, ignore);
}
};
BOOST_PYTHON_MODULE(moveit_collision_checker_py)
{
def("init_roscpp", init_roscpp);
def("shutdown_roscpp", shutdown_roscpp);
def("spin_once", ros::spinOnce);
class_<CheckerWrapper>("Checker", init<std::string, std::string, std::string>())
.def("check_state", &CheckerWrapper::check_state)
.def("get_joint_names", &CheckerWrapper::get_joint_names)
.def("print_objects", &CheckerWrapper::printObjects)
;
};