A Discrete-Event Network Simulator
API
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
ns3::AcousticModemEnergyModel Class Reference

WHOI micro-modem energy model. More...

#include <acoustic-modem-energy-model.h>

+ Inheritance diagram for ns3::AcousticModemEnergyModel:
+ Collaboration diagram for ns3::AcousticModemEnergyModel:

Public Types

typedef Callback< void > AcousticModemEnergyDepletionCallback
 Callback type for energy depletion handling. More...
 
- Public Types inherited from ns3::DeviceEnergyModel
typedef Callback< void, int > ChangeStateCallback
 Callback type for ChangeState function. More...
 

Public Member Functions

 AcousticModemEnergyModel ()
 Constructor. More...
 
virtual ~AcousticModemEnergyModel ()
 Dummy destructor, see DoDispose. More...
 
virtual void ChangeState (int newState)
 Changes state of the AcousticModemEnergyModel. More...
 
int GetCurrentState (void) const
 Get the current state of the modem. More...
 
double GetIdlePowerW (void) const
 Get the idle power of the modem. More...
 
virtual Ptr< NodeGetNode (void) const
 Gets pointer to node. More...
 
double GetRxPowerW (void) const
 Get the recieving power. More...
 
double GetSleepPowerW (void) const
 Get the sleep state power of the modem. More...
 
virtual double GetTotalEnergyConsumption (void) const
 
double GetTxPowerW (void) const
 Get the transmission power of the modem. More...
 
virtual void HandleEnergyDepletion (void)
 Handles energy depletion. More...
 
void SetEnergyDepletionCallback (AcousticModemEnergyDepletionCallback callback)
 
virtual void SetEnergySource (Ptr< EnergySource > source)
 
void SetIdlePowerW (double idlePowerW)
 Set the idle state power of the modem. More...
 
virtual void SetNode (Ptr< Node > node)
 Sets pointer to node. More...
 
void SetRxPowerW (double rxPowerW)
 Set the receiving power of the modem. More...
 
void SetSleepPowerW (double sleepPowerW)
 Set the sleep power of the modem. More...
 
void SetTxPowerW (double txPowerW)
 Set the transmission power of the modem. More...
 
- Public Member Functions inherited from ns3::DeviceEnergyModel
 DeviceEnergyModel ()
 
virtual ~DeviceEnergyModel ()
 
double GetCurrentA (void) const
 
- Public Member Functions inherited from ns3::Object
 Object ()
 
virtual ~Object ()
 
void AggregateObject (Ptr< Object > other)
 
void Dispose (void)
 Run the DoDispose methods of this object and all the objects aggregated to it. More...
 
AggregateIterator GetAggregateIterator (void) const
 
virtual TypeId GetInstanceTypeId (void) const
 
template<typename T >
Ptr< T > GetObject (void) const
 
template<typename T >
Ptr< T > GetObject (TypeId tid) const
 
void Initialize (void)
 This method calls the virtual DoInitialize method on all the objects aggregated to this object. More...
 
- Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter >
 SimpleRefCount ()
 Constructor. More...
 
 SimpleRefCount (const SimpleRefCount &o)
 Copy constructor. More...
 
uint32_t GetReferenceCount (void) const
 Get the reference count of the object. More...
 
SimpleRefCountoperator= (const SimpleRefCount &o)
 Assignment. More...
 
void Ref (void) const
 Increment the reference count. More...
 
void Unref (void) const
 Decrement the reference count. More...
 
- Public Member Functions inherited from ns3::ObjectBase
virtual ~ObjectBase ()
 Virtual destructor. More...
 
void GetAttribute (std::string name, AttributeValue &value) const
 
bool GetAttributeFailSafe (std::string name, AttributeValue &attribute) const
 
void SetAttribute (std::string name, const AttributeValue &value)
 
bool SetAttributeFailSafe (std::string name, const AttributeValue &value)
 
bool TraceConnect (std::string name, std::string context, const CallbackBase &cb)
 
bool TraceConnectWithoutContext (std::string name, const CallbackBase &cb)
 
bool TraceDisconnect (std::string name, std::string context, const CallbackBase &cb)
 
bool TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb)
 

Static Public Member Functions

static TypeId GetTypeId (void)
 Register this type. More...
 
- Static Public Member Functions inherited from ns3::DeviceEnergyModel
static TypeId GetTypeId (void)
 
- Static Public Member Functions inherited from ns3::Object
static TypeId GetTypeId (void)
 Register this type. More...
 
- Static Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter >
static void Cleanup (void)
 Noop. More...
 
