/* * 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 . */ #ifndef Latan_Global_hpp_ #define Latan_Global_hpp_ #include #include #include #include #include #include #define BEGIN_NAMESPACE namespace Latan { #define END_NAMESPACE } // macro utilities #define unique_arg(...) __VA_ARGS__ // attribute to switch off unused warnings with gcc #ifndef __GNUC__ #define __unused #endif // max length for paths #define MAX_PATH_LENGTH 512u // copy/assignement from Eigen expression #define EIGEN_EXPR_CTOR(ctorName, Class, Base, EigenBase) \ template \ ctorName(const Eigen::EigenBase &m): Base(m) {}\ template\ Class & operator=(const Eigen::EigenBase &m)\ {\ this->Base::operator=(m);\ return *this;\ } BEGIN_NAMESPACE // Eigen type aliases ////////////////////////////////////////////////////////// const int dynamic = -1; // array types template using Array = Eigen::Array; // matrix types template using Mat = Eigen::Matrix; typedef Mat IMat; typedef Mat DMatBase; // vector types template using Vec = Mat; typedef Vec IVec; typedef Vec DVec; #define FOR_VEC(vec, i) \ for (Latan::Index i = 0; i < (vec).size(); ++i) // block types template using Block = Eigen::Block; template using ConstBlock = const Eigen::Block; template using Row = typename Derived::RowXpr; template using ConstRow = typename Derived::ConstRowXpr; template using Col = typename Derived::ColXpr; template using ConstCol = typename Derived::ConstColXpr; // map type template using Map = Eigen::Map; template using ConstMap = Eigen::Map; // Index type ////////////////////////////////////////////////////////////////// typedef DMatBase::Index Index; // Type utilities ////////////////////////////////////////////////////////////// // pointer type test template inline bool isDerivedFrom(const Base *pt) { return (dynamic_cast(pt) != nullptr); } // static logical or template struct static_or; template struct static_or : static_or {}; template struct static_or : std::false_type {}; template <> struct static_or<> : std::true_type {}; // Environment ///////////////////////////////////////////////////////////////// namespace Env { extern const std::string fullName; extern const std::string name; extern const std::string version; extern const std::string msgPrefix; } // String conversions ////////////////////////////////////////////////////////// template inline T strTo(const std::string &str) { T buf; std::istringstream stream(str); stream >> buf; return buf; } // optimized specializations template <> inline float strTo(const std::string &str) { return strtof(str.c_str(), (char **)NULL); } template <> inline double strTo(const std::string &str) { return strtod(str.c_str(), (char **)NULL); } template <> inline int strTo(const std::string &str) { return (int)(strtol(str.c_str(), (char **)NULL, 10)); } template inline std::string strFrom(const T x) { std::ostringstream stream; stream << x; return stream.str(); } END_NAMESPACE #include #endif // Latan_Global_hpp_