37 #include <visp3/gui/vpPlot.h> 
   41 Ta( 
const vpHomogeneousMatrix &edMe )
 
   43   vpMatrix Lx( 6, 6 ), Lw( 3, 3 ), skew_u( 3, 3 );
 
   46   vpThetaUVector tu( edMe );
 
   51   tu.extract( theta, u );
 
   52   skew_u = vpColVector::skew( u );
 
   56     Lw -= 0.5 * theta * skew_u;
 
   57     Lw += ( 1 - ( ( vpMath::sinc( theta ) ) / ( vpMath::sqr( vpMath::sinc( theta * 0.5 ) ) ) ) ) * skew_u * skew_u;
 
   60   Lx.insert( Lw, 3, 3 );
 
   66 main( 
int argc, 
char **argv )
 
   68   bool opt_coppeliasim_sync_mode = 
false;
 
   69   bool opt_verbose               = 
false;
 
   70   bool opt_save_data             = 
false;
 
   72   for ( 
int i = 1; i < argc; i++ )
 
   74     if ( std::string( argv[i] ) == 
"--enable-coppeliasim-sync-mode" )
 
   76       opt_coppeliasim_sync_mode = 
true;
 
   78     else if ( std::string( argv[i] ) == 
"--verbose" || std::string( argv[i] ) == 
"-v" )
 
   82     else if ( std::string( argv[i] ) == 
"--save" )
 
   86     else if ( std::string( argv[i] ) == 
"--help" || std::string( argv[i] ) == 
"-h" )
 
   88       std::cout << argv[0] << 
"[--enable-coppeliasim-sync-mode]" 
   90                 << 
" [--verbose] [-v] " 
   91                 << 
" [--help] [-h]" << std::endl;
 
  111     std::cout << 
"Coppeliasim sync mode enabled: " << ( opt_coppeliasim_sync_mode ? 
"yes" : 
"no" ) << std::endl;
 
  117     vpColVector q_init( { 0, vpMath::rad( -45 ), 0, vpMath::rad( -135 ), 0, vpMath::rad( 90 ), vpMath::rad( 45 ) } );
 
  123     vpPlot *plotter = 
nullptr;
 
  125     plotter = 
new vpPlot( 4, 800, 800, 10, 10, 
"Real time curves plotter" );
 
  126     plotter->setTitle( 0, 
"Joint positions [rad]" );
 
  127     plotter->initGraph( 0, 7 );
 
  128     plotter->setLegend( 0, 0, 
"q1" );
 
  129     plotter->setLegend( 0, 1, 
"q2" );
 
  130     plotter->setLegend( 0, 2, 
"q3" );
 
  131     plotter->setLegend( 0, 3, 
"q4" );
 
  132     plotter->setLegend( 0, 4, 
"q5" );
 
  133     plotter->setLegend( 0, 5, 
"q6" );
 
  134     plotter->setLegend( 0, 6, 
"q7" );
 
  136     plotter->setTitle( 1, 
"Joint torques measure [Nm]" );
 
  137     plotter->initGraph( 1, 7 );
 
  138     plotter->setLegend( 1, 0, 
"Tau1" );
 
  139     plotter->setLegend( 1, 1, 
"Tau2" );
 
  140     plotter->setLegend( 1, 2, 
"Tau3" );
 
  141     plotter->setLegend( 1, 3, 
"Tau4" );
 
  142     plotter->setLegend( 1, 4, 
"Tau5" );
 
  143     plotter->setLegend( 1, 5, 
"Tau6" );
 
  144     plotter->setLegend( 1, 6, 
"Tau7" );
 
  146     plotter->setTitle( 2, 
"Cartesian EE pose error [m] - [rad]" );
 
  147     plotter->initGraph( 2, 6 );
 
  148     plotter->setLegend( 2, 0, 
"e_x" );
 
  149     plotter->setLegend( 2, 1, 
"e_y" );
 
  150     plotter->setLegend( 2, 2, 
"e_z" );
 
  151     plotter->setLegend( 2, 3, 
"e_tu_x" );
 
  152     plotter->setLegend( 2, 4, 
"e_tu_y" );
 
  153     plotter->setLegend( 2, 5, 
"e_tu_z" );
 
  155     plotter->setTitle( 3, 
"Pose error norm [m] - [rad]" );
 
  156     plotter->initGraph( 3, 2 );
 
  157     plotter->setLegend( 3, 0, 
"||e_p||" );
 
  158     plotter->setLegend( 3, 1, 
"||e_o||" );
 
  160     vpColVector q( 7, 0 ), dq( 7, 0 ), tau_d( 7, 0 ), C( 7, 0 ), F( 7, 0 ), tau_d0( 7, 0 ), tau_cmd( 7, 0 ),
 
  161         x_e( 6, 0 ), dx_e( 6, 0 ), dx_ed( 6, 0 ), ddx_ed( 6, 0 );
 
  162     vpMatrix fJe( 6, 7 ), Ja( 6, 7 ), dJa( 6, 7 ), Ja_old( 6, 7 ), B( 7, 7 ), I7( 7, 7 ), Ja_pinv_B_t( 6, 7 );
 
  163     vpColVector pose_err_norm( 2, 0 ), tau( 7, 0 );
 
  165     std::cout << 
"Reading current joint position" << std::endl;
 
  167     std::cout << 
