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

Ros2-ugv-description #456

Open
wants to merge 10 commits into
base: ros2-devel
Choose a base branch
from
Open

Ros2-ugv-description #456

wants to merge 10 commits into from

Conversation

rafal-gorecki
Copy link
Contributor

@rafal-gorecki rafal-gorecki commented Dec 5, 2024

Description

  • Merge panther/lynx descriptions
  • Rename frames base_link -> body_link into base_footprint -> base_link

Requirements

  • Code style guidelines followed
  • Documentation updated

Tests 🧪

  • Robot
  • Container
  • Simulation

Summary by CodeRabbit

  • New Features

    • Updated configuration paths for various components and launch files to reflect the new husarion_ugv naming convention.
    • Introduced new launch files for enhanced robot model configuration and RViz visualization.
    • Added new URDF files for the Lynx base, establishing a foundational structure for the robot.
  • Bug Fixes

    • Corrected dependencies and paths in multiple packages to ensure accurate functionality.
  • Documentation

    • Updated README and configuration documentation to reflect new paths and package names.
    • Enhanced clarity in launch file descriptions and configuration parameters.
  • Chores

    • Renamed and reorganized package structures for consistency and clarity across the project.

Copy link
Contributor

coderabbitai bot commented Dec 5, 2024

Walkthrough

The changes in this pull request involve a comprehensive rebranding of the project from "panther" to "husarion_ugv" across multiple packages. Key updates include modifications to configuration paths, removal of deprecated launch arguments, and version upgrades for pre-commit hooks. Additionally, several files were deleted as part of the transition, and new URDF files were introduced for the Husarion UGV. The overall structure of the documentation and configuration files was adjusted to reflect the new naming conventions and paths, ensuring consistency throughout the project.

Changes

