SEEnvironment.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/system/SESystem.h>
15 #include <biogears/schema/cdm/Environment.hxx>
16 
17 namespace biogears {
18 class SESubstance;
19 class SESubstanceFraction;
20 class SESubstanceManager;
21 class SEEnvironmentalConditions;
22 class SEEnvironmentChange;
23 class SEInitialEnvironment;
24 class SEActiveHeating;
25 class SEActiveCooling;
26 class SEAppliedTemperature;
27 
28 class SEScalarPower;
29 class PowerUnit;
30 class SEScalarHeatConductancePerArea;
31 class HeatConductancePerAreaUnit;
32 
33 class BIOGEARS_API SEEnvironment : public SESystem {
34 public:
35  SEEnvironment(SESubstanceManager& substances);
36  ~SEEnvironment() override;
37 
38  static size_t TypeHash() { return reinterpret_cast<size_t>(&TypeHash); }
39  static constexpr char const * const TypeTag() { return "SEEnvironment"; }
40  const char* classname() const override { return TypeTag(); }
41  size_t hash_code() const override { return TypeHash(); }
42 
43  void Clear() override;
44 
45  bool Load(const CDM::EnvironmentData& in);
46  bool Load(const char* patientFile);
47  bool Load(const std::string& patientFile);
48 
49  CDM::EnvironmentData* Unload() const override;
50  Tree<const char*> GetPhysiologyRequestGraph() const override;
54  bool ProcessChange(const SEEnvironmentChange& action);
55 
59  bool ProcessChange(const SEInitialEnvironment& change);
60 
66  virtual void StateChange() = 0;
67 
68 public:
69  const SEScalar* GetScalar(const char* name) override;
70  const SEScalar* GetScalar(const std::string& name) override;
71 
72  std::string GetName() const;
73  const char* GetName_cStr() const;
74  void SetName(const char* name);
75  void SetName(const std::string& name);
76  bool HasName() const;
77  void InvalidateName();
78 
79  bool HasConditions() const;
80  SEEnvironmentalConditions& GetConditions();
81  const SEEnvironmentalConditions* GetConditions() const;
82  void RemoveConditions();
83 
84  bool HasConvectiveHeatLoss() const;
85  SEScalarPower& GetConvectiveHeatLoss();
86  double GetConvectiveHeatLoss(const PowerUnit& unit) const;
87 
88  bool HasConvectiveHeatTranferCoefficient() const;
89  SEScalarHeatConductancePerArea& GetConvectiveHeatTranferCoefficient();
90  double GetConvectiveHeatTranferCoefficient(const HeatConductancePerAreaUnit& unit) const;
91 
92  bool HasEvaporativeHeatLoss() const;
93  SEScalarPower& GetEvaporativeHeatLoss();
94  double GetEvaporativeHeatLoss(const PowerUnit& unit) const;
95 
96  bool HasEvaporativeHeatTranferCoefficient() const;
97  SEScalarHeatConductancePerArea& GetEvaporativeHeatTranferCoefficient();
98  double GetEvaporativeHeatTranferCoefficient(const HeatConductancePerAreaUnit& unit) const;
99 
100  bool HasRadiativeHeatLoss() const;
101  SEScalarPower& GetRadiativeHeatLoss();
102  double GetRadiativeHeatLoss(const PowerUnit& unit) const;
103 
104  bool HasRadiativeHeatTranferCoefficient() const;
105  SEScalarHeatConductancePerArea& GetRadiativeHeatTranferCoefficient();
106  double GetRadiativeHeatTranferCoefficient(const HeatConductancePerAreaUnit& unit) const;
107 
108  bool HasRespirationHeatLoss() const;
109  SEScalarPower& GetRespirationHeatLoss();
110  double GetRespirationHeatLoss(const PowerUnit& unit) const;
111 
112  bool HasSkinHeatLoss() const;
113  SEScalarPower& GetSkinHeatLoss();
114  double GetSkinHeatLoss(const PowerUnit& unit) const;
115 
116 protected:
117  void Unload(CDM::EnvironmentData& data) const;
118 
119 protected:
120  std::string m_Name;
129 
131 
133 };
134 }
SESubstanceManager & m_Substances
Definition: SEEnvironment.h:132
SEScalarPower * m_EvaporativeHeatLoss
Definition: SEEnvironment.h:123
Definition: SEScalarHeatConductancePerArea.h:35
Definition: SEScalarHeatConductancePerArea.h:18
const char * classname() const override
Definition: SEEnvironment.h:40
Definition: SEEnvironmentalConditions.h:42
Definition: SEScalar.h:33
std::string m_Name
Definition: SEEnvironment.h:120
SEScalarHeatConductancePerArea * m_RadiativeHeatTranferCoefficient
Definition: SEEnvironment.h:126
SEScalarPower * m_SkinHeatLoss
Definition: SEEnvironment.h:128
SEScalarPower * m_RadiativeHeatLoss
Definition: SEEnvironment.h:125
SEScalarHeatConductancePerArea * m_EvaporativeHeatTranferCoefficient
Definition: SEEnvironment.h:124
Definition: SESystem.h:27
Definition: SEEnvironmentChange.h:18
size_t hash_code() const override
Definition: SEEnvironment.h:41
Definition: SEInitialEnvironment.h:18
SEScalarPower * m_ConvectiveHeatLoss
Definition: SEEnvironment.h:121
Class corresponding to the EnvironmentData schema type.
Definition: Environment.hxx:2961
SEEnvironmentalConditions * m_Conditions
Definition: SEEnvironment.h:130
Definition: SEScalarPower.h:38
Definition: SEScalarPower.h:18
SEScalarPower * m_RespirationHeatLoss
Definition: SEEnvironment.h:127
static size_t TypeHash()
Definition: SEEnvironment.h:38
static constexpr char const *const TypeTag()
Definition: SEEnvironment.h:39
SEScalarHeatConductancePerArea * m_ConvectiveHeatTranferCoefficient
Definition: SEEnvironment.h:122
Definition: SESubstanceManager.h:23
Definition: SEElectricalCircuit.h:18
Definition: SEEnvironment.h:33