- Static Public Member Functions inherited from ns3::ObjectBase
static TypeId GetTypeId (void)
 Get the type ID. More...
 

Private Member Functions

void DoDispose (void)
 This method is called by Object::Dispose or by the object's destructor, whichever comes first. More...
 
virtual double DoGetCurrentA (void) const
 
bool IsStateTransitionValid (const int destState)
 
void SetMicroModemState (const int state)
 

Private Attributes

int m_currentState
 Current modem state. More...
 
AcousticModemEnergyDepletionCallback m_energyDepletionCallback
 Energy depletion callback. More...
 
double m_idlePowerW
 The idle power, in watts. More...
 
Time m_lastUpdateTime
 Time stamp of previous energy update. More...
 
Ptr< Nodem_node
 The node hosting this transducer. More...
 
double m_rxPowerW
 The receiver power, in watts. More...
 
double m_sleepPowerW
 The sleep power, in watts. More...
 
Ptr< EnergySourcem_source
 The energy source. More...
 
TracedValue< double > m_totalEnergyConsumption
 The total energy consumed by this model. More...
 
double m_txPowerW
 The transmitter power, in watts. More...
 

Additional Inherited Members

- Protected Member Functions inherited from ns3::Object
 Object (const Object &o)
 
virtual void DoInitialize (void)
 This method is called only once by Object::Initialize. More...
 
virtual void NotifyNewAggregate (void)
 This method is invoked whenever two sets of objects are aggregated together. More...
 
- Protected Member Functions inherited from ns3::ObjectBase
void ConstructSelf (const AttributeConstructionList &attributes)
 
virtual void NotifyConstructionCompleted (void)
 This method is invoked once all member attributes have been initialized. More...
 

Detailed Description

WHOI micro-modem energy model.

Doxygen introspection did not find any typical Config paths.

Basing on the Device Energy Model interface, has been implemented a specific energy model for the WHOI micro modem. The class follows pretty closely the RadioEnergyModel class as the transducer behaviour is pretty close to the one of a wifi radio, with identical states (rx, tx, idle, sleep).

The power consumption values implemented into the model are as follows [1]:

Modem State Power Consumption TX 50 W RX 158 mW Idle 158 mW Sleep 5.8 mW

References: [1] Freitag et al., The whoi micro-modem: an acoustic communications and navigation system for multiple platforms, in In Proc. IEEE OCEANS05 Conf, 2005. URL: http://ieeexplore.ieee.org/iel5/10918/34367/01639901.pdf


Attributes

  • TxPowerW: The modem Tx power in Watts
    • Set with class: ns3::DoubleValue
    • Underlying type: double -1.79769e+308:1.79769e+308
    • Initial value: 50
    • Flags: construct write read
  • RxPowerW: The modem Rx power in Watts
    • Set with class: ns3::DoubleValue
    • Underlying type: double -1.79769e+308:1.79769e+308
    • Initial value: 0.158
    • Flags: construct write read
  • IdlePowerW: The modem Idle power in Watts
    • Set with class: ns3::DoubleValue
    • Underlying type: double -1.79769e+308:1.79769e+308
    • Initial value: 0.158
    • Flags: construct write read
  • SleepPowerW: The modem Sleep power in Watts
    • Set with class: ns3::DoubleValue
    • Underlying type: double -1.79769e+308:1.79769e+308
    • Initial value: 0.0058
    • Flags: construct write read

TraceSources

  • TotalEnergyConsumption: Total energy consumption of the modem device.

Definition at line 55 of file acoustic-modem-energy-model.h.

Member Typedef Documentation

Callback type for energy depletion handling.

Definition at line 59 of file acoustic-modem-energy-model.h.

Constructor & Destructor Documentation

ns3::AcousticModemEnergyModel::AcousticModemEnergyModel ( )
ns3::AcousticModemEnergyModel::~AcousticModemEnergyModel ( )
virtual

Dummy destructor, see DoDispose.

Definition at line 84 of file acoustic-modem-energy-model.cc.

Member Function Documentation

void ns3::AcousticModemEnergyModel::ChangeState ( int  newState)
virtual
void ns3::AcousticModemEnergyModel::DoDispose ( void  )
privatevirtual

This method is called by Object::Dispose or by the object's destructor, whichever comes first.

Subclasses are expected to implement their real destruction code in an overriden version of this method and chain up to their parent's implementation once they are done. i.e., for simplicity, the destructor of every subclass should be empty and its content should be moved to the associated DoDispose method.

It is safe to call GetObject from within this method.

Reimplemented from ns3::Object.

