SESubstanceBolus.h
1/* Distributed under the Apache License, Version 2.0.
2 See accompanying NOTICE file for details.*/
3
4#pragma once
5#include "cdm/patient/actions/SESubstanceAdministration.h"
6class SESubstance;
7
8class CDM_DECL SESubstanceBolus : public SEPatientAction
9{
10 friend class PBPatientAction;//friend the serialization class
11public:
12
13 SESubstanceBolus(const SESubstance& substance, Logger* logger=nullptr);
14 virtual ~SESubstanceBolus();
15
16 static constexpr char const* Name = "Substance Bolus";
17 virtual std::string GetName() const { return Name; }
18
19 virtual void Clear(); //clear memory
20 virtual void Copy(const SESubstanceBolus& src, bool /*preserveState*/=false);
21
22 virtual bool IsValid() const;
23 virtual bool IsActive() const;
24 virtual void Activate();
25 virtual void Deactivate();
26
27 virtual eSubstanceAdministration_Route GetAdminRoute() const;
28 virtual void SetAdminRoute(eSubstanceAdministration_Route name);
29
30 virtual bool HasAdminDuration() const;
31 virtual SEScalarTime& GetAdminDuration();
32 virtual double GetAdminDuration(const TimeUnit& unit) const;
33
34 virtual bool HasConcentration() const;
35 virtual SEScalarMassPerVolume& GetConcentration();
36 virtual double GetConcentration(const MassPerVolumeUnit& unit) const;
37
38 virtual bool HasDose() const;
39 virtual SEScalarVolume& GetDose();
40 virtual double GetDose(const VolumeUnit& unit) const;
41
42 virtual SESubstance& GetSubstance();
43 virtual const SESubstance& GetSubstance() const;
44
45 virtual const SEScalar* GetScalar(const std::string& name);
46
47 virtual bool HasTotalInfusedDose() const;
48 virtual SEScalarVolume& GetTotalInfusedDose();
49 virtual double GetTotalInfusedDose(const VolumeUnit& unit) const;
50
51protected:
52
54 eSubstanceAdministration_Route m_AdminRoute;
59};
Definition: Logger.h:71
Definition: SEScalarMassPerVolume.h:8
Definition: PBPatientActions.h:48
virtual const SEScalar * GetScalar(const std::string &name)=0
virtual void Activate()
Definition: SEAction.h:40
virtual bool IsActive() const
Definition: SEAction.h:39
virtual void Deactivate()
Definition: SEAction.h:41
static SEAction * Copy(const SEAction &, const SESubstanceManager &)
Definition: SEAction.cpp:54
Definition: SEPatientAction.h:8
virtual bool IsValid() const
Definition: SEPatientAction.cpp:22
virtual void Clear()
Definition: SEPatientAction.cpp:17
Definition: SEScalar.h:19
Definition: SEScalarMassPerVolume.h:37
Definition: SEScalarTime.h:28
Definition: SEScalarVolume.h:28
Definition: SESubstanceBolus.h:9
eSubstanceAdministration_Route m_AdminRoute
Definition: SESubstanceBolus.h:54
SEScalarTime * m_AdminDuration
Definition: SESubstanceBolus.h:55
virtual std::string GetName() const
Definition: SESubstanceBolus.h:17
SEScalarVolume * m_Dose
Definition: SESubstanceBolus.h:57
SEScalarMassPerVolume * m_Concentration
Definition: SESubstanceBolus.h:56
SEScalarVolume * m_TotalInfusedDose
Definition: SESubstanceBolus.h:58
const SESubstance & m_Substance
Definition: SESubstanceBolus.h:53
Definition: SESubstance.h:15
Definition: SEScalarTime.h:8
Definition: SEScalarVolume.h:8

Distributed under the Apache License, Version 2.0.

See accompanying NOTICE file for details.