-
Notifications
You must be signed in to change notification settings - Fork 98
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Nick Lamprianidis <[email protected]> Co-authored-by: Steve Peters <[email protected]>
- Loading branch information
Showing
14 changed files
with
453 additions
and
8 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -15,6 +15,7 @@ set (headers | |
Error.hh | ||
Exception.hh | ||
Filesystem.hh | ||
ForceTorque.hh | ||
Frame.hh | ||
Geometry.hh | ||
Gui.hh | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,139 @@ | ||
/* | ||
* Copyright 2020 Open Source Robotics Foundation | ||
* | ||
* Licensed under the Apache License, Version 2.0 (the "License"); | ||
* you may not use this file except in compliance with the License. | ||
* You may obtain a copy of the License at | ||
* | ||
* http://www.apache.org/licenses/LICENSE-2.0 | ||
* | ||
* Unless required by applicable law or agreed to in writing, software | ||
* distributed under the License is distributed on an "AS IS" BASIS, | ||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | ||
* See the License for the specific language governing permissions and | ||
* limitations under the License. | ||
* | ||
*/ | ||
#ifndef SDF_FORCE_TORQUE_HH_ | ||
#define SDF_FORCE_TORQUE_HH_ | ||
|
||
#include <string> | ||
#include <sdf/Error.hh> | ||
#include <sdf/Element.hh> | ||
#include <sdf/Noise.hh> | ||
#include <sdf/sdf_config.h> | ||
|
||
namespace sdf | ||
{ | ||
// Inline bracket to help doxygen filtering. | ||
inline namespace SDF_VERSION_NAMESPACE { | ||
// Forward declare private data class. | ||
class ForceTorquePrivate; | ||
|
||
/// \enum ForceTorqueFrame | ||
/// \brief The set of supported frames of the wrench values. | ||
enum class ForceTorqueFrame : uint8_t | ||
{ | ||
/// \brief Invalid frame | ||
INVALID = 0, | ||
|
||
/// \brief Wrench expressed in the orientation of the parent link frame | ||
PARENT = 1, | ||
|
||
/// \brief Wrench expressed in the orientation of the child link frame | ||
CHILD = 2, | ||
|
||
/// \brief Wrench expressed in the orientation of the joint sensor frame | ||
SENSOR = 3 | ||
}; | ||
|
||
/// \enum ForceTorqueMeasureDirection | ||
/// \brief The set of measure directions of the wrench values. | ||
enum class ForceTorqueMeasureDirection : uint8_t | ||
{ | ||
/// \brief Invalid frame | ||
INVALID = 0, | ||
|
||
/// \brief Wrench measured as applied by the parent link on the child link | ||
PARENT_TO_CHILD = 1, | ||
|
||
/// \brief Wrench measured as applied by the child link on the parent link | ||
CHILD_TO_PARENT = 2 | ||
}; | ||
|
||
/// \brief ForceTorque contains information about a force torque sensor. | ||
/// This sensor can be attached to a joint. | ||
class SDFORMAT_VISIBLE ForceTorque | ||
{ | ||
/// \brief Default constructor | ||
public: ForceTorque(); | ||
|
||
/// \brief Copy constructor | ||
/// \param[in] _ft The force torque sensor to copy. | ||
public: ForceTorque(const ForceTorque &_ft); | ||
|
||
/// \brief Move constructor | ||
/// \param[in] _ft The force torque sensor to move. | ||
public: ForceTorque(ForceTorque &&_ft) noexcept; | ||
|
||
/// \brief Destructor | ||
public: ~ForceTorque(); | ||
|
||
/// \brief Assignment operator. | ||
/// \param[in] _ft The force torque sensor to set values from. | ||
/// \return *this | ||
public: ForceTorque &operator=(const ForceTorque &_ft); | ||
|
||
/// \brief Move assignment operator. | ||
/// \param[in] _ft The force torque sensor to set values from. | ||
/// \return *this | ||
public: ForceTorque &operator=(ForceTorque &&_ft) noexcept; | ||
|
||
/// \brief Load the force torque sensor based on an element pointer. This is | ||
/// *not* the usual entry point. Typical usage of the SDF DOM is through the | ||
/// Root object. | ||
/// \param[in] _sdf The SDF Element pointer | ||
/// \return Errors, which is a vector of Error objects. Each Error includes | ||
/// an error code and message. An empty vector indicates no error. | ||
public: Errors Load(ElementPtr _sdf); | ||
|
||
/// \brief Get a pointer to the SDF element that was used during load. | ||
/// \return SDF element pointer. The value will be nullptr if Load has | ||
/// not been called. | ||
public: sdf::ElementPtr Element() const; | ||
|
||
/// \brief Get the frame in which the wrench values are reported. | ||
/// \return The frame of the wrench values. | ||
public: ForceTorqueFrame Frame() const; | ||
|
||
/// \brief Set the frame in which the wrench values are reported. | ||
/// \param[in] _frame The frame of the wrench values. | ||
public: void SetFrame(ForceTorqueFrame _frame) const; | ||
|
||
/// \brief Get the measure direction of the wrench values. | ||
/// \return The measure direction of the wrench values. | ||
public: ForceTorqueMeasureDirection MeasureDirection() const; | ||
|
||
/// \brief Set the measure direction of the wrench values. | ||
/// \param[in] _direction The measure direction of the wrench values. | ||
public: void SetMeasureDirection( | ||
ForceTorqueMeasureDirection _direction) const; | ||
|
||
/// \brief Return true if both force torque objects contain the same values. | ||
/// \param[_in] _ft Force torque value to compare. | ||
/// \returen True if 'this' == _ft. | ||
public: bool operator==(const ForceTorque &_ft) const; | ||
|
||
/// \brief Return true this force torque object does not contain the same | ||
/// values as the passed-in parameter. | ||
/// \param[_in] _ft Force torque value to compare. | ||
/// \returen True if 'this' != _ft. | ||
public: bool operator!=(const ForceTorque &_ft) const; | ||
|
||
/// \brief Private data pointer. | ||
private: ForceTorquePrivate *dataPtr; | ||
}; | ||
} | ||
} | ||
|
||
#endif |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.