Definition at line 260 of file acoustic-modem-energy-model.cc.

References m_energyDepletionCallback, m_node, m_source, NS_LOG_FUNCTION, and ns3::Callback< R, T1, T2, T3, T4, T5, T6, T7, T8, T9 >::Nullify().

+ Here is the call graph for this function:

double ns3::AcousticModemEnergyModel::DoGetCurrentA ( void  ) const
privatevirtual
int ns3::AcousticModemEnergyModel::GetCurrentState ( void  ) const

Get the current state of the modem.

Returns
Current state.

Definition at line 174 of file acoustic-modem-energy-model.cc.

References m_currentState, and NS_LOG_FUNCTION.

double ns3::AcousticModemEnergyModel::GetIdlePowerW ( void  ) const

Get the idle power of the modem.

Returns
The idle power in Watts

Definition at line 146 of file acoustic-modem-energy-model.cc.

References m_idlePowerW, and NS_LOG_FUNCTION.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

Ptr< Node > ns3::AcousticModemEnergyModel::GetNode ( void  ) const
virtual

Gets pointer to node.

Returns
Pointer to node.

Definition at line 97 of file acoustic-modem-energy-model.cc.

References m_node.

double ns3::AcousticModemEnergyModel::GetRxPowerW ( void  ) const

Get the recieving power.

Returns
The receiving power in Watts

Definition at line 132 of file acoustic-modem-energy-model.cc.

References m_rxPowerW, and NS_LOG_FUNCTION.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

double ns3::AcousticModemEnergyModel::GetSleepPowerW ( void  ) const

Get the sleep state power of the modem.

Returns
Sleep power of the modem in Watts

Definition at line 160 of file acoustic-modem-energy-model.cc.

References m_sleepPowerW, and NS_LOG_FUNCTION.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

double ns3::AcousticModemEnergyModel::GetTotalEnergyConsumption ( void  ) const
virtual
Returns
Total energy consumption of the device.

DeviceEnergyModel records its own energy consumption during simulation.

Implements ns3::DeviceEnergyModel.

Definition at line 111 of file acoustic-modem-energy-model.cc.

References m_totalEnergyConsumption, and NS_LOG_FUNCTION.

double ns3::AcousticModemEnergyModel::GetTxPowerW ( void  ) const

Get the transmission power of the modem.

Returns
The transmission power in Watts.

Definition at line 118 of file acoustic-modem-energy-model.cc.

References m_txPowerW, and NS_LOG_FUNCTION.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

TypeId ns3::AcousticModemEnergyModel::GetTypeId ( void  )
static
void ns3::AcousticModemEnergyModel::HandleEnergyDepletion ( void  )
virtual
bool ns3::AcousticModemEnergyModel::IsStateTransitionValid ( const int  destState)
private
Parameters
destStateModem state to switch to.
Returns
True if the transition is allowed.

This function checks if a given modem state transition is allowed.

Definition at line 298 of file acoustic-modem-energy-model.cc.

References NS_LOG_FUNCTION.

Referenced by SetMicroModemState().

+ Here is the caller graph for this function:

void ns3::AcousticModemEnergyModel::SetEnergyDepletionCallback ( AcousticModemEnergyDepletionCallback  callback)
Parameters
callbackCallback function.

Sets callback for energy depletion handling.

Definition at line 181 of file acoustic-modem-energy-model.cc.

References ns3::Callback< R, T1, T2, T3, T4, T5, T6, T7, T8, T9 >::IsNull(), m_energyDepletionCallback, NS_LOG_DEBUG, and NS_LOG_FUNCTION.

+ Here is the call graph for this function:

void ns3::AcousticModemEnergyModel::SetEnergySource ( Ptr< EnergySource source)
virtual
Parameters
sourcePointer to energy source installed on node.

This function sets the pointer to energy source installed on node. Should be called only by DeviceEnergyModel helper classes.

Implements ns3::DeviceEnergyModel.

Definition at line 103 of file acoustic-modem-energy-model.cc.

References m_source, NS_ASSERT, and NS_LOG_FUNCTION.

void ns3::AcousticModemEnergyModel::SetIdlePowerW ( double  idlePowerW)

Set the idle state power of the modem.

Parameters
idlePowerWIdle power of the modem in watts.

Definition at line 153 of file acoustic-modem-energy-model.cc.

References m_idlePowerW, and NS_LOG_FUNCTION.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

void ns3::AcousticModemEnergyModel::SetMicroModemState ( const int  state)
private
Parameters
stateNew state the modem is currently in.

Sets current state. This function is private so that only the energy model can change its own state.

