PhysiologyEngineStabilization.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/exports.h>
15 
16 #include <biogears/cdm/CommonDataModel.h>
17 
18 #include <biogears/schema/cdm/Properties.hxx>
19 
20 CDM_BIND_DECL(PhysiologyEngineStabilizationData)
21 
22 namespace biogears {
23 class PhysiologyEngine;
24 class PhysiologyEngineTrack;
25 class PhysiologyEngineConfiguration;
26 class SECondition;
27 
28 class BIOGEARS_API PhysiologyEngineStabilization : public Loggable {
29 public:
32 
33  virtual void Clear();
34 
35  virtual bool Load(const CDM::PhysiologyEngineStabilizationData& in);
36  virtual CDM::PhysiologyEngineStabilizationData* Unload() const;
37 
38 protected:
39  virtual void Unload(CDM::PhysiologyEngineStabilizationData& data) const;
40 
41 public:
42  virtual bool Load(const char* file) = 0;
43  virtual bool Load(const std::string& file) = 0;
44 
45  virtual bool StabilizeRestingState(PhysiologyEngine& engine) = 0;
46  virtual bool StabilizeFeedbackState(PhysiologyEngine& engine) = 0;
47  virtual bool StabilizeConditions(PhysiologyEngine& engine, const std::vector<const SECondition*>& conditions) = 0;
48 
49  virtual void LogProgress(bool b);
50 
51  virtual void CancelStabilization();
52 
53  virtual bool HasStabilizationDuration();
54  virtual SEScalarTime& GetStabilizationDuration();
55 
56 protected:
60  std::stringstream m_ss;
61 
63 };
64 }
double m_currentTime_s
Definition: PhysiologyEngineStabilization.h:59
Definition: Logger.h:27
Class corresponding to the PhysiologyEngineStabilizationData schema type.
Definition: EngineConfiguration.hxx:1247
bool m_LogProgress
Definition: PhysiologyEngineStabilization.h:58
bool m_Cancelled
Definition: PhysiologyEngineStabilization.h:57
Definition: Logger.h:75
Definition: PhysiologyEngine.h:68
Definition: SEScalarTime.h:37
Definition: PhysiologyEngineStabilization.h:28
std::stringstream m_ss
Definition: PhysiologyEngineStabilization.h:60
SEScalarTime * m_StabilizationDuration
Definition: PhysiologyEngineStabilization.h:62
Definition: SEElectricalCircuit.h:18