Revision 2a483a61e70d3b8642c66229630a9171d8816b79 authored by Thomas Fischer on 09 July 2021, 15:15:16 UTC, committed by Dmitry Yu. Naumov on 05 October 2021, 20:56:20 UTC
1 parent e8af0af
CreateJacobianAssembler.cpp
/**
* \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
*
*/
#include "CreateJacobianAssembler.h"
#include "AnalyticalJacobianAssembler.h"
#include "BaseLib/Error.h"
#include "CentralDifferencesJacobianAssembler.h"
#include "CompareJacobiansJacobianAssembler.h"
namespace ProcessLib
{
std::unique_ptr<AbstractJacobianAssembler> createJacobianAssembler(
std::optional<BaseLib::ConfigTree> const& config)
{
if (!config)
{
return std::make_unique<AnalyticalJacobianAssembler>();
}
//! \ogs_file_param{prj__processes__process__jacobian_assembler__type}
auto const type = config->peekConfigParameter<std::string>("type");
if (type == "Analytical")
{
config->ignoreConfigParameter("type");
return std::make_unique<AnalyticalJacobianAssembler>();
}
if (type == "CentralDifferences")
{
return createCentralDifferencesJacobianAssembler(*config);
}
if (type == "CompareJacobians")
{
return createCompareJacobiansJacobianAssembler(*config);
}
OGS_FATAL("Unknown Jacobian assembler type: `{:s}'.", type);
}
} // namespace ProcessLib
Computing file changes ...