1
0
mirror of https://bitbucket.org/librepilot/librepilot.git synced 2025-01-09 20:46:07 +01:00
LibrePilot/ground/openpilotgcs/src/plugins/config/assertions.h

80 lines
2.0 KiB
C
Raw Normal View History

2013-04-05 22:46:56 +02:00
/*
* assertions.hpp
*
* Created on: Aug 6, 2009
* Author: Jonathan Brandmeyer
*
* This file is part of libeknav, imported into the OpenPilot
* project by Jonathan Brandmeyer.
*
* Libeknav is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, version 3.
*
* Libeknav is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
* You should have received a copy of the GNU General Public License
* along with libeknav. If not, see <http://www.gnu.org/licenses/>.
*
*/
#ifndef AHRS_ASSERTIONS_HPP
#define AHRS_ASSERTIONS_HPP
#include <Eigen/Core>
#include <cmath>
template<typename MatrixBase>
bool hasNaN(const MatrixBase & expr);
2013-04-05 22:46:56 +02:00
template<typename MatrixBase>
bool hasInf(const MatrixBase & expr);
2013-04-05 22:46:56 +02:00
template<typename MatrixBase>
bool perpendicular(const MatrixBase & expl, const MatrixBase & expr);
2013-04-05 22:46:56 +02:00
template<typename MatrixBase>
bool hasNaN(const MatrixBase & expr)
2013-04-05 22:46:56 +02:00
{
for (int j = 0; j != expr.cols(); ++j) {
for (int i = 0; i != expr.rows(); ++i) {
if (std::isnan(expr.coeff(i, j))) {
return true;
}
}
}
return false;
2013-04-05 22:46:56 +02:00
}
template<typename MatrixBase>
bool hasInf(const MatrixBase & expr)
2013-04-05 22:46:56 +02:00
{
for (int i = 0; i != expr.cols(); ++i) {
for (int j = 0; j != expr.rows(); ++j) {
if (std::isinf(expr.coeff(j, i))) {
return true;
}
}
}
return false;
2013-04-05 22:46:56 +02:00
}
template<typename MatrixBase>
bool isReal(const MatrixBase & exp)
2013-04-05 22:46:56 +02:00
{
return !hasNaN(exp) && !hasInf(exp);
2013-04-05 22:46:56 +02:00
}
template<typename MatrixBase>
bool perpendicular(const MatrixBase & lhs, const MatrixBase & rhs)
2013-04-05 22:46:56 +02:00
{
// A really weak check for "almost perpendicular". Use it for debugging
// purposes only.
return fabs(rhs.dot(lhs)) < 0.0001;
2013-04-05 22:46:56 +02:00
}
#endif /* ASSERTIONS_HPP_ */