File Path Change Summary
.pre-commit-config.yaml Updated versions for pre-commit-hooks, clang-format, black, and doc8; modified doc8 exclude pattern.
README.md Updated configuration paths for components_config_path and wheel_config_path; removed launch arguments for robot position and orientation.
husarion_ugv/CHANGELOG.rst Changed package name from panther to husarion_ugv.
husarion_ugv_battery/CHANGELOG.rst Changed package name from panther_battery to husarion_ugv_battery.
husarion_ugv_bringup/CHANGELOG.rst Changed package name from panther_bringup to husarion_ugv_bringup.
husarion_ugv_controller/CHANGELOG.rst Changed package name from panther_controller to husarion_ugv_controller.
husarion_ugv_controller/CONFIGURATION.md Updated configuration file path for wheel type.
husarion_ugv_controller/launch/controller.launch.py Updated wheel_config_path, removed robot_description_file, added urdf_file.
husarion_ugv_controller/package.xml Added new execution dependency husarion_ugv_descriptions; removed lynx_description and panther_description.
husarion_ugv_description/CHANGELOG.rst Changed package name from panther_description to husarion_ugv_description.
husarion_ugv_description/CMakeLists.txt Updated project name from panther_description to husarion_ugv_descriptions.
husarion_ugv_description/README.md Changed package name from panther_description to husarion_ugv_descriptions; added new launch files.
husarion_ugv_description/config/*.yaml Updated mesh_package field from panther_description to husarion_ugv_descriptions.
husarion_ugv_description/config/components.yaml Updated comment from "panther" to "Husarion UGV".
husarion_ugv_description/launch/*.launch.py Updated paths and launch configurations to reference the new package structure.
husarion_ugv_description/urdf/*.urdf.xacro Updated URDF files to reflect new package paths and structure; added new Lynx base definition.
husarion_ugv_diagnostics/CHANGELOG.rst Changed package name from panther_diagnostics to husarion_ugv_diagnostics.
husarion_ugv_gazebo/CHANGELOG.rst Changed package name from panther_gazebo to husarion_ugv_gazebo.
husarion_ugv_gazebo/README.md Updated paths to URDF files in documentation.
husarion_ugv_gazebo/launch/*.launch.py Updated launch files to reference the new package structure.
husarion_ugv_hardware_interfaces/CHANGELOG.rst Changed package name from panther_hardware_interfaces to husarion_ugv_hardware_interfaces.
husarion_ugv_hardware_interfaces/README.md Updated links to URDF files to point to husarion_ugv_descriptions.
husarion_ugv_lights/CHANGELOG.rst Changed package name from panther_lights to husarion_ugv_lights.
husarion_ugv_localization/CHANGELOG.rst Changed package name from panther_localization to husarion_ugv_localization.
husarion_ugv_manager/CHANGELOG.rst Changed package name from panther_manager to husarion_ugv_manager.
husarion_ugv_utils/CHANGELOG.rst Changed package name from panther_utils to husarion_ugv_utils.
lynx_description/* Deleted files related to lynx_description package as part of the rebranding.

Sequence Diagram(s)

sequenceDiagram
    participant User
    participant LaunchSystem
    participant Robot

    User->>LaunchSystem: Start launch process
    LaunchSystem->>Robot: Load URDF and configurations
    Robot-->>LaunchSystem: Confirm loading
    LaunchSystem->>User: Launch successful
Loading

Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media?

❤️ Share
🪧 Tips

Chat

There are 3 ways to chat with CodeRabbit:

  • Review comments: Directly reply to a review comment made by CodeRabbit. Example:
    • I pushed a fix in commit <commit_id>, please review it.
    • Generate unit testing code for this file.
    • Open a follow-up GitHub issue for this discussion.
  • Files and specific lines of code (under the "Files changed" tab): Tag @coderabbitai in a new review comment at the desired location with your query. Examples:
    • @coderabbitai generate unit testing code for this file.
    • @coderabbitai modularize this function.
  • PR comments: Tag @coderabbitai in a new PR comment to ask questions about the PR branch. For the best results, please provide a very specific query, as very limited context is provided in this mode. Examples:
    • @coderabbitai gather interesting stats about this repository and render them as a table. Additionally, render a pie chart showing the language distribution in the codebase.
    • @coderabbitai read src/utils.ts and generate unit testing code.
    • @coderabbitai read the files in the src/scheduler package and generate a class diagram using mermaid and a README in the markdown format.
    • @coderabbitai help me debug CodeRabbit configuration file.

Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments.

CodeRabbit Commands (Invoked using PR comments)

  • @coderabbitai pause to pause the reviews on a PR.
  • @coderabbitai resume to resume the paused reviews.
  • @coderabbitai review to trigger an incremental review. This is useful when automatic reviews are disabled for the repository.
  • @coderabbitai full review to do a full review from scratch and review all the files again.
  • @coderabbitai summary to regenerate the summary of the PR.
  • @coderabbitai generate docstrings to generate docstrings for this PR. (Experiment)
  • @coderabbitai resolve resolve all the CodeRabbit review comments.
  • @coderabbitai configuration to show the current CodeRabbit configuration for the repository.
  • @coderabbitai help to get help.

Other keywords and placeholders

  • Add @coderabbitai ignore anywhere in the PR description to prevent this PR from being reviewed.
  • Add @coderabbitai summary to generate the high-level summary at a specific location in the PR description.
  • Add @coderabbitai anywhere in the PR title to generate the title automatically.

Documentation and Community

  • Visit our Documentation for detailed information on how to use CodeRabbit.
  • Join our Discord Community to get help, request features, and share feedback.
  • Follow us on X/Twitter for updates and announcements.

Base automatically changed from ros2-lynx-devel to ros2-devel December 6, 2024 08:45
@rafal-gorecki rafal-gorecki requested a review from BOOTCFG December 6, 2024 10:30
Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 1

🧹 Outside diff range and nitpick comments (14)
husarion_ugv_controller/config/WH04_controller.yaml (1)

Line range hint 28-31: Address TODO comment regarding wheel separation multiplier

The TODO comment indicates that the wheel separation multiplier needs verification. This is important for accurate kinematics, especially since it affects the ICR coefficient for skid drive.

Would you like me to help create a GitHub issue to track the verification of the wheel separation multiplier?

husarion_ugv_description/urdf/lynx/body.urdf.xacro (7)

26-28: Update collision geometry when models are ready

The TODO comment indicates that the collision geometry needs to be updated with the correct models once they are ready.

Would you like assistance in preparing the updated collision geometry when the models are available?


35-38: Calculate and update accurate inertia properties

The real inertia values need to be calculated and updated to ensure accurate simulation and control of the robot.

I can help calculate the inertia properties based on the physical dimensions and mass distribution. Would you like me to assist with this?


55-60: Update collision geometry for the user compartment

The collision geometry for the user_compartment_link is currently commented out and marked as a TODO.

Let me know if you'd like help in defining the collision geometry once the models are ready.


63-68: Calculate and update inertia for the user compartment

Accurate inertia properties are important for simulation fidelity.

Would you like assistance in calculating and updating the inertia values for the user compartment?


84-90: Update collision geometry for the battery

The collision geometry for the battery_link is commented out with a TODO note.

I can help define the collision geometry when the appropriate models are available.


94-98: Calculate and update inertia for the battery

The inertia values need to be calculated to reflect the battery's mass and distribution.

I'm available to assist with calculating these values if needed.


110-111: Update origin values for the cover joint

The TODO comment suggests that the origin values are placeholders and need to be set to real values.

Would you like help in determining the accurate position and orientation for the body_to_cover_joint?

husarion_ugv_description/README.md (1)

8-8: Use 'can' instead of 'is able to' for conciseness

Consider rephrasing for clarity:

  • Original: "launch is able to change robot_description topic in runtime."
  • Suggested: "launch can change the robot_description topic at runtime."

Apply this diff for improved readability:

- `overwrite_robot_description.launch.py` - launch is able to change `robot_description` topic in runtime.
+ `overwrite_robot_description.launch.py` - launch can change the `robot_description` topic at runtime.
🧰 Tools
🪛 LanguageTool

[style] ~8-~8: As a shorter alternative for ‘able to’, consider using “can”.
Context: ...e_robot_description.launch.py- launch is able to changerobot_description` topic in run...

(BE_ABLE_TO)


[uncategorized] ~8-~8: You might be missing the article “the” here.
Context: ...n.launch.py- launch is able to changerobot_descriptiontopic in runtime. -...

(AI_EN_LECTOR_MISSING_DETERMINER_THE)

husarion_ugv_description/package.xml (1)

11-12: Update repository URLs to match new package naming

The repository URL still contains "panther_ros" while the package has been renamed to "husarion_ugv". Consider updating the URLs to maintain consistency with the new naming scheme.

husarion_ugv_description/urdf/lynx.urdf.xacro (1)

Frame renaming changes not implemented as specified

The search results show that both Lynx and Panther URDF files still use the original frame naming convention:

  • base_footprint as the root frame
  • base_link as the body frame

This contradicts the PR objectives which required renaming:

  • base_footprintbase_link
  • base_linkbody_link
🔗 Analysis chain

Line range hint 16-24: Verify frame renaming implementation

The PR objectives mention renaming frames from "base_link" to "body_link" and "base_footprint" to "base_link", but these changes aren't visible in the provided URDF files. Please ensure these changes are implemented in the macro files.

Also applies to: 17-25

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for frame definitions in macro files
rg -A 2 "base_link|body_link|base_footprint" husarion_ugv_description/urdf/

Length of output: 4161

husarion_ugv_description/urdf/panther/body.urdf.xacro (1)

Line range hint 33-38: Address TODO comment about inertial origin

There's a TODO comment about fixing the origin in the inertial properties. This should be addressed as incorrect inertial properties can affect simulation behavior.

Would you like help calculating the correct inertial origin based on the mesh geometry?

husarion_ugv_description/urdf/lynx/lynx_macro.urdf.xacro (1)

179-181: Track the TODO for lights visualization.

The lights visualization has been temporarily removed. Would you like me to create a GitHub issue to track the implementation of lights visualization?

husarion_ugv_gazebo/launch/simulate_robot.launch.py (1)

94-100: Consider aligning default values across launch files.

While the implementation is correct, the default value here is "panther" while in load_urdf.launch.py it's "PTH". Consider standardizing the defaults.

📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 4fc2d95 and 4e090f4.

⛔ Files ignored due to path filters (20)
  • husarion_ugv_description/meshes/WH01/fl_wheel.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/WH01/fr_wheel.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/WH01/rl_wheel.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/WH01/rr_wheel.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/WH02/fl_wheel.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/WH02/fr_wheel.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/WH02/rl_wheel.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/WH02/rr_wheel.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/WH04/fl_wheel.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/WH04/fr_wheel.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/WH04/rl_wheel.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/WH04/rr_wheel.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/WH05/fl_wheel.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/WH05/fr_wheel.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/WH05/rl_wheel.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/WH05/rr_wheel.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/lynx/base.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/lynx/battery.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/lynx/user_compartment.dae is excluded by !**/*.dae
  • husarion_ugv_description/meshes/panther/base.dae is excluded by !**/*.dae
📒 Files selected for processing (60)
  • .pre-commit-config.yaml (4 hunks)
  • README.md (2 hunks)
  • husarion_ugv/CHANGELOG.rst (1 hunks)
  • husarion_ugv_battery/CHANGELOG.rst (1 hunks)
  • husarion_ugv_bringup/CHANGELOG.rst (1 hunks)
  • husarion_ugv_controller/CHANGELOG.rst (1 hunks)
  • husarion_ugv_controller/CONFIGURATION.md (1 hunks)
  • husarion_ugv_controller/config/WH01_controller.yaml (1 hunks)
  • husarion_ugv_controller/config/WH02_controller.yaml (1 hunks)
  • husarion_ugv_controller/config/WH04_controller.yaml (1 hunks)
  • husarion_ugv_controller/config/WH05_controller.yaml (1 hunks)
  • husarion_ugv_controller/launch/controller.launch.py (2 hunks)
  • husarion_ugv_controller/package.xml (1 hunks)
  • husarion_ugv_description/CHANGELOG.rst (1 hunks)
  • husarion_ugv_description/CMakeLists.txt (1 hunks)
  • husarion_ugv_description/README.md (1 hunks)
  • husarion_ugv_description/config/WH01.yaml (1 hunks)
  • husarion_ugv_description/config/WH02.yaml (1 hunks)
  • husarion_ugv_description/config/WH04.yaml (1 hunks)
  • husarion_ugv_description/config/WH05.yaml (1 hunks)
  • husarion_ugv_description/config/components.yaml (1 hunks)
  • husarion_ugv_description/launch/load_urdf.launch.py (5 hunks)
  • husarion_ugv_description/launch/overwrite_robot_description.launch.py (5 hunks)
  • husarion_ugv_description/launch/rviz.launch.py (1 hunks)
  • husarion_ugv_description/package.xml (1 hunks)
  • husarion_ugv_description/urdf/common/wheel.urdf.xacro (2 hunks)
  • husarion_ugv_description/urdf/lynx.urdf.xacro (2 hunks)
  • husarion_ugv_description/urdf/lynx/body.urdf.xacro (1 hunks)
  • husarion_ugv_description/urdf/lynx/lynx_macro.urdf.xacro (3 hunks)
  • husarion_ugv_description/urdf/panther.urdf.xacro (2 hunks)
  • husarion_ugv_description/urdf/panther/body.urdf.xacro (4 hunks)
  • husarion_ugv_description/urdf/panther/panther_macro.urdf.xacro (1 hunks)
  • husarion_ugv_diagnostics/CHANGELOG.rst (1 hunks)
  • husarion_ugv_gazebo/CHANGELOG.rst (1 hunks)
  • husarion_ugv_gazebo/CONFIGURATION.md (1 hunks)
  • husarion_ugv_gazebo/README.md (2 hunks)
  • husarion_ugv_gazebo/launch/simulate_robot.launch.py (5 hunks)
  • husarion_ugv_gazebo/launch/simulation.launch.py (1 hunks)
  • husarion_ugv_gazebo/launch/spawn_robot.launch.py (2 hunks)
  • husarion_ugv_gazebo/package.xml (1 hunks)
  • husarion_ugv_hardware_interfaces/CHANGELOG.rst (1 hunks)
  • husarion_ugv_hardware_interfaces/README.md (3 hunks)
  • husarion_ugv_lights/CHANGELOG.rst (1 hunks)
  • husarion_ugv_lights/launch/lights.launch.py (1 hunks)
  • husarion_ugv_localization/CHANGELOG.rst (1 hunks)
  • husarion_ugv_localization/config/enu_localization.yaml (1 hunks)
  • husarion_ugv_localization/config/enu_localization_with_gps.yaml (1 hunks)
  • husarion_ugv_localization/config/relative_localization.yaml (1 hunks)
  • husarion_ugv_localization/config/relative_localization_with_gps.yaml (1 hunks)
  • husarion_ugv_manager/CHANGELOG.rst (1 hunks)
  • husarion_ugv_utils/CHANGELOG.rst (1 hunks)
  • lynx_description/CMakeLists.txt (0 hunks)
  • lynx_description/README.md (0 hunks)
  • lynx_description/config/components.yaml (0 hunks)
  • lynx_description/package.xml (0 hunks)
  • lynx_description/urdf/body.urdf.xacro (0 hunks)
  • lynx_description/urdf/gazebo.urdf.xacro (0 hunks)
  • lynx_description/urdf/wheel.urdf.xacro (0 hunks)
  • panther_description/hooks/panther_description.sh.in (0 hunks)
  • panther_description/launch/load_urdf.launch.py (0 hunks)
💤 Files with no reviewable changes (9)
  • lynx_description/config/components.yaml
  • panther_description/hooks/panther_description.sh.in
  • lynx_description/CMakeLists.txt
  • lynx_description/README.md
  • lynx_description/package.xml
  • panther_description/launch/load_urdf.launch.py
  • lynx_description/urdf/wheel.urdf.xacro
  • lynx_description/urdf/body.urdf.xacro
  • lynx_description/urdf/gazebo.urdf.xacro
✅ Files skipped from review due to trivial changes (15)
  • husarion_ugv_description/config/components.yaml
  • husarion_ugv/CHANGELOG.rst
  • husarion_ugv_controller/CONFIGURATION.md
  • husarion_ugv_hardware_interfaces/README.md
  • husarion_ugv_diagnostics/CHANGELOG.rst
  • husarion_ugv_lights/launch/lights.launch.py
  • husarion_ugv_description/config/WH04.yaml
  • husarion_ugv_hardware_interfaces/CHANGELOG.rst
  • husarion_ugv_localization/CHANGELOG.rst
  • husarion_ugv_description/config/WH01.yaml
  • husarion_ugv_battery/CHANGELOG.rst
  • husarion_ugv_controller/CHANGELOG.rst
  • husarion_ugv_utils/CHANGELOG.rst
  • husarion_ugv_gazebo/README.md
  • husarion_ugv_description/config/WH05.yaml
🧰 Additional context used
🪛 LanguageTool
husarion_ugv_description/README.md

[style] ~8-~8: As a shorter alternative for ‘able to’, consider using “can”.
Context: ...e_robot_description.launch.py- launch is able to changerobot_description` topic in run...

(BE_ABLE_TO)


[uncategorized] ~8-~8: You might be missing the article “the” here.
Context: ...n.launch.py- launch is able to changerobot_descriptiontopic in runtime. -...

(AI_EN_LECTOR_MISSING_DETERMINER_THE)


[uncategorized] ~13-~13: Loose punctuation mark.
Context: ...ponents.yaml`](./config/components.yaml): Allows you to quickly add visualization...

(UNLIKELY_OPENING_PUNCTUATION)


[uncategorized] ~14-~14: Loose punctuation mark.
Context: ...tor. - WH01.yaml: Description of physical and visual para...

(UNLIKELY_OPENING_PUNCTUATION)


[uncategorized] ~15-~15: Loose punctuation mark.
Context: ...H01. - WH02.yaml: Description of physical and visual para...

(UNLIKELY_OPENING_PUNCTUATION)


[uncategorized] ~16-~16: Loose punctuation mark.
Context: ...H02. - WH04.yaml: Description of physical and visual para...

(UNLIKELY_OPENING_PUNCTUATION)


[uncategorized] ~17-~17: Loose punctuation mark.
Context: ...H04. - WH05.yaml: Description of physical and visual para...

(UNLIKELY_OPENING_PUNCTUATION)

🔇 Additional comments (55)
husarion_ugv_controller/config/WH05_controller.yaml (1)

44-44: ⚠️ Potential issue

Verify the correct frame ID naming convention

There appears to be an inconsistency between the PR objectives and the implementation. The PR description states that "base_footprint" should be renamed to "base_link", but this line sets base_frame_id: base_footprint.

Let's verify the frame naming convention across the codebase:

husarion_ugv_lights/CHANGELOG.rst (1)

2-2: LGTM! Package name updated as part of rebranding.

The package renaming from panther_lights to husarion_ugv_lights is consistent with the broader rebranding effort mentioned in the PR objectives.

Let's verify the consistency of this rebranding across the codebase:

husarion_ugv_controller/config/WH04_controller.yaml (2)

Line range hint 1-89: Well-documented configuration with empirical values

The configuration file is well-structured with:

  • Clear documentation of hardware specifications (e.g., IMU link)
  • Experimental/empirical values for covariances with explanatory comments
  • Comprehensive velocity and acceleration limits

45-45: Verify frame ID naming convention

The PR objectives state that "base_footprint" should be renamed to "base_link", but this line sets base_frame_id: base_footprint. Please verify if this is intentional or needs to be updated to align with the PR objectives.

husarion_ugv_controller/config/WH02_controller.yaml (3)

45-45: Verify frame transformation chain consistency

The change from base_link to base_footprint aligns with PR objectives. However, we should verify:

  1. Consistent frame naming across all controller configurations
  2. Proper TF tree setup with the new frame hierarchy
✅ Verification successful

Let's verify the frame definitions in the URDF files to ensure proper TF tree setup.


Frame transformation chain is properly configured

The verification shows:

  • All controller configurations consistently use base_footprint as the base frame
  • URDF files for both Lynx and Panther robots have proper frame hierarchy:
    • base_footprint is the root frame
    • base_link is properly connected to base_footprint with fixed joint and correct wheel radius offset
    • All other components (wheels, sensors) are correctly attached to base_link
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check frame_id consistency across controller configs
echo "Checking base_frame_id in controller configs:"
rg "base_frame_id:" --type yaml

# Check for TF tree definitions
echo "Checking URDF/xacro files for frame definitions:"
fd -e urdf -e xacro | xargs rg -l "base_footprint|base_link"

Length of output: 813


Script:

#!/bin/bash
# Check the frame definitions in the URDF files
echo "Checking base_footprint and base_link definitions in body.urdf.xacro files:"
rg -A 5 "base_footprint|base_link" husarion_ugv_description/urdf/panther/body.urdf.xacro husarion_ugv_description/urdf/lynx/body.urdf.xacro

echo -e "\nChecking wheel connections to base frames:"
rg -A 3 "parent|child" husarion_ugv_description/urdf/common/wheel.urdf.xacro

Length of output: 6525


Line range hint 15-22: Verify IMU frame naming consistency

The PR objectives mention frame renaming changes, but frame_id: imu_link remains unchanged. Please verify if this frame name should also be updated to maintain consistency with the new frame naming scheme.

✅ Verification successful

No frame renaming needed for imu_link

The imu_link frame name should remain unchanged. The URDF files show that imu_link is consistently defined as a child of base_link in both Lynx and Panther robot descriptions. The PR's frame renaming objectives specifically focused on changing base_link to body_link and modifying the frame hierarchy between base_footprint and base_link, but did not include changes to sensor-specific frames like imu_link.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for imu_link frame references across the codebase
rg "imu_link" --type yaml --type xml

Length of output: 344


Script:

#!/bin/bash
# Let's check URDF/xacro files for imu_link frame definition and its parent frame
fd -e urdf -e xacro | xargs rg -l "imu_link|body_link|base_link" -A 5 -B 5

Length of output: 410


Script:

#!/bin/bash
# Let's examine the actual content of these files to see the imu_link frame definition
rg "imu_link" husarion_ugv_description/urdf/panther/panther_macro.urdf.xacro husarion_ugv_description/urdf/panther/body.urdf.xacro husarion_ugv_description/urdf/lynx/lynx_macro.urdf.xacro husarion_ugv_description/urdf/lynx/body.urdf.xacro -A 3 -B 3

Length of output: 4033


Line range hint 52-54: Review odometry configuration with new frame setup

The configuration shows:

  • enable_odom_tf: false - TF publishing is disabled
  • position_feedback: false - Only velocity is used for odometry

Please verify that this configuration works correctly with the new frame hierarchy and sensor fusion setup.

✅ Verification successful

The search results show that the robot uses the robot_localization package with an EKF (Extended Kalman Filter) node for sensor fusion. The configuration is intentional and consistent across all controller configurations (WH01-WH05):

  • All controllers have enable_odom_tf: false and position_feedback: false
  • The robot has dedicated localization packages and launch files that handle the sensor fusion
  • The README and ROS API documentation confirm that EKF is used to fuse odometry data from wheel encoders, IMU, and optionally GPS

Let me verify the EKF configuration to ensure it properly handles the odometry data:


The EKF configuration files and TF setup reveal that the odometry configuration is intentionally designed this way. The robot uses:

  1. EKF node for sensor fusion with:

    • publish_tf: true - EKF publishes the transforms
    • odom0: odometry/wheels configured for velocity only (x, y, yaw)
    • imu0: imu/data for orientation
    • Proper frame setup: map -> odom -> base_footprint
  2. Controller configuration with:

    • enable_odom_tf: false - Letting EKF handle the transforms
    • position_feedback: false - Using only velocity feedback for better accuracy

The odometry configuration is correct and properly integrated with the sensor fusion setup

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check for odometry configuration in launch files and other relevant configs
echo "Checking launch files for odometry setup:"
fd -e launch | xargs rg "robot_localization|ekf|ukf"

echo "Checking other odometry-related configurations:"
rg "enable_odom_tf|position_feedback" --type yaml

Length of output: 9433


Script:

#!/bin/bash
# Check EKF configuration files
echo "EKF configuration files content:"
fd -e yaml | rg "localization" | xargs cat

# Check if there are any TF-related configurations
echo -e "\nTF configurations in launch files:"
fd -e launch | xargs rg "tf|transform"

Length of output: 44669

husarion_ugv_description/config/WH02.yaml (1)

7-7: mesh_package updated to reflect new package structure

The change from panther_description to husarion_ugv_description ensures consistency with the new package naming.

husarion_ugv_description/CMakeLists.txt (2)

2-2: Project name updated to husarion_ugv_description

The update aligns the project name with the new package structure.


9-9: Environment hooks updated to use setup_envs.sh.in

Changing the environment hook ensures the correct setup script is referenced.

husarion_ugv_controller/package.xml (1)

21-21: Added husarion_ugv_description as an execution dependency

Including husarion_ugv_description ensures all necessary resources are available.

husarion_ugv_description/package.xml (1)

Line range hint 28-28: Verify HUSARION_ROS_BUILD_TYPE environment variable

The conditional exec_depend for rviz2 uses $HUSARION_ROS_BUILD_TYPE. Please ensure this environment variable is properly documented and set in the build system.

✅ Verification successful

Environment variable HUSARION_ROS_BUILD_TYPE is properly documented and used consistently

The environment variable HUSARION_ROS_BUILD_TYPE is well documented in the repository's README.md file, which explains its usage for both hardware (hardware) and simulation (simulation) builds. The variable is consistently used across multiple package.xml files to conditionally include dependencies based on the build type, following a clear pattern:

  • Hardware-specific dependencies use condition="$HUSARION_ROS_BUILD_TYPE == hardware"
  • Simulation-specific dependencies use condition="$HUSARION_ROS_BUILD_TYPE == simulation"
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for HUSARION_ROS_BUILD_TYPE usage and documentation
rg -A 2 "HUSARION_ROS_BUILD_TYPE" 

Length of output: 5714

husarion_ugv_description/urdf/panther.urdf.xacro (2)

4-6: Verify IMU parameters across robot models

The IMU parameters (xyz: "0.169 0.025 0.092", rpy: "0.0 0.0 -1.57") are identical between panther and lynx models. Please verify if this is intentional, as these parameters should typically be specific to each robot's physical configuration.


16-16: Verify path structure for robot-specific components

The new path structure places panther-specific files in a subdirectory (urdf/panther/). Please ensure all related files (meshes, configs) follow this organization pattern for consistency.

✅ Verification successful

Directory structure follows consistent organization pattern

The verification confirms that both robot-specific components (Panther and Lynx) follow a consistent organization pattern with dedicated subdirectories under both meshes/ and urdf/ folders.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check directory structure consistency
fd -t d "panther|lynx" husarion_ugv_description/

Length of output: 204

husarion_ugv_description/urdf/lynx.urdf.xacro (1)

27-27: Consider separating component configurations

Both panther and lynx robots are using the same components.yaml. Consider maintaining separate component configurations for each robot model to prevent unintended sharing of parameters and improve maintainability.

husarion_ugv_description/launch/rviz.launch.py (1)

44-44: Verify RViz config file path exists

The path has been updated to reflect the package rename, but we should verify the config file exists at the new location.

✅ Verification successful

RViz config file path verified

The RViz configuration file exists at the expected location: husarion_ugv_description/rviz/husarion_ugv.rviz

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Verify RViz config file exists in the new package
fd "husarion_ugv.rviz" --type f

Length of output: 79

.pre-commit-config.yaml (1)

3-3: Hook version updates and exclude pattern refinement look good

The updates include:

  • pre-commit-hooks: v5.0.0
  • clang-format: v19.1.3
  • black: 24.10.0
  • doc8: v1.1.2
  • Refined doc8 exclude pattern to be more specific

Also applies to: 37-37, 66-66, 90-90, 94-94

husarion_ugv_description/urdf/panther/body.urdf.xacro (4)

9-9: Frame renaming follows ROS conventions

The renaming of frames follows ROS conventions where:

  • base_footprint represents the ground projection
  • base_link represents the main robot body

Also applies to: 13-14


44-44: Consistent parent link updates

All joint parent links have been updated from body_link to base_link, maintaining consistency with the frame renaming.

Also applies to: 52-52, 68-68, 84-84


21-21: Verify mesh files exist in new package location

The mesh paths have been updated to the new package structure. Let's verify the files exist.

Also applies to: 28-28

✅ Verification successful

Mesh files are present in the expected locations

The verification confirms that the required mesh files base.dae and base_collision.stl exist in the correct package location at husarion_ugv_description/meshes/panther/.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check if mesh files exist in the new package
fd "base.dae|base_collision.stl" --type f

Length of output: 197


9-14: Verify frame name changes across the codebase

The renaming of frames from base_link to base_footprint and body_link to base_link might affect other packages that reference these frames.

✅ Verification successful

Frame renaming is already properly aligned across the codebase

The configuration files in husarion_ugv_localization are already using the correct frame name base_footprint, which matches the URDF changes. No modifications are needed as the frame naming is consistent.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for potential references to old frame names
rg -l "body_link|base_link" --type xml --type yaml

Length of output: 300


Script:

#!/bin/bash
# Check the content of localization config files to understand the frame usage
for file in husarion_ugv_localization/config/*.yaml; do
    echo "=== $file ==="
    cat "$file" | grep -A 2 -B 2 "base_link\|body_link"
done

Length of output: 2034

husarion_ugv_controller/config/WH01_controller.yaml (1)

44-44: Verify frame naming consistency with PR objectives

The PR objectives state that frames should be renamed from "base_footprint" to "base_link", but here base_frame_id is set to "base_footprint". Please verify if this is intentional or needs to be updated to "base_link" for consistency.

husarion_ugv_gazebo/package.xml (1)

33-33: LGTM! Dependencies updated correctly

The addition of husarion_ugv_description and removal of lynx_description and panther_description aligns with the PR objective of merging the descriptions.

husarion_ugv_gazebo/launch/simulation.launch.py (1)

75-77: LGTM! Package reference updated correctly

The package reference has been properly updated from panther_description to husarion_ugv_description, maintaining consistency with the package renaming.

husarion_ugv_description/urdf/common/wheel.urdf.xacro (2)

46-46: LGTM: Improved XML formatting

The mesh and cylinder tags are now properly self-closing, following XML best practices.

Also applies to: 53-53


34-34: Verify frame naming consistency with PR objectives

The parent link is set to "base_link", but according to the PR objectives, frames should be renamed from "base_link" to "body_link". Please verify if this is intentional or needs to be updated.

husarion_ugv_gazebo/CONFIGURATION.md (1)

11-11: LGTM: Documentation path updated correctly

The path to components.yaml has been updated to reflect the new package structure.

husarion_ugv_gazebo/launch/spawn_robot.launch.py (2)

87-87: LGTM: Package path and parameters updated correctly

The package path has been updated to use husarion_ugv_description, and the robot_model parameter is properly configured.

Also applies to: 93-93


44-46: Review robot model choices after description merge

Given that the PR objectives mention merging panther and lynx descriptions, should the choices list be updated to reflect this change?

✅ Verification successful

Based on the gathered information, I can now provide a final response:

Keep robot model choices as they are

The current choices list ["lynx", "panther"] should be maintained because:

  • Both robot models are still actively used and referenced throughout the codebase
  • Each robot has its own distinct URDF definitions (lynx.urdf.xacro and panther.urdf.xacro)
  • The robot model parameter is consistently used across multiple launch files for model-specific configurations
  • While descriptions are being merged for maintainability, the robots remain as separate models with different physical characteristics and configurations (e.g., different wheel configurations - WH05 for Lynx, WH01 for Panther)
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check for other references to robot models
echo "Checking robot model references..."
rg -A 1 '(lynx|panther)' --type python

Length of output: 150


Script:

#!/bin/bash
# Check for robot model references without file type restriction
echo "Checking robot model references..."
rg -A 1 '(lynx|panther)'

# Also check launch files specifically
echo -e "\nChecking launch files..."
fd -e launch.py -x cat {}

Length of output: 69273


Script:

#!/bin/bash
# Check launch files specifically for robot model references
echo "Checking launch files for robot model references..."
fd -e launch.py -x grep -A 2 -B 2 'robot_model.*=.*\["lynx", "panther"\]' {}

# Check URDF files for robot model definitions
echo -e "\nChecking URDF files..."
fd -e urdf.xacro -x grep -A 2 -B 2 'name="(lynx|panther)' {}

Length of output: 319


Script:

#!/bin/bash
# Check all files for robot model choices
echo "Checking for robot model choices..."
rg -B 3 -A 3 'choices=\["lynx", "panther"\]'

# Check for robot model parameter usage
echo -e "\nChecking robot model parameter usage..."
rg -B 3 -A 3 'robot_model.*=.*lynx|robot_model.*=.*panther'

# Check URDF files for robot-specific content
echo -e "\nChecking URDF files for robot definitions..."
fd . -e urdf.xacro -x head -n 20 {}

Length of output: 14123

husarion_ugv_description/launch/overwrite_robot_description.launch.py (4)

50-54: LGTM! Path update and improved documentation.

The path update aligns with the package renaming, and the description now provides better guidance by referencing the manual.


83-91: LGTM! Well-structured robot model configuration.

The implementation provides good flexibility through environment variables while maintaining proper constraints on valid choices.


137-137: Verify URDF file existence for both robot models.

The dynamic URDF file selection looks good, but we should verify that both lynx.urdf.xacro and panther.urdf.xacro exist in the specified location.

Also applies to: 143-143

✅ Verification successful

URDF files for both robot models are present in the expected location

Both lynx.urdf.xacro and panther.urdf.xacro exist in the husarion_ugv_description/urdf/ directory, along with their corresponding macro and body files. The dynamic URDF file selection will work correctly for both robot models.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check for URDF file existence
fd -e urdf.xacro -e URDF.xacro . | grep -E "lynx|panther"

Length of output: 379


118-127: Verify wheel type compatibility with robot models.

While the implementation looks good, please ensure that the new wheel type "WH05" is compatible with both robot models, particularly since it's set as the default for the lynx model.

✅ Verification successful

Let me gather more information about the wheel configurations and their usage.


Let me try one more search to find wheel type references in Python files with a different approach.


Based on the gathered information, I can now provide a final response:

WH05 wheel configuration is properly defined and compatible with the Lynx model

The wheel configuration files and launch scripts show that:

  • WH05 has appropriate configuration in husarion_ugv_description/config/WH05.yaml with defined parameters like wheel radius (0.1348m), width (0.09m), and separation (0.45m)
  • It's properly set as the default wheel type for the Lynx model in the launch configuration
  • The wheel type is non-mecanum, which is consistent with Lynx's locomotion system
  • The configuration is properly integrated into the launch system with appropriate parameter handling and file paths
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check for wheel type configurations and their usage
rg -A 5 "WH05" --type yaml

Length of output: 150


Script:

#!/bin/bash
# Check for wheel configurations and their usage patterns
echo "=== Checking wheel config files ==="
fd "WH.*\.yaml" husarion_ugv_description/config/ --exec cat {}

echo -e "\n=== Checking robot model configurations ==="
fd "lynx|panther" -e yaml --exec cat {}

echo -e "\n=== Checking for wheel type references in launch files ==="
rg "wheel_type|WH[0-9]+" --type python

Length of output: 7382


Script:

#!/bin/bash
# Search for wheel configurations in Python files
echo "=== Checking wheel configurations in Python files ==="
fd -e py --exec grep -A 5 -B 5 "wheel_type\|WH[0-9]\+" {}

echo "=== Checking robot model specific configurations ==="
fd -e urdf --exec grep -A 10 -B 10 "wheel\|WH[0-9]\+" {}

Length of output: 8470

husarion_ugv_description/urdf/lynx/lynx_macro.urdf.xacro (2)

14-14: LGTM! Improved namespace handling.

The simplified ternary expression is more concise while maintaining the same functionality.


20-22: Verify the existence of referenced URDF files.

The path updates align with the new package structure, particularly the move of common components to a shared location.

✅ Verification successful

All referenced URDF files exist in the expected locations

The verification confirms that all URDF files referenced in the include statements are present:

  • body.urdf.xacro exists in husarion_ugv_description/urdf/lynx/
  • gazebo.urdf.xacro and wheel.urdf.xacro exist in husarion_ugv_description/urdf/common/
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check for referenced URDF files
echo "Checking for body.urdf.xacro..."
fd "body.urdf.xacro" -p "husarion_ugv_description/urdf/lynx"
echo "Checking for common URDFs..."
fd -e urdf.xacro . -p "husarion_ugv_description/urdf/common"

Length of output: 419

husarion_ugv_description/urdf/panther/panther_macro.urdf.xacro (1)

25-27: LGTM! Consistent path structure with lynx_macro.

The path updates maintain consistency with the lynx_macro.urdf.xacro file, properly organizing common components in a shared location.

husarion_ugv_description/launch/load_urdf.launch.py (4)

59-64: LGTM: Package path and documentation updates are appropriate.

The changes correctly reflect the new package name and include helpful documentation references.


127-136: LGTM: Wheel type configuration is well-structured.

The mapping of default wheel types to robot models is clear and the expanded choices provide good flexibility.


146-152: LGTM: URDF file handling supports multiple robot models.

The dynamic URDF file selection based on robot model is implemented correctly.

Let's verify the URDF files exist for both models:

✅ Verification successful

URDF files for both robot models are present and correctly organized

The verification confirms that both lynx.urdf.xacro and panther.urdf.xacro files exist in the expected location under husarion_ugv_description/urdf/, along with their supporting macro and component files. The implementation will work correctly for both robot models.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify URDF files existence
# Check if both robot model URDF files are present

fd -g "*.urdf.xacro" -t f

Length of output: 456


92-100: LGTM: Robot model configuration supports both platforms.

The implementation correctly handles model selection through environment variables and launch arguments.

Let's verify the robot model choices are used consistently:

✅ Verification successful

LGTM: Robot model references are consistently handled across the codebase

The verification shows that robot model references are properly managed:

  • Launch files use environment variables and launch arguments for model selection
  • URDF/Xacro files maintain separate, dedicated configurations for each model
  • Mesh file references are correctly segregated by model type
  • Consistent use of "lynx" and "panther" choices in launch configurations
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify robot model usage across launch files
# Check for any hardcoded robot model references that should use the new configuration

rg -g '*.launch.py' -g '*.xacro' "panther|lynx" --no-filename

Length of output: 3012

husarion_ugv_gazebo/launch/simulate_robot.launch.py (1)

Line range hint 122-134: LGTM: Conditional launches handle model-specific features appropriately.

The conditions correctly manage feature availability based on the robot model.

husarion_ugv_manager/CHANGELOG.rst (1)

1-2: LGTM: Changelog properly reflects package renaming.

The package renaming is correctly documented in the changelog header.

husarion_ugv_gazebo/CHANGELOG.rst (1)

1-2: LGTM! Package renaming is consistently reflected.

The changelog has been properly updated to reflect the package renaming from panther_gazebo to husarion_ugv_gazebo.

husarion_ugv_controller/launch/controller.launch.py (2)

125-134: LGTM! Package path update aligns with project restructuring.

The hardcoded package name husarion_ugv_description is consistent with the PR objectives of merging the panther and lynx descriptions.


156-156: LGTM! Variable renaming and path update improve clarity.

The changes:

  1. Renamed variable to urdf_file for better clarity
  2. Updated path to use husarion_ugv_description consistently

Also applies to: 162-162

README.md (1)

92-92: LGTM! Documentation paths updated consistently.

The configuration paths have been properly updated to reflect the new package structure:

  • Components configuration path now points to husarion_ugv_description
  • Wheel configuration path now points to husarion_ugv_description

Also applies to: 114-114

husarion_ugv_description/CHANGELOG.rst (1)

2-2: Package name change is properly documented.

The changelog correctly reflects the package rename from panther_description to husarion_ugv_description, aligning with the project's rebranding efforts.

husarion_ugv_bringup/CHANGELOG.rst (2)

2-2: Package name change is properly documented.

The changelog correctly reflects the package rename from panther_bringup to husarion_ugv_bringup, maintaining consistency with the project's rebranding efforts.


Line range hint 1-24: Verify documentation of frame renaming changes.

The PR objectives mention renaming frames from "base_link" to "body_link" and "base_footprint" to "base_link", but these specific changes are not explicitly documented in the changelog entries.

husarion_ugv_localization/config/relative_localization.yaml (1)

13-13: Verify frame transformation chain

The change from base_link to base_footprint aligns with ROS 2 conventions. However, we should verify that the transformation chain is properly maintained.

✅ Verification successful

Frame transformation chain is properly maintained

The URDF files show that both robot models (Panther and Lynx) properly define the transformation chain between base_footprint and base_link:

  • base_footprint is the root frame
  • A fixed joint base_to_body_joint connects base_footprint to base_link
  • The transformation is set at the wheel radius height (xyz="0.0 0.0 ${wheel_radius}")
  • All other robot components are properly attached to base_link
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Check for tf2 frame definitions and transformations
# Look for tf2 static transform publishers or URDF definitions that establish the base_footprint to base_link transform

# Search for static transform publishers
rg -l "static_transform_publisher.*base_footprint.*base_link" 

# Search for URDF/xacro definitions
fd -e urdf -e xacro | xargs rg "base_footprint.*base_link"

Length of output: 124


Script:

#!/bin/bash
# Let's try a broader search to understand the frame relationships

# Search for any mentions of base_footprint in launch files, config files, and Python/C++ sources
rg -g '!*.pyc' -g '!*.so' -l "base_footprint"

# Search for any mentions of base_link in the same types of files
rg -g '!*.pyc' -g '!*.so' -l "base_link"

# Look for robot description or URDF loading
rg -g '*.launch.*' -g '*.py' -g '*.xml' -g '*.yaml' "robot_description|robot_state_publisher" -A 3

Length of output: 8396


Script:

#!/bin/bash
# Let's examine the URDF files more closely to understand the frame relationships
rg -g '*.urdf.xacro' 'base_footprint|base_link' -B 2 -A 2 husarion_ugv_description/urdf/

# Also check the localization configuration files
cat husarion_ugv_localization/config/relative_localization.yaml

Length of output: 12401

husarion_ugv_localization/config/enu_localization.yaml (1)

13-13: Verify ENU frame configuration

The frame change is consistent with other configuration files. For ENU localization, ensure that the GPS and IMU measurements are properly transformed through the new frame hierarchy.

✅ Verification successful

Frame configuration is properly set for ENU localization

The configuration files show that the frame hierarchy and transformations are correctly set up:

  1. The EKF filter configurations properly integrate IMU and GPS data with base_footprint as the base_link_frame
  2. The IMU data is correctly configured with relative transforms disabled and gravity compensation handled appropriately
  3. In the GPS-enabled configuration, the navsat_transform node is properly configured to handle the GPS measurements in the ENU frame

The frame change to base_footprint is consistent across all configurations and the sensor measurements (IMU, GPS, odometry) are properly transformed through this frame hierarchy.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Check for GPS and IMU frame configurations

# Search for GPS frame configurations
rg -A 5 "frame_id.*base_footprint.*gps"

# Search for IMU frame configurations
rg -A 5 "frame_id.*base_footprint.*imu"

Length of output: 83


Script:

#!/bin/bash
# Let's search for frame configurations more broadly

# Search for GPS-related configurations
echo "=== GPS Frame Configurations ==="
rg -i "frame.*gps" --type yaml

# Search for IMU-related configurations
echo -e "\n=== IMU Frame Configurations ==="
rg -i "frame.*imu" --type yaml

# Search for base_footprint references in yaml files
echo -e "\n=== base_footprint References ==="
rg "base_footprint" --type yaml

# List all yaml files in the config directory for context
echo -e "\n=== YAML Files in Config ==="
fd -e yaml -e yml

Length of output: 3234


Script:

#!/bin/bash
# Let's examine the localization configurations in detail

# Check ENU localization configurations
echo "=== ENU Localization Configuration ==="
cat husarion_ugv_localization/config/enu_localization.yaml
echo -e "\n=== ENU Localization with GPS Configuration ==="
cat husarion_ugv_localization/config/enu_localization_with_gps.yaml

# Check GPS configuration
echo -e "\n=== NMEA NavSat Configuration ==="
cat husarion_ugv_localization/config/nmea_navsat.yaml

# Check IMU configuration in hardware interfaces
echo -e "\n=== Phidgets Spatial Parameters ==="
cat husarion_ugv_hardware_interfaces/config/phidgets_spatial_parameters.yaml

Length of output: 17629

husarion_ugv_localization/config/relative_localization_with_gps.yaml (2)

Line range hint 28-34: Review GPS odometry configuration

The GPS odometry configuration (odom1) looks correct with position-only measurements enabled. This aligns well with the new frame hierarchy where GPS measurements would be referenced to the base_footprint frame.


13-13: Verify GPS integration with new frame hierarchy

The frame change is consistent. For GPS-enabled relative localization, we need to ensure that the navsat_transform node properly handles the new frame hierarchy.

✅ Verification successful

Frame change is consistent with GPS integration

The verification shows that the base_footprint frame is consistently used across all localization configurations, including both GPS and non-GPS variants. The navsat_transform node's configuration in relative_localization_with_gps.yaml aligns with other configurations and the launch file properly handles the frame transformations with correct topic remappings for GPS data integration.

  • The frame is consistently used in:
    • All localization configurations (ENU and relative modes)
    • Controller configurations
    • GPS-enabled configurations maintain the same frame hierarchy
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Check navsat_transform configuration and frame handling

# Search for navsat_transform configurations
rg -A 10 "navsat_transform.*base_footprint"

# Check for any custom GPS frame transformations
rg -l "tf2.*base_footprint.*gps"

Length of output: 80


Script:

#!/bin/bash
# Let's broaden the search to find navsat configurations and GPS-related settings

# Search for navsat_transform configurations without specific frame
rg -A 10 "navsat_transform"

# Search for GPS-related configurations
rg -A 5 "gps.*frame|frame.*gps" --type yaml

# Look for any base_footprint frame references in launch or config files
fd -e yaml -e launch | xargs rg "base_footprint"

Length of output: 9754

husarion_ugv_localization/config/enu_localization_with_gps.yaml (2)

13-13: Clarify frame renaming inconsistency

There appears to be a discrepancy between the PR description and the implementation:

  • PR states: changing from "base_link" to "body_link"
  • Implementation shows: changing to "base_footprint"

Please clarify if this is intentional or needs adjustment to match the PR objectives.


13-13: Verify sensor transformation chain integrity

The frame change affects the EKF's reference frame for sensor fusion. Please verify:

  1. All sensor transformations (IMU, GPS, wheel odometry) are properly updated
  2. The transformation chain remains valid from map->odom->base_footprint
✅ Verification successful

Let me gather more information about the launch files and sensor configurations to verify the complete transformation chain.


Let me check the URDF files to verify the complete transformation chain.


Based on the analysis of the configuration files and URDF descriptions, I can now provide a final response:

Sensor transformation chain is properly configured

The transformation chain is correctly maintained:

  • The base_footprint frame is properly defined as the base frame in both EKF configurations and URDF
  • IMU sensor is correctly mounted with a fixed transform to base_link
  • All sensor configurations (IMU, wheel odometry) use consistent frame references
  • The transformation chain map->odom->base_footprint is preserved in the EKF configuration with proper frame declarations
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Search for sensor-related transform configurations
echo "Checking sensor transform configurations..."
rg -A 5 "(_frame:|frame_id:|frame:|parent:|child:)" --type yaml

# Look for potential TF configuration in launch files
echo -e "\nChecking launch files for transform configurations..."
fd -e launch.py -e launch.xml | xargs grep -l "transform"

Length of output: 9444


Script:

#!/bin/bash
# Check launch files content for transform configurations
echo "Checking transform configurations in launch files..."
cat husarion_ugv_gazebo/launch/simulate_robot.launch.py
cat husarion_ugv_localization/launch/localization.launch.py

# Check for IMU and GPS configurations
echo -e "\nChecking for IMU and GPS configurations..."
fd -e yaml | xargs grep -l "imu\|gps"

# If any IMU/GPS config files found, display their content
for f in $(fd -e yaml | xargs grep -l "imu\|gps"); do
    echo -e "\nContent of $f:"
    cat "$f"
done

Length of output: 57483


Script:

#!/bin/bash
# Search for URDF files and their content
echo "Checking URDF files for transformation chain..."
fd -e urdf -e xacro | xargs cat

# Look for robot state publisher configurations
echo -e "\nChecking for robot state publisher configurations..."
rg -A 5 "robot_state_publisher" --type xml --type launch

Length of output: 34800

Comment on lines 5 to 7
<!-- TODO find IMU position -->
<xacro:arg name="imu_xyz" default="0.169 0.025 0.092" />
<xacro:arg name="imu_rpy" default="0.0 0.0 -1.57" />
Copy link
Contributor

Choose a reason for hiding this comment

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

⚠️ Potential issue

Address TODO comment regarding IMU position

The TODO comment indicates uncertainty about the IMU position. This is critical for proper robot operation and should be resolved before merging.

Would you like me to create a GitHub issue to track the IMU position verification task?

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 6

🧹 Outside diff range and nitpick comments (15)
husarion_ugv_description/launch/overwrite_robot_description.launch.py (1)

118-118: Robust wheel type configuration with model-specific defaults!

The implementation properly maps default wheel types to robot models and includes comprehensive wheel type choices.

Consider adding a validation check to ensure the default_wheel_type dictionary covers all robot models:

     default_wheel_type = {"lynx": "WH05", "panther": "WH01"}
+    if not all(model in default_wheel_type for model in ["lynx", "panther"]):
+        raise ValueError("Missing wheel type mapping for some robot models")

Also applies to: 121-121, 127-127

husarion_ugv_description/launch/load_urdf.launch.py (2)

62-63: Consider using versioned documentation links

While the link to the manuals is helpful, consider using a versioned URL to ensure users are directed to documentation that matches their software version.


92-100: Enhance environment variable validation

The robot model configuration could be more robust:

  1. Consider validating that ROBOT_MODEL contains only allowed values
  2. Add error handling for unknown robot models

Here's a suggested improvement:

-    robot_model_dict = {"LNX": "lynx", "PTH": "panther"}
-    robot_model_env = os.environ.get("ROBOT_MODEL", default="PTH")
-    declare_robot_model_arg = DeclareLaunchArgument(
+    VALID_ROBOT_MODELS = {"LNX": "lynx", "PTH": "panther"}
+    robot_model_env = os.environ.get("ROBOT_MODEL", default="PTH")
+    if robot_model_env not in VALID_ROBOT_MODELS:
+        raise ValueError(f"Invalid ROBOT_MODEL: {robot_model_env}. Must be one of {list(VALID_ROBOT_MODELS.keys())}")
+    declare_robot_model_arg = DeclareLaunchArgument(
husarion_ugv_description/README.md (1)

8-9: Enhance launch file descriptions

The descriptions could be more informative:

  1. For overwrite_robot_description.launch.py: Consider "Allows changing the robot_description topic in runtime."
  2. For rviz.launch.py: Consider adding what the "basic configuration" includes.
🧰 Tools
🪛 LanguageTool

[style] ~8-~8: As a shorter alternative for ‘able to’, consider using “can”.
Context: ...e_robot_description.launch.py- launch is able to changerobot_description` topic in run...

(BE_ABLE_TO)


[uncategorized] ~8-~8: You might be missing the article “the” here.
Context: ...n.launch.py- launch is able to changerobot_descriptiontopic in runtime. -...

(AI_EN_LECTOR_MISSING_DETERMINER_THE)

husarion_ugv_description/package.xml (1)

14-18: Sort author list alphabetically

Consider sorting the author list alphabetically by last name for better maintainability.

-  <author email="dawid.kmak@husarion.com">Dawid Kmak</author>
-  <author email="krzysztof.wojciechowski@husarion.com">Krzysztof Wojciechowski</author>
-  <author email="maciej.stepien@husarion.com">Maciej Stepien</author>
-  <author email="pawel.kowalski@husarion.com">Paweł Kowalski</author>
-  <author email="rafal.gorecki@husarion.com">Rafal Gorecki</author>
+  <author email="rafal.gorecki@husarion.com">Rafal Gorecki</author>
+  <author email="dawid.kmak@husarion.com">Dawid Kmak</author>
+  <author email="pawel.kowalski@husarion.com">Paweł Kowalski</author>
+  <author email="maciej.stepien@husarion.com">Maciej Stepien</author>
+  <author email="krzysztof.wojciechowski@husarion.com">Krzysztof Wojciechowski</author>
husarion_ugv_description/urdf/lynx/body.urdf.xacro (10)

26-28: Update package reference in commented collision mesh

The commented collision mesh on line 27 references the panther package. Please update it to husarion_ugv_descriptions to reflect the new package naming when the models are ready.


35-35: Fix typo in TODO comment

There's a typo in the comment. The word "interia" should be "inertia".


35-39: Calculate and update real inertia values

The inertia values for base_link are placeholders. Calculating and updating these with accurate values will improve simulation accuracy and robot behavior.

Would you like assistance in calculating the inertia values or setting up a procedure to obtain them?


55-60: Update package reference in commented collision mesh

The commented collision mesh references the panther package. Please update it to husarion_ugv_descriptions when the models are ready.


63-63: Fix typo in TODO comment

There's a typo in the comment. The word "interia" should be "inertia".


63-68: Calculate and update real inertia values for user_compartment_link

The inertia values are placeholders. Updating them with accurate values is important for correct physical simulation.

Would you like assistance in determining these inertia values?


84-90: Update package reference in commented collision mesh

The commented collision mesh for battery_link references the panther package. Please update it to husarion_ugv_descriptions when the models are ready.


94-94: Fix typo in TODO comment

There's a typo in the comment. The word "interia" should be "inertia".


94-98: Calculate and update real inertia values for battery_link

The inertia values are currently placeholders. Accurate inertia values are crucial for proper dynamics in simulation.

Would you like assistance in calculating these inertia values?


110-111: Update origin values for body_to_cover_joint

The origin values for the joint are placeholders, as indicated by the TODO comment. Please update them with the correct values when available.

Let me know if you need help determining the correct origin coordinates.

📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 4e090f4 and 4eb1aba.

📒 Files selected for processing (27)
  • README.md (2 hunks)
  • husarion_ugv_controller/CONFIGURATION.md (1 hunks)
  • husarion_ugv_controller/launch/controller.launch.py (2 hunks)
  • husarion_ugv_controller/package.xml (1 hunks)
  • husarion_ugv_description/CMakeLists.txt (1 hunks)
  • husarion_ugv_description/README.md (1 hunks)
  • husarion_ugv_description/config/WH01.yaml (1 hunks)
  • husarion_ugv_description/config/WH02.yaml (1 hunks)
  • husarion_ugv_description/config/WH04.yaml (1 hunks)
  • husarion_ugv_description/config/WH05.yaml (1 hunks)
  • husarion_ugv_description/launch/load_urdf.launch.py (5 hunks)
  • husarion_ugv_description/launch/overwrite_robot_description.launch.py (5 hunks)
  • husarion_ugv_description/launch/rviz.launch.py (1 hunks)
  • husarion_ugv_description/package.xml (1 hunks)
  • husarion_ugv_description/urdf/lynx.urdf.xacro (2 hunks)
  • husarion_ugv_description/urdf/lynx/body.urdf.xacro (1 hunks)
  • husarion_ugv_description/urdf/lynx/lynx_macro.urdf.xacro (3 hunks)
  • husarion_ugv_description/urdf/panther.urdf.xacro (2 hunks)
  • husarion_ugv_description/urdf/panther/body.urdf.xacro (4 hunks)
  • husarion_ugv_description/urdf/panther/panther_macro.urdf.xacro (1 hunks)
  • husarion_ugv_gazebo/CONFIGURATION.md (1 hunks)
  • husarion_ugv_gazebo/README.md (2 hunks)
  • husarion_ugv_gazebo/launch/simulate_robot.launch.py (5 hunks)
  • husarion_ugv_gazebo/launch/simulation.launch.py (1 hunks)
  • husarion_ugv_gazebo/launch/spawn_robot.launch.py (2 hunks)
  • husarion_ugv_gazebo/package.xml (1 hunks)
  • husarion_ugv_hardware_interfaces/README.md (3 hunks)
🚧 Files skipped from review as they are similar to previous changes (22)
  • husarion_ugv_controller/CONFIGURATION.md
  • husarion_ugv_description/config/WH01.yaml
  • husarion_ugv_description/config/WH02.yaml
  • husarion_ugv_gazebo/launch/simulation.launch.py
  • husarion_ugv_controller/package.xml
  • husarion_ugv_description/config/WH04.yaml
  • husarion_ugv_description/config/WH05.yaml
  • husarion_ugv_gazebo/CONFIGURATION.md
  • husarion_ugv_hardware_interfaces/README.md
  • husarion_ugv_description/urdf/panther/panther_macro.urdf.xacro
  • husarion_ugv_description/launch/rviz.launch.py
  • husarion_ugv_description/CMakeLists.txt
  • husarion_ugv_gazebo/package.xml
  • husarion_ugv_gazebo/launch/simulate_robot.launch.py
  • husarion_ugv_gazebo/launch/spawn_robot.launch.py
  • README.md
  • husarion_ugv_controller/launch/controller.launch.py
  • husarion_ugv_gazebo/README.md
  • husarion_ugv_description/urdf/panther.urdf.xacro
  • husarion_ugv_description/urdf/lynx.urdf.xacro
  • husarion_ugv_description/urdf/panther/body.urdf.xacro
  • husarion_ugv_description/urdf/lynx/lynx_macro.urdf.xacro
🧰 Additional context used
🪛 LanguageTool
husarion_ugv_description/README.md

[style] ~8-~8: As a shorter alternative for ‘able to’, consider using “can”.
Context: ...e_robot_description.launch.py- launch is able to changerobot_description` topic in run...

(BE_ABLE_TO)


[uncategorized] ~8-~8: You might be missing the article “the” here.
Context: ...n.launch.py- launch is able to changerobot_descriptiontopic in runtime. -...

(AI_EN_LECTOR_MISSING_DETERMINER_THE)


[uncategorized] ~13-~13: Loose punctuation mark.
Context: ...ponents.yaml`](./config/components.yaml): Allows you to quickly add visualization...

(UNLIKELY_OPENING_PUNCTUATION)


[uncategorized] ~14-~14: Loose punctuation mark.
Context: ...tor. - WH01.yaml: Description of physical and visual para...

(UNLIKELY_OPENING_PUNCTUATION)


[uncategorized] ~15-~15: Loose punctuation mark.
Context: ...H01. - WH02.yaml: Description of physical and visual para...

(UNLIKELY_OPENING_PUNCTUATION)


[uncategorized] ~16-~16: Loose punctuation mark.
Context: ...H02. - WH04.yaml: Description of physical and visual para...

(UNLIKELY_OPENING_PUNCTUATION)


[uncategorized] ~17-~17: Loose punctuation mark.
Context: ...H04. - WH05.yaml: Description of physical and visual para...

(UNLIKELY_OPENING_PUNCTUATION)

🔇 Additional comments (7)
husarion_ugv_description/launch/overwrite_robot_description.launch.py (3)

83-91: Well-structured robot model configuration!

The implementation properly handles:

  • Environment variable configuration with sensible defaults
  • Clear model choices validation ("lynx", "panther")
  • Consistent mapping between env var codes and model names

181-181: Launch sequence ordering is correct!

The robot_model declaration is properly placed before wheel_type in the launch sequence, with clear documentation of the dependency.


137-137: URDF file handling looks good!

The implementation correctly handles dynamic URDF file selection based on the robot model.

Also applies to: 143-143

✅ Verification successful

URDF file handling is correctly implemented

The verification confirms that both required URDF files (lynx.urdf.xacro and panther.urdf.xacro) exist in the expected location within the husarion_ugv_description/urdf/ directory, validating the dynamic URDF file selection implementation.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Verify URDF files exist for both robot models
fd -p "urdf/.*\.urdf\.xacro$" -t f | grep -E "(lynx|panther)\.urdf\.xacro"

Length of output: 171

husarion_ugv_description/launch/load_urdf.launch.py (4)

127-136: LGTM! Well-structured wheel configuration

The wheel configuration is well-designed with:

  • Clear mapping of default wheel types per robot model
  • Comprehensive list of wheel type choices
  • Good integration with the robot model configuration

198-198: LGTM! Well-documented argument dependencies

The comment clearly explains the dependency between robot_model and wheel_type arguments, helping future maintainers understand the required ordering.


146-146: Add URDF file existence validation

Consider validating that the URDF file exists before attempting to load it to provide better error messages.

Let's verify the URDF files exist:

Also applies to: 152-152


59-59: ⚠️ Potential issue

Fix package name inconsistency

The package name in the FindPackageShare calls is "husarion_ugv_descriptions" (plural), but the file path shows "husarion_ugv_description" (singular). This inconsistency could cause runtime errors.

Let's verify the correct package name:

Also applies to: 115-115

@@ -47,13 +47,11 @@ def generate_launch_description():
declare_components_config_path_arg = DeclareLaunchArgument(
"components_config_path",
default_value=PathJoinSubstitution(
[FindPackageShare("panther_description"), "config", "components.yaml"]
[FindPackageShare("husarion_ugv_descriptions"), "config", "components.yaml"]
Copy link
Contributor

Choose a reason for hiding this comment

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

💡 Codebase verification

Package name in launch file needs correction

The launch file references husarion_ugv_descriptions (plural) but the actual package name is husarion_ugv_description (singular) as evidenced by the file path found. This mismatch will cause runtime failures.

  • Change FindPackageShare("husarion_ugv_descriptions") to FindPackageShare("husarion_ugv_description") on line 50
🔗 Analysis chain

Package path and documentation updates look good!

The package rename from "panther_description" to "husarion_ugv_descriptions" aligns with the project restructuring. The updated description helpfully references the manuals.

Also applies to: 53-54

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Verify the package exists and contains the expected config path
ros2 pkg prefix husarion_ugv_descriptions 2>/dev/null || echo "Package not found"
fd -p "config/components.yaml$" -t f

Length of output: 175

@@ -95,27 +103,28 @@
"wheel_config_path",
default_value=PathJoinSubstitution(
[
FindPackageShare("panther_description"),
FindPackageShare("husarion_ugv_descriptions"),
Copy link
Contributor

Choose a reason for hiding this comment

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

💡 Codebase verification

Package path update needs attention - missing wheel configuration

The package path update to "husarion_ugv_descriptions" is incorrect as the actual package name is "husarion_ugv_description" (without 's'). Additionally, the wheel configuration WH03.yaml is missing from the config directory while other wheel configurations (WH01, WH02, WH04, WH05) are present.

  • Line 106: Change FindPackageShare("husarion_ugv_descriptions") to FindPackageShare("husarion_ugv_description")
  • Line 113: Same correction needed
  • Missing wheel configuration: husarion_ugv_description/config/WH03.yaml
🔗 Analysis chain

Package path update is consistent!

The wheel configuration path update maintains consistency with the package renaming.

Also applies to: 113-113

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Verify the wheel config files exist in the new location
fd -p "config/.*\.yaml$" -t f | grep -E "WH0[1-5]\.yaml"

Length of output: 226


Script:

#!/bin/bash
# Check if there are any references to the new package name in the codebase
rg "husarion_ugv_descriptions" -l

# Also check for any references to WH03.yaml which seems to be missing
rg "WH03\.yaml" -l

Length of output: 1253

Comment on lines +1 to +17
# husarion_ugv_descriptions

The package contains URDF files responsible for creating a representation of the robot by specifying the relationships and types of connections (joints) between individual links. It also contains information about the robot's mesh.

## Launch Files

- `load_urdf.launch.py` - loads the robot's URDF and creates simple bindings to display moving joints.
- `overwrite_robot_description.launch.py` - launch is able to change `robot_description` topic in runtime.
- `rviz.launch.py` - launch RViz2 with basic configuration.

## Configuration Files

- [`components.yaml`](./config/components.yaml): Allows you to quickly add visualization of sensors, TF connections and simulate their behavior in the simulator.
- [`WH01.yaml`](./config/WH01.yaml): Description of physical and visual parameters for the wheel WH01.
- [`WH02.yaml`](./config/WH02.yaml): Description of physical and visual parameters for the wheel WH02.
- [`WH04.yaml`](./config/WH04.yaml): Description of physical and visual parameters for the wheel WH04.
- [`WH05.yaml`](./config/WH05.yaml): Description of physical and visual parameters for the wheel WH05.
Copy link
Contributor

Choose a reason for hiding this comment

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

⚠️ Potential issue

Document frame renaming changes

The PR involves renaming frames from "base_link" to "body_link" and "base_footprint" to "base_link", but this significant change isn't documented in the README.

Consider adding a new section about frame conventions, explaining:

  • The new frame naming scheme
  • Rationale for the changes
  • Impact on existing configurations
🧰 Tools
🪛 LanguageTool

[style] ~8-~8: As a shorter alternative for ‘able to’, consider using “can”.
Context: ...e_robot_description.launch.py- launch is able to changerobot_description` topic in run...

(BE_ABLE_TO)


[uncategorized] ~8-~8: You might be missing the article “the” here.
Context: ...n.launch.py- launch is able to changerobot_descriptiontopic in runtime. -...

(AI_EN_LECTOR_MISSING_DETERMINER_THE)


[uncategorized] ~13-~13: Loose punctuation mark.
Context: ...ponents.yaml`](./config/components.yaml): Allows you to quickly add visualization...

(UNLIKELY_OPENING_PUNCTUATION)


[uncategorized] ~14-~14: Loose punctuation mark.
Context: ...tor. - WH01.yaml: Description of physical and visual para...

(UNLIKELY_OPENING_PUNCTUATION)


[uncategorized] ~15-~15: Loose punctuation mark.
Context: ...H01. - WH02.yaml: Description of physical and visual para...

(UNLIKELY_OPENING_PUNCTUATION)


[uncategorized] ~16-~16: Loose punctuation mark.
Context: ...H02. - WH04.yaml: Description of physical and visual para...

(UNLIKELY_OPENING_PUNCTUATION)


[uncategorized] ~17-~17: Loose punctuation mark.
Context: ...H04. - WH05.yaml: Description of physical and visual para...

(UNLIKELY_OPENING_PUNCTUATION)


## Configuration Files

- [`components.yaml`](./config/components.yaml): Allows you to quickly add visualization of sensors, TF connections and simulate their behavior in the simulator.
- [`WH01.yaml`](./config/WH01.yaml): Description of physical and visual parameters for the wheel WH01.
- [`WH02.yaml`](./config/WH02.yaml): Description of physical and visual parameters for the wheel WH02.
- [`WH04.yaml`](./config/WH04.yaml): Description of physical and visual parameters for the wheel WH04.
- [`WH05.yaml`](./config/WH05.yaml): Description of physical and visual parameters for the wheel WH05.
Copy link
Contributor

Choose a reason for hiding this comment

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

💡 Codebase verification

Missing wheel parameters and TODO note needs attention

The WH05 configuration represents a medium-sized non-mecanum wheel (radius: 0.1348m, width: 0.09m) with a wheel separation of 0.45m. However, there are two issues that need attention:

  • The configuration file is missing the wheel_radius, wheel_width, and wheel_separation parameters that are present in all other wheel configurations
  • There's a TODO comment indicating that mass and inertia values are not finalized
🔗 Analysis chain

Document wheel configuration changes

Please provide context for the addition of WH05.yaml. What type of wheel is it and how does it differ from the other configurations?

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check for any documentation or comments about WH05 in the config file
cat husarion_ugv_description/config/WH05.yaml | grep -A 5 "^#"

Length of output: 258


Script:

#!/bin/bash
# Let's check for other wheel configurations to compare
fd "WH.*\.yaml" husarion_ugv_description/config/ --exec cat {} \;

Length of output: 1038

🧰 Tools
🪛 LanguageTool

[uncategorized] ~17-~17: Loose punctuation mark.
Context: ...H04. - WH05.yaml: Description of physical and visual para...

(UNLIKELY_OPENING_PUNCTUATION)

Comment on lines 11 to 12
<url type="repository">https://github.com/husarion/panther_ros</url>
<url type="bugtracker">https://github.com/husarion/panther_ros/issues</url>
Copy link
Contributor

Choose a reason for hiding this comment

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

⚠️ Potential issue

Update repository URLs

The repository and bugtracker URLs still reference "panther_ros" despite the rebranding effort to "husarion_ugv".

Verify if these URLs should be updated as part of the rebranding:

-  <url type="repository">https://github.com/husarion/panther_ros</url>
-  <url type="bugtracker">https://github.com/husarion/panther_ros/issues</url>
+  <url type="repository">https://github.com/husarion/husarion_ugv</url>
+  <url type="bugtracker">https://github.com/husarion/husarion_ugv/issues</url>
📝 Committable suggestion

‼️ IMPORTANT
Carefully review the code before committing. Ensure that it accurately replaces the highlighted code, contains no missing lines, and has no issues with indentation. Thoroughly test & benchmark the code to ensure it meets the requirements.

Suggested change
<url type="repository">https://github.com/husarion/panther_ros</url>
<url type="bugtracker">https://github.com/husarion/panther_ros/issues</url>
<url type="repository">https://github.com/husarion/husarion_ugv</url>
<url type="bugtracker">https://github.com/husarion/husarion_ugv/issues</url>

@@ -1,19 +1,21 @@
<?xml version="1.0"?>
<?xml-model href="http://download.ros.org/schema/package_format3.xsd" schematypens="http://www.w3.org/2001/XMLSchema"?>
<package format="3">
<name>panther_description</name>
<name>husarion_ugv_descriptions</name>
Copy link
Contributor

Choose a reason for hiding this comment

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

💡 Codebase verification

⚠️ Potential issue

The verification results show a clear inconsistency between the package name and its usage throughout the codebase. The directory is named husarion_ugv_description (singular), but the package is named husarion_ugv_descriptions (plural) in package.xml and CMakeLists.txt. This plural form is referenced extensively across the codebase in various files including launch files, URDF files, and dependencies.

Package name needs to be changed to singular form

The package name should be changed from husarion_ugv_descriptions to husarion_ugv_description to match:

  • The directory name husarion_ugv_description/
  • The naming convention of other packages in the repository (all singular)
  • The CHANGELOG.rst which uses singular form

This change will require updating:

  • package.xml
  • CMakeLists.txt
  • All references in URDF, launch files, and configuration files
  • Dependencies in other packages (husarion_ugv_controller, husarion_ugv_gazebo)
🔗 Analysis chain

Review package naming convention

The package name uses plural form "descriptions" while the directory name uses singular form "description". Consider maintaining consistency across the codebase.

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check for any other occurrences of both forms
echo "Checking for 'description' usage:"
rg -i "husarion_ugv.?description" --glob '!*.md'

echo -e "\nChecking directory name:"
ls -d */

