36 double const Nu_inner_pipe,
37 double const Nu_annulus_pipe,
38 int const section_index = 0)
const;
45 static std::array<std::pair<std::size_t ,
int >, 2>
47 std::size_t
const top_node_id,
49 int const in_component_id);
52 std::array<std::pair<std::size_t ,
int >, 2>>
54 int const in_component_id,
55 int const out_component_id);
58 int const section_index = 0)
const;
61 Eigen::Vector3d
const& ,
62 int const section_index = 0)
const;
81 double const& R_gs,
double const& R_ff,
double const& R_fg)
const = 0;
std::vector< double > calcThermalResistances(double const Nu_inner_pipe, double const Nu_annulus_pipe, int const section_index=0) const
double updateFlowRateAndTemperature(double T_out, double current_time)
BHECommonCoaxial(BoreholeGeometry const &borehole, RefrigerantProperties const &refrigerant, GroutParameters const &grout, FlowAndTemperatureControl const &flowAndTemperatureControl, PipeConfigurationCoaxial const &pipes, bool const use_python_bcs)
void updateHeatTransferCoefficients(double const flow_rate)
static constexpr int number_of_unknowns
std::array< double, number_of_unknowns > pipeHeatCapacities() const
std::array< Eigen::Vector3d, number_of_unknowns > pipeAdvectionVectors(Eigen::Vector3d const &, int const section_index=0) const
virtual void assignVelocities(double inner_vel, double annulus_vel)=0
std::array< double, number_of_unknowns > pipeHeatConductions(int const section_index=0) const
double cross_section_area_annulus
static std::optional< std::array< std::pair< std::size_t, int >, 2 > > getBHEBottomDirichletBCNodesAndComponents(std::size_t const bottom_node_id, int const in_component_id, int const out_component_id)
double cross_section_area_inner_pipe
std::array< double, 2 > velocities() const
static constexpr std::pair< int, int > inflow_outflow_bc_component_ids[]
static std::array< std::pair< std::size_t, int >, 2 > getBHEInflowDirichletBCNodesAndComponents(std::size_t const top_node_id, std::size_t const, int const in_component_id)
virtual std::vector< double > getThermalResistances(double const &R_gs, double const &R_ff, double const &R_fg) const =0
PipeConfigurationCoaxial const _pipes
static constexpr int number_of_grout_zones
bool const use_python_bcs
RefrigerantProperties const refrigerant
std::vector< double > _flow_velocities
GroutParameters const grout
BHECommon(BoreholeGeometry const &borehole_geometry_, RefrigerantProperties const &refrigerant_, GroutParameters const &grout_, FlowAndTemperatureControl const &flowAndTemperatureControl_, bool const use_python_bcs_)
FlowAndTemperatureControl const flowAndTemperatureControl
std::variant< InflowTemperature, Power, BuildingPower, BuildingPowerHotWaterActiveCooling, BuildingPowerHotWaterPassiveCooling, BuildingPowerHotWater, BuildingPowerActiveCooling, BuildingPowerPassiveCooling, ActiveCooling > FlowAndTemperatureControl