Package Summary

Tags No category tags.
Version 0.20.0
License BSD
Build type CATKIN
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/ros-controls/ros_control.git
VCS Type git
VCS Version noetic-devel
Last Updated 2023-10-27
Dev Status MAINTAINED
CI status
Released RELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

Transmission Interface.

Additional Links

Maintainers

  • Bence Magyar
  • Enrique Fernandez
  • Mathias Lüdtke

Authors

  • Adolfo Rodriguez Tsouroukdissian

Transmission Interface

Overview

transmission_interface contains data structures for representing mechanical transmissions, and methods for propagating position, velocity and effort variables between actuator and joint spaces.

In the same spirit as the hardware_interface package, this package wraps existing raw data (eg. current actuator position, reference joint command, etc.) under a consistent interface. By not imposing a specific layout on the raw data, it becomes easier to support arbitrary hardware drivers to software control.

Structure

There are three main elements involved in setting up a transmission_interface: - The Transmission class defines an abstract interface for mapping position, velocity and effort variables between actuator and joint space. Derived classes implement specific transmission types, such as simple reducers, differentials and four-bar linkages. Note that a single transmission may couple the variables of multiple actuators and joints (eg. a differential couples two actuators to two joints).

  • The TransmissionHandle class associates a name to a Transmission instance and a set of raw data variables it operates on (specified through the ActuatorData and JointData structures). Derived classes implement specific maps, such as JointToActuatorEffortHandle or ActuatorToJointStateHandle.

  • The TransmissionInterface class manages a set of transmission handles of the same type. Note that although the handles are of the same type, the underlying transmissions can be heterogeneous eg. a single ActuatorToJointPositionInterface can be set up to transform position variables from actuator to joint space for an arm with a four-bar-linkage in the shoulder, a differential in the wrist, and simple reducers elsewhere.

Examples

Please refer to the transmission_interface wiki page.

CHANGELOG

Changelog for package transmission_interface

0.20.0 (2023-10-27)

0.19.6 (2022-10-21)

0.19.5 (2021-06-16)

0.19.4 (2020-12-05)