Length of output: 6737

Comment on lines 11 to 15
<joint name="base_to_body_joint" type="fixed">
<origin xyz="0.0 0.0 ${wheel_radius}" rpy="0.0 0.0 0.0" />
<parent link="base_link" />
<child link="body_link" />
<parent link="base_footprint" />
<child link="base_link" />
</joint>
Copy link
Contributor

Choose a reason for hiding this comment

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

I'll just mention that base_link should be the main link of the robot and a parent to all other links. base_footprint should just be a helper link for visualization/navigation. Btw, check also joint names

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 4

🧹 Outside diff range and nitpick comments (4)
husarion_ugv_description/urdf/lynx/body.urdf.xacro (4)

18-21: Update collision geometry for 'base_link' when models are ready

The collision geometry for base_link is currently using a placeholder box, and the actual collision mesh is commented out. To improve simulation accuracy, please update the collision geometry when the models are available.

Would you like assistance in creating a temporary collision mesh or opening a GitHub issue to track this task?


55-60: Update collision geometry for 'user_compartment_link' when models are ready

The collision geometry for user_compartment_link is commented out, and currently, there is no collision geometry defined. This affects simulation and collision detection.

Would you like help in creating a placeholder collision geometry or tracking this task in an issue?


84-89: Update collision geometry for 'battery_link' when models are ready

