OGS
CreateBHE1PType.cpp
Go to the documentation of this file.
1// SPDX-FileCopyrightText: Copyright (c) OpenGeoSys Community (opengeosys.org)
2// SPDX-License-Identifier: BSD-3-Clause
3
4#include "BHE_1P.h"
6#include "CreateBHEUType.h"
8
9namespace ProcessLib
10{
11namespace HeatTransportBHE
12{
13namespace BHE
14{
15static std::tuple<BoreholeGeometry,
20 bool>
22 BaseLib::ConfigTree const& config,
23 std::map<std::string,
24 std::unique_ptr<MathLib::PiecewiseLinearInterpolation>> const&
25 curves)
26{
27 // if the BHE is using python boundary condition
28 auto const bhe_if_use_python_bc_conf =
30 config.getConfigParameter<bool>("use_bhe_pipe_network", false);
31
32 if (bhe_if_use_python_bc_conf)
33 {
34 DBUG("BHE 1P using python boundary conditions.");
35 }
36
37 auto const borehole_geometry =
39 createBoreholeGeometry(config.getConfigSubtree("borehole"));
40
42 auto const& pipes_config = config.getConfigSubtree("pipes");
44 Pipe const inlet_pipe = createPipe(pipes_config.getConfigSubtree("inlet"));
45
46 const auto pipe_longitudinal_dispersion_length =
48 pipes_config.getConfigParameter<double>(
49 "longitudinal_dispersion_length");
50 PipeConfiguration1PType const pipes{inlet_pipe,
51 pipe_longitudinal_dispersion_length};
52
54 auto const grout = createGroutParameters(config.getConfigSubtree("grout"));
55
56 auto const refrigerant =
58 createRefrigerantProperties(config.getConfigSubtree("refrigerant"));
59
60 auto const flowAndTemperatureControl = createFlowAndTemperatureControl(
62 config.getConfigSubtree("flow_and_temperature_control"),
63 curves,
64 refrigerant);
65
66 return {borehole_geometry, refrigerant, grout,
67 flowAndTemperatureControl, pipes, bhe_if_use_python_bc_conf};
68}
69
70template <typename T_BHE>
72 BaseLib::ConfigTree const& config,
73 std::map<std::string,
74 std::unique_ptr<MathLib::PiecewiseLinearInterpolation>> const&
75 curves)
76{
77 auto SinglePipeType = parseBHE1PTypeConfig(config, curves);
78 return {std::get<0>(SinglePipeType), std::get<1>(SinglePipeType),
79 std::get<2>(SinglePipeType), std::get<3>(SinglePipeType),
80 std::get<4>(SinglePipeType), std::get<5>(SinglePipeType)};
81}
82
84 BaseLib::ConfigTree const& config,
85 std::map<std::string,
86 std::unique_ptr<MathLib::PiecewiseLinearInterpolation>> const&
87 curves);
88} // namespace BHE
89} // namespace HeatTransportBHE
90} // namespace ProcessLib
void DBUG(fmt::format_string< Args... > fmt, Args &&... args)
Definition Logging.h:22
T getConfigParameter(std::string const &param) const
ConfigTree getConfigSubtree(std::string const &root) const
RefrigerantProperties createRefrigerantProperties(BaseLib::ConfigTree const &config)
static std::tuple< BoreholeGeometry, RefrigerantProperties, GroutParameters, FlowAndTemperatureControl, PipeConfiguration1PType, bool > parseBHE1PTypeConfig(BaseLib::ConfigTree const &config, std::map< std::string, std::unique_ptr< MathLib::PiecewiseLinearInterpolation > > const &curves)
std::variant< TemperatureCurveConstantFlow, TemperatureCurveFlowCurve, FixedPowerConstantFlow, FixedPowerFlowCurve, PowerCurveConstantFlow, PowerCurveFlowCurve, BuildingPowerCurveConstantFlow, BuildingPowerCurveHotWaterCurveActiveCoolingCurveFlowCurve, BuildingPowerCurveHotWaterCurvePassiveCoolingCurveFlowCurve, BuildingPowerCurveHotWaterCurveFlowCurve, BuildingPowerCurveActiveCoolingCurveFlowCurve, BuildingPowerCurvePassiveCoolingCurveFlowCurve, BuildingPowerCurveFlowCurve, ActiveCoolingCurveFlowCurve > FlowAndTemperatureControl
Pipe createPipe(BaseLib::ConfigTree const &config)
Definition Pipe.cpp:14
FlowAndTemperatureControl createFlowAndTemperatureControl(BaseLib::ConfigTree const &config, std::map< std::string, std::unique_ptr< MathLib::PiecewiseLinearInterpolation > > const &curves, RefrigerantProperties const &refrigerant)
T_BHE createBHE1PType(BaseLib::ConfigTree const &config, std::map< std::string, std::unique_ptr< MathLib::PiecewiseLinearInterpolation > > const &curves)
template BHE_1P createBHE1PType< BHE_1P >(BaseLib::ConfigTree const &config, std::map< std::string, std::unique_ptr< MathLib::PiecewiseLinearInterpolation > > const &curves)
GroutParameters createGroutParameters(BaseLib::ConfigTree const &config)
BoreholeGeometry createBoreholeGeometry(BaseLib::ConfigTree const &config)