void L1Controller::goalReachingCB(const ros::TimerEvent&) { if(goal_received) { double car2goal_dist = getCar2GoalDist(); if(car2goal_dist < goalRadius) { goal_reached = true; goal_received = false; //ROS_INFO("Goal Reached !"); car_stop = 100; } } }
时间: 2024-02-14 18:35:37 浏览: 22
这是一个ROS的回调函数,它是通过定时器事件触发的。该函数的主要作用是检测小车是否到达了目标点。首先它会判断是否接收到了目标点的信息,如果接收到了就会计算小车到目标点的距离。如果小车到目标点的距离小于goalRadius(一个预设的半径),则认为小车到达了目标点,会将goal_reached变量设置为true,同时停止小车的运动(car_stop=100)。需要注意的是,该函数中使用了一些全局变量,如goal_received、goal_reached和car_stop,需要在其他地方进行定义和初始化。
相关问题
ouble L1Controller::getSteeringAngle(double eta) { //纯追踪算舵机打角 double steeringAnge = atan2((L * sin(eta)), ((Lfw / 2) + lfw * cos(eta))) * (180.0 / PI); // ROS_INFO("Steering Angle = %.2f", steeringAnge); return steeringAnge; } void L1Controller::goalReachingCB(const ros::TimerEvent &) { //小车到达目标点后 if (goal_received) { double car2goal_dist = getCar2GoalDist(); if (car2goal_dist < goalRadius) { goal_reached = true; goal_received = false; cmd_vel.linear.x = 0.0; cmd_vel.angular.z = 0.0; pub_.publish(cmd_vel); ROS_INFO("Goal Reached !!!!!!!"); } } }
这段代码中含有两个函数。
第一个函数 `getSteeringAngle` 是 L1 控制器中的一个函数,用于计算车辆的舵机打角。函数接收一个参数 eta,它表示车辆当前位置与目标点的连线与正前方之间的夹角。函数内部根据车辆的轮距 L、车辆重心到前轴的距离 Lfw、左前轮到重心的水平距离 lfw,以及 eta 计算舵机打角。最后返回计算得到的舵机打角值(单位为度)。
第二个函数 `goalReachingCB` 是 L1 控制器中的一个回调函数,它会周期性地检测小车是否到达目标点。如果车辆到达目标点,则将目标到达标志 `goal_reached` 置为 true,并停止车辆运动。函数内部首先计算车辆到目标点的距离 `car2goal_dist`,如果 `car2goal_dist` 小于设定的目标半径 `goalRadius`,则认为车辆已经到达目标点,将标志 `goal_reached` 置为 true,并停止车辆运动。
ouble L1Controller::getL1Distance(const double &_Vcmd) { //根据速度变前瞻距离 double L1 = 0; double car2goal_dist = getCar2GoalDist(); double v = _Vcmd; /*if (car2goal_dist < 1) { L1 = 0.5; } else {*/ L1 = 1.45; //} // L1 = 0.65 + 0.6 * _Vcmd; return L1; }
这段代码是 L1 控制器中的一个函数,用于计算前瞻距离 L1。函数接收一个目标速度参数 _Vcmd,并返回计算得到的前瞻距离 L1。
具体来说,L1 控制器是一种路径跟踪控制器,它根据车辆速度和目标点的距离来计算前瞻距离,以控制车辆沿着路径运动。在该函数中,首先获取车辆到目标点的距离 car2goal_dist 和目标速度 v。然后,根据经验公式计算前瞻距离 L1,其中 1.45 表示一个经验常数,可以根据具体应用进行调整。最后返回计算得到的前瞻距离 L1。