The collision geometry for battery_link is commented out, and currently, there is no collision geometry defined. This affects simulation and collision detection.

Would you like help in creating a placeholder collision geometry or tracking this task in an issue?


110-111: Update origin values for 'base_to_cover_joint'

There's a TODO comment indicating that the origin values need to be updated to real values. Accurate joint origins ensure correct placement of the cover_link.

Would you like assistance in determining the correct origin values or opening a GitHub issue to track this task?

📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 4eb1aba and 5bea48b.

📒 Files selected for processing (5)
  • README.md (2 hunks)
  • husarion_ugv_controller/launch/controller.launch.py (2 hunks)
  • husarion_ugv_description/urdf/lynx/body.urdf.xacro (1 hunks)
  • husarion_ugv_description/urdf/panther/body.urdf.xacro (4 hunks)
  • husarion_ugv_lights/launch/lights.launch.py (1 hunks)
🚧 Files skipped from review as they are similar to previous changes (3)
  • husarion_ugv_lights/launch/lights.launch.py
  • husarion_ugv_controller/launch/controller.launch.py
  • README.md
🔇 Additional comments (5)
husarion_ugv_description/urdf/panther/body.urdf.xacro (5)

Line range hint 9-33: Link renaming aligns with ROS conventions.

The renaming from body_link to base_link follows ROS conventions where base_link serves as the main reference frame for the robot.