Definition at line 305 of file acoustic-modem-energy-model.cc.

References ns3::UanPhy::IDLE, IsStateTransitionValid(), m_currentState, ns3::Simulator::Now(), NS_FATAL_ERROR, NS_LOG_DEBUG, NS_LOG_FUNCTION, ns3::UanPhy::RX, ns3::UanPhy::SLEEP, and ns3::UanPhy::TX.

Referenced by ChangeState().

+ Here is the call graph for this function:

+ Here is the caller graph for this function:

void ns3::AcousticModemEnergyModel::SetNode ( Ptr< Node node)
virtual

Sets pointer to node.

Parameters
nodePointer to node.

Definition at line 89 of file acoustic-modem-energy-model.cc.

References m_node, NS_ASSERT, and NS_LOG_FUNCTION.

void ns3::AcousticModemEnergyModel::SetRxPowerW ( double  rxPowerW)

Set the receiving power of the modem.

Parameters
rxPowerWReceiving power in watts

Definition at line 139 of file acoustic-modem-energy-model.cc.

References m_rxPowerW, and NS_LOG_FUNCTION.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

void ns3::AcousticModemEnergyModel::SetSleepPowerW ( double  sleepPowerW)

Set the sleep power of the modem.

Parameters
sleepPowerWSleep power of the modem in watts.

Definition at line 167 of file acoustic-modem-energy-model.cc.

References m_sleepPowerW, and NS_LOG_FUNCTION.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

void ns3::AcousticModemEnergyModel::SetTxPowerW ( double  txPowerW)

Set the transmission power of the modem.

Parameters
txPowerWTransmission power in watts.

Definition at line 125 of file acoustic-modem-energy-model.cc.

References m_txPowerW, and NS_LOG_FUNCTION.

Referenced by GetTypeId().

+ Here is the caller graph for this function:

Member Data Documentation

int ns3::AcousticModemEnergyModel::m_currentState
private
AcousticModemEnergyDepletionCallback ns3::AcousticModemEnergyModel::m_energyDepletionCallback
private

Energy depletion callback.

Definition at line 215 of file acoustic-modem-energy-model.h.

Referenced by AcousticModemEnergyModel(), DoDispose(), HandleEnergyDepletion(), and SetEnergyDepletionCallback().

double ns3::AcousticModemEnergyModel::m_idlePowerW
private

The idle power, in watts.

Definition at line 204 of file acoustic-modem-energy-model.h.

Referenced by ChangeState(), DoGetCurrentA(), GetIdlePowerW(), and SetIdlePowerW().

Time ns3::AcousticModemEnergyModel::m_lastUpdateTime
private

Time stamp of previous energy update.

Definition at line 212 of file acoustic-modem-energy-model.h.

Referenced by AcousticModemEnergyModel(), and ChangeState().

Ptr<Node> ns3::AcousticModemEnergyModel::m_node
private

The node hosting this transducer.

Definition at line 198 of file acoustic-modem-energy-model.h.

Referenced by AcousticModemEnergyModel(), ChangeState(), DoDispose(), GetNode(), HandleEnergyDepletion(), and SetNode().

double ns3::AcousticModemEnergyModel::m_rxPowerW
private

The receiver power, in watts.

Definition at line 203 of file acoustic-modem-energy-model.h.

Referenced by ChangeState(), DoGetCurrentA(), GetRxPowerW(), and SetRxPowerW().

double ns3::AcousticModemEnergyModel::m_sleepPowerW
private

The sleep power, in watts.

Definition at line 205 of file acoustic-modem-energy-model.h.

Referenced by ChangeState(), DoGetCurrentA(), GetSleepPowerW(), and SetSleepPowerW().

Ptr<EnergySource> ns3::AcousticModemEnergyModel::m_source
private

The energy source.

Definition at line 199 of file acoustic-modem-energy-model.h.

Referenced by AcousticModemEnergyModel(), ChangeState(), DoDispose(), DoGetCurrentA(), and SetEnergySource().

TracedValue<double> ns3::AcousticModemEnergyModel::m_totalEnergyConsumption
private

The total energy consumed by this model.

Definition at line 208 of file acoustic-modem-energy-model.h.

Referenced by ChangeState(), GetTotalEnergyConsumption(), and GetTypeId().

double ns3::AcousticModemEnergyModel::m_txPowerW
private

The transmitter power, in watts.

Definition at line 202 of file acoustic-modem-energy-model.h.

Referenced by ChangeState(), DoGetCurrentA(), GetTxPowerW(), and SetTxPowerW().


The documentation for this class was generated from the following files: