SELiquidCompartment.h
1/* Distributed under the Apache License, Version 2.0.
2 See accompanying NOTICE file for details.*/
3
4#pragma once
5#include "cdm/compartment/fluid/SEFluidCompartment.h"
6#include "cdm/compartment/fluid/SELiquidCompartmentLink.h"
7#include "cdm/compartment/substances/SELiquidSubstanceQuantity.h"
8#include "cdm/substance/SESubstanceTransport.h"
10
11class CDM_DECL SELiquidCompartment : public SEFluidCompartment<SELiquidCompartmentLink, SELiquidTransportVertex, SELiquidTransportSubstance, SELiquidSubstanceQuantity>
12{
13 friend class PBCompartment;//friend the serialization class
14 friend class SETissueCompartment;
17protected:
18 SELiquidCompartment(const std::string& name, Logger* logger);
19public:
20 virtual ~SELiquidCompartment();
21
22 virtual void Clear();
23
24 virtual const SEScalar* GetScalar(const std::string& name);
25
26 virtual void StateChange();
27
28 virtual void Balance(BalanceLiquidBy e);// Balance all substances based on a specific property
29
30 virtual bool HasPerfusion() const;
31 virtual SEScalarVolumePerTime& GetPerfusion();
32 virtual double GetPerfusion(const VolumePerTimeUnit& unit) const;
33
34 virtual bool HasPH() const;
35 virtual SEScalar& GetPH();
36 virtual double GetPH() const;
37
38 virtual bool HasWaterVolumeFraction() const;
39 virtual SEScalar0To1& GetWaterVolumeFraction();
40 virtual double GetWaterVolumeFraction() const;
41
42 virtual void AddChild(SELiquidCompartment& child);
43 virtual const std::vector<SELiquidCompartment*>& GetChildren() { return m_Children; }
44 virtual const std::vector<SELiquidCompartment*>& GetLeaves() { return m_Leaves; }
45
46protected:
47 virtual SELiquidSubstanceQuantity& CreateSubstanceQuantity(SESubstance& substance, bool zeroOut=true);
48
52
53 std::vector<SELiquidCompartment*> m_Children;
54 std::vector<SELiquidCompartment*> m_Leaves;
55};
Definition: Logger.h:71
Definition: PBCompartment.h:28
virtual void StateChange()=0
Definition: SECompartmentManager.h:25
Definition: SEFluidCompartment.h:19
virtual void Clear()
Definition: SEFluidCompartment.cpp:32
virtual const SEScalar * GetScalar(const std::string &name)
Definition: SEFluidCompartment.cpp:51
Definition: SELiquidBlackBox.h:11
Definition: SELiquidCompartment.h:12
virtual const std::vector< SELiquidCompartment * > & GetLeaves()
Definition: SELiquidCompartment.h:44
std::vector< SELiquidCompartment * > m_Children
Definition: SELiquidCompartment.h:53
std::vector< SELiquidCompartment * > m_Leaves
Definition: SELiquidCompartment.h:54
SEScalar0To1 * m_WaterVolumeFraction
Definition: SELiquidCompartment.h:51
SEScalarVolumePerTime * m_Perfusion
Definition: SELiquidCompartment.h:49
SEScalar * m_pH
Definition: SELiquidCompartment.h:50
virtual const std::vector< SELiquidCompartment * > & GetChildren()
Definition: SELiquidCompartment.h:43
Definition: SELiquidSubstanceQuantity.h:12
std::vector< SELiquidSubstanceQuantity * > m_Children
Definition: SELiquidSubstanceQuantity.h:81
virtual void AddChild(SELiquidSubstanceQuantity &subQ)
Definition: SELiquidSubstanceQuantity.cpp:579
friend class SELiquidCompartment
Definition: SELiquidSubstanceQuantity.h:14
virtual void Balance(BalanceLiquidBy e)
Definition: SELiquidSubstanceQuantity.cpp:154
Definition: SEScalar0To1.h:8
Definition: SEScalar.h:19
Definition: SEScalarVolumePerTime.h:31
Definition: SESubstance.h:15
Definition: SETissueCompartment.h:9
Definition: SEScalarVolumePerTime.h:8

Distributed under the Apache License, Version 2.0.

See accompanying NOTICE file for details.