42-47: IMU joint changes look good.

The joint has been correctly updated to use base_link as the parent while maintaining the parameterized positioning.


Line range hint 50-86: Bumper and light joint changes are consistent.

The changes maintain the correct transformation chain while adapting to the new naming scheme:

  • Renamed joints from body_* to base_*
  • Updated parent links to base_link
  • Preserved light channel relationships

Line range hint 25-31: Address TODO comment regarding inertial origin.

The inertial origin needs verification as it's critical for proper physics simulation. The current values (0,0,0) might not represent the true center of mass of the robot.


34-40: Verify intended link hierarchy against PR objectives.

The PR description mentions changing "base_footprint" to "base_link", but the implementation shows:

  • base_link as the parent
  • base_footprint as the child
  • base_footprint being added as a new link

This appears to be the opposite of what was described in the PR objectives. Please clarify if this is intentional, as typically in ROS:

  • base_footprint represents the robot's projection on the ground
  • base_link should be the main reference frame for the robot's body

Comment on lines 26 to 31
<mass value="30.0" />
<!-- TODO calculate real interia -->
<inertia ixx="0.46856" ixy="0.0" ixz="0.0"
iyy="1.22285" iyz="0.0"
izz="1.51185" />
</inertial>
Copy link
Contributor

Choose a reason for hiding this comment

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

