0

ノードからデータをサブスクライブし、PID コントローラーの出力を計算して別のトピックに公開する ROS ノードを実行しようとしています。 ..参照用のコードは次のとおりです。

namespace youbot {

PidController::PidController(double P, double I, double D, double I1, double I2) :
p_gain_(P), i_gain_(I), d_gain_(D), i_max_(I1), i_min_(I2)
{

   p_error_last_ = 0.0;
   p_error_ = 0.0;
   d_error_ = 0.0;

   i_error_ = 0.0;
   cmd_ = 0.0;
   last_i_error = 0.0;
}

double PidController::updatePid(double error, boost::posix_time::time_duration dt)
{
    double p_term, d_term, i_term;
    p_error_ = error; //this is pError = pState-pTarget
    double deltatime = (double)dt.total_microseconds()/1000.0; //in milli seconds


   if (deltatime == 0.0 || isnan(error) || isinf(error))
      return 0.0;
   p_term = p_gain_ * p_error_;
   i_error_ = last_i_error + deltatime * p_error_;
   last_i_error = deltatime * p_error_;
   i_term = i_gain_ * i_error_;
   if (i_term > i_max_)
   {  
     i_term = i_max_;
     i_error_=i_term/i_gain_;
   }
   else if (i_term < i_min_)
   {
     i_term = i_min_;
     i_error_=i_term/i_gain_;
   }


  if (deltatime != 0)
  {
     d_error_ = (p_error_ - p_error_last_) / deltatime;
     p_error_last_ = p_error_;
  }
  d_term = d_gain_ * d_error_;
  cmd_ = -p_term - i_term - d_term;

  p_error_, i_error_, p_term, i_term, deltatime, cmd_);

  return cmd_;
}
}

using namespace std;
using namespace youbot;

double currentPos[3];
void arrayCallback(const geometry_msgs::Point::ConstPtr& cord);
double calculateControllerOutput(double pos, double targetPos);


int main(int argc, char **argv)
{

ros::init(argc, argv, "coordinateSubscriber");
ros::NodeHandle n;
ros::Subscriber sub3 = n.subscribe("position", 100, arrayCallback);
ros::spin();

return 0;
}

どの部分がエラーを引き起こしているのか推測できません.どんな助けでも大歓迎です..ありがとう!

4

0 に答える 0