2014-02-06 18:52:13 +00:00
|
|
|
/*
|
|
|
|
* Global.hpp, part of LatAnalyze 3
|
|
|
|
*
|
|
|
|
* Copyright (C) 2013 - 2014 Antonin Portelli
|
|
|
|
*
|
|
|
|
* LatAnalyze 3 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, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* LatAnalyze 3 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 LatAnalyze 3. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef Latan_Global_hpp_
|
|
|
|
#define Latan_Global_hpp_
|
2013-05-21 18:02:42 +01:00
|
|
|
|
2014-03-12 18:41:20 +00:00
|
|
|
// supress warning for the osbolete use of 'register' keyword in Eigen
|
|
|
|
#pragma GCC diagnostic ignored "-Wdeprecated-register"
|
|
|
|
|
2014-02-26 18:36:29 +00:00
|
|
|
#include <latan/Eigen/Dense>
|
2014-03-03 14:21:37 +00:00
|
|
|
#include <memory>
|
2013-05-21 18:02:42 +01:00
|
|
|
#include <string>
|
2014-02-26 18:36:29 +00:00
|
|
|
#include <sstream>
|
2014-03-03 13:04:53 +00:00
|
|
|
#include <type_traits>
|
2014-02-26 18:36:29 +00:00
|
|
|
#include <cstdlib>
|
2013-05-21 18:02:42 +01:00
|
|
|
|
2014-02-06 18:52:13 +00:00
|
|
|
#define BEGIN_NAMESPACE namespace Latan {
|
|
|
|
#define END_NAMESPACE }
|
2013-05-21 18:02:42 +01:00
|
|
|
|
2014-02-17 18:50:03 +00:00
|
|
|
// macro utilities
|
|
|
|
#define unique_arg(...) __VA_ARGS__
|
2014-03-12 18:41:36 +00:00
|
|
|
#define DEBUG_VAR(x) std::cout << #x << "= " << x << std::endl
|
|
|
|
#define DEBUG_MAT(m) std::cout << #m << "=\n" << m << std::endl
|
2014-02-17 18:50:03 +00:00
|
|
|
|
2013-05-21 18:02:42 +01:00
|
|
|
// attribute to switch off unused warnings with gcc
|
2014-03-03 13:04:53 +00:00
|
|
|
#ifndef __GNUC__
|
|
|
|
#define __unused
|
2013-05-21 18:02:42 +01:00
|
|
|
#endif
|
|
|
|
|
2014-02-12 18:33:33 +00:00
|
|
|
// max length for paths
|
2014-02-17 18:50:03 +00:00
|
|
|
#define MAX_PATH_LENGTH 512u
|
|
|
|
|
|
|
|
// copy/assignement from Eigen expression
|
|
|
|
#define EIGEN_EXPR_CTOR(ctorName, Class, Base, EigenBase) \
|
|
|
|
template <typename Derived>\
|
2014-02-20 20:20:37 +00:00
|
|
|
ctorName(const Eigen::EigenBase<Derived> &m): Base(m) {}\
|
2014-02-17 18:50:03 +00:00
|
|
|
template<typename Derived>\
|
|
|
|
Class & operator=(const Eigen::EigenBase<Derived> &m)\
|
|
|
|
{\
|
|
|
|
this->Base::operator=(m);\
|
|
|
|
return *this;\
|
|
|
|
}
|
2014-02-12 18:33:33 +00:00
|
|
|
|
2014-02-06 18:52:13 +00:00
|
|
|
BEGIN_NAMESPACE
|
2013-05-21 18:02:42 +01:00
|
|
|
|
2014-02-26 18:36:29 +00:00
|
|
|
// Eigen type aliases //////////////////////////////////////////////////////////
|
|
|
|
const int dynamic = -1;
|
|
|
|
|
|
|
|
// array types
|
|
|
|
template <typename T, int nRow = dynamic, int nCol = dynamic>
|
|
|
|
using Array = Eigen::Array<T, nRow, nCol>;
|
|
|
|
|
|
|
|
// matrix types
|
|
|
|
template <typename T, int nRow = dynamic, int nCol = dynamic>
|
|
|
|
using Mat = Eigen::Matrix<T, nRow, nCol>;
|
|
|
|
|
|
|
|
typedef Mat<int> IMat;
|
|
|
|
typedef Mat<double> DMatBase;
|
|
|
|
|
|
|
|
// vector types
|
|
|
|
template <typename T>
|
|
|
|
using Vec = Mat<T, dynamic, 1>;
|
|
|
|
|
|
|
|
typedef Vec<int> IVec;
|
|
|
|
typedef Vec<double> DVec;
|
|
|
|
|
2014-03-04 17:16:36 +00:00
|
|
|
#define FOR_VEC(vec, i) for (Latan::Index i = 0; i < (vec).size(); ++i)
|
|
|
|
#define FOR_ARRAY(ar, i) FOR_VEC(ar, i)
|
2014-03-03 12:41:48 +00:00
|
|
|
|
2014-02-26 18:36:29 +00:00
|
|
|
// block types
|
|
|
|
template <typename Derived>
|
|
|
|
using Block = Eigen::Block<Derived>;
|
|
|
|
template <typename Derived>
|
|
|
|
using ConstBlock = const Eigen::Block<const Derived>;
|
|
|
|
|
|
|
|
template <typename Derived>
|
|
|
|
using Row = typename Derived::RowXpr;
|
|
|
|
template <typename Derived>
|
|
|
|
using ConstRow = typename Derived::ConstRowXpr;
|
|
|
|
|
|
|
|
template <typename Derived>
|
|
|
|
using Col = typename Derived::ColXpr;
|
|
|
|
template <typename Derived>
|
|
|
|
using ConstCol = typename Derived::ConstColXpr;
|
|
|
|
|
|
|
|
// map type
|
|
|
|
template <typename Derived>
|
|
|
|
using Map = Eigen::Map<Derived>;
|
|
|
|
template <typename Derived>
|
|
|
|
using ConstMap = Eigen::Map<const Derived>;
|
|
|
|
|
|
|
|
// Index type //////////////////////////////////////////////////////////////////
|
|
|
|
typedef DMatBase::Index Index;
|
|
|
|
|
2014-03-03 13:04:53 +00:00
|
|
|
// Type utilities //////////////////////////////////////////////////////////////
|
|
|
|
// pointer type test
|
|
|
|
template <typename Derived, typename Base>
|
|
|
|
inline bool isDerivedFrom(const Base *pt)
|
|
|
|
{
|
|
|
|
return (dynamic_cast<const Derived *>(pt) != nullptr);
|
|
|
|
}
|
|
|
|
|
|
|
|
// static logical or
|
|
|
|
template <bool... b>
|
|
|
|
struct static_or;
|
|
|
|
|
|
|
|
template <bool... tail>
|
|
|
|
struct static_or<true, tail...> : static_or<tail...> {};
|
|
|
|
|
|
|
|
template <bool... tail>
|
|
|
|
struct static_or<false, tail...> : std::false_type {};
|
|
|
|
|
|
|
|
template <>
|
|
|
|
struct static_or<> : std::true_type {};
|
|
|
|
|
2014-02-26 18:36:29 +00:00
|
|
|
// Environment /////////////////////////////////////////////////////////////////
|
2013-05-21 18:02:42 +01:00
|
|
|
namespace Env
|
|
|
|
{
|
2014-01-22 15:57:47 +00:00
|
|
|
extern const std::string fullName;
|
|
|
|
extern const std::string name;
|
|
|
|
extern const std::string version;
|
2014-02-20 22:54:11 +00:00
|
|
|
extern const std::string msgPrefix;
|
2013-05-21 18:02:42 +01:00
|
|
|
}
|
|
|
|
|
2014-03-03 13:04:53 +00:00
|
|
|
// String conversions //////////////////////////////////////////////////////////
|
2013-05-21 18:02:42 +01:00
|
|
|
template <typename T>
|
2014-02-18 18:09:41 +00:00
|
|
|
inline T strTo(const std::string &str)
|
2013-05-21 18:02:42 +01:00
|
|
|
{
|
|
|
|
T buf;
|
|
|
|
std::istringstream stream(str);
|
|
|
|
|
|
|
|
stream >> buf;
|
|
|
|
|
|
|
|
return buf;
|
|
|
|
}
|
|
|
|
|
2014-03-03 12:41:48 +00:00
|
|
|
// optimized specializations
|
2014-02-12 18:36:36 +00:00
|
|
|
template <>
|
2014-02-18 18:09:41 +00:00
|
|
|
inline float strTo<float>(const std::string &str)
|
|
|
|
{
|
|
|
|
return strtof(str.c_str(), (char **)NULL);
|
|
|
|
}
|
2014-02-12 18:36:36 +00:00
|
|
|
template <>
|
2014-02-18 18:09:41 +00:00
|
|
|
inline double strTo<double>(const std::string &str)
|
|
|
|
{
|
|
|
|
return strtod(str.c_str(), (char **)NULL);
|
|
|
|
}
|
2014-02-12 18:36:36 +00:00
|
|
|
template <>
|
2014-02-18 18:09:41 +00:00
|
|
|
inline int strTo<int>(const std::string &str)
|
|
|
|
{
|
|
|
|
return (int)(strtol(str.c_str(), (char **)NULL, 10));
|
|
|
|
}
|
2014-02-12 18:36:36 +00:00
|
|
|
|
2013-05-21 18:02:42 +01:00
|
|
|
template <typename T>
|
2014-02-18 18:09:41 +00:00
|
|
|
inline std::string strFrom(const T x)
|
2013-05-21 18:02:42 +01:00
|
|
|
{
|
|
|
|
std::ostringstream stream;
|
|
|
|
|
|
|
|
stream << x;
|
|
|
|
|
|
|
|
return stream.str();
|
|
|
|
}
|
|
|
|
|
2014-02-06 18:52:13 +00:00
|
|
|
END_NAMESPACE
|
2013-05-21 18:02:42 +01:00
|
|
|
|
|
|
|
#include <latan/Exceptions.hpp>
|
|
|
|
|
2014-02-06 18:52:13 +00:00
|
|
|
#endif // Latan_Global_hpp_
|