🛠️ Refactor suggestion

Calculate and update accurate inertial properties for 'base_link'

The inertial properties for base_link are placeholders, as indicated by the TODO comment. Accurate inertial properties are essential for realistic physics simulation.

Can I assist in calculating the correct inertia values or opening a GitHub issue to track this task?

Comment on lines 63 to 68
<!-- TODO calculate real interia -->
<mass value="30.0" />
<inertia ixx="0.46856" ixy="0.0" ixz="0.0"
iyy="1.22285" iyz="0.0"
izz="1.51185" />
</inertial>
Copy link
Contributor

Choose a reason for hiding this comment

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

🛠️ Refactor suggestion

Calculate and update inertial properties for 'user_compartment_link'

The inertial properties are placeholders and need to be calculated to improve simulation accuracy.

Can I assist in determining the appropriate mass and inertia values or open a GitHub issue to address this?

Comment on lines 94 to 98
<!-- TODO calculate real interia -->
<inertia ixx="0.46856" ixy="0.0" ixz="0.0"
iyy="1.22285" iyz="0.0"
izz="1.51185" />
</inertial>
Copy link
Contributor

Choose a reason for hiding this comment

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

🛠️ Refactor suggestion

Calculate and update inertial properties for 'battery_link'

The inertial properties are placeholders and need to be calculated to improve simulation accuracy.

