24 std::vector<std::unique_ptr<ParameterLib::ParameterBase>>& parameters,
26 std::unique_ptr<MathLib::PiecewiseLinearInterpolation>>
const&
28 std::vector<MeshLib::Node*>
const& bhe_nodes)
31 auto const bhe_if_use_python_bc_conf =
34 DBUG(
"If using python boundary condition : {:s}",
35 (bhe_if_use_python_bc_conf) ?
"true" :
"false");
37 auto const borehole_geometry =
45 Pipe const inlet_pipe =
createPipe(pipes_config.getConfigSubtree(
"inlet"));
46 Pipe const outlet_pipe =
48 createPipe(pipes_config.getConfigSubtree(
"outlet"));
49 const auto pipe_distance =
51 pipes_config.getConfigParameter<
double>(
"distance_between_pipes");
52 const auto pipe_longitudinal_dispersion_length =
54 pipes_config.getConfigParameter<
double>(
55 "longitudinal_dispersion_length");
57 pipe_longitudinal_dispersion_length};
59 if (pipe_distance <= 0)
62 "distance_between_pipes must be positive for U-type BHEs, got "
68 std::max(pipes.inlet.outsideDiameter(), pipes.outlet.outsideDiameter());
69 if (pipe_distance < d0)
72 "distance_between_pipes ({:g}) must be >= pipe outside diameter "
73 "({:g}) for valid U-type thermal resistance formulas.",
77 for (
int section_index = 0;
78 section_index < borehole_geometry.sections.getNumberOfSections();
82 borehole_geometry.sections.diameterAtSection(section_index);
86 "Invalid U-type geometry at section {:d}: borehole diameter "
87 "{:g} must be greater than 2*pipe outside diameter {:g}.",
88 section_index, D, 2.0 * d0);
91 double const acosh_argument =
92 (D * D + d0 * d0 - pipe_distance * pipe_distance) / (2.0 * D * d0);
93 if (!std::isfinite(acosh_argument) || acosh_argument < 1.0)
96 "Invalid U-type geometry at section {:d}: acosh argument "
97 "for grout resistance is {:g}, must be >= 1. "
98 "(D={:g}, d0={:g}, distance_between_pipes={:g})",
99 section_index, acosh_argument, D, d0, pipe_distance);
106 auto const refrigerant =
117 return {borehole_geometry, refrigerant, grout,
118 flowAndTemperatureControl, pipes, bhe_if_use_python_bc_conf};
121template <
typename T_BHE>
124 std::vector<std::unique_ptr<ParameterLib::ParameterBase>>& parameters,
125 std::map<std::string,
126 std::unique_ptr<MathLib::PiecewiseLinearInterpolation>>
const&
128 std::vector<MeshLib::Node*>
const& bhe_nodes)
131 return {std::get<0>(UType), std::get<1>(UType), std::get<2>(UType),
132 std::get<3>(UType), std::get<4>(UType), std::get<5>(UType)};
137 std::vector<std::unique_ptr<ParameterLib::ParameterBase>>& parameters,
138 std::map<std::string,
139 std::unique_ptr<MathLib::PiecewiseLinearInterpolation>>
const&
141 std::vector<MeshLib::Node*>
const& bhe_nodes);
145 std::vector<std::unique_ptr<ParameterLib::ParameterBase>>& parameters,
146 std::map<std::string,
147 std::unique_ptr<MathLib::PiecewiseLinearInterpolation>>
const&
149 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)
Pipe createPipe(BaseLib::ConfigTree const &config)
T_BHE createBHEUType(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)
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_2U createBHEUType< BHE_2U >(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)
static std::tuple< BoreholeGeometry, RefrigerantProperties, GroutParameters, FlowAndTemperatureControl, PipeConfigurationUType, bool > parseBHEUTypeConfig(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_1U createBHEUType< BHE_1U >(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)