Skip to content

Commit

Permalink
Better debugging feedback on failed plan
Browse files Browse the repository at this point in the history
  • Loading branch information
marrts committed Oct 25, 2023
1 parent 1c6104e commit 6fe2c3b
Show file tree
Hide file tree
Showing 4 changed files with 63 additions and 7 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -70,9 +70,9 @@ class DescartesCollision
/**
* @brief This check is the provided solution passes the collision test defined by this class
* @param pos The joint values array to validate
* @return True if passes collision test, otherwise false
* @return ContactResultMap containing any contacts for the given solution
*/
bool validate(const Eigen::Ref<const Eigen::VectorXd>& pos);
tesseract_collision::ContactResultMap validate(const Eigen::Ref<const Eigen::VectorXd>& pos);

/**
* @brief This gets the distance to the closest object
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,8 @@ class DescartesRobotSampler : public descartes_light::WaypointSampler<FloatType>

std::vector<descartes_light::StateSample<FloatType>> sample() const override;

void print(std::ostream& os) const override;

private:
/** @brief The target pose working frame */
std::string target_working_frame_;
Expand Down Expand Up @@ -102,6 +104,9 @@ class DescartesRobotSampler : public descartes_light::WaypointSampler<FloatType>

/** @brief Should redundant solutions be used */
bool use_redundant_joint_solutions_{ false };

/** @brief String message to print out with details about planning failure */
mutable std::string error_string_;
};

using DescartesRobotSamplerF = DescartesRobotSampler<float>;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -72,10 +72,15 @@ std::vector<descartes_light::StateSample<FloatType>> DescartesRobotSampler<Float
// Generate all possible Cartesian poses
tesseract_common::VectorIsometry3d target_poses = target_pose_sampler_(target_pose_);

bool found_ik_sol = false;
std::stringstream error_string_stream;

// Generate the IK solutions for those poses
std::vector<descartes_light::StateSample<FloatType>> samples;
for (const auto& pose : target_poses)
for (std::size_t i = 0; i < target_poses.size(); i++)
{
const auto& pose = target_poses[i];

// Get the transformation to the kinematic tip link
Eigen::Isometry3d target_pose = pose * tcp_offset_.inverse();

Expand All @@ -86,9 +91,15 @@ std::vector<descartes_light::StateSample<FloatType>> DescartesRobotSampler<Float
if (ik_solutions.empty())
continue;

tesseract_collision::ContactTrajectoryResults traj_contacts(manip_->getJointNames(), ik_solutions.size());

found_ik_sol = true;

// Check each individual joint solution
for (const auto& sol : ik_solutions)
for (std::size_t j = 0; j < ik_solutions.size(); j++)
{
const auto& sol = ik_solutions[j];

if ((is_valid_ != nullptr) && !(*is_valid_)(sol))
continue;

Expand All @@ -99,19 +110,48 @@ std::vector<descartes_light::StateSample<FloatType>> DescartesRobotSampler<Float
}
else if (!allow_collision_)
{
if (collision_->validate(sol))
tesseract_collision::ContactResultMap coll_results = collision_->validate(sol);
if (coll_results.empty())
{
samples.push_back(descartes_light::StateSample<FloatType>{ state, 0.0 });
}
else if (console_bridge::getLogLevel() == console_bridge::LogLevel::CONSOLE_BRIDGE_LOG_DEBUG)
{
tesseract_collision::ContactTrajectoryStepResults step_contacts(j, sol, sol, 1);
tesseract_collision::ContactTrajectorySubstepResults substep_contacts(1, sol);
substep_contacts.contacts = coll_results;
step_contacts.substeps[0] = substep_contacts;
traj_contacts.steps[j] = step_contacts;
}
}
else
{
const FloatType cost = static_cast<FloatType>(collision_->distance(sol));
samples.push_back(descartes_light::StateSample<FloatType>{ state, cost });
}
}

if (console_bridge::getLogLevel() == console_bridge::LogLevel::CONSOLE_BRIDGE_LOG_DEBUG)
{
error_string_stream << "For sample " << i << " " << ik_solutions.size() << " IK solutions were found, with a collision summary of:" << std::endl;
error_string_stream << traj_contacts.trajectoryCollisionResultsTable().str();
}
}

if (samples.empty())
{
std::stringstream ss;
ss << "Descartes vertex failure: ";
if (!found_ik_sol)
ss << "No IK solutions were found. ";
else
ss << "All IK solutions found were in collision or invalid. ";
ss << target_poses.size() << " samples tried." << std::endl;
if (found_ik_sol)
ss << error_string_stream.str();
error_string_ = ss.str();
return samples;
}

if (allow_collision_)
{
Expand Down Expand Up @@ -162,9 +202,20 @@ std::vector<descartes_light::StateSample<FloatType>> DescartesRobotSampler<Float
samples.insert(samples.end(), redundant_samples.begin(), redundant_samples.end());
}

error_string_ = "Found at least 1 valid solution";

return samples;
}

template <typename FloatType>
void DescartesRobotSampler<FloatType>::print(std::ostream& os) const
{
os << "Working Frame: " << target_working_frame_ << ", TCP Frame: " << tcp_frame_ << "\n";
os << "Target Pose:\n" << target_pose_.matrix() << "\n";
os << "TCP Offset:\n" << tcp_offset_.matrix() << "\n";
os << "Error string:\n" << error_string_;
}

} // namespace tesseract_planning

#endif // TESSERACT_MOTION_PLANNERS_DESCARTES_ROBOT_SAMPLER_HPP
Original file line number Diff line number Diff line change
Expand Up @@ -52,7 +52,7 @@ DescartesCollision::DescartesCollision(const DescartesCollision& collision_inter
contact_manager_->applyContactManagerConfig(collision_check_config_.contact_manager_config);
}

bool DescartesCollision::validate(const Eigen::Ref<const Eigen::VectorXd>& pos)
tesseract_collision::ContactResultMap DescartesCollision::validate(const Eigen::Ref<const Eigen::VectorXd>& pos)
{
// Happens in two phases:
// 1. Compute the transform of all objects
Expand All @@ -63,7 +63,7 @@ bool DescartesCollision::validate(const Eigen::Ref<const Eigen::VectorXd>& pos)

tesseract_collision::ContactResultMap results;
tesseract_environment::checkTrajectoryState(results, *contact_manager_, state, config);
return results.empty();
return results;
}

double DescartesCollision::distance(const Eigen::Ref<const Eigen::VectorXd>& pos)
Expand Down

0 comments on commit 6fe2c3b

Please sign in to comment.