Can I assist in determining the appropriate mass and inertia values or open a GitHub issue to address this?


<inertial>
<origin xyz="0.0 0.0 0.0" rpy="0.0 0.0 0.0" />
<mass value="30.0" />
Copy link
Contributor

Choose a reason for hiding this comment

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

💡 Codebase verification

Mass values need adjustment and proper calculation

The verification reveals several concerns:

  • Three identical masses of 30.0 kg in lynx/body.urdf.xacro for different components
  • Comments indicating "TODO calculate real inertia" suggest these are placeholder values
  • The same components in panther/body.urdf.xacro use different mass (43.0 kg)
  • Wheel masses are parameterized using wheel_config['mass']

This suggests the mass values are not properly calculated and need to be adjusted based on:

  • Actual component weights
  • Proper inertia calculations
  • Consistency with similar robot models (e.g., Panther)
🔗 Analysis chain

Verify cumulative mass of the robot

The mass values for base_link, user_compartment_link, and battery_link are all set to 30.0 kg. This may result in an unintended total mass. Please verify if these values are accurate or need adjustment.

Run the following script to sum up the masses of all links and check the total mass:

Also applies to: 64-64, 93-93

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Calculate the total mass of all links in the URDF file.

# Extract mass values from the URDF file and sum them
grep '<mass value' husarion_ugv_description/urdf/lynx/body.urdf.xacro \
  | grep -oP 'value="[^"]+"' \
  | awk -F'"' '{sum += $2} END {print "Total mass:", sum, "kg"}'

