/*
* Copyright (c) 2009, Michael Lehn
*
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1) Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2) Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
* 3) Neither the name of the FLENS development group nor the names of
* its contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
* OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef FLENS_DEBUG_AUX_BASENAME_TCC
#define FLENS_DEBUG_AUX_BASENAME_TCC 1
#include <flens/matrixtypes/matrixtypes.h>
#include <flens/vectortypes/vectortypes.h>
namespace flens { namespace verbose {
template <typename T>
std::string
basename(const T &var)
{
if (typeId(var)==std::string("Scalar")) {
return "alpha";
}
if (typeId(var)==std::string("CxxScalar")) {
return "c";
}
return "??";
}
template <typename I>
std::string
basename(const Matrix<I> &)
{
return "M";
}
template <typename I>
std::string
basename(const GeneralMatrix<I> &)
{
return "GM";
}
template <typename FS>
std::string
basename(const GeMatrix<FS> &)
{
return "A";
}
template <typename FS>
std::string
basename(const HeMatrix<FS> &)
{
return "H";
}
template <typename FS>
std::string
basename(const SyMatrix<FS> &)
{
return "S";
}
template <typename FS>
std::string
basename(const TrMatrix<FS> &)
{
return "T";
}
template <typename I>
std::string
basename(const Vector<I> &)
{
return "v";
}
template <typename A>
std::string
basename(const DenseVector<A> &)
{
return "x";
}
} } // namespace verbose, namespace flens
#endif // FLENS_DEBUG_AUX_BASENAME_TCC
|