SESubstanceCompoundInfusion.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"
7 
9 {
10  friend class PBPatientAction;//friend the serialization class
11 public:
12 
13  SESubstanceCompoundInfusion(const SESubstanceCompound& compound, Logger* logger=nullptr);
14  virtual ~SESubstanceCompoundInfusion();
15 
16  static constexpr char const* Name = "Substance Compound Infusion";
17  std::string GetName() const override { return Name; }
18 
19  void Clear() override;
20  void Copy(const SESubstanceCompoundInfusion& src, bool preserveState=false);
21 
22  const SEScalar* GetScalar(const std::string& name) override;
23 
24  bool IsValid() const override;
25  bool IsActive() const override;
26  void Deactivate() override;
27 
28  virtual bool HasBagVolume() const;
29  virtual SEScalarVolume& GetBagVolume();
30  virtual double GetBagVolume(const VolumeUnit& unit) const;
31 
32  virtual bool HasRate() const;
33  virtual SEScalarVolumePerTime& GetRate();
34  virtual double GetRate(const VolumePerTimeUnit& unit) const;
35 
36  virtual SESubstanceCompound& GetSubstanceCompound();
37  virtual const SESubstanceCompound& GetSubstanceCompound() const;
38 
39 protected:
43 };
Definition: Logger.h:71
Definition: PBPatientActions.h:52
virtual const SEScalar * GetScalar(const std::string &name)=0
static SEAction * Copy(const SEAction &, const SESubstanceManager &)
Definition: SEAction.cpp:53
Definition: SEPatientAction.h:8
void Deactivate() override
Definition: SEPatientAction.h:23
void Clear() override
Definition: SEPatientAction.h:18
bool IsValid() const override
Definition: SEPatientAction.h:19
bool IsActive() const override
Definition: SEPatientAction.h:22
Definition: SEScalar.h:19
Definition: SEScalarVolume.h:28
Definition: SEScalarVolumePerTime.h:32
Definition: SESubstanceCompound.h:10
Definition: SESubstanceCompoundInfusion.h:9
SEScalarVolume * m_BagVolume
Definition: SESubstanceCompoundInfusion.h:40
const SESubstanceCompound & m_Compound
Definition: SESubstanceCompoundInfusion.h:42
std::string GetName() const override
Definition: SESubstanceCompoundInfusion.h:17
SEScalarVolumePerTime * m_Rate
Definition: SESubstanceCompoundInfusion.h:41
Definition: SEScalarVolumePerTime.h:8
Definition: SEScalarVolume.h:8

Distributed under the Apache License, Version 2.0.

See accompanying NOTICE file for details.