Length of output: 179


Script:

#!/bin/bash
# Let's check if there are any other URDF/xacro files that might contribute to the total mass
fd -e urdf -e xacro | xargs grep -l '<mass value'

# Then let's examine all mass values across all URDF files to get a complete picture
echo "=== Mass values in all URDF/xacro files ==="
fd -e urdf -e xacro | xargs grep -A1 '<link' | grep -B1 '<mass value'

Length of output: 379


Script:

#!/bin/bash
# Let's examine the mass values directly in each file
echo "=== Mass values in wheel.urdf.xacro ==="
grep -A1 '<mass' husarion_ugv_description/urdf/common/wheel.urdf.xacro

echo -e "\n=== Mass values in lynx/body.urdf.xacro ==="
grep -A1 '<mass' husarion_ugv_description/urdf/lynx/body.urdf.xacro

echo -e "\n=== Mass values in panther/body.urdf.xacro ==="
grep -A1 '<mass' husarion_ugv_description/urdf/panther/body.urdf.xacro

Length of output: 917

Copy link
Contributor

@coderabbitai coderabbitai bot left a comment

Choose a reason for hiding this comment

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

Actionable comments posted: 4

🧹 Outside diff range and nitpick comments (1)
README.md (1)

117-117: Fix markdown formatting

Remove spaces inside the code span element -2.0.

-Initial robot position in the global 'y' axis. <br/> ***float:***` -2.0`
+Initial robot position in the global 'y' axis. <br/> ***float:*** `-2.0`
🧰 Tools
🪛 Markdownlint (0.35.0)

117-117: null
Spaces inside code span elements

(MD038, no-space-in-code)

📜 Review details

Configuration used: .coderabbit.yaml
Review profile: CHILL

📥 Commits

Reviewing files that changed from the base of the PR and between 5bea48b and b8ccaf0.

📒 Files selected for processing (8)
  • README.md (2 hunks)
  • husarion_ugv_description/launch/rviz.launch.py (2 hunks)
  • husarion_ugv_description/rviz/husarion_ugv.rviz (3 hunks)
  • husarion_ugv_description/urdf/lynx/base.urdf.xacro (1 hunks)
  • husarion_ugv_description/urdf/lynx/lynx_macro.urdf.xacro (3 hunks)
  • husarion_ugv_description/urdf/panther/base.urdf.xacro (4 hunks)
  • husarion_ugv_description/urdf/panther/panther_macro.urdf.xacro (1 hunks)
  • husarion_ugv_gazebo/launch/spawn_robot.launch.py (3 hunks)
🚧 Files skipped from review as they are similar to previous changes (4)
  • husarion_ugv_description/urdf/panther/panther_macro.urdf.xacro
  • husarion_ugv_description/launch/rviz.launch.py
  • husarion_ugv_gazebo/launch/spawn_robot.launch.py
  • husarion_ugv_description/urdf/lynx/lynx_macro.urdf.xacro
🧰 Additional context used
🪛 Markdownlint (0.35.0)
README.md

117-117: null
Spaces inside code span elements

(MD038, no-space-in-code)

🔇 Additional comments (5)
husarion_ugv_description/urdf/panther/base.urdf.xacro (2)

34-45: Frame transformations look good

The frame renaming and transformation chain follows ROS REP 105 conventions:

  • base_footprint as the robot's projection on the ground
  • base_link as the main reference frame
  • Consistent naming of joints with "base_to_*" pattern

Line range hint 25-30: Verify inertial properties

The TODO comment suggests that the origin needs fixing. Additionally, please verify:

  1. The mass value of 43.0 kg is accurate
  2. The inertia matrix values are correct for the robot's mass distribution
husarion_ugv_description/rviz/husarion_ugv.rviz (2)

48-48: Frame references are correctly configured

The RViz configuration properly uses:

  • base_footprint as the reference frame
  • Consistent namespace templating for multi-robot support
  • odom as the fixed frame

Also applies to: 76-76, 138-138


Line range hint 76-114: Display configurations are well organized

The RViz setup provides a clean initial view with:

  • Essential RobotModel display enabled
  • Optional displays (TF, Odometry) disabled by default
  • Proper topic configurations for all displays
README.md (1)

118-118: Verify the impact of the default z-value change

The default z-value for robot spawning has been changed from 0.0 to 0.2. This change might affect existing setups or scripts that rely on the default value.

✅ Verification successful

Default z-value change appears safe to implement

The change of default z-value from 0.0 to 0.2 in the robot spawn configuration appears safe. The search results show:

  • The z-value is only explicitly set in spawn_robot.launch.py and is used as a launch argument
  • No hardcoded dependencies on z=0.0 were found in the codebase
  • Other configuration files that reference z-coordinates are unrelated to robot spawning (mostly inertia configs and controller parameters)
🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Search for any references to the z-value in launch files and tests

# Search for z parameter usage in launch files
rg --type python "DeclareLaunchArgument.*['\"]z['\"]" -A 5

# Search for hardcoded z values in tests
rg --type python "z.*=.*0\.0" test/

Length of output: 164


Script:

#!/bin/bash
# Search for any references to z parameter in launch files
rg "DeclareLaunchArgument.*['\"]z['\"]"

# Search for z parameter usage in Python files
rg "z\s*=\s*0\.0"

# Search for any robot spawning or positioning related files
fd -e py -e launch | xargs rg "robot.*position|spawn.*robot"

# Look for configuration files that might contain default positions
fd -e yaml -e xml | xargs rg "z:|z=|<z>|position.*z"

Length of output: 2148

<visual>
<origin xyz="0.0 0.0 0.0" rpy="0.0 0.0 0.0" />
<geometry>
<mesh filename="package://panther_description/meshes/body.dae" />
<mesh filename="package://husarion_ugv_descriptions/meshes/panther/base.dae" />
Copy link
Contributor

Choose a reason for hiding this comment

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

⚠️ Potential issue

Fix package name in mesh paths

The package name in mesh paths contains an extra 's' which doesn't match the actual package name "husarion_ugv_description".

Apply this fix:

-          <mesh filename="package://husarion_ugv_descriptions/meshes/panther/base.dae" />
+          <mesh filename="package://husarion_ugv_description/meshes/panther/base.dae" />
-          <mesh filename="package://husarion_ugv_descriptions/meshes/panther/base_collision.stl" />
+          <mesh filename="package://husarion_ugv_description/meshes/panther/base_collision.stl" />

Also applies to: 20-20

Comment on lines +27 to +30
<!-- TODO calculate real interia -->
<inertia ixx="0.46856" ixy="0.0" ixz="0.0"
iyy="1.22285" iyz="0.0"
izz="1.51185" />
Copy link
Contributor

Choose a reason for hiding this comment

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

⚠️ Potential issue

Calculate accurate inertial properties

Multiple components have placeholder inertial properties:

  1. Base link: 30.0 kg mass with TODO for inertia
  2. User compartment: Same values as base link
  3. Battery: Same values as base link

This could significantly affect the robot's dynamic behavior in simulation.

Consider using CAD software or ROS tools to calculate accurate inertial properties based on the component geometries and materials.

Also applies to: 63-67, 94-97

Comment on lines +18 to +21
<!-- TODO change when models ready -->
<!-- <mesh filename="package://husarion_ugv_descriptions/meshes/panther/body_collision.stl" /> -->
<box size="0.64 0.34 0.28" />
</geometry>
Copy link
Contributor

Choose a reason for hiding this comment

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

💡 Codebase verification

Missing collision meshes need to be created for Lynx robot

The repository contains visual meshes for the Lynx robot (base.dae, battery.dae, user_compartment.dae) but lacks corresponding collision meshes. While Panther robot has a collision mesh (base_collision.stl), similar collision-specific meshes are missing for the Lynx components.

  • Create collision meshes for:
    • husarion_ugv_description/meshes/lynx/base_collision.stl
    • husarion_ugv_description/meshes/lynx/battery_collision.stl
    • husarion_ugv_description/meshes/lynx/user_compartment_collision.stl
🔗 Analysis chain

Implement proper collision meshes

Several collision geometries are using temporary solutions:

  1. Base link uses a simple box primitive
  2. User compartment collision mesh is commented out
  3. Battery collision mesh is commented out

This could affect simulation accuracy, especially for collision detection and physics calculations.

Also applies to: 56-60, 85-89

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Check if collision meshes exist in the repository
fd -e stl -e dae ".*collision.*" meshes/

Length of output: 137


Script:

#!/bin/bash
# First, let's find any directory containing 'mesh' to locate the correct path
fd -t d -i mesh

# Then check for STL or DAE files in the repository
fd -e stl -e dae

Length of output: 1130

@@ -89,7 +89,7 @@ Launch arguments are largely common to both simulation and physical robot. Howev
| ❌ | ✅ | `add_world_transform` | Adds a world frame that connects the tf trees of individual robots (useful when running multiple robots). <br/> ***bool:*** `False` |
| ✅ | ✅ | `animations_config_path` | Path to a YAML file with a description of led configuration. This file includes definition of robot panels, virtual segments and default animations. <br/> ***string:*** [`{robot_model}_animations.yaml`](./husarion_ugv_lights/config) |
| ❌ | ✅ | `battery_config_path` | Path to the Ignition LinearBatteryPlugin configuration file. This configuration is intended for use in simulations only. <br/> ***string:*** `None` |
| ✅ | ✅ | `components_config_path` | Additional components configuration file. Components described in this file are dynamically included in robot's URDF. Available options are described in [the manual](https://husarion.com/manuals/panther/panther-options). <br/> ***string:*** [`components.yaml`](./panther_description/config/components.yaml) |
| ✅ | ✅ | `components_config_path` | Additional components configuration file. Components described in this file are dynamically included in robot's URDF. Available options are described in [the manual](https://husarion.com/manuals/panther/panther-options). <br/> ***string:*** [`components.yaml`](./husarion_ugv_descriptions/config/components.yaml) |
Copy link
Contributor

Choose a reason for hiding this comment

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

💡 Codebase verification

Path in README needs to be updated

The README points to husarion_ugv_descriptions/config/components.yaml, but the actual path in the repository is husarion_ugv_description/config/components.yaml (singular 'description'). The wheel configuration files are also located in the same directory.

  • Update path in README from husarion_ugv_descriptions to husarion_ugv_description
🔗 Analysis chain

Verify the updated configuration paths

The path updates align with the rebranding from "panther" to "husarion_ugv". Let's verify these paths exist in the repository.

Also applies to: 114-114

🏁 Scripts executed

The following scripts were executed for the analysis:

Script:

#!/bin/bash
# Description: Verify the existence of the updated configuration paths

# Check components.yaml
fd --type f "components.yaml" husarion_ugv_descriptions/config

# Check wheel configuration files
fd --type f "WH01.yaml|WH02.yaml|WH04.yaml|WH05.yaml" husarion_ugv_descriptions/config

Length of output: 391


Script:

#!/bin/bash
# Let's first check the correct directory structure
fd --type d "descriptions"

# Then search for yaml files in the entire repository
fd -e yaml

Length of output: 1784

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