Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fix/refactor codebase #1

Closed
wants to merge 11 commits into from
Closed

Fix/refactor codebase #1

wants to merge 11 commits into from

Conversation

CihatAltiparmak
Copy link
Member

No description provided.

- Refactored test_scenario_perception_pipeline.cpp
- Added event handler because of interaction problem between panda_arm_spawner and test_scenario_perception_pipeline node
launch/test_scenario_perception_pipeline.launch.py Outdated Show resolved Hide resolved
test/test_scenario_perception_pipeline.cpp Outdated Show resolved Hide resolved
class ScenarioPerceptionPipelineTestCaseCreator
{
private:
static inline std::vector<std::vector<geometry_msgs::msg::Pose>> test_cases_ = {};
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is this part okay or do we need to get better implementation?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I also need some insights about this part, @sjahr, @henningkayser


BENCHMARK_DEFINE_F(ScenarioPerceptionPipelineFixture, test_scenario_perception_pipeline)(benchmark::State& st)
{
auto selected_test_case = ScenarioPerceptionPipelineTestCaseCreator::selectTestCases(0);
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Test case selection must be based on given arguments to benchmark class.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Dear @henningkayser and @sjahr, I actually solved this issue by giving this argument in launch file. But i need some insights related to this part.

test/test_scenario_perception_pipeline.cpp Outdated Show resolved Hide resolved
@CihatAltiparmak
Copy link
Member Author

Dear @henningkayser and @sjahr ,

I need some review for beginning of implementations. I already reviewed some parts before. While reviewing, it would be great to review all parts of code, not changed parts at the moment. Thank you in advance for your efforts 🙏

@CihatAltiparmak CihatAltiparmak requested a review from sjahr June 18, 2024 10:06
Copy link
Contributor

@sjahr sjahr left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thank you! I gave it a first high-level pass, still need to test it though. It is great that you have already developed so much and we can start refining it 👍 An important first step is to restructure the repository such that it follows the same patterns as MoveIt does and thus make it easier to review and iterate for all of us (see my comments)

package.xml Show resolved Hide resolved
}
}
moveit::planning_interface::MoveGroupInterface::Plan plan_msg;
const auto ok = static_cast<bool>(move_group_interface_ptr_->plan(plan_msg));
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

That static_cast shouldn't be necessary because the result class has a bool operator. I think you could just put move_group_interface_ptr_->plan(plan_msg) into the if statement without temporary variables

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I have stolen here 🙈 . But it is bad practice. I have yet to solve this part but i will. We must fix this bad practice in documentation as well.


if (ok)
{
move_group_interface_ptr_->execute(plan_msg);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Do we need the execution at all? If not you could just return move_group_interface_ptr_->plan(plan_msg) with from this function

Copy link
Member Author

@CihatAltiparmak CihatAltiparmak Jun 21, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I couldn't understand your question. Wasn't our goal to test all pipeline rather than just planning pipeline? By the way i think the effectively measuring of middleware benchmarking is proportional to data-transfering works. I'm wondering your ideas about all of it.

@@ -7,92 +7,165 @@
#include <moveit/moveit_cpp/planning_component.h>
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I think you should separate the declarations form the implementations by adding header files for your classes. That way everything would be more cleaned up and easier to work with. I'd propose this repository structure:

launch/
include/
 scenario_perception_pipeline.hpp --> Contains class definitions
src/
  scenario_perception_pipeline.cpp --> Contains all the class definitions
  benchmark_main.cpp --> contains just the main function
test/ --> Usually this contains the unittests (you can neglect it for now until we get to the point where we write unittests)

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I refactored based on your review with a couple of details. Could you take a look at it and then give a feedback again?

test/test_scenario_perception_pipeline.cpp Outdated Show resolved Hide resolved
test/test_scenario_perception_pipeline.cpp Outdated Show resolved Hide resolved
test/test_scenario_perception_pipeline.cpp Outdated Show resolved Hide resolved
- Added upstream workspace envrionment to CI
- Changed ROS version in CI
- Fixed CMakeList.txt and package.xml based on the feedbacks of CI
- Fixed upstream repository urls
- Changed test cases for more convenient benchmarking
- Added middleware implementations to exec_depend ( #1 (comment) )
- Refactored package directory tree structure ( #1 (comment) )
- Added namespace ( #1 (comment) )
@CihatAltiparmak
Copy link
Member Author

CihatAltiparmak commented Jun 21, 2024

An important first step is to restructure the repository such that it follows the same patterns as MoveIt does and thus make it easier to review and iterate for all of us (see my comments)

@sjahr Is there any documentation of how to create a new moveit repository and what its procedure is e.g. here? Or is there any boilerplate to create moveit-like repository? If the answers are yes, maybe i can help you to spend the less effort by applying this steps.

- Added documentation for each methods and variables except global variables ( #1 (comment) )
- Put constants into anoymous namespace ( #1 (comment) )
- Modified condition checking in senfTargetPose ( #1 (comment) )
- Fixed middleware packages in package.xml
- Renamed the test case config
- Removed ScenarioPerceptionPipelineTestCaseGenerator class and added its methods to ScenarioPerceptionPipelineFixture
- Renamed ScenarioPerceptionPipelineFixture/selectTestCase method as ScenarioPerceptionPipelineFixture/selectTestCase
- Added documentation for ScenarioPerceptionPipelineFixture/setUp and ScenarioPerceptionPipelineFixture/tearDown methods
@CihatAltiparmak
Copy link
Member Author

I'm closing this PR because the PR started to be so complex. It's great to continue from another PR.

This was referenced Jul 1, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants