/* * Copyright (C) 2014 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 _GAZEBO_VECTOR3_STATS_HH_ #define _GAZEBO_VECTOR3_STATS_HH_ #include #include "gazebo/math/SignalStats.hh" #include "gazebo/math/Vector3.hh" #include "gazebo/util/system.hh" namespace gazebo { namespace math { /// \addtogroup gazebo_math /// \{ /// \brief Forward declare private data class. class Vector3StatsPrivate; /// \class Vector3Stats Vector3Stats.hh math/gzmath.hh /// \brief Collection of statistics for a Vector3 signal. class GZ_MATH_VISIBLE Vector3Stats { /// \brief Constructor public: Vector3Stats(); /// \brief Destructor public: ~Vector3Stats(); /// \brief Add a new sample to the statistical measures. /// \param[in] _data New signal data point. public: void InsertData(const Vector3 &_data); /// \brief Add a new type of statistic. /// \param[in] _name Short name of new statistic. /// Valid values include: /// "maxAbs" /// "mean" /// "rms" /// \return True if statistic was successfully added, /// false if name was not recognized or had already /// been inserted. public: bool InsertStatistic(const std::string &_name); /// \brief Add multiple statistics. /// \param[in] _names Comma-separated list of new statistics. /// For example, all statistics could be added with: /// "maxAbs,mean,rms" /// \return True if all statistics were successfully added, /// false if any names were not recognized or had already /// been inserted. public: bool InsertStatistics(const std::string &_names); /// \brief Forget all previous data. public: void Reset(); /// \brief Get statistics for x component of signal. /// \return Statistics for x component of signal. public: SignalStats X() const; /// \brief Get statistics for y component of signal. /// \return Statistics for y component of signal. public: SignalStats Y() const; /// \brief Get statistics for z component of signal. /// \return Statistics for z component of signal. public: SignalStats Z() const; /// \brief Get statistics for mag component of signal. /// \return Statistics for mag component of signal. public: SignalStats Mag() const; /// \brief Get mutable reference to statistics for x component of signal. /// \return Statistics for x component of signal. public: SignalStats &X(); /// \brief Get mutable reference to statistics for y component of signal. /// \return Statistics for y component of signal. public: SignalStats &Y(); /// \brief Get mutable reference to statistics for z component of signal. /// \return Statistics for z component of signal. public: SignalStats &Z(); /// \brief Get mutable reference to statistics for magnitude of signal. /// \return Statistics for magnitude of signal. public: SignalStats &Mag(); /// \brief Pointer to private data. protected: Vector3StatsPrivate *dataPtr; }; /// \} } } #endif