0.19.3 (2020-10-11)

  • Fix jnt-to-act command propagation check in transmission_interface_loader_test (#473)
    • Fix jnt-to-act command propagation check
    • Fix jnt-to-act command propagation check of bidirectional transmissions
  • Remove ParseStatus enum (#470)
  • Remove irrelevant test case (resolve #460) (#472)
  • Contributors: Mateus Amarante, Jordan Lack

0.19.2 (2020-08-17)

0.19.1 (2020-05-10)

  • Function specifiers noetic (#453)

    • Add override specifiers & default constructors
    • Delete ControllerBase copy & move ctors
    • Remove unnecessary default constructors
    • Modernize additional constructors
    • Revert ImuSensorHandle::Data::Data() = default
    • Remove unnecessary default overridden constructors

    * Remove semicolon after function body Co-authored-by: Matt Reynolds <mtreynolds@uwaterloo.ca>

  • Use setuptools instead of distutils (#429)

  • Contributors: Bence Magyar, Matt Reynolds

0.19.0 (2020-04-23)

  • Replace enums with enum classes (#412)
  • Contributors: Matt Reynolds

0.18.0 (2020-04-16)

  • Add xmlns for URDF, remove xmlns:xacro (#436)
  • Fixed compile tests (#434)
  • Replace internal::is_permutation with std (#419)
  • Bump CMake version to avoid CMP0048 (#427)
  • Contributors: Alejandro Hern

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Recent questions tagged transmission_interface at Robotics Stack Exchange

Package Summary

Tags No category tags.
Version 0.13.5
License BSD
Build type CATKIN
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/ros-controls/ros_control.git
VCS Type git
VCS Version kinetic-devel
Last Updated 2020-04-17
Dev Status MAINTAINED
CI status Continuous Integration
Released RELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

Transmission Interface.

Additional Links

Maintainers

  • Bence Magyar
  • Enrique Fernandez
  • Mathias Lüdtke

Authors

  • Adolfo Rodriguez Tsouroukdissian

Transmission Interface

Overview

transmission_interface contains data structures for representing mechanical transmissions, and methods for propagating position, velocity and effort variables between actuator and joint spaces.

In the same spirit as the hardware_interface package, this package wraps existing raw data (eg. current actuator position, reference joint command, etc.) under a consistent interface. By not imposing a specific layout on the raw data, it becomes easier to support arbitrary hardware drivers to software control.

Structure

There are three main elements involved in setting up a transmission_interface: - The Transmission class defines an abstract interface for mapping position, velocity and effort variables between actuator and joint space. Derived classes implement specific transmission types, such as simple reducers, differentials and four-bar linkages. Note that a single transmission may couple the variables of multiple actuators and joints (eg. a differential couples two actuators to two joints).

  • The TransmissionHandle class associates a name to a Transmission instance and a set of raw data variables it operates on (specified through the ActuatorData and JointData structures). Derived classes implement specific maps, such as JointToActuatorEffortHandle or ActuatorToJointStateHandle.

  • The TransmissionInterface class manages a set of transmission handles of the same type. Note that although the handles are of the same type, the underlying transmissions can be heterogeneous eg. a single ActuatorToJointPositionInterface can be set up to transform position variables from actuator to joint space for an arm with a four-bar-linkage in the shoulder, a differential in the wrist, and simple reducers elsewhere.

Examples

Please refer to the transmission_interface wiki page.

CHANGELOG

Changelog for package transmission_interface

0.13.5 (2020-02-09)

0.13.4 (2020-01-12)

  • add minimum required pluginlib version
  • Contributors: Mikael Arguedas

0.13.3 (2018-04-26)

  • Introduce shared_ptr typedefs
  • Update maintainers
  • Fix catkin_lint errors and warnings
  • fix license string
  • Update transmission parser to parse the joint role
  • Contributors: Bence Magyar, Patrick Holthaus, jlack1987

0.13.2 (2018-04-16)

  • migrate to new class list macros header
  • migrate classloader headers
  • Contributors: Mathias L

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Recent questions tagged transmission_interface at Robotics Stack Exchange

Package Summary

Tags No category tags.
Version 0.10.2
License Modified BSD
Build type CATKIN
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/ros-controls/ros_control.git
VCS Type git
VCS Version jade-devel
Last Updated 2016-11-28
Dev Status MAINTAINED
CI status Continuous Integration
Released RELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

Transmission Interface.

Additional Links

Maintainers

  • Adolfo Rodriguez Tsouroukdissian
  • Dave Coleman

Authors

  • Adolfo Rodriguez Tsouroukdissian

Transmission Interface

Overview

transmission_interface contains data structures for representing mechanical transmissions, and methods for propagating position, velocity and effort variables between actuator and joint spaces.

In the same spirit as the hardware_interface package, this package wraps existing raw data (eg. current actuator position, reference joint command, etc.) under a consistent interface. By not imposing a specific layout on the raw data, it becomes easier to support arbitrary hardware drivers to software control.

Structure

There are three main elements involved in setting up a transmission_interface: - The Transmission class defines an abstract interface for mapping position, velocity and effort variables between actuator and joint space. Derived classes implement specific transmission types, such as simple reducers, differentials and four-bar linkages. Note that a single transmission may couple the variables of multiple actuators and joints (eg. a differential couples two actuators to two joints).

  • The TransmissionHandle class associates a name to a Transmission instance and a set of raw data variables it operates on (specified through the ActuatorData and JointData structures). Derived classes implement specific maps, such as JointToActuatorEffortHandle or ActuatorToJointStateHandle.

  • The TransmissionInterface class manages a set of transmission handles of the same type. Note that although the handles are of the same type, the underlying transmissions can be heterogeneous eg. a single ActuatorToJointPositionInterface can be set up to transform position variables from actuator to joint space for an arm with a four-bar-linkage in the shoulder, a differential in the wrist, and simple reducers elsewhere.

Examples

Please refer to the transmission_interface wiki page.

CHANGELOG

Changelog for package transmission_interface

0.10.1 (2016-11-28)

0.10.0 (2015-11-20)

  • Allow loading transmissions from a vector of TransmissionInfo instances.
  • Address -Wunused-parameter warnings
  • Contributors: Adolfo Rodriguez Tsouroukdissian

0.9.3 (2015-05-05)

0.9.2 (2015-05-04)

0.9.1 (2014-11-03)

0.9.0 (2014-10-31)

  • Buildsystem and documentation fixes
  • Contributors: Adolfo Rodriguez Tsouroukdissian, shadowmanos

0.8.2 (2014-06-25)

0.8.1 (2014-06-24)

0.8.0 (2014-05-12)

  • Add developer documentation.
  • Build script fixes.
    • Add missing libraries to catkin_package call.
    • Gate tests with CATKIN_ENABLE_TESTING.
    • Add missing files to install target.
  • Fix possible memory corruption in tests.
  • Perform sanity checks on members, not parameters.
    • The result is the same, but this is more uniform with the rest of the code.
  • Enable joint reduction spec for 4-bar linkages. - As in the differential transmission, it\'s convenient to specify an additional mechanical reduction on the joint output. This is especially convenient for flipping the rotation direction of a joint (negative reduction value).

    • Update URDF loader.
    • Update documentation and tests.
  • Trivial, cosmetic fixes.

  • C++11 compatibility fixes.

  • Fix resource check for multi-dof transmisisons.

  • Efficiency fix.

    • cppcheck flagged a [passedByValue] warning. Using const references instead.
  • Fix compiler warning.

  • Fix license header in some files.

  • Test transmission handle duplication.

  • Use less pointers in transmission loader data. - Only RobotHW and RobotTransmission instances are pointers as they are owned by the robot hardware abstraction. The rest are plain members whose lifetime is bound to the loader struct.

  • Trivial test addition.

  • Remove unnecessary header dependencies.

  • Catkin fixes.

  • Fix bug when adding multiple transmissions. - std::vectors were being used to store raw joint data, and when new transmissions were added, push_back()s would (potentially) reallocate the vectors and invalidate already stored pointers in hardware_interfaces. We now use std::map.

    • Move plugin implementations to a separate library.
    • Export link libraries to the outside.
    • More complete tests.
  • Log message change.

  • Test greceful error-out with unsupported features.

  • Add four-bar-linkage transmission parser.

  • Add differential drive transmission parser.

  • Move common XML parsing code to TransmissionLoader Mechanical reductions, offsets and roles are used by many transmission types. The TransmissionLoader base class exposes convenience methods for parsing these elements.

  • Remove dead code.

  • Update loader test, better log statements.

  • First draft of transmission loading.

    • Only simple transmission type currently supported.
    • Can load forward map for act->jnt state and jnt->act pos,vel.eff commands.
    • Partial testing.
  • Add class for holding transmission interfaces.

    • Mirrors hardware_interface::RobotHW, but for transmissions.
  • Allow multiple hw interfaces, Fix #112, and test.

    • Allow to specify multiple hardware interfaces for joints and actuators.
    • Fix invalid xml_element tag. Contents are now stored as a string.
    • Unit test parser.
  • Remove rosbuild artifacts. Fix #154.

  • Contributors: Adolfo Rodriguez Tsouroukdissian

0.7.2 (2014-04-01)

0.7.1 (2014-03-31)

0.7.0 (2014-03-28)

0.6.0 (2014-02-05)

  • Add accessors to get transmission configuration.
  • Contributors: Adolfo Rodriguez Tsouroukdissian

0.5.8 (2013-10-11)

  • Renamed manifest.xml to prevent conflicts with rosdep
  • CMakeLists fix to fit with OpenEmbedded/Yocto meta-ros layer. Increase the compatibility of the ros_control code with meta-ros, an OpenEmbedded/Yocto layer that provides recipes for ROS packages disabling catking checking the variable CATKIN_ENABLE_TESTING.
  • Fix license header in some files.
  • Fix cppcheck uninit\'d variable warnings in tests.

0.5.7 (2013-07-30)

  • Fix for building ros_control
  • Updated CHANGELOG

0.5.6 (2013-07-29)

  • NOTE: ros_control now requires ros-*-cmake-modules for source-installations. Install via rosdep or manually
  • Removed the local FindTINYXML.cmake and switched to catkin\'s cmake_modules version
  • Installed missing transmission_interface_library

0.5.5 (2013-07-23)

  • transmission_interface: fixup finding tinyxml

0.5.4 (2013-07-23)

0.5.3 (2013-07-22)

  • Duplicated URDF\'s method of including tinyxml

0.5.2 (2013-07-22)

  • Trivial cleanup
  • tinyxml include dir fix

0.5.1 (2013-07-19)

  • Added new maintainer
  • Attempt to fix transmission interface tinyxml build error

0.5.0 (2013-07-16)

  • Minor Doxygen fixes. - Revert back to using file instead of brief, as the latter was documenting the namespace and not the file scope. - Escape angular brackets on XML tag documentation, as Doxygen was parsing them printing warnings. \@davetcoleman

  • Code consistency fixes.

    • Add missing header guard.
    • Make existing header guards comply with the NAMESPACE_CLASS_H convention.

    - Make Doxygen structural commands start with \'\' instead of \'@\', as most of the new ros_control code. - Remove trailing whitespaces. - Remove commented-out code used for debugging.

  • Build script fixes.

    • Add missing tinyxml dependency.
    • Drop unnecessary Boost dependency.
    • Add URDF parsing code to rosbuild.
  • Add meta tags to packages not specifying them.

    • Website, bugtracker, repository.
  • Documentation improvements.

    • More consistency between transmission and joint limits interfaces doc.

    - Make explicit that these interfaces are not meant to be used by controllers, but by the robot abstraction.

  • Transmission parsing

  • Merged hydro-devel into master

  • Fix doc typo. Refs #78.

  • Tests build.

  • Reneamed Github repo in documentation to ros-controls

  • Make specific transmission interfaces proper types.

    • Proper types instead of namespaces allow to provide less cryptic feedback.

    * Using typedefs: \"transmission_interface::TransmissionInterface<transmission_interface::ActuatorToJointPositionHandle>\" * Using a new type: \"transmission_interface::ActuatorToJointPositionInterface\" - Added error message printing to tests for manual inspection.

0.4.0 (2013-06-25)

  • Version 0.4.0
  • 1.0.1
  • Update Doxygen examples with recent API changes.
  • Update README.md Move examples out of readme and into ros_control\'s wiki.
  • Trivial doc/whitespace fix.
  • Merge branch \'master\' into hardware_interface_rework Conflicts: hardware_interface/CMakeLists.txt
  • Leverage ResourceManager in TransmissionInterface.

    - Leverage hardware_interface::internal::ResourceManager to implement TransmissionInterface more compactly and consistently. - Update unit tests.

  • adding install targets

  • adding missing manifests

  • removing comment

  • merging CMakeLists.txt files from rosbuild and catkin

  • adding hybrid-buildsystem makefiles

  • Harmonize how variables are quoted in logs.

    • Unify to using \'single quotes\'.
    • Fixes #42.
  • catkinizing, could still be cleaned up

  • Group transmission types in a Doxygen module.

  • Rename TransmissionException class. Rename TransmissionException to TransmissionInterfaceException. It is more verbose, but more consistent with the existing HardwareInterfaceException.

  • Add additional minimal example to mainpage doc. Existing example was complete, but quite long. It\'s better to start with a small and simple example.

  • Update README.md Add additional minimal example.

  • Update package wiki URL.

  • Update README.md

  • Update README.md

  • Trivial doc fix.

  • Add main page to documentation. It includes an overview of the transmission_interface package, pointers to the more relevant classes, and a commented example.

  • Make transmission interface more general. The previous API assumed that to map a variable like position, one only needed actuator and joint space position variables. Although this is often the case (eg. fully actuated/determined transmissions), this does not hold in general. Underactuated transmissions are a typical example of this. Now each map accepts full <position,velocity,effort> triplets for actuator and joint space variables, and uses only the ones it needs. Although the current API has gained in generality, it has lost some of the explicitness it had before. For instance, if only position variables are needed for a map, one still needs to pass the full triplet (velocity and effort variables can be empty). Finally, unit tests and documentation have been updated to reflect the changes.

  • Minor documentation building fixes.

    • Remove test folder from docs.
    • Add proper export element in manifest.
  • Update transmission_interface/README.md

  • Update transmission_interface/README.md

  • Add readme file.

  • Remove pure virtual method.

  • Use name commands in documentation.

  • Add pthread dependency to tests. After moving from Ubuntu 10.04 to 12.04 these dependencies need to be explicitly stated in my dev machine. This should be looked upon in greater detail, as such dependecies should be taken care of by rosbuild.

  • Remove dependency from manifest.

  • Add transmission interface class and test.

  • Add transmission accessors test.

  • Remove unnecessary virtual keywords.

  • Add credit statement in docs.

  • Add comprehensive doc to implemented transmissions.

    • More desriptive overview.

    - Images depicting each transmission type. Binary pngs are under version control instead of getting auto-generated in the Makefile as not all build environments may have the necessary svg->png filters. - Expressions governing transmissions in tabular form.

  • Basic documentation for implemented transmissions.

  • Document abstract Transmission class.

  • Add basic support for mechanical transmissions.

    • Base transmission class with abstract interface.

    - Specializations for three common transmission types: simple, differential and four-bar-linkage. - Unit tests with exercising preconditions, black-box and white-box tests.

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Recent questions tagged transmission_interface at Robotics Stack Exchange

Package Summary

Tags No category tags.
Version 0.9.7
License Modified BSD
Build type CATKIN
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/ros-controls/ros_control.git
VCS Type git
VCS Version indigo-devel
Last Updated 2018-05-31
Dev Status MAINTAINED
CI status Continuous Integration
Released RELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

Transmission Interface.

Additional Links

Maintainers

  • Adolfo Rodriguez Tsouroukdissian
  • Dave Coleman

Authors

  • Adolfo Rodriguez Tsouroukdissian

Transmission Interface

Overview

transmission_interface contains data structures for representing mechanical transmissions, and methods for propagating position, velocity and effort variables between actuator and joint spaces.

In the same spirit as the hardware_interface package, this package wraps existing raw data (eg. current actuator position, reference joint command, etc.) under a consistent interface. By not imposing a specific layout on the raw data, it becomes easier to support arbitrary hardware drivers to software control.

Structure

There are three main elements involved in setting up a transmission_interface: - The Transmission class defines an abstract interface for mapping position, velocity and effort variables between actuator and joint space. Derived classes implement specific transmission types, such as simple reducers, differentials and four-bar linkages. Note that a single transmission may couple the variables of multiple actuators and joints (eg. a differential couples two actuators to two joints).

  • The TransmissionHandle class associates a name to a Transmission instance and a set of raw data variables it operates on (specified through the ActuatorData and JointData structures). Derived classes implement specific maps, such as JointToActuatorEffortHandle or ActuatorToJointStateHandle.

  • The TransmissionInterface class manages a set of transmission handles of the same type. Note that although the handles are of the same type, the underlying transmissions can be heterogeneous eg. a single ActuatorToJointPositionInterface can be set up to transform position variables from actuator to joint space for an arm with a four-bar-linkage in the shoulder, a differential in the wrist, and simple reducers elsewhere.

Examples

Please refer to the transmission_interface wiki page.

CHANGELOG

Changelog for package transmission_interface

0.9.7 (2018-05-19)

  • Introduce shared_ptr typedefs
  • Contributors: Bence Magyar

0.9.6 (2018-04-16)

0.9.5 (2018-03-26)

0.9.4 (2016-02-12)

  • Clarify that hardwareInterface element is optional for actuators
  • Allow loading transmissions from a vector of TransmissionInfo instances.
  • Address -Wunused-parameter warnings
  • Contributors: Adolfo Rodriguez Tsouroukdissian, Dave Coleman

0.9.3 (2015-05-05)

0.9.2 (2015-05-04)

0.9.1 (2014-11-03)

0.9.0 (2014-10-31)

  • Buildsystem and documentation fixes
  • Contributors: Adolfo Rodriguez Tsouroukdissian, shadowmanos

0.8.2 (2014-06-25)

0.8.1 (2014-06-24)

0.8.0 (2014-05-12)

  • Add developer documentation.
  • Build script fixes.
    • Add missing libraries to catkin_package call.
    • Gate tests with CATKIN_ENABLE_TESTING.
    • Add missing files to install target.
  • Fix possible memory corruption in tests.
  • Perform sanity checks on members, not parameters.
    • The result is the same, but this is more uniform with the rest of the code.
  • Enable joint reduction spec for 4-bar linkages. - As in the differential transmission, it\'s convenient to specify an additional mechanical reduction on the joint output. This is especially convenient for flipping the rotation direction of a joint (negative reduction value).

    • Update URDF loader.
    • Update documentation and tests.
  • Trivial, cosmetic fixes.

  • C++11 compatibility fixes.

  • Fix resource check for multi-dof transmisisons.

  • Efficiency fix.

    • cppcheck flagged a [passedByValue] warning. Using const references instead.
  • Fix compiler warning.

  • Fix license header in some files.

  • Test transmission handle duplication.

  • Use less pointers in transmission loader data. - Only RobotHW and RobotTransmission instances are pointers as they are owned by the robot hardware abstraction. The rest are plain members whose lifetime is bound to the loader struct.

  • Trivial test addition.

  • Remove unnecessary header dependencies.

  • Catkin fixes.

  • Fix bug when adding multiple transmissions. - std::vectors were being used to store raw joint data, and when new transmissions were added, push_back()s would (potentially) reallocate the vectors and invalidate already stored pointers in hardware_interfaces. We now use std::map.

    • Move plugin implementations to a separate library.
    • Export link libraries to the outside.
    • More complete tests.
  • Log message change.

  • Test greceful error-out with unsupported features.

  • Add four-bar-linkage transmission parser.

  • Add differential drive transmission parser.

  • Move common XML parsing code to TransmissionLoader Mechanical reductions, offsets and roles are used by many transmission types. The TransmissionLoader base class exposes convenience methods for parsing these elements.

  • Remove dead code.

  • Update loader test, better log statements.

  • First draft of transmission loading.

    • Only simple transmission type currently supported.
    • Can load forward map for act->jnt state and jnt->act pos,vel.eff commands.
    • Partial testing.
  • Add class for holding transmission interfaces.

    • Mirrors hardware_interface::RobotHW, but for transmissions.
  • Allow multiple hw interfaces, Fix #112, and test.

    • Allow to specify multiple hardware interfaces for joints and actuators.
    • Fix invalid xml_element tag. Contents are now stored as a string.
    • Unit test parser.
  • Remove rosbuild artifacts. Fix #154.

  • Contributors: Adolfo Rodriguez Tsouroukdissian

0.7.2 (2014-04-01)

0.7.1 (2014-03-31)

0.7.0 (2014-03-28)

0.6.0 (2014-02-05)

  • Add accessors to get transmission configuration.
  • Contributors: Adolfo Rodriguez Tsouroukdissian

0.5.8 (2013-10-11)

  • Renamed manifest.xml to prevent conflicts with rosdep
  • CMakeLists fix to fit with OpenEmbedded/Yocto meta-ros layer. Increase the compatibility of the ros_control code with meta-ros, an OpenEmbedded/Yocto layer that provides recipes for ROS packages disabling catking checking the variable CATKIN_ENABLE_TESTING.
  • Fix license header in some files.
  • Fix cppcheck uninit\'d variable warnings in tests.

0.5.7 (2013-07-30)

  • Fix for building ros_control
  • Updated CHANGELOG

0.5.6 (2013-07-29)

  • NOTE: ros_control now requires ros-*-cmake-modules for source-installations. Install via rosdep or manually
  • Removed the local FindTINYXML.cmake and switched to catkin\'s cmake_modules version
  • Installed missing transmission_interface_library

0.5.5 (2013-07-23)

  • transmission_interface: fixup finding tinyxml

0.5.4 (2013-07-23)

0.5.3 (2013-07-22)

  • Duplicated URDF\'s method of including tinyxml

0.5.2 (2013-07-22)

  • Trivial cleanup
  • tinyxml include dir fix

0.5.1 (2013-07-19)

  • Added new maintainer
  • Attempt to fix transmission interface tinyxml build error

0.5.0 (2013-07-16)

  • Minor Doxygen fixes. - Revert back to using file instead of brief, as the latter was documenting the namespace and not the file scope. - Escape angular brackets on XML tag documentation, as Doxygen was parsing them printing warnings. \@davetcoleman

  • Code consistency fixes.

    • Add missing header guard.
    • Make existing header guards comply with the NAMESPACE_CLASS_H convention.

    - Make Doxygen structural commands start with \'\' instead of \'@\', as most of the new ros_control code. - Remove trailing whitespaces. - Remove commented-out code used for debugging.

  • Build script fixes.

    • Add missing tinyxml dependency.
    • Drop unnecessary Boost dependency.
    • Add URDF parsing code to rosbuild.
  • Add meta tags to packages not specifying them.

    • Website, bugtracker, repository.
  • Documentation improvements.

    • More consistency between transmission and joint limits interfaces doc.

    - Make explicit that these interfaces are not meant to be used by controllers, but by the robot abstraction.

  • Transmission parsing

  • Merged hydro-devel into master

  • Fix doc typo. Refs #78.

  • Tests build.

  • Reneamed Github repo in documentation to ros-controls

  • Make specific transmission interfaces proper types.

    • Proper types instead of namespaces allow to provide less cryptic feedback.

    * Using typedefs: \"transmission_interface::TransmissionInterface<transmission_interface::ActuatorToJointPositionHandle>\" * Using a new type: \"transmission_interface::ActuatorToJointPositionInterface\" - Added error message printing to tests for manual inspection.

0.4.0 (2013-06-25)

  • Version 0.4.0
  • 1.0.1
  • Update Doxygen examples with recent API changes.
  • Update README.md Move examples out of readme and into ros_control\'s wiki.
  • Trivial doc/whitespace fix.
  • Merge branch \'master\' into hardware_interface_rework Conflicts: hardware_interface/CMakeLists.txt
  • Leverage ResourceManager in TransmissionInterface.

    - Leverage hardware_interface::internal::ResourceManager to implement TransmissionInterface more compactly and consistently. - Update unit tests.

  • adding install targets

  • adding missing manifests

  • removing comment

  • merging CMakeLists.txt files from rosbuild and catkin

  • adding hybrid-buildsystem makefiles

  • Harmonize how variables are quoted in logs.

    • Unify to using \'single quotes\'.
    • Fixes #42.
  • catkinizing, could still be cleaned up

  • Group transmission types in a Doxygen module.

  • Rename TransmissionException class. Rename TransmissionException to TransmissionInterfaceException. It is more verbose, but more consistent with the existing HardwareInterfaceException.

  • Add additional minimal example to mainpage doc. Existing example was complete, but quite long. It\'s better to start with a small and simple example.

  • Update README.md Add additional minimal example.

  • Update package wiki URL.

  • Update README.md

  • Update README.md

  • Trivial doc fix.

  • Add main page to documentation. It includes an overview of the transmission_interface package, pointers to the more relevant classes, and a commented example.

  • Make transmission interface more general. The previous API assumed that to map a variable like position, one only needed actuator and joint space position variables. Although this is often the case (eg. fully actuated/determined transmissions), this does not hold in general. Underactuated transmissions are a typical example of this. Now each map accepts full <position,velocity,effort> triplets for actuator and joint space variables, and uses only the ones it needs. Although the current API has gained in generality, it has lost some of the explicitness it had before. For instance, if only position variables are needed for a map, one still needs to pass the full triplet (velocity and effort variables can be empty). Finally, unit tests and documentation have been updated to reflect the changes.

  • Minor documentation building fixes.

    • Remove test folder from docs.
    • Add proper export element in manifest.
  • Update transmission_interface/README.md

  • Update transmission_interface/README.md

  • Add readme file.

  • Remove pure virtual method.

  • Use name commands in documentation.

  • Add pthread dependency to tests. After moving from Ubuntu 10.04 to 12.04 these dependencies need to be explicitly stated in my dev machine. This should be looked upon in greater detail, as such dependecies should be taken care of by rosbuild.

  • Remove dependency from manifest.

  • Add transmission interface class and test.

  • Add transmission accessors test.

  • Remove unnecessary virtual keywords.

  • Add credit statement in docs.

  • Add comprehensive doc to implemented transmissions.

    • More desriptive overview.

    - Images depicting each transmission type. Binary pngs are under version control instead of getting auto-generated in the Makefile as not all build environments may have the necessary svg->png filters. - Expressions governing transmissions in tabular form.

  • Basic documentation for implemented transmissions.

  • Document abstract Transmission class.

  • Add basic support for mechanical transmissions.

    • Base transmission class with abstract interface.

    - Specializations for three common transmission types: simple, differential and four-bar-linkage. - Unit tests with exercising preconditions, black-box and white-box tests.

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Recent questions tagged transmission_interface at Robotics Stack Exchange

Package Summary

Tags No category tags.
Version 0.7.3
License Modified BSD
Build type CATKIN
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/ros-controls/ros_control.git
VCS Type git
VCS Version hydro-devel
Last Updated 2014-10-28
Dev Status MAINTAINED
CI status Continuous Integration
Released RELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

Transmission Interface.

Additional Links

Maintainers

  • Adolfo Rodriguez Tsouroukdissian
  • Dave Coleman

Authors

  • Adolfo Rodriguez Tsouroukdissian

Transmission Interface

Overview

transmission_interface contains data structures for representing mechanical transmissions, and methods for propagating position, velocity and effort variables between actuator and joint spaces.

In the same spirit as the hardware_interface package, this package wraps existing raw data (eg. current actuator positon, reference joint command, etc.) under a consistent interface. By not imposing a specific layout on the raw data, it becomes easier to support arbitrary hardware drivers to software control.

Structure

There are three main elements involved in setting up a transmission_interface: - The Transmission class defines an abstract interface for mapping position, velocity and effort variables between actuator and joint space. Derived classes implement specific transmission types, such as simple reducers, differentials and four-bar linkages. Note that a single transmission may couple the variables of multiple actuators and joints (eg. a differential couples two actuators to two joints).

  • The TransmissionHandle class associates a name to a Transmission instance and a set of raw data variables it operates on (specified through the ActuatorData and JointData structures). Derived classes implement specific maps, such as JointToActuatorEffortHandle or ActuatorToJointStateHandle.

  • The TransmissionInterface class manages a set of transmission handles of the same type. Note that although the handles are of the same type, the underlying transmissions can be heterogeneous eg. a single ActuatorToJointPositionInterface can be set up to transform position variables from actuator to joint space for an arm with a four-bar-linkage in the shoulder, a differential in the wrist, and simple reducers elsewhere.

TODO

  • Read transmission configuration from configuration files.

Examples

Please refer to the transmission_interface wiki page.

CHANGELOG

Changelog for package transmission_interface

0.7.3 (2014-10-28)

0.7.2 (2014-04-01)

0.7.1 (2014-03-31)

0.7.0 (2014-03-28)

0.6.0 (2014-02-05)

  • Add accessors to get transmission configuration.
  • Contributors: Adolfo Rodriguez Tsouroukdissian

0.5.8 (2013-10-11)

  • Renamed manifest.xml to prevent conflicts with rosdep
  • CMakeLists fix to fit with OpenEmbedded/Yocto meta-ros layer. Increase the compatibility of the ros_control code with meta-ros, an OpenEmbedded/Yocto layer that provides recipes for ROS packages disabling catking checking the variable CATKIN_ENABLE_TESTING.
  • Fix license header in some files.
  • Fix cppcheck uninit\'d variable warnings in tests.

0.5.7 (2013-07-30)

  • Fix for building ros_control
  • Updated CHANGELOG

0.5.6 (2013-07-29)

  • NOTE: ros_control now requires ros-*-cmake-modules for source-installations. Install via rosdep or manually
  • Removed the local FindTINYXML.cmake and switched to catkin\'s cmake_modules version
  • Installed missing transmission_interface_library

0.5.5 (2013-07-23)

  • transmission_interface: fixup finding tinyxml

0.5.4 (2013-07-23)

0.5.3 (2013-07-22)

  • Duplicated URDF\'s method of including tinyxml

0.5.2 (2013-07-22)

  • Trivial cleanup
  • tinyxml include dir fix

0.5.1 (2013-07-19)

  • Added new maintainer
  • Attempt to fix transmission interface tinyxml build error

0.5.0 (2013-07-16)

  • Minor Doxygen fixes. - Revert back to using file instead of brief, as the latter was documenting the namespace and not the file scope. - Escape angular brackets on XML tag documentation, as Doxygen was parsing them printing warnings. \@davetcoleman

  • Code consistency fixes.

    • Add missing header guard.
    • Make existing header guards comply with the NAMESPACE_CLASS_H convention.

    - Make Doxygen structural commands start with \'\' instead of \'@\', as most of the new ros_control code. - Remove trailing whitespaces. - Remove commented-out code used for debugging.

  • Build script fixes.

    • Add missing tinyxml dependency.
    • Drop unnecessary Boost dependency.
    • Add URDF parsing code to rosbuild.
  • Add meta tags to packages not specifying them.

    • Website, bugtracker, repository.
  • Documentation improvements.

    • More consistency between transmission and joint limits interfaces doc.

    - Make explicit that these interfaces are not meant to be used by controllers, but by the robot abstraction.

  • Transmission parsing

  • Merged hydro-devel into master

  • Fix doc typo. Refs #78.

  • Tests build.

  • Reneamed Github repo in documentation to ros-controls

  • Make specific transmission interfaces proper types.

    • Proper types instead of namespaces allow to provide less cryptic feedback.

    * Using typedefs: \"transmission_interface::TransmissionInterface<transmission_interface::ActuatorToJointPositionHandle>\" * Using a new type: \"transmission_interface::ActuatorToJointPositionInterface\" - Added error message printing to tests for manual inspection.

0.4.0 (2013-06-25)

  • Version 0.4.0
  • 1.0.1
  • Update Doxygen examples with recent API changes.
  • Update README.md Move examples out of readme and into ros_control\'s wiki.
  • Trivial doc/whitespace fix.
  • Merge branch \'master\' into hardware_interface_rework Conflicts: hardware_interface/CMakeLists.txt
  • Leverage ResourceManager in TransmissionInterface.

    - Leverage hardware_interface::internal::ResourceManager to implement TransmissionInterface more compactly and consistently. - Update unit tests.

  • adding install targets

  • adding missing manifests

  • removing comment

  • merging CMakeLists.txt files from rosbuild and catkin

  • adding hybrid-buildsystem makefiles

  • Harmonize how variables are quoted in logs.

    • Unify to using \'single quotes\'.
    • Fixes #42.
  • catkinizing, could still be cleaned up

  • Group transmission types in a Doxygen module.

  • Rename TransmissionException class. Rename TransmissionException to TransmissionInterfaceException. It is more verbose, but more consistent with the existing HardwareInterfaceException.

  • Add additional minimal example to mainpage doc. Existing example was complete, but quite long. It\'s better to start with a small and simple example.

  • Update README.md Add additional minimal example.

  • Update package wiki URL.

  • Update README.md

  • Update README.md

  • Trivial doc fix.

  • Add main page to documentation. It includes an overview of the transmission_interface package, pointers to the more relevant classes, and a commented example.

  • Make transmission interface more general. The previous API assumed that to map a variable like position, one only needed actuator and joint space position variables. Although this is often the case (eg. fully actuated/determined transmissions), this does not hold in general. Underactuated transmissions are a typical example of this. Now each map accepts full <position,velocity,effort> triplets for actuator and joint space variables, and uses only the ones it needs. Although the current API has gained in generality, it has lost some of the explicitness it had before. For instance, if only position variables are needed for a map, one still needs to pass the full triplet (velocity and effort variables can be empty). Finally, unit tests and documentation have been updated to reflect the changes.

  • Minor documentation building fixes.

    • Remove test folder from docs.
    • Add proper export element in manifest.
  • Update transmission_interface/README.md

  • Update transmission_interface/README.md

  • Add readme file.

  • Remove pure virtual method.

  • Use name commands in documentation.

  • Add pthread dependency to tests. After moving from Ubuntu 10.04 to 12.04 these dependencies need to be explicitly stated in my dev machine. This should be looked upon in greater detail, as such dependecies should be taken care of by rosbuild.

  • Remove dependency from manifest.

  • Add transmission interface class and test.

  • Add transmission accessors test.

  • Remove unnecessary virtual keywords.

  • Add credit statement in docs.

  • Add comprehensive doc to implemented transmissions.

    • More desriptive overview.

    - Images depicting each transmission type. Binary pngs are under version control instead of getting auto-generated in the Makefile as not all build environments may have the necessary svg->png filters. - Expressions governing transmissions in tabular form.

  • Basic documentation for implemented transmissions.

  • Document abstract Transmission class.

  • Add basic support for mechanical transmissions.

    • Base transmission class with abstract interface.

    - Specializations for three common transmission types: simple, differential and four-bar-linkage. - Unit tests with exercising preconditions, black-box and white-box tests.

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Plugins

No plugins found.

Recent questions tagged transmission_interface at Robotics Stack Exchange

Package Summary

Tags No category tags.
Version 0.13.5
License BSD
Build type CATKIN
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/ros-controls/ros_control.git
VCS Type git
VCS Version kinetic-devel
Last Updated 2020-04-17
Dev Status MAINTAINED
CI status Continuous Integration
Released RELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

Transmission Interface.

Additional Links

Maintainers

  • Bence Magyar
  • Enrique Fernandez
  • Mathias Lüdtke

Authors

  • Adolfo Rodriguez Tsouroukdissian

Transmission Interface

Overview

transmission_interface contains data structures for representing mechanical transmissions, and methods for propagating position, velocity and effort variables between actuator and joint spaces.

In the same spirit as the hardware_interface package, this package wraps existing raw data (eg. current actuator position, reference joint command, etc.) under a consistent interface. By not imposing a specific layout on the raw data, it becomes easier to support arbitrary hardware drivers to software control.

Structure

There are three main elements involved in setting up a transmission_interface: - The Transmission class defines an abstract interface for mapping position, velocity and effort variables between actuator and joint space. Derived classes implement specific transmission types, such as simple reducers, differentials and four-bar linkages. Note that a single transmission may couple the variables of multiple actuators and joints (eg. a differential couples two actuators to two joints).

  • The TransmissionHandle class associates a name to a Transmission instance and a set of raw data variables it operates on (specified through the ActuatorData and JointData structures). Derived classes implement specific maps, such as JointToActuatorEffortHandle or ActuatorToJointStateHandle.

  • The TransmissionInterface class manages a set of transmission handles of the same type. Note that although the handles are of the same type, the underlying transmissions can be heterogeneous eg. a single ActuatorToJointPositionInterface can be set up to transform position variables from actuator to joint space for an arm with a four-bar-linkage in the shoulder, a differential in the wrist, and simple reducers elsewhere.

Examples

Please refer to the transmission_interface wiki page.

CHANGELOG

Changelog for package transmission_interface

0.13.5 (2020-02-09)

0.13.4 (2020-01-12)

  • add minimum required pluginlib version
  • Contributors: Mikael Arguedas

0.13.3 (2018-04-26)

  • Introduce shared_ptr typedefs
  • Update maintainers
  • Fix catkin_lint errors and warnings
  • fix license string
  • Update transmission parser to parse the joint role
  • Contributors: Bence Magyar, Patrick Holthaus, jlack1987

0.13.2 (2018-04-16)

  • migrate to new class list macros header
  • migrate classloader headers
  • Contributors: Mathias L

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Recent questions tagged transmission_interface at Robotics Stack Exchange

Package Summary

Tags No category tags.
Version 0.18.4
License BSD
Build type CATKIN
Use RECOMMENDED

Repository Summary

Checkout URI https://github.com/ros-controls/ros_control.git
VCS Type git
VCS Version melodic-devel
Last Updated 2023-10-27
Dev Status MAINTAINED
CI status
Released RELEASED
Tags No category tags.
Contributing Help Wanted (0)
Good First Issues (0)
Pull Requests to Review (0)

Package Description

Transmission Interface.

Additional Links

Maintainers

  • Bence Magyar
  • Enrique Fernandez
  • Mathias Lüdtke

Authors

  • Adolfo Rodriguez Tsouroukdissian

Transmission Interface

Overview

transmission_interface contains data structures for representing mechanical transmissions, and methods for propagating position, velocity and effort variables between actuator and joint spaces.

In the same spirit as the hardware_interface package, this package wraps existing raw data (eg. current actuator position, reference joint command, etc.) under a consistent interface. By not imposing a specific layout on the raw data, it becomes easier to support arbitrary hardware drivers to software control.

Structure

There are three main elements involved in setting up a transmission_interface: - The Transmission class defines an abstract interface for mapping position, velocity and effort variables between actuator and joint space. Derived classes implement specific transmission types, such as simple reducers, differentials and four-bar linkages. Note that a single transmission may couple the variables of multiple actuators and joints (eg. a differential couples two actuators to two joints).

  • The TransmissionHandle class associates a name to a Transmission instance and a set of raw data variables it operates on (specified through the ActuatorData and JointData structures). Derived classes implement specific maps, such as JointToActuatorEffortHandle or ActuatorToJointStateHandle.

  • The TransmissionInterface class manages a set of transmission handles of the same type. Note that although the handles are of the same type, the underlying transmissions can be heterogeneous eg. a single ActuatorToJointPositionInterface can be set up to transform position variables from actuator to joint space for an arm with a four-bar-linkage in the shoulder, a differential in the wrist, and simple reducers elsewhere.

Examples

Please refer to the transmission_interface wiki page.

CHANGELOG

Changelog for package transmission_interface

0.18.4 (2021-06-16)

0.18.3 (2020-12-05)

  • Update docs in hardware_interface
  • Contributors: Franz Pucher

0.18.2 (2020-08-17)

0.18.1 (2020-05-09)

  • Add function specifiers and modernize constructors (#430)
    • Add override specifiers & default constructors
    • Delete ControllerBase copy & move ctors
    • Remove unnecessary default constructors
    • Modernize additional constructors
    • Revert ImuSensorHandle::Data::Data() = default
    • Remove unnecessary default overridden constructors
    • Remove semicolon after function body
  • Contributors: Matt Reynolds

0.18.0 (2020-04-16)

  • Add xmlns for URDF, remove xmlns:xacro (#436)
  • Fixed compile tests (#434)
  • Replace internal::is_permutation with std (#419)
  • Bump CMake version to avoid CMP0048 (#427)
  • Contributors: Alejandro Hern

Wiki Tutorials

This package does not provide any links to tutorials in it's rosindex metadata. You can check on the ROS Wiki Tutorials page for the package.

Launch files

No launch files found

Messages

No message files found.

Services

No service files found

Recent questions tagged transmission_interface at Robotics Stack Exchange