SEScenarioInitialParameters.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/CommonDataModel.h>
15 #include <biogears/exports.h>
16 
17 CDM_BIND_DECL(ScenarioInitialParametersData)
18 
19 namespace biogears {
20 class SEScenario;
21 class SEPatient;
22 class SECondition;
23 class SESubstanceManager;
24 class PhysiologyEngineConfiguration;
25 
26 class BIOGEARS_API SEScenarioInitialParameters : public Loggable {
27 protected:
28  friend SEScenario;
30  virtual ~SEScenarioInitialParameters();
31 
32 
33 public:
34  virtual void Clear(); //clear memory
35 
36  bool Load(const CDM::ScenarioInitialParametersData& in);
37  CDM::ScenarioInitialParametersData* Unload() const;
38 
39 protected:
40  void Unload(CDM::ScenarioInitialParametersData& data) const;
41 
42 public:
43  virtual bool IsValid() const;
44 
45  virtual PhysiologyEngineConfiguration& GetConfiguration();
46  virtual const PhysiologyEngineConfiguration* GetConfiguration() const;
47  virtual void SetConfiguration(const PhysiologyEngineConfiguration& config);
48  virtual bool HasConfiguration() const;
49  virtual void InvalidateConfiguration();
50 
51  virtual const char* GetPatientFile() const;
52  virtual void SetPatientFile(const char* patientFile);
53  virtual void SetPatientFile(const std::string& patientFile);
54  virtual bool HasPatientFile() const;
55  virtual void InvalidatePatientFile();
56 
57  virtual SEPatient& GetPatient();
58  virtual const SEPatient* GetPatient() const;
59  virtual void SetPatient(const SEPatient& patient);
60  virtual bool HasPatient() const;
61  virtual void InvalidatePatient();
62 
63  virtual void AddCondition(const SECondition& c);
64  virtual const std::vector<SECondition*>& GetConditions() const;
65 
66  virtual bool TrackingStabilization() const;
67  virtual void SetTrackStabilization(bool flag);
68 
69  protected:
73  std::string m_PatientFile;
74  std::vector<SECondition*> m_Conditions;
76 
77 };
78 }
bool m_DoTrackStabilization
Definition: SEScenarioInitialParameters.h:75
Class corresponding to the ScenarioInitialParametersData schema type.
Definition: Scenario.hxx:4081
PhysiologyEngineConfiguration * m_Configuration
Definition: SEScenarioInitialParameters.h:71
SEPatient * m_Patient
Definition: SEScenarioInitialParameters.h:72
std::vector< SECondition * > m_Conditions
Definition: SEScenarioInitialParameters.h:74
Definition: SEPatient.h:48
Definition: Logger.h:27
SESubstanceManager & m_SubMgr
Definition: SEScenarioInitialParameters.h:70
Definition: SEScenarioInitialParameters.h:26
friend SEScenario
Definition: SEScenarioInitialParameters.h:28
std::string m_PatientFile
Definition: SEScenarioInitialParameters.h:73
Definition: SESubstanceManager.h:23
Definition: SEElectricalCircuit.h:18
Definition: SECondition.h:22
Definition: PhysiologyEngineConfiguration.h:28