SESubstanceConcentration.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/cdm/properties/SEScalarMassPerVolume.h>
16 #include <biogears/exports.h>
17 
18 CDM_BIND_DECL(SubstanceConcentrationData)
19 
20 namespace biogears {
21 class SESubstance;
22 class SESubstanceManager;
23 class SEEnvironmentalConditions;
24 
25 class BIOGEARS_API SESubstanceConcentration : public Loggable {
26 protected:
27  friend SEEnvironmentalConditions; // So it can add substances to the manager
28 public:
31  SESubstanceConcentration(SESubstance& substance, double concentration, const MassPerVolumeUnit& unit);
32  virtual ~SESubstanceConcentration();
33 
34  virtual void Clear();
35 
36  virtual bool Load(const CDM::SubstanceConcentrationData& in);
37  virtual CDM::SubstanceConcentrationData* Unload() const;
38 
39 protected:
40  virtual void Unload(CDM::SubstanceConcentrationData& data) const;
41 
42 public:
43  virtual bool HasConcentration() const;
44  virtual SEScalarMassPerVolume& GetConcentration();
45  virtual double GetConcentration(const MassPerVolumeUnit& unit) const;
46 
47  virtual SESubstance& GetSubstance() const;
48 
49  bool operator==(SESubstanceConcentration const& rhs) const;
50  bool operator!=(SESubstanceConcentration const& rhs) const;
52 
53 protected:
56 };
57 }
Class corresponding to the SubstanceConcentrationData schema type.
Definition: Substance.hxx:7213
SEScalarMassPerVolume m_Concentration
Definition: SESubstanceConcentration.h:55
friend SEEnvironmentalConditions
Definition: SESubstanceConcentration.h:27
Definition: Logger.h:27
bool operator!=(double lhs, const SEScalar &rhs)
Definition: SEScalar.h:129
SESubstance * m_Substance
Definition: SESubstanceConcentration.h:54
Definition: SESubstanceConcentration.h:25
bool operator==(double lhs, const SEScalar &rhs)
Definition: SEScalar.h:128
Definition: SESubstance.h:49
Definition: SEScalarMassPerVolume.h:46
Definition: SEScalarMassPerVolume.h:18
Definition: SEElectricalCircuit.h:18