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) |
Public Member Functions inherited from ns3::PropagationLossModel | |
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'. More... | |
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. More... | |
Ptr< PropagationLossModel > | GetNext () |
Gets the next PropagationLossModel in the chain of loss models that act on the signal. More... | |
PropagationLossModel & | operator= (const PropagationLossModel &)=delete |
void | SetNext (Ptr< PropagationLossModel > next) |
Enables a chain of loss models to act on the signal. More... | |
Public Member Functions inherited from ns3::Object | |
Object () | |
Constructor. More... | |
~Object () override | |
Destructor. More... | |
void | AggregateObject (Ptr< Object > other) |
Aggregate two Objects together. More... | |
void | Dispose () |
Dispose of this Object. More... | |
AggregateIterator | GetAggregateIterator () const |
Get an iterator to the Objects aggregated to this one. More... | |
TypeId | GetInstanceTypeId () const override |
Get the most derived TypeId for this Object. More... | |
template<typename T > | |
Ptr< T > | GetObject () const |
Get a pointer to the requested aggregated Object. More... | |
template<> | |
Ptr< Object > | GetObject () const |
Specialization of () for objects of type ns3::Object. More... | |
template<typename T > | |
Ptr< T > | GetObject (TypeId tid) const |
Get a pointer to the requested aggregated Object by TypeId. More... | |
template<> | |
Ptr< Object > | GetObject (TypeId tid) const |
Specialization of (TypeId tid) for objects of type ns3::Object. More... | |
void | Initialize () |
Invoke DoInitialize on all Objects aggregated to this one. More... | |
bool | IsInitialized () const |
Check if the object has been initialized. More... | |
Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter > | |
SimpleRefCount () | |
Default constructor. More... | |
SimpleRefCount (const SimpleRefCount &o[[maybe_unused]]) | |
Copy constructor. More... | |
uint32_t | GetReferenceCount () const |
Get the reference count of the object. More... | |
SimpleRefCount & | operator= (const SimpleRefCount &o[[maybe_unused]]) |
Assignment operator. More... | |
void | Ref () const |
Increment the reference count. More... | |
void | Unref () 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 |
Get the value of an attribute, raising fatal errors if unsuccessful. More... | |
bool | GetAttributeFailSafe (std::string name, AttributeValue &value) const |
Get the value of an attribute without raising errors. More... | |
void | SetAttribute (std::string name, const AttributeValue &value) |
Set a single attribute, raising fatal errors if unsuccessful. More... | |
bool | SetAttributeFailSafe (std::string name, const AttributeValue &value) |
Set a single attribute without raising errors. More... | |
bool | TraceConnect (std::string name, std::string context, const CallbackBase &cb) |
Connect a TraceSource to a Callback with a context. More... | |
bool | TraceConnectWithoutContext (std::string name, const CallbackBase &cb) |
Connect a TraceSource to a Callback without a context. More... | |
bool | TraceDisconnect (std::string name, std::string context, const CallbackBase &cb) |
Disconnect from a TraceSource a Callback previously connected with a context. More... | |
bool | TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb) |
Disconnect from a TraceSource a Callback previously connected without a context. More... | |
Static Public Member Functions | |
static TypeId | GetTypeId () |
Get the type ID. More... | |
Static Public Member Functions inherited from ns3::PropagationLossModel | |
static TypeId | GetTypeId () |
Get the type ID. More... | |
Static Public Member Functions inherited from ns3::Object | |
static TypeId | GetTypeId () |
Register this type. More... | |
Static Public Member Functions inherited from ns3::ObjectBase | |
static TypeId | GetTypeId () |
Get the type ID. More... | |
Private Member Functions | |
double | DbmFromW (double w) const |
Transforms a Watt value to Dbm. More... | |
double | DbmToW (double dbm) const |
Transforms a Dbm value to Watt. More... | |
int64_t | DoAssignStreams (int64_t stream) override |
Assign a fixed random variable stream number to the random variables used by this model. More... | |
double | DoCalcRxPower (double txPowerDbm, Ptr< MobilityModel > a, Ptr< MobilityModel > b) const override |
PropagationLossModel. More... | |
Private Attributes | |
double | m_frequency |
the carrier frequency More... | |
double | m_lambda |
the carrier wavelength More... | |
double | m_minLoss |
the minimum loss More... | |
double | m_systemLoss |
the system loss More... | |
Additional Inherited Members | |
Protected Member Functions inherited from ns3::Object | |
Object (const Object &o) | |
Copy an Object. More... | |
virtual void | DoDispose () |
Destructor implementation. More... | |
virtual void | DoInitialize () |
Initialize() implementation. More... | |
virtual void | NotifyNewAggregate () |
Notify all Objects aggregated to this one of a new Object being aggregated. More... | |
Protected Member Functions inherited from ns3::ObjectBase | |
void | ConstructSelf (const AttributeConstructionList &attributes) |
Complete construction of ObjectBase; invoked by derived classes. More... | |
virtual void | NotifyConstructionCompleted () |
Notifier called once the ObjectBase is fully constructed. More... | |
Related Functions inherited from ns3::ObjectBase | |
static TypeId | GetObjectIid () |
Ensure the TypeId for ObjectBase gets fully configured to anchor the inheritance tree properly. More... | |
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: with the following equation for the case of an isotropic antenna with no heat loss:
The final equation becomes:
Modern extensions to this original equation are:
With:
In the implementation, is calculated as , where m/s is the speed of light in vacuum, and is the frequency in Hz which can be configured by the user via the Frequency attribute.
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 . The model will still return a value for , as doing so (rather than triggering a fatal error) is practical for many simulation scenarios. However, we stress that the values obtained in such conditions shall not be considered realistic.
Related with this issue, we note that the Friis formula is undefined for , and results in for . Both these conditions occur outside of the far field region, so in principle the Friis model shall not be used in these conditions. In practice, however, Friis is often used in scenarios where accurate propagation modeling is not deemed important, and values of can occur. To allow practical use of the model in such scenarios, we have to 1) return some value for , and 2) avoid large discontinuities in propagation loss values (which could lead to artifacts such as bogus capture effects which are much worse than inaccurate propagation loss values). The two issues are conflicting, as, according to the Friis formula, ; so if, for , we use a fixed loss value, we end up with an infinitely large discontinuity, which as we discussed can cause undesirable simulation artifacts.
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 continuously increases for , until MinLoss is reached, and then stay constant; this allow to return a value for and at the same time avoid discontinuities. The model won't be much realistic, but at least the simulation artifacts discussed before are avoided. The default value of MinLoss is 0 dB, which means that by default the model will return for . We note that this value of is outside of the far field region, hence the validity of the model in the far field region is not affected.
Definition at line 252 of file propagation-loss-model.h.
ns3::FriisPropagationLossModel::FriisPropagationLossModel | ( | ) |
Definition at line 177 of file propagation-loss-model.cc.
|
delete |
|
private |
Transforms a Watt value to Dbm.
w | the Watt value |
Definition at line 227 of file propagation-loss-model.cc.
|
private |
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 ns3::MobilityModel::GetDistanceFrom(), m_lambda, m_minLoss, m_systemLoss, max, 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().