11 #define rad2deg(rad) (rad * 180 / M_PI) 14 #define deg2rad(deg) (deg * M_PI / 180) 24 const std::vector<double>& time_vec)
27 std::string fname(
"/tmp/plot-otd.dat");
28 FILE*
fp = fopen(fname.c_str(),
"w");
30 bool detected =
false;
31 for (
size_t i = 0;
i < time_vec.size();
i++) {
33 if (tmp_detected && !detected) {
34 detect_time = time_vec[i];
42 std::string titles[2] = {
"Wrench",
"Dwrench"};
44 FILE* gp =
popen(
"gnuplot",
"w");
45 fprintf(gp,
"set multiplot layout 2, 1 title 'Results'\n");
46 fprintf(gp,
"set xlabel 'Time [s]'\n");
47 fprintf(gp,
"set ylabel 'Wrench'\n");
48 fprintf(gp,
"set arrow from %f,%f to %f,%f\n", detect_time, force_vec.front(), detect_time, force_vec.back());
49 fprintf(gp,
"plot '/tmp/plot-otd.dat' using 1:2 with lines title 'Wrench' lw 4, '/tmp/plot-otd.dat' using 1:3 with lines title 'FilteredWrench' lw 4\n");
50 fprintf(gp,
"set xlabel 'Time [s]'\n");
51 fprintf(gp,
"set ylabel 'Dwrench'\n");
52 fprintf(gp,
"plot '/tmp/plot-otd.dat' using 1:4 with lines title 'Dwrench' lw 4\n");
64 std::cerr <<
"test0 : Set" << std::endl;
65 double tm = 0.0, total_tm = 2.0, df = 10;
66 std::vector<double> time_vec, force_vec;
67 for (
size_t i = 0; i < static_cast<size_t>(total_tm/
dt);
i++) {
68 time_vec.push_back(tm);
69 if (
i*dt < total_tm*0.2) {
70 force_vec.push_back(0);
71 }
else if (
i*dt > total_tm*0.8) {
72 force_vec.push_back(df*total_tm*(0.8-0.2));
74 force_vec.push_back(df*(
i*dt-total_tm*0.2));
83 for (
unsigned int i = 0;
i < arg_strs.size(); ++
i) {
84 if ( arg_strs[
i]==
"--use-gnuplot" ) {
85 if (++
i < arg_strs.size()) use_gnuplot = (arg_strs[
i]==
"true");
93 std::cerr <<
"Usage : testObjectTurnaroundDetector [option]" << std::endl;
94 std::cerr <<
" [option] should be:" << std::endl;
95 std::cerr <<
" --test0 : Set ref force" << std::endl;
99 int main(
int argc,
char* argv[])
104 for (
int i = 1;
i < argc; ++
i) {
105 totd.
arg_strs.push_back(std::string(argv[
i]));
107 if (std::string(argv[1]) ==
"--test0") {
double getFilteredDwrench() const
double getFilteredWrench() const
RTC::ReturnCode_t ret(RTC::Local::ReturnCode_t r)
bool checkDetection(const std::vector< hrp::Vector3 > &fmv, const std::vector< hrp::Vector3 > &hposv)
int main(int argc, char *argv[])
ObjectTurnaroundDetector otd
FILE * popen(const char *cmd, const char *mode)
testObjectTurnaroundDetector(const double _dt=0.004)
std::vector< std::string > arg_strs
void gen_pattern_and_plot(const std::vector< double > &force_vec, const std::vector< double > &time_vec)
void startDetection(const double _ref_diff_wrench, const double _max_time)