Source code for tespy.components.basics.subsystem_interface

# -*- coding: utf-8

"""Module for class SubsystemInterface.


This file is part of project TESPy (github.com/oemof/tespy). It's copyrighted
by the contributors recorded in the version control history of the file,
available from its original location
tespy/components/basics/subsystem_interface.py

SPDX-License-Identifier: MIT
"""

from tespy.components.component import Component
from tespy.tools.data_containers import SimpleDataContainer as dc_simple


[docs] class SubsystemInterface(Component): r""" The subsystem interface does not change fluid properties. **Mandatory Equations** - :py:meth:`tespy.components.component.Component.fluid_func` - :py:meth:`tespy.components.component.Component.mass_flow_func` - :py:meth:`tespy.components.component.Component.pressure_equality_func` - :py:meth:`tespy.components.component.Component.enthalpy_equality_func` Inlets/Outlets - Specify number of inlets and outlets with :code:`num_inter`, predefined value: 1. Image .. image:: /api/_images/SubsystemInterface.svg :alt: flowsheet of the subsystem interface :align: center :class: only-light .. image:: /api/_images/SubsystemInterface_darkmode.svg :alt: flowsheet of the subsystem interface :align: center :class: only-dark Parameters ---------- label : str The label of the component. design : list List containing design parameters (stated as String). offdesign : list List containing offdesign parameters (stated as String). design_path : str Path to the components design case. local_offdesign : boolean Treat this component in offdesign mode in a design calculation. local_design : boolean Treat this component in design mode in an offdesign calculation. char_warnings : boolean Ignore warnings on default characteristics usage for this component. printout : boolean Include this component in the network's results printout. num_inter : float, dict Number of interfaces for subsystem. Note ---- This component passes all fluid properties and mass flow from its inlet to the outlet. Example ------- As connections can only connect a component with a different component, the subsystem interface is used to connect subsystems with the rest of your network. It is necessary to specify the number of interfaces of the subsystem interface, if you want any number other than 1. We will not go in depth of subsystem usage in this example. Please refer to :ref:`this section <tespy_subsystems_label>` for more information on building your own subsystems. >>> from tespy.components import Sink, Source, SubsystemInterface >>> from tespy.connections import Connection >>> from tespy.networks import Network >>> nw = Network() >>> nw.set_attr(p_unit='bar', T_unit='C', h_unit='kJ / kg', iterinfo=False) >>> so1 = Source('source 1') >>> si1 = Sink('sink 1') >>> so2 = Source('source 2') >>> si2 = Sink('sink 2') >>> IF = SubsystemInterface('subsystem interface', num_inter=2) >>> IF.component() 'subsystem interface' >>> len(IF.inlets()) 2 The interface does not change the fluid properties in any way. >>> inc1 = Connection(so1, 'out1', IF, 'in1') >>> outg1 = Connection(IF, 'out1', si1, 'in1') >>> inc2 = Connection(so2, 'out1', IF, 'in2') >>> outg2 = Connection(IF, 'out2', si2, 'in1') >>> nw.add_conns(inc1, outg1, inc2, outg2) >>> inc1.set_attr(fluid={'H2O': 1}, T=40, p=3, m=100) >>> inc2.set_attr(fluid={'N2': 1}, T=60, p=1, v=10) >>> nw.solve('design') >>> inc1.m.val_SI == outg1.m.val_SI True >>> inc2.m.val_SI == outg2.m.val_SI True >>> inc1.h.val_SI == outg1.h.val_SI True >>> inc2.h.val_SI == outg2.h.val_SI True """
[docs] @staticmethod def component(): return 'subsystem interface'
[docs] def get_mandatory_constraints(self): return { 'pressure_equality_constraints': { 'func': self.pressure_equality_func, 'deriv': self.pressure_equality_deriv, 'constant_deriv': True, 'latex': self.pressure_equality_func_doc, 'num_eq': self.num_i}, 'enthalpy_equality_constraints': { 'func': self.enthalpy_equality_func, 'deriv': self.enthalpy_equality_deriv, 'constant_deriv': True, 'latex': self.enthalpy_equality_func_doc, 'num_eq': self.num_i} }
[docs] @staticmethod def get_parameters(): return {'num_inter': dc_simple()}
[docs] def inlets(self): if self.num_inter.is_set: return ['in' + str(i + 1) for i in range(self.num_inter.val)] else: return ['in1']
[docs] def outlets(self): if self.num_inter.is_set: return ['out' + str(i + 1) for i in range(self.num_inter.val)] else: return ['out1']