SEPulmonaryFunctionTest.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/patient/assessments/SEPatientAssessment.h>
15 #include <biogears/schema/cdm/PatientAssessments.hxx>
16 
17 namespace biogears {
18 class SEPatient;
19 class SERespiratorySystem;
20 class SEScalarVolume;
21 class SEScalarVolumePerTime;
22 class SEFunctionVolumeVsTime;
23 
24 class BIOGEARS_API SEPulmonaryFunctionTest : public SEPatientAssessment {
25 public:
27  virtual ~SEPulmonaryFunctionTest();
28 
29  static constexpr const char* TypeTag() { return "SEPulmonaryFunctionTest"; };
30  const char* classname() const override { return TypeTag(); }
31 
32  virtual void Reset();
33  virtual void Clear();
34 
35  virtual bool Load(const CDM::PulmonaryFunctionTestData& in);
36  virtual CDM::PulmonaryFunctionTestData* Unload();
37 
38 protected:
39  virtual void Unload(CDM::PulmonaryFunctionTestData& data);
40 
41 public:
42  virtual int GetNumberOfPlotPoints() { return m_NumberOfPlotPoints; }
43  virtual void SetNumberOfPlotPoints(int n) { m_NumberOfPlotPoints = n; }
44 
45  virtual bool HasExpiratoryReserveVolume();
46  virtual SEScalarVolume& GetExpiratoryReserveVolume();
47 
48  virtual bool HasForcedVitalCapacity();
49  virtual SEScalarVolume& GetForcedVitalCapacity();
50 
51  virtual bool HasForcedExpiratoryVolume();
52  virtual SEScalarVolume& GetForcedExpiratoryVolume();
53 
54  virtual bool HasForcedExpiratoryFlow();
55  virtual SEScalarVolumePerTime& GetForcedExpiratoryFlow();
56 
57  virtual bool HasFunctionalResidualCapacity();
58  virtual SEScalarVolume& GetFunctionalResidualCapacity();
59 
60  virtual bool HasInspiratoryCapacity();
61  virtual SEScalarVolume& GetInspiratoryCapacity();
62 
63  virtual bool HasInspiratoryReserveVolume();
64  virtual SEScalarVolume& GetInspiratoryReserveVolume();
65 
66  virtual bool HasMaximumVoluntaryVentilation();
67  virtual SEScalarVolume& GetMaximumVoluntaryVentilation();
68 
69  virtual bool HasPeakExpiratoryFlow();
70  virtual SEScalarVolumePerTime& GetPeakExpiratoryFlow();
71 
72  virtual bool HasResidualVolume();
73  virtual SEScalarVolume& GetResidualVolume();
74 
75  virtual bool HasSlowVitalCapacity();
76  virtual SEScalarVolume& GetSlowVitalCapacity();
77 
78  virtual bool HasTotalLungCapacity();
79  virtual SEScalarVolume& GetTotalLungCapacity();
80 
81  virtual bool HasVitalCapacity();
82  virtual SEScalarVolume& GetVitalCapacity();
83 
84  virtual bool HasLungVolumePlot();
85  virtual SEFunctionVolumeVsTime& GetLungVolumePlot();
86 
87 protected:
102 
104 };
105 }
SEScalarVolumePerTime * m_ForcedExpiratoryFlow
Definition: SEPulmonaryFunctionTest.h:92
virtual int GetNumberOfPlotPoints()
Definition: SEPulmonaryFunctionTest.h:42
int m_NumberOfPlotPoints
Definition: SEPulmonaryFunctionTest.h:88
const char * classname() const override
Definition: SEPulmonaryFunctionTest.h:30
SEScalarVolume * m_ResidualVolume
Definition: SEPulmonaryFunctionTest.h:98
static constexpr const char * TypeTag()
Definition: SEPulmonaryFunctionTest.h:29
Class corresponding to the PulmonaryFunctionTestData schema type.
Definition: PatientAssessments.hxx:762
SEScalarVolume * m_ForcedExpiratoryVolume
Definition: SEPulmonaryFunctionTest.h:91
Data formed at a level of a clinicians report. This is high level data, such as a mean or generalized...
Definition: SEPatientAssessment.h:25
SEScalarVolume * m_MaximumVoluntaryVentilation
Definition: SEPulmonaryFunctionTest.h:96
SEScalarVolume * m_ForcedVitalCapacity
Definition: SEPulmonaryFunctionTest.h:90
SEScalarVolume * m_VitalCapacity
Definition: SEPulmonaryFunctionTest.h:101
SEScalarVolume * m_ExpiratoryReserveVolume
Definition: SEPulmonaryFunctionTest.h:89
SEScalarVolumePerTime * m_PeakExpiratoryFlow
Definition: SEPulmonaryFunctionTest.h:97
Definition: SEFunctionVolumeVsTime.h:20
SEScalarVolume * m_InspiratoryCapacity
Definition: SEPulmonaryFunctionTest.h:94
Definition: SEPulmonaryFunctionTest.h:24
Definition: SEScalarVolume.h:37
Definition: SEScalarVolumePerTime.h:40
SEScalarVolume * m_TotalLungCapacity
Definition: SEPulmonaryFunctionTest.h:100
SEScalarVolume * m_FunctionalResidualCapacity
Definition: SEPulmonaryFunctionTest.h:93
virtual void SetNumberOfPlotPoints(int n)
Definition: SEPulmonaryFunctionTest.h:43
SEScalarVolume * m_InspiratoryReserveVolume
Definition: SEPulmonaryFunctionTest.h:95
SEFunctionVolumeVsTime * m_LungVolumePlot
Definition: SEPulmonaryFunctionTest.h:103
SEScalarVolume * m_SlowVitalCapacity
Definition: SEPulmonaryFunctionTest.h:99
Definition: SEElectricalCircuit.h:18