21 std::vector<std::unique_ptr<ParameterLib::ParameterBase>>& parameters,
23 std::unique_ptr<MathLib::PiecewiseLinearInterpolation>>
const&
25 std::vector<MeshLib::Node*>
const& bhe_nodes)
28 auto const bhe_if_use_python_bc_conf =
31 DBUG(
"If using python boundary condition : {:s}",
32 (bhe_if_use_python_bc_conf) ?
"true" :
"false");
34 auto const borehole_geometry =
42 Pipe const outer_pipe =
createPipe(pipes_config.getConfigSubtree(
"outer"));
43 Pipe const inner_pipe =
45 createPipe(pipes_config.getConfigSubtree(
"inner"));
46 const auto pipe_longitudinal_dispersion_length =
48 pipes_config.getConfigParameter<
double>(
49 "longitudinal_dispersion_length");
51 pipe_longitudinal_dispersion_length};
53 double const annulus_diameter =
55 if (annulus_diameter <= 0)
58 "Invalid coaxial pipe geometry: outer pipe inner diameter ({:g}) "
59 "must be greater than inner pipe outside diameter ({:g}).",
60 pipes.outer_pipe.diameter, pipes.inner_pipe.outsideDiameter());
63 double const outer_pipe_outside_diameter =
64 pipes.outer_pipe.outsideDiameter();
65 for (
int section_index = 0;
66 section_index < borehole_geometry.sections.getNumberOfSections();
70 borehole_geometry.sections.diameterAtSection(section_index);
71 if (D <= outer_pipe_outside_diameter)
74 "Invalid coaxial geometry at section {:d}: borehole diameter "
75 "{:g} must be greater than outer pipe outside diameter {:g}.",
76 section_index, D, outer_pipe_outside_diameter);
83 auto const refrigerant =
94 return {borehole_geometry, refrigerant, grout,
95 flowAndTemperatureControl, pipes, bhe_if_use_python_bc_conf};
98template <
typename T_BHE>
101 std::vector<std::unique_ptr<ParameterLib::ParameterBase>>& parameters,
102 std::map<std::string,
103 std::unique_ptr<MathLib::PiecewiseLinearInterpolation>>
const&
105 std::vector<MeshLib::Node*>
const& bhe_nodes)
108 return {std::get<0>(coaxial), std::get<1>(coaxial), std::get<2>(coaxial),
109 std::get<3>(coaxial), std::get<4>(coaxial), std::get<5>(coaxial)};
114 std::vector<std::unique_ptr<ParameterLib::ParameterBase>>& parameters,
115 std::map<std::string,
116 std::unique_ptr<MathLib::PiecewiseLinearInterpolation>>
const&
118 std::vector<MeshLib::Node*>
const& bhe_nodes);
122 std::vector<std::unique_ptr<ParameterLib::ParameterBase>>& parameters,
123 std::map<std::string,
124 std::unique_ptr<MathLib::PiecewiseLinearInterpolation>>
const&
126 std::vector<MeshLib::Node*>
const& bhe_nodes);
void DBUG(fmt::format_string< Args... > fmt, Args &&... args)
T getConfigParameter(std::string const ¶m) const
ConfigTree getConfigSubtree(std::string const &root) const
RefrigerantProperties createRefrigerantProperties(BaseLib::ConfigTree const &config)
BoreholeGeometry createBoreholeGeometry(BaseLib::ConfigTree const &config, std::vector< std::unique_ptr< ParameterLib::ParameterBase > > ¶meters, std::vector< MeshLib::Node * > const &bhe_nodes)
T_BHE createBHECoaxial(BaseLib::ConfigTree const &config, std::vector< std::unique_ptr< ParameterLib::ParameterBase > > ¶meters, std::map< std::string, std::unique_ptr< MathLib::PiecewiseLinearInterpolation > > const &curves, std::vector< MeshLib::Node * > const &bhe_nodes)
Pipe createPipe(BaseLib::ConfigTree const &config)
double coaxialPipesAnnulusDiameter(Pipe const &inner_pipe, Pipe const &outer_pipe)
FlowAndTemperatureControl createFlowAndTemperatureControl(BaseLib::ConfigTree const &config, std::vector< std::unique_ptr< ParameterLib::ParameterBase > > ¶meters, std::map< std::string, std::unique_ptr< MathLib::PiecewiseLinearInterpolation > > const &curves, RefrigerantProperties const &refrigerant)
template BHE_CXA createBHECoaxial< BHE_CXA >(BaseLib::ConfigTree const &config, std::vector< std::unique_ptr< ParameterLib::ParameterBase > > ¶meters, std::map< std::string, std::unique_ptr< MathLib::PiecewiseLinearInterpolation > > const &curves, std::vector< MeshLib::Node * > const &bhe_nodes)
std::variant< InflowTemperature, Power, BuildingPower, BuildingPowerHotWaterActiveCooling, BuildingPowerHotWaterPassiveCooling, BuildingPowerHotWater, BuildingPowerActiveCooling, BuildingPowerPassiveCooling, ActiveCooling > FlowAndTemperatureControl
GroutParameters createGroutParameters(BaseLib::ConfigTree const &config)
static std::tuple< BoreholeGeometry, RefrigerantProperties, GroutParameters, FlowAndTemperatureControl, PipeConfigurationCoaxial, bool > parseBHECoaxialConfig(BaseLib::ConfigTree const &config, std::vector< std::unique_ptr< ParameterLib::ParameterBase > > ¶meters, std::map< std::string, std::unique_ptr< MathLib::PiecewiseLinearInterpolation > > const &curves, std::vector< MeshLib::Node * > const &bhe_nodes)
template BHE_CXC createBHECoaxial< BHE_CXC >(BaseLib::ConfigTree const &config, std::vector< std::unique_ptr< ParameterLib::ParameterBase > > ¶meters, std::map< std::string, std::unique_ptr< MathLib::PiecewiseLinearInterpolation > > const &curves, std::vector< MeshLib::Node * > const &bhe_nodes)