/* * Sample.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_Sample_hpp_ #define Latan_Sample_hpp_ #include #include #include #include BEGIN_NAMESPACE const int central = -1; /****************************************************************************** * Sample class * ******************************************************************************/ template class Sample: public StatArray, public IoObject { private: typedef StatArray Base; public: // constructors Sample(void); Sample(const unsigned int nSample); template Sample(const Eigen::EigenBase &s); // destructor virtual ~Sample(void); // operators T& operator[](const int s); // IO type virtual IoType getType(void) const; private: // index of the first element to take into account for statistics virtual unsigned int getOffset(void) const; }; template <> IoObject::IoType Sample::getType(void) const; // specialization aliases typedef Sample DMatSample; /****************************************************************************** * Sample class template implementation * ******************************************************************************/ // constructor ///////////////////////////////////////////////////////////////// template Sample::Sample(void) : Base(static_cast(getOffset())) {} template Sample::Sample(const unsigned int nSample) : Base(static_cast(nSample + getOffset())) {} template template Sample::Sample(const Eigen::EigenBase &s) : Base(s) {} // destructor ////////////////////////////////////////////////////////////////// template Sample::~Sample(void) {} // operators /////////////////////////////////////////////////////////////////// template T& Sample::operator[](const int s) { if (s >= 0) { return Base::operator[](s + 1); } else { return Base::operator[](0); } } // IO type ///////////////////////////////////////////////////////////////////// template IoObject::IoType Sample::getType(void) const { return IoType::noType; } // statistics ////////////////////////////////////////////////////////////////// template unsigned int Sample::getOffset(void) const { return 1u; } END_NAMESPACE #endif // Latan_Sample_hpp_