Skip to content
Snippets Groups Projects
gmpfield.hh 1.37 KiB
Newer Older
  • Learn to ignore specific revisions
  • // -*- tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 2 -*-
    // vi: set et ts=4 sw=2 sts=2:
    #ifndef DUNE_GMPFIELD_HH
    #define DUNE_GMPFIELD_HH
    
    
    Oliver Sander's avatar
    Oliver Sander committed
    /** \file
     * \brief Wrapper for the GNU multiprecision (GMP) library
     */
    
    
    
    #if HAVE_GMP
    
    #include <gmpxx.h>
    
    namespace Dune
    {
    
      template< unsigned int precision >
      class GMPField
        : public mpf_class
      {
        typedef mpf_class Base;
    
      public:
    
        /** default constructor, initialize to zero */
    
        /** \brief initialize from a string
    
            \note this is the only reliable way to initialize with higher precision values
    
         */
        GMPField ( const char* str )
          : Base(str,precision)
        {}
    
        /** \brief initialize from a string
    
            \note this is the only reliable way to initialize with higher precision values
    
         */
        GMPField ( const std::string& str )
          : Base(str,precision)
        {}
    
        /** \brief initialize from a compatible scalar type
         */
        template< class T,
                  typename EnableIf = typename std::enable_if<
                    std::is_convertible<T, mpf_class>::value>::type
                  >
    
        GMPField ( const T &v )
          : Base( v,precision )
        {}
    
    
        // type conversion operators
        operator double () const
        {
          return this->get_d();
        }
    
    
    #endif // #ifndef DUNE_GMPFIELD_HH