Files
opm-common/opm/material/Constants.hpp
Andreas Lauser 99a61df00a re-add the vim and emacs modelines
conceptually, this may not be the purest conceivable solution, but it
is the most practical one.
2015-06-18 13:47:26 +02:00

94 lines
2.3 KiB
C++

// -*- mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*-
// vi: set et ts=4 sw=4 sts=4:
/*
Copyright (C) 2011-2013 by Andreas Lauser
Copyright (C) 2011 by Bernd Flemisch
This file is part of the Open Porous Media project (OPM).
OPM 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 2 of the License, or
(at your option) any later version.
OPM 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 OPM. If not, see <http://www.gnu.org/licenses/>.
*/
/*!
* \file
* \copydoc Opm::Constants
*/
#ifndef OPM_CONSTANTS_HPP
#define OPM_CONSTANTS_HPP
#include <cmath>
namespace Opm
{
/*!
* \brief A central place for various physical constants occuring in
* some equations.
*/
template<class Scalar>
class Constants
{ public:
/*!
* \brief The ideal gas constant [J/(mol K)]
*/
static const Scalar R;
/*!
* \brief The Avogadro constant [1/mol]
*/
static const Scalar Na;
/*!
* \brief The Boltzmann constant [J/K]
*/
static const Scalar kb;
/*!
* \brief Speed of light in vacuum [m/s]
*/
static const Scalar c;
/*!
* \brief Newtonian constant of gravitation [m^3/(kg s^2)]
*/
static const Scalar G;
/*!
* \brief Planck constant [J s]
*/
static const Scalar h;
/*!
* \brief Reduced Planck constant [J s]
*/
static const Scalar hRed;
};
template<class Scalar>
const Scalar Constants<Scalar>::R = 8.314472;
template <class Scalar>
const Scalar Constants<Scalar>::Na = 6.02214179e23;
template <class Scalar>
const Scalar Constants<Scalar>::kb = R/Na;
template <class Scalar>
const Scalar Constants<Scalar>::c = 299792458.0;
template <class Scalar>
const Scalar Constants<Scalar>::G = 6.67428e-11;
template <class Scalar>
const Scalar Constants<Scalar>::h = 6.62606896e-34;
template <class Scalar>
const Scalar Constants<Scalar>::hRed = h / (2 * M_PI);
} // namespace Opm
#endif