SEMechanicalVentilation.h
1 /**************************************************************************************
2 Copyright 2015 Applied Research Associates, Inc.
3 Licensed under the Apache License, Version 2.0 (the "License"); you may not use
4 this file except in compliance with the License. You may obtain a copy of the License
5 at:
6 http://www.apache.org/licenses/LICENSE-2.0
7 Unless required by applicable law or agreed to in writing, software distributed under
8 the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
9 CONDITIONS OF ANY KIND, either express or implied. See the License for the
10 specific language governing permissions and limitations under the License.
11 **************************************************************************************/
12 
13 #pragma once
14 #include "biogears/cdm/properties/SEScalarPressure.h"
15 #include <biogears/cdm/patient/actions/SEPatientAction.h>
16 #include <biogears/schema/cdm/PatientActions.hxx>
17 
18 namespace biogears {
19 class Serializer;
20 class SESubstance;
21 class SESubstanceFraction;
22 class SEMechanicalVentilationConfiguration;
23 class SEScalarVolumePerTime;
24 class VolumePerTimeUnit;
25 class SEScalarPressure;
26 class PressureUnit;
27 
28 class BIOGEARS_API SEMechanicalVentilation : public SEPatientAction {
29 protected:
30 public:
32  virtual ~SEMechanicalVentilation() override;
33 
34  static constexpr const char* TypeTag() { return "SEMechanicalVentilation"; };
35  const char* classname() const override { return TypeTag(); }
36 
37  virtual void Clear() override;
38 
39  virtual bool IsValid() const override;
40  virtual bool IsActive() const override;
41 
42  virtual bool Load(const CDM::MechanicalVentilationData& in, const SESubstanceManager& subMgr);
43  virtual CDM::MechanicalVentilationData* Unload() const override;
44 
45 protected:
46  virtual void Unload(CDM::MechanicalVentilationData& data) const;
47 
48 public:
49  virtual CDM::enumOnOff::value GetState() const;
50  virtual void SetState(CDM::enumOnOff::value name);
51  virtual bool HasState() const;
52  virtual void InvalidateState();
53 
54  virtual bool HasFlow() const;
55  virtual SEScalarVolumePerTime& GetFlow();
56  virtual double GetFlow(const VolumePerTimeUnit& unit) const;
57 
58  virtual bool HasPressure() const;
59  virtual SEScalarPressure& GetPressure();
60  virtual double GetPressure(const PressureUnit& unit) const;
61 
62  bool HasGasFraction() const;
63  bool HasGasFraction(const SESubstance& substance) const;
64  const std::vector<SESubstanceFraction*>& GetGasFractions();
65  const std::vector<const SESubstanceFraction*>& GetGasFractions() const;
66  SESubstanceFraction& GetGasFraction(SESubstance& substance);
67  const SESubstanceFraction* GetGasFraction(const SESubstance& substance) const;
68  void RemoveGasFraction(const SESubstance& substance);
69  void RemoveGasFractions();
70 
71  virtual void ToString(std::ostream& str) const override;
72 
73 protected:
74  std::stringstream m_ss;
75 
79 
80  std::vector<SESubstanceFraction*> m_GasFractions;
81  std::vector<const SESubstanceFraction*> m_cGasFractions;
82 };
83 }
std::vector< const SESubstanceFraction * > m_cGasFractions
Definition: SEMechanicalVentilation.h:81
CDM::enumOnOff::value m_State
Definition: SEMechanicalVentilation.h:76
Definition: SEPatientAction.h:18
Definition: SEScalarVolumePerTime.h:18
Definition: SEMechanicalVentilation.h:28
const char * classname() const override
Definition: SEMechanicalVentilation.h:35
Definition: SEScalarPressure.h:37
Definition: SESubstance.h:49
Class corresponding to the MechanicalVentilationData schema type.
Definition: PatientActions.hxx:7399
Definition: SEScalarVolumePerTime.h:40
Definition: SESubstanceFraction.h:25
std::stringstream m_ss
Definition: SEMechanicalVentilation.h:74
Definition: SEScalarPressure.h:18
value
Underlying enum type.
Definition: Properties.hxx:2070
Definition: SESubstanceManager.h:23
Definition: SEElectricalCircuit.h:18
static constexpr const char * TypeTag()
Definition: SEMechanicalVentilation.h:34
SEScalarVolumePerTime * m_Flow
Definition: SEMechanicalVentilation.h:77
SEScalarPressure * m_Pressure
Definition: SEMechanicalVentilation.h:78
std::vector< SESubstanceFraction * > m_GasFractions
Definition: SEMechanicalVentilation.h:80