"Initial joint position: " << q.t() << std::endl;
 
  172     vpHomogeneousMatrix fMed, fMed0;
 
  176     bool final_quit       = 
false;
 
  177     bool first_time       = 
false;
 
  178     bool start_trajectory = 
false;
 
  180     vpMatrix K( 6, 6 ), D( 6, 6 ), edVf( 6, 6 );
 
  184     K.diag( { wp * wp, wp * wp, wp * wp, wo * wo, wo * wo, wo * wo } );
 
  185     D.diag( { 2 * wp, 2 * wp, 2 * wp, 2 * wo, 2 * wo, 2 * wo } );
 
  191     double time_start_trajectory, time_prev, time_cur;
 
  192     double delay_before_trajectory = 0.5; 
 
  195     while ( !final_quit )
 
  207       if ( time_cur < delay_before_trajectory )
 
  209         time_start_trajectory = time_cur; 
 
  212       else if ( !start_trajectory ) 
 
  214         time_start_trajectory = time_cur;
 
  215         start_trajectory      = 
true;
 
  220       fMed[1][3] = fMed0[1][3] + ( start_trajectory ? ( 0.1 * sin( 2 * M_PI * 0.3 * ( time_cur - time_start_trajectory  ) ) ) : 0 );
 
  221       fMed[2][3] = fMed0[2][3] - ( start_trajectory ? ( 0.05 * sin( 2 * M_PI * 0.6 * ( time_cur - time_start_trajectory  ) ) ) : 0) ;
 
  223       dx_ed[1] = ( start_trajectory ? (2 * M_PI * 0.3 * 0.1 * cos( 2 * M_PI * 0.3 * ( time_cur - time_start_trajectory  ) ) ) : 0) ;
 
  224       dx_ed[2] = ( start_trajectory ? (-2 * M_PI * 0.6 * 0.05 * cos( 2 * M_PI * 0.6 * ( time_cur - time_start_trajectory  ) ) ) : 0) ;
 
  226       ddx_ed[1] = ( start_trajectory ? (-2 * M_PI * 0.3 * 2 * M_PI * 0.3 * 0.1 * sin( 2 * M_PI * 0.3 * ( time_cur - time_start_trajectory  ) ) ) : 0) ;
 
  227       ddx_ed[2] = ( start_trajectory ? (2 * M_PI * 0.6 * 2 * M_PI * 0.6 * 0.05 * sin( 2 * M_PI * 0.6 * ( time_cur - time_start_trajectory  ) ) ) : 0) ;
 
  230       edVf.insert( fMed.getRotationMatrix().t(), 0, 0 );
 
  231       edVf.insert( fMed.getRotationMatrix().t(), 3, 3 );
 
  233       x_e = (vpColVector)vpPoseVector( fMed.inverse() * robot.
get_fMe() ); 
 
  234       Ja  = 
Ta( fMed.inverse() * robot.
get_fMe() ) * edVf * fJe;
 
  236       dx_e = 
Ta( fMed.inverse() * robot.
get_fMe() ) * edVf * ( dx_ed - fJe * dq );
 
  238       dt = time_cur - time_prev;
 
  242         dJa = ( Ja - Ja_old ) / dt;
 
  250       Ja_pinv_B_t = ( Ja * B.inverseByCholesky() * Ja.t() ).inverseByCholesky() * Ja * B.inverseByCholesky();
 
  253       tau_d = B * Ja.pseudoInverse() * ( -K * ( x_e ) + D * (dx_e)-dJa * dq + ddx_ed ) + C + F -
 
  254               ( I7 - Ja.t() * Ja_pinv_B_t ) * B * dq * 100;
 
  261       tau_cmd = tau_d - tau_d0 * std::exp( -mu * ( time_cur - time_start_trajectory ) );
 
  265       plotter->plot( 0, time_cur, q );
 
  266       plotter->plot( 1, time_cur, tau );
 
  267       plotter->plot( 2, time_cur, x_e );
 
  268       pose_err_norm[0] = sqrt( x_e.extract( 0, 3 ).sumSquare() );
 
  269       pose_err_norm[1] = sqrt( x_e.extract( 3, 3 ).sumSquare() );
 
  270       plotter->plot( 3, time_cur, pose_err_norm );
 
  272       vpMouseButton::vpMouseButtonType button;
 
  273       if ( vpDisplay::getClick( plotter->I, button, 
false ) )
 
  275         if ( button == vpMouseButton::button3 )
 
  279           std::cout << 
"Stop the robot " << std::endl;
 
  286         std::cout << 
"dt: " << dt << std::endl;
 
  289       time_prev = time_cur;
 
  290       robot.
wait( time_cur, 0.001 ); 
 
  295       plotter->saveData( 0, 
"sim-cart-joint-position.txt", 
"# " );
 
  296       plotter->saveData( 1, 
"sim-cart-joint-torques.txt", 
"# " );
 
  297       plotter->saveData( 2, 
"sim-cart-pose-error.txt", 
"# " );
 
  298       plotter->saveData( 3, 
"sim-cart-pose-error-norm.txt", 
"# " );
 
  301     if ( plotter != 
nullptr )
 
  308   catch ( 
const vpException &e )
 
  310     std::cout << 
"ViSP exception: " << e.what() << std::endl;
 
  311     std::cout << 
"Stop the robot " << std::endl;