A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
device-energy-model-container.cc
Go to the documentation of this file.
1/*
2 * Copyright (c) 2008 INRIA
3 * Copyright (c) 2010 Network Security Lab, University of Washington, Seattle.
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 as
7 * published by the Free Software Foundation;
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 *
18 * Authors: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
19 * Sidharth Nabar <snabar@uw.edu>, He Wu <mdzz@u.washington.edu>
20 */
21
23
24#include "ns3/log.h"
25#include "ns3/names.h"
26
27namespace ns3
28{
29namespace energy
30{
31
32NS_LOG_COMPONENT_DEFINE("DeviceEnergyModelContainer");
33
35{
36 NS_LOG_FUNCTION(this);
37}
38
40{
41 NS_LOG_FUNCTION(this << model);
42 NS_ASSERT(model);
43 m_models.push_back(model);
44}
45
47{
48 NS_LOG_FUNCTION(this << modelName);
49 Ptr<DeviceEnergyModel> model = Names::Find<DeviceEnergyModel>(modelName);
50 NS_ASSERT(model);
51 m_models.push_back(model);
52}
53
56{
57 NS_LOG_FUNCTION(this << &a << &b);
58 *this = a;
59 Add(b);
60}
61
64{
65 NS_LOG_FUNCTION(this);
66 return m_models.begin();
67}
68
71{
72 NS_LOG_FUNCTION(this);
73 return m_models.end();
74}
75
78{
79 NS_LOG_FUNCTION(this);
80 return m_models.size();
81}
82
85{
86 NS_LOG_FUNCTION(this << i);
87 return m_models[i];
88}
89
90void
92{
93 NS_LOG_FUNCTION(this << &container);
94 for (auto i = container.Begin(); i != container.End(); i++)
95 {
96 m_models.push_back(*i);
97 }
98}
99
100void
102{
103 NS_LOG_FUNCTION(this << model);
104 NS_ASSERT(model);
105 m_models.push_back(model);
106}
107
108void
110{
111 NS_LOG_FUNCTION(this << modelName);
112 Ptr<DeviceEnergyModel> model = Names::Find<DeviceEnergyModel>(modelName);
113 NS_ASSERT(model);
114 m_models.push_back(model);
115}
116
117void
119{
120 NS_LOG_FUNCTION(this);
121 m_models.clear();
122}
123
124} // namespace energy
125} // namespace ns3
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:77
Holds a vector of ns3::DeviceEnergyModel pointers.
void Add(DeviceEnergyModelContainer container)
std::vector< Ptr< DeviceEnergyModel > >::const_iterator Iterator
Const iterator of DeviceEnergyModel container.
std::vector< Ptr< DeviceEnergyModel > > m_models
Container of Energy models.
Ptr< DeviceEnergyModel > Get(uint32_t i) const
Get the i-th Ptr<DeviceEnergyModel> stored in this container.
DeviceEnergyModelContainer()
Creates an empty DeviceEnergyModelContainer.
Iterator End() const
Get an iterator which refers to the last DeviceEnergyModel pointer in the container.
Iterator Begin() const
Get an iterator which refers to the first DeviceEnergyModel pointer in the container.
void Clear()
Removes all elements in the container.
uint32_t GetN() const
Get the number of Ptr<DeviceEnergyModel> stored in this container.
#define NS_ASSERT(condition)
At runtime, in debugging builds, if this condition is not true, the program prints the source file,...
Definition: assert.h:66
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition: log.h:202
#define NS_LOG_FUNCTION(parameters)
If log level LOG_FUNCTION is enabled, this macro will output all input parameters separated by ",...
Every class exported by the ns3 library is enclosed in the ns3 namespace.