a Friis propagation loss model More...
#include "propagation-loss-model.h"
Public Member Functions | |
FriisPropagationLossModel () | |
FriisPropagationLossModel (const FriisPropagationLossModel &)=delete | |
double | GetFrequency () const |
double | GetMinLoss () const |
double | GetSystemLoss () const |
FriisPropagationLossModel & | operator= (const FriisPropagationLossModel &)=delete |
void | SetFrequency (double frequency) |
void | SetMinLoss (double minLoss) |
void | SetSystemLoss (double systemLoss) |
![]() | |
PropagationLossModel () | |
PropagationLossModel (const PropagationLossModel &)=delete | |
~PropagationLossModel () override | |
int64_t | AssignStreams (int64_t stream) |
If this loss model uses objects of type RandomVariableStream, set the stream numbers to the integers starting with the offset 'stream'. | |
double | CalcRxPower (double txPowerDbm, Ptr< MobilityModel > a, Ptr< MobilityModel > b) const |
Returns the Rx Power taking into account all the PropagationLossModel(s) chained to the current one. | |
Ptr< PropagationLossModel > | GetNext () |
Gets the next PropagationLossModel in the chain of loss models that act on the signal. | |
PropagationLossModel & | operator= (const PropagationLossModel &)=delete |
void | SetNext (Ptr< PropagationLossModel > next) |
Enables a chain of loss models to act on the signal. | |
![]() | |
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. | |
![]() | |
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. | |
![]() | |
virtual | ~ObjectBase () |
Virtual destructor. | |
void | GetAttribute (std::string name, AttributeValue &value) 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. | |
virtual TypeId | GetInstanceTypeId () const =0 |
Get the most derived TypeId for this Object. | |
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 TypeId | GetTypeId () |
Get the type ID. | |
![]() | |
static TypeId | GetTypeId () |
Register this type. | |
![]() | |
static TypeId | GetTypeId () |
Get the type ID. | |
Private Member Functions | |
double | DbmFromW (double w) const |
Transforms a Watt value to Dbm. | |
double | DbmToW (double dbm) const |
Transforms a Dbm value to Watt. | |
int64_t | DoAssignStreams (int64_t stream) override |
Assign a fixed random variable stream number to the random variables used by this model. | |
double | DoCalcRxPower (double txPowerDbm, Ptr< MobilityModel > a, Ptr< MobilityModel > b) const override |
PropagationLossModel. | |
Private Attributes | |
double | m_frequency |
the carrier frequency | |
double | m_lambda |
the carrier wavelength | |
double | m_minLoss |
the minimum loss | |
double | m_systemLoss |
the system loss | |
Additional Inherited Members | |
virtual int64_t | DoAssignStreams (int64_t stream)=0 |
Assign a fixed random variable stream number to the random variables used by this model. | |
![]() | |
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. | |
![]() | |
void | ConstructSelf (const AttributeConstructionList &attributes) |
Complete construction of ObjectBase; invoked by derived classes. | |
virtual void | NotifyConstructionCompleted () |
Notifier called once the ObjectBase is fully constructed. | |
![]() | |
static TypeId | GetObjectIid () |
Ensure the TypeId for ObjectBase gets fully configured to anchor the inheritance tree properly. | |
a Friis propagation loss model
The Friis propagation loss model was first described in "A Note on a Simple Transmission Formula", by "Harald T. Friis".
The original equation was described as:
The final equation becomes:
Modern extensions to this original equation are:
With:
In the implementation,
The Friis model is valid only for propagation in free space within the so-called far field region, which can be considered approximately as the region for
Related with this issue, we note that the Friis formula is undefined for
To avoid these artifact, this implementation of the Friis model provides an attribute called MinLoss which allows to specify the minimum total loss (in dB) returned by the model. This is used in such a way that
ns3::FriisPropagationLossModel is accessible through the following paths with Config::Set and Config::Connect:
No TraceSources are defined for this type.
Size of this type is 72 bytes (on a 64-bit architecture).
Definition at line 252 of file propagation-loss-model.h.
ns3::FriisPropagationLossModel::FriisPropagationLossModel | ( | ) |
Definition at line 177 of file propagation-loss-model.cc.
|
delete |
Transforms a Watt value to Dbm.
w | the Watt value |
Definition at line 227 of file propagation-loss-model.cc.
Transforms a Dbm value to Watt.
dbm | the Dbm value |
Definition at line 220 of file propagation-loss-model.cc.
|
overrideprivatevirtual |
Assign a fixed random variable stream number to the random variables used by this model.
Subclasses must implement this; those not using random variables can return zero.
stream | first stream index to use |
Implements ns3::PropagationLossModel.
Definition at line 285 of file propagation-loss-model.cc.
|
overrideprivatevirtual |
txPowerDbm | current transmission power (in dBm) |
a | the mobility model of the source |
b | the mobility model of the destination |
Implements ns3::PropagationLossModel.
Definition at line 234 of file propagation-loss-model.cc.
References m_lambda, m_minLoss, m_systemLoss, NS_LOG_DEBUG, and NS_LOG_WARN.
double ns3::FriisPropagationLossModel::GetFrequency | ( | ) | const |
Definition at line 214 of file propagation-loss-model.cc.
References m_frequency.
Referenced by GetTypeId().
double ns3::FriisPropagationLossModel::GetMinLoss | ( | ) | const |
Definition at line 200 of file propagation-loss-model.cc.
References m_minLoss.
Referenced by GetTypeId().
double ns3::FriisPropagationLossModel::GetSystemLoss | ( | ) | const |
Definition at line 188 of file propagation-loss-model.cc.
References m_systemLoss.
|
static |
Get the type ID.
Definition at line 149 of file propagation-loss-model.cc.
References GetFrequency(), GetMinLoss(), m_systemLoss, ns3::MakeDoubleAccessor(), SetFrequency(), SetMinLoss(), and ns3::TypeId::SetParent().
Referenced by ns3::LteHelper::GetTypeId().
|
delete |
void ns3::FriisPropagationLossModel::SetFrequency | ( | double | frequency | ) |
frequency | (Hz) |
Set the carrier frequency used in the Friis model calculation.
Definition at line 206 of file propagation-loss-model.cc.
References m_frequency, and m_lambda.
Referenced by GetTypeId().
void ns3::FriisPropagationLossModel::SetMinLoss | ( | double | minLoss | ) |
minLoss | the minimum loss (dB) |
no matter how short the distance, the total propagation loss (in dB) will always be greater or equal than this value
Definition at line 194 of file propagation-loss-model.cc.
References m_minLoss.
Referenced by GetTypeId().
void ns3::FriisPropagationLossModel::SetSystemLoss | ( | double | systemLoss | ) |
systemLoss | (dimension-less) |
Set the system loss used by the Friis propagation model.
Definition at line 182 of file propagation-loss-model.cc.
References m_systemLoss.
|
private |
the carrier frequency
Definition at line 323 of file propagation-loss-model.h.
Referenced by GetFrequency(), and SetFrequency().
|
private |
the carrier wavelength
Definition at line 322 of file propagation-loss-model.h.
Referenced by DoCalcRxPower(), and SetFrequency().
|
private |
the minimum loss
Definition at line 325 of file propagation-loss-model.h.
Referenced by DoCalcRxPower(), GetMinLoss(), and SetMinLoss().
|
private |
the system loss
Definition at line 324 of file propagation-loss-model.h.
Referenced by DoCalcRxPower(), GetSystemLoss(), GetTypeId(), and SetSystemLoss().