General error model that can be used to corrupt packets. More...
#include "error-model.h"
Public Member Functions | |
ErrorModel () | |
~ErrorModel () override | |
void | Disable () |
Disable the error model. | |
void | Enable () |
Enable the error model. | |
bool | IsCorrupt (Ptr< Packet > pkt) |
Note: Depending on the error model, this function may or may not alter the contents of the packet upon returning true. | |
bool | IsEnabled () const |
void | Reset () |
Reset any state associated with the error model. | |
Public Member Functions inherited from ns3::Object | |
Object () | |
Constructor. | |
~Object () override | |
Destructor. | |
void | AggregateObject (Ptr< Object > other) |
Aggregate two Objects together. | |
void | Dispose () |
Dispose of this Object. | |
AggregateIterator | GetAggregateIterator () const |
Get an iterator to the Objects aggregated to this one. | |
TypeId | GetInstanceTypeId () const override |
Get the most derived TypeId for this Object. | |
template<typename T > | |
Ptr< T > | GetObject () const |
Get a pointer to the requested aggregated Object. | |
template<> | |
Ptr< Object > | GetObject () const |
Specialization of () for objects of type ns3::Object. | |
template<typename T > | |
Ptr< T > | GetObject (TypeId tid) const |
Get a pointer to the requested aggregated Object by TypeId. | |
template<> | |
Ptr< Object > | GetObject (TypeId tid) const |
Specialization of (TypeId tid) for objects of type ns3::Object. | |
void | Initialize () |
Invoke DoInitialize on all Objects aggregated to this one. | |
bool | IsInitialized () const |
Check if the object has been initialized. | |
void | UnidirectionalAggregateObject (Ptr< Object > other) |
Aggregate an Object to another Object. | |
Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter > | |
SimpleRefCount () | |
Default constructor. | |
SimpleRefCount (const SimpleRefCount &o) | |
Copy constructor. | |
uint32_t | GetReferenceCount () const |
Get the reference count of the object. | |
SimpleRefCount & | operator= (const SimpleRefCount &o) |
Assignment operator. | |
void | Ref () const |
Increment the reference count. | |
void | Unref () const |
Decrement the reference count. | |
Public Member Functions inherited from ns3::ObjectBase | |
virtual | ~ObjectBase () |
Virtual destructor. | |
void | GetAttribute (std::string name, AttributeValue &value, bool permissive=false) const |
Get the value of an attribute, raising fatal errors if unsuccessful. | |
bool | GetAttributeFailSafe (std::string name, AttributeValue &value) const |
Get the value of an attribute without raising errors. | |
void | SetAttribute (std::string name, const AttributeValue &value) |
Set a single attribute, raising fatal errors if unsuccessful. | |
bool | SetAttributeFailSafe (std::string name, const AttributeValue &value) |
Set a single attribute without raising errors. | |
bool | TraceConnect (std::string name, std::string context, const CallbackBase &cb) |
Connect a TraceSource to a Callback with a context. | |
bool | TraceConnectWithoutContext (std::string name, const CallbackBase &cb) |
Connect a TraceSource to a Callback without a context. | |
bool | TraceDisconnect (std::string name, std::string context, const CallbackBase &cb) |
Disconnect from a TraceSource a Callback previously connected with a context. | |
bool | TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb) |
Disconnect from a TraceSource a Callback previously connected without a context. | |
Static Public Member Functions | |
static TypeId | GetTypeId () |
Get the type ID. | |
Static Public Member Functions inherited from ns3::Object | |
static TypeId | GetTypeId () |
Register this type. | |
Static Public Member Functions inherited from ns3::ObjectBase | |
static TypeId | GetTypeId () |
Get the type ID. | |
Private Member Functions | |
virtual bool | DoCorrupt (Ptr< Packet > p)=0 |
Corrupt a packet according to the specified model. | |
virtual void | DoReset ()=0 |
Re-initialize any state. | |
Private Attributes | |
bool | m_enable |
True if the error model is enabled. | |
Additional Inherited Members | |
Protected Member Functions inherited from ns3::Object | |
Object (const Object &o) | |
Copy an Object. | |
virtual void | DoDispose () |
Destructor implementation. | |
virtual void | DoInitialize () |
Initialize() implementation. | |
virtual void | NotifyNewAggregate () |
Notify all Objects aggregated to this one of a new Object being aggregated. | |
Protected Member Functions inherited from ns3::ObjectBase | |
void | ConstructSelf (const AttributeConstructionList &attributes) |
Complete construction of ObjectBase; invoked by derived classes. | |
virtual void | NotifyConstructionCompleted () |
Notifier called once the ObjectBase is fully constructed. | |
Related Symbols inherited from ns3::ObjectBase | |
static TypeId | GetObjectIid () |
Ensure the TypeId for ObjectBase gets fully configured to anchor the inheritance tree properly. | |
General error model that can be used to corrupt packets.
This object is used to flag packets as being lost/errored or not. It is part of the Object framework and can be aggregated to other ns3 objects and handled by the Ptr class.
The main method is IsCorrupt(Ptr<Packet> p) which returns true if the packet is to be corrupted according to the underlying model. Depending on the error model, the packet itself may have its packet data buffer errored or not, or side information may be returned to the client in the form of a packet tag. (Note: No such error models that actually error the bits in a packet presently exist). The object can have state (resettable by Reset()). The object can also be enabled and disabled via two public member functions.
Typical code (simplified) to use an ErrorModel may look something like this:
Four practical error models, a RateErrorModel, a BurstErrorModel, a ListErrorModel, and a ReceiveListErrorModel, are currently implemented.
Definition at line 105 of file error-model.h.
ns3::ErrorModel::ErrorModel | ( | ) |
Definition at line 85 of file error-model.cc.
References NS_LOG_FUNCTION.
|
override |
Definition at line 91 of file error-model.cc.
References NS_LOG_FUNCTION.
void ns3::ErrorModel::Disable | ( | ) |
Disable the error model.
Definition at line 122 of file error-model.cc.
References m_enable, and NS_LOG_FUNCTION.
Corrupt a packet according to the specified model.
p | the packet to corrupt |
Implemented in ns3::BinaryErrorModel, ns3::BurstErrorModel, ns3::ListErrorModel, ns3::RateErrorModel, ns3::ReceiveListErrorModel, and ns3::TcpGeneralErrorModel.
Referenced by IsCorrupt().
|
privatepure virtual |
Re-initialize any state.
Implemented in ns3::BinaryErrorModel, ns3::BurstErrorModel, ns3::ListErrorModel, ns3::RateErrorModel, ns3::ReceiveListErrorModel, ns3::TcpFlagErrorModel, ns3::TcpSeqErrorModel, and TcpDropRatioErrorModel.
Referenced by Reset().
void ns3::ErrorModel::Enable | ( | ) |
Enable the error model.
Definition at line 115 of file error-model.cc.
References m_enable, and NS_LOG_FUNCTION.
|
static |
Get the type ID.
Definition at line 72 of file error-model.cc.
References m_enable, ns3::MakeBooleanAccessor(), ns3::MakeBooleanChecker(), and ns3::TypeId::SetParent().
Note: Depending on the error model, this function may or may not alter the contents of the packet upon returning true.
pkt | Packet to apply error model to |
Definition at line 97 of file error-model.cc.
References DoCorrupt(), and NS_LOG_FUNCTION.
bool ns3::ErrorModel::IsEnabled | ( | ) | const |
Definition at line 129 of file error-model.cc.
References m_enable, and NS_LOG_FUNCTION.
Referenced by ns3::BinaryErrorModel::DoCorrupt(), ns3::BurstErrorModel::DoCorrupt(), ns3::ListErrorModel::DoCorrupt(), ns3::RateErrorModel::DoCorrupt(), ns3::ReceiveListErrorModel::DoCorrupt(), and ns3::TcpGeneralErrorModel::DoCorrupt().
void ns3::ErrorModel::Reset | ( | ) |
Reset any state associated with the error model.
Definition at line 108 of file error-model.cc.
References DoReset(), and NS_LOG_FUNCTION.
|
private |
True if the error model is enabled.
Definition at line 154 of file error-model.h.
Referenced by Disable(), Enable(), GetTypeId(), and IsEnabled().