author | Stefano Avallone <stefano.avallone@unina.it> |
Fri, 05 Sep 2014 16:33:57 -0700 | |
changeset 10883 | d919e7194e23 |
parent 10218 | 97da49da2d6c |
child 11341 | aba202c0c922 |
permissions | -rw-r--r-- |
7385
10beb0e53130
standardize emacs c++ mode comments
Vedran Miletić <rivanvx@gmail.com>
parents:
7238
diff
changeset
|
1 |
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */ |
6699
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
2 |
/* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
3 |
* Copyright (c) 2010 Network Security Lab, University of Washington, Seattle. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
4 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
5 |
* This program is free software; you can redistribute it and/or modify |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
6 |
* it under the terms of the GNU General Public License version 2 as |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
7 |
* published by the Free Software Foundation; |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
8 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
9 |
* This program is distributed in the hope that it will be useful, |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
10 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
11 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
12 |
* GNU General Public License for more details. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
13 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
14 |
* You should have received a copy of the GNU General Public License |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
15 |
* along with this program; if not, write to the Free Software |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
16 |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
17 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
18 |
* Authors: Sidharth Nabar <snabar@uw.edu>, He Wu <mdzz@u.washington.edu> |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
19 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
20 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
21 |
#ifndef RV_BATTERY_MODEL_H |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
22 |
#define RV_BATTERY_MODEL_H |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
23 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
24 |
#include "ns3/traced-value.h" |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
25 |
#include "ns3/nstime.h" |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
26 |
#include "ns3/event-id.h" |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
27 |
#include "energy-source.h" |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
28 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
29 |
namespace ns3 { |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
30 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
31 |
/** |
7238
85a7e87bb4cc
Make some more modules show up on doxygen modules page
Mitch Watrous <watrous@u.washington.edu>
parents:
6938
diff
changeset
|
32 |
* \ingroup energy |
6699
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
33 |
* \brief Rakhmatov Vrudhula non-linear battery model. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
34 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
35 |
* This (energy source) model implements an analytical non-linear battery model. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
36 |
* It is capable of capturing load capacity and recovery effects of batteries. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
37 |
* Batteries are characterized by 2 parameters, alpha and beta, which can both |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
38 |
* be obtained from the discharge curve of the batteries. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
39 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
40 |
* The model is developed by Daler Rakhmatov & Sarma Vrudhula in: "Battery |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
41 |
* Lifetime Prediction for Energy-Aware Computing" and "An Analytical High-Level |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
42 |
* Battery Model for Use in Energy Management of Portable Electronic Systems". |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
43 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
44 |
* The real-time algorithm is developed by Matthias Handy & Dirk Timmermann in: |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
45 |
* "Simulation of Mobile Wireless Networks with Accurate Modeling of non-linear |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
46 |
* battery effects". The real-time algorithm is modified by the authors of this |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
47 |
* code for improved accuracy and reduced computation (sampling) overhead. |
7238
85a7e87bb4cc
Make some more modules show up on doxygen modules page
Mitch Watrous <watrous@u.washington.edu>
parents:
6938
diff
changeset
|
48 |
* |
6699
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
49 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
50 |
class RvBatteryModel : public EnergySource |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
51 |
{ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
52 |
public: |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
53 |
static TypeId GetTypeId (void); |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
54 |
RvBatteryModel (); |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
55 |
virtual ~RvBatteryModel (); |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
56 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
57 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
58 |
* \return Initial energy stored (theoretical capacity) in the battery. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
59 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
60 |
* Implements GetInitialEnergy. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
61 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
62 |
virtual double GetInitialEnergy (void) const; |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
63 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
64 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
65 |
* \returns Supply voltage at the energy source. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
66 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
67 |
* Implements GetSupplyVoltage. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
68 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
69 |
virtual double GetSupplyVoltage (void) const; |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
70 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
71 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
72 |
* \return Remaining energy in energy source, in Joules |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
73 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
74 |
* Implements GetRemainingEnergy. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
75 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
76 |
virtual double GetRemainingEnergy (void); |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
77 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
78 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
79 |
* \returns Energy fraction. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
80 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
81 |
* Implements GetEnergyFraction. For the RV battery model, energy fraction is |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
82 |
* equivalent to battery level. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
83 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
84 |
virtual double GetEnergyFraction (void); |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
85 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
86 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
87 |
* Implements UpdateEnergySource. This function samples the total load (total |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
88 |
* current) from all devices to discharge the battery. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
89 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
90 |
virtual void UpdateEnergySource (void); |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
91 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
92 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
93 |
* \param interval Energy update interval. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
94 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
95 |
* This function sets the interval between each energy update. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
96 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
97 |
void SetSamplingInterval (Time interval); |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
98 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
99 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
100 |
* \returns The interval between each energy update. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
101 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
102 |
Time GetSamplingInterval (void) const; |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
103 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
104 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
105 |
* \brief Sets open circuit voltage of battery. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
106 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
107 |
* \param voltage Open circuit voltage. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
108 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
109 |
void SetOpenCircuitVoltage (double voltage); |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
110 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
111 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
112 |
* \return Open circuit voltage of battery. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
113 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
114 |
double GetOpenCircuitVoltage (void) const; |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
115 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
116 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
117 |
* \brief Sets cutoff voltage of battery. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
118 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
119 |
* \param voltage Cutoff voltage. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
120 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
121 |
void SetCutoffVoltage (double voltage); |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
122 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
123 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
124 |
* \returns Cutoff voltage of battery. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
125 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
126 |
double GetCutoffVoltage (void) const; |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
127 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
128 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
129 |
* \brief Sets the alpha value for the battery model. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
130 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
131 |
* \param alpha Alpha. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
132 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
133 |
void SetAlpha (double alpha); |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
134 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
135 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
136 |
* \returns The alpha value used by the battery model. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
137 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
138 |
double GetAlpha (void) const; |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
139 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
140 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
141 |
* \brief Sets the beta value for the battery model. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
142 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
143 |
* \param beta Beta. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
144 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
145 |
void SetBeta (double beta); |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
146 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
147 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
148 |
* \returns The beta value used by the battery model. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
149 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
150 |
double GetBeta (void) const; |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
151 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
152 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
153 |
* \returns Battery level [0, 1]. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
154 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
155 |
double GetBatteryLevel (void); |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
156 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
157 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
158 |
* \returns Lifetime of the battery. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
159 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
160 |
Time GetLifetime (void) const; |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
161 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
162 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
163 |
* \brief Sets the number of terms of the infinite sum for estimating battery |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
164 |
* level. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
165 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
166 |
* \param num Number of terms. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
167 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
168 |
void SetNumOfTerms (int num); |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
169 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
170 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
171 |
* \returns The number of terms of the infinite sum for estimating battery |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
172 |
* level. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
173 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
174 |
int GetNumOfTerms (void) const; |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
175 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
176 |
private: |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
177 |
/// Defined in ns3::Object |
9703
681f35b212ff
Rename Start and DoStart methods to Initialize and DoInitialize
Vedran Miletić <rivanvx@gmail.com>
parents:
7385
diff
changeset
|
178 |
virtual void DoInitialize (void); |
6699
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
179 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
180 |
/// Defined in ns3::Object |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
181 |
virtual void DoDispose (void); |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
182 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
183 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
184 |
* Handles the remaining energy going to zero event. This function notifies |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
185 |
* all the energy models aggregated to the node about the energy being |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
186 |
* depleted. Each energy model is then responsible for its own handler. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
187 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
188 |
void HandleEnergyDrainedEvent (void); |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
189 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
190 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
191 |
* \brief Discharges the battery. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
192 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
193 |
* \param load Load value (total current form devices, in mA). |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
194 |
* \param t Time stamp of the load value. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
195 |
* \returns Calculated alpha value. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
196 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
197 |
* Discharge function calculates a value which is then compared to the alpha |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
198 |
* value to determine if the battery is dead. It will also update the battery |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
199 |
* level. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
200 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
201 |
* Note that the load value passed to Discharge has to be in mA. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
202 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
203 |
double Discharge (double load, Time t); |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
204 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
205 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
206 |
* \brief RV model A function. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
207 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
208 |
* \param t Current time. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
209 |
* \param sk Time stamp in array position k |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
210 |
* \param sk_1 Time stamp in array position k-1 |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
211 |
* \param beta Beta value used by the battery model. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
212 |
* \returns Result of A function. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
213 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
214 |
* This function computes alpha value using the recorded load profile. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
215 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
216 |
double RvModelAFunction (Time t, Time sk, Time sk_1, double beta); |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
217 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
218 |
private: |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
219 |
double m_openCircuitVoltage; |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
220 |
double m_cutoffVoltage; |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
221 |
double m_alpha; // alpha value of RV model, in Coulomb |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
222 |
double m_beta; // beta value of RV model, in second^-1 |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
223 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
224 |
double m_previousLoad; // load value (total current) of previous sampling |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
225 |
std::vector<double> m_load; // load profile |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
226 |
std::vector<Time> m_timeStamps; // time stamps of load profile |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
227 |
Time m_lastSampleTime; |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
228 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
229 |
int m_numOfTerms; // # of terms for infinite sum in battery level estimation |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
230 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
231 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
232 |
* Battery level is defined as: output of Discharge function / alpha value |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
233 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
234 |
* The output of Discharge function is an estimated charge consumption of the |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
235 |
* battery. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
236 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
237 |
* The alpha value is the amount of charges stored in the battery, or battery |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
238 |
* capacity (in Coulomb). |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
239 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
240 |
* When the battery is fully charged (no charge is consumed from the battery) |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
241 |
* the battery level is 1. When the battery is fully discharged, the battery |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
242 |
* level is 0. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
243 |
* |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
244 |
* NOTE Note that the definition in Timmermann's paper is the inverse of this |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
245 |
* definition. In the paper, battery level = 1 when the battery is drained. |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
246 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
247 |
TracedValue<double> m_batteryLevel; |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
248 |
|
10883
d919e7194e23
add support for a Wifi sleep mode
Stefano Avallone <stefano.avallone@unina.it>
parents:
10218
diff
changeset
|
249 |
double m_lowBatteryTh; // low battery threshold, as a fraction of the initial energy |
d919e7194e23
add support for a Wifi sleep mode
Stefano Avallone <stefano.avallone@unina.it>
parents:
10218
diff
changeset
|
250 |
|
6699
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
251 |
/** |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
252 |
* (1 / sampling interval) = sampling frequency |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
253 |
*/ |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
254 |
Time m_samplingInterval; |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
255 |
EventId m_currentSampleEvent; |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
256 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
257 |
TracedValue<Time> m_lifetime; // time of death of the battery |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
258 |
}; |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
259 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
260 |
} // namespace ns3 |
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
261 |
|
d8909a1fd0ff
RV battery model and WiFi energy example
He Wu <mdzz@u.washington.edu>
parents:
diff
changeset
|
262 |
#endif /* RV_BATTERY_MODEL_H */ |