SEFunctionElectricPotentialVsTime.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/properties/SEFunction.h>
15 #include <biogears/schema/cdm/Properties.hxx>
16 
17 namespace biogears {
18 class TimeUnit;
19 class ElectricPotentialUnit;
20 
21 class BIOGEARS_API SEFunctionElectricPotentialVsTime : public SEFunction {
22 public:
25 
26  virtual void Clear();
27 
28  virtual bool Load(const CDM::FunctionElectricPotentialVsTimeData& in);
29  virtual CDM::FunctionElectricPotentialVsTimeData* Unload() const;
30 
31 protected:
32  virtual void Unload(CDM::FunctionElectricPotentialVsTimeData& data) const;
33 
34 public:
35  double GetIndependentValue(unsigned int index) = delete;
36  virtual double GetTimeValue(unsigned int index, const TimeUnit& unit);
37  virtual std::vector<double>& GetTime();
38  virtual const TimeUnit* GetTimeUnit();
39  virtual void SetTimeUnit(const TimeUnit& unit);
40 
41  double GetDependentValue(unsigned int index) = delete;
42  virtual double GetElectricPotentialValue(unsigned int index, const ElectricPotentialUnit& unit);
43  virtual std::vector<double>& GetElectricPotential();
44  virtual const ElectricPotentialUnit* GetElectricPotentialUnit();
45  virtual void SetElectricPotentialUnit(const ElectricPotentialUnit& unit);
46 
47  virtual SEFunctionElectricPotentialVsTime* InterpolateToTime(std::vector<double>& Independent, const TimeUnit& unit);
48 
49 protected:
52 };
53 }
Definition: SEFunction.h:23
Definition: SEFunctionElectricPotentialVsTime.h:21
const ElectricPotentialUnit * m_ElectricPotentialUnit
Definition: SEFunctionElectricPotentialVsTime.h:51
Definition: SEScalarElectricPotential.h:18
Definition: SEScalarTime.h:18
const TimeUnit * m_TimeUnit
Definition: SEFunctionElectricPotentialVsTime.h:50
Definition: SEElectricalCircuit.h:18
Class corresponding to the FunctionElectricPotentialVsTimeData schema type.
Definition: Properties.hxx:8935