"""Connector objects."""
from circadapt.components import Component
[docs]
class Connector(Component):
"""Connector objects."""
parameters = [
'prox',
'dist',
]
signals = [
'q',
]
[docs]
def add(self, name, prox, dist):
super().add(name)
self._model.set_component(name+'.prox', prox)
self._model.set_component(name+'.dist', dist)
[docs]
class ArtVen(Connector):
"""
ArtVen connects two nodes with a passive, flow-dependent resistance.
Parameters
==========
k [-]: double
Exponent in pressure-flow relationship
p0 [Pa]: double
Reference pressure at q=q0
q0 [m :sup:`3`/s]: double
Reference flow at p=p0
Signals
==========
q [m :sup:`3`/s]: float
Flow over ArtVen
"""
parameters = [
'p0',
'q0',
'k',
'prox',
'dist',
]
signals = [
'q',
]
[docs]
class ArtVen2022(Connector):
"""ArtVen2022 object."""
parameters = [
'p0',
'q0AV',
'kAV',
'prox',
'dist',
]
signals = [
'q',
]
[docs]
class Diode(Connector):
"""
Ideal diode describing flow between nodes at positive pressure gradient.
Parameters
==========
R: double
Resistance
Signals
==========
q: float
Flow through the valve
"""
parameters = [
'R',
'prox',
'dist',
]
signals = [
'q',
]
[docs]
class Resistance(Connector):
"""
Simple Resistance describing flow between nodes.
Parameters
==========
R: double
Resistance
Signals
==========
q: float
Flow through the valve
"""
parameters = [
'R',
'prox',
'dist',
]
signals = [
'q',
]
[docs]
class Valve2022(Connector):
r"""
Module to simulate valvular flow.
This model simulates flow :math:`q` based on the pressure gradient between
the proximal and distal node :math:`\Delta p` by solving the ordinary
differential equation:
.. math::
\frac{dq}{dt} = \frac{A_{eff}}{l_{eff}} \Bigg[\frac{q\cdot|q|}{2}
(\frac{1}{A_{prox}^2}-\frac{1}{A_{eff}^2})+\frac{\Delta p}{\rho}\Bigg]
Parameters
----------
adaptation_Aopen_fac [-]: double
Factor used in adaptation to determine Aopen based on vessel flow.
A_open [m\ :sup:`2`]: float
Opening area
A_leak [m\ :sup:`2`]: float
Leaking valve area
l [m]: float
Length of valve
rho_b [kg/m\ :sup:`3`]: float
Blood density
papillary_muscles [-]: bool
If true, papilary muscle implementation is activated
soft_closure [-]: bool
If true, a soft closure is activated
Signals
-------
q [m\ :sup:`3`/s]: float
Flow through the valve
dq_dt [m\ :sup:`3`/s\ :sup:`2`]: float
Time derivative of the flow q
"""
parameters = [
'adaptation_A_open_fac',
'A_open',
'A_leak',
'l',
'L_fac_prox',
'L_fac_dist',
'L_fac_valve',
'rho_b',
'papillary_muscles',
'papillary_muscles_slope',
'papillary_muscles_min',
'papillary_muscles_A_open_fac',
'soft_closure',
'fraction_A_open_Aext',
'prox',
'dist',
]
signals = [
'q',
'dq_dt',
'L',
'A',
'Dp',
'DpB',
'diast',
]
[docs]
class Valve(Connector):
r"""
Module to simulate valvular flow.
This model simulates flow :math:`q` based on the pressure gradient between
the proximal and distal node :math:`\Delta p` by solving the ordinary
differential equation:
.. math::
\frac{dq}{dt} = \frac{A_{eff}}{l_{eff}} \Bigg[\frac{q\cdot|q|}{2}
(\frac{1}{A_{prox}^2}-\frac{1}{A_{eff}^2})+\frac{\Delta p}{\rho}\Bigg]
Parameters
----------
adaptation_Aopen_fac [-]: double
Factor used in adaptation to determine Aopen based on vessel flow.
A_open [m\ :sup:`2`]: float
Opening area
A_leak [m\ :sup:`2`]: float
Leaking valve area
l [m]: float
Length of valve
rho_b [kg/m\ :sup:`3`]: float
Blood density
papillary_muscles [-]: bool
If true, papilary muscle implementation is activated
soft_closure [-]: bool
If true, a soft closure is activated
Signals
-------
q [m\ :sup:`3`/s]: float
Flow through the valve
dq_dt [m\ :sup:`3`/s\ :sup:`2`]: float
Time derivative of the flow q
"""
parameters = [
'adaptation_A_open_fac',
'A_open',
'A_leak',
'l',
'L_fac_prox',
'L_fac_dist',
'L_fac_valve',
'rho_b',
'papillary_muscles',
'papillary_muscles_slope',
'papillary_muscles_min',
'papillary_muscles_A_open_fac',
'soft_closure',
'fraction_A_open_Aext',
'prox',
'dist',
]
signals = [
'q',
'dq_dt',
'L',
'A',
'Dp',
'DpB',
'diast',
]
[docs]
class Valve2024(Valve2022):
pass