https://gitlab.opengeosys.org/ogs/ogs.git
Raw File
Tip revision: 61c54e3073ade13fb1c115a4fb62da06c9438261 authored by montoyav on 12 October 2021, 11:40:58 UTC
Merge branch 'patch-1' into 'master'
Tip revision: 61c54e3
Reaction.h
/**
 * \file
 * \copyright
 * Copyright (c) 2012-2021, OpenGeoSys Community (http://www.opengeosys.org)
 *            Distributed under a Modified BSD License.
 *              See accompanying file LICENSE.txt or
 *              http://www.opengeosys.org/project/license
 */

#pragma once

#include <memory>

namespace BaseLib { class ConfigTree; }

namespace Adsorption
{

class Reaction
{
public:
    static std::unique_ptr<Reaction> newInstance(
        BaseLib::ConfigTree const& conf);

    virtual double getEnthalpy(const double p_Ads, const double T_Ads, const double M_Ads) const = 0;
    virtual double getReactionRate(const double p_Ads, const double T_Ads,
                                     const double M_Ads, const double loading) const = 0;

    // TODO get rid of
    virtual double getEquilibriumLoading(const double /*unused*/,
                                         const double /*unused*/,
                                         const double /*unused*/) const
    {
        return -1.0;
    }

    virtual ~Reaction() = default;
};

}  // namespace Adsorption
back to top