Cosine Antenna Model. More...
#include "cosine-antenna-model.h"
Public Member Functions | |
virtual double | GetGainDb (Angles a) |
this method is expected to be re-implemented by each antenna model More... | |
double | GetHorizontalBeamwidth (void) const |
Get the horizontal 3 dB beamwidth of the cosine antenna model. More... | |
double | GetOrientation (void) const |
Get the horizontal orientation of the antenna element. More... | |
double | GetVerticalBeamwidth (void) const |
Get the vertical 3 dB beamwidth of the cosine antenna model. More... | |
Public Member Functions inherited from ns3::AntennaModel | |
AntennaModel () | |
virtual | ~AntennaModel () |
Public Member Functions inherited from ns3::Object | |
Object () | |
Constructor. More... | |
virtual | ~Object () |
Destructor. More... | |
void | AggregateObject (Ptr< Object > other) |
Aggregate two Objects together. More... | |
void | Dispose (void) |
Dispose of this Object. More... | |
AggregateIterator | GetAggregateIterator (void) const |
Get an iterator to the Objects aggregated to this one. More... | |
virtual TypeId | GetInstanceTypeId (void) const |
Get the most derived TypeId for this 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... | |
template<typename T > | |
Ptr< T > | GetObject (void) const |
Get a pointer to the requested aggregated Object. More... | |
void | Initialize (void) |
Invoke DoInitialize on all Objects aggregated to this one. More... | |
bool | IsInitialized (void) 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 (void) const |
Get the reference count of the object. More... | |
SimpleRefCount & | operator= ([[maybe_unused]] const SimpleRefCount &o) |
Assignment operator. 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 |
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 erros. 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::AntennaModel | |
static TypeId | GetTypeId () |
Get the type ID. More... | |
Static Public Member Functions inherited from ns3::Object | |
static TypeId | GetTypeId (void) |
Register this type. More... | |
Static Public Member Functions inherited from ns3::ObjectBase | |
static TypeId | GetTypeId (void) |
Get the type ID. More... | |
Private Member Functions | |
void | SetHorizontalBeamwidth (double horizontalBeamwidthDegrees) |
Set the horizontal 3 dB beamwidth (bilateral) of the cosine antenna model. More... | |
void | SetOrientation (double orientationDegrees) |
Set the horizontal orientation of the antenna element. More... | |
void | SetVerticalBeamwidth (double verticalBeamwidthDegrees) |
Set the vertical 3 dB beamwidth (bilateral) of the cosine antenna model. More... | |
Static Private Member Functions | |
static double | GetBeamwidthFromExponent (double exponent) |
Compute the beamwidth of the cosine antenna model from the exponent. More... | |
static double | GetExponentFromBeamwidth (double beamwidthDegrees) |
Compute the exponent of the cosine antenna model from the beamwidth. More... | |
Private Attributes | |
double | m_horizontalExponent |
exponent of the horizontal direction More... | |
double | m_maxGain |
antenna gain in dB towards the main orientation More... | |
double | m_orientationRadians |
orientation in radians in the horizontal direction (bearing) More... | |
double | m_verticalExponent |
exponent of the vertical direction More... | |
Additional Inherited Members | |
Protected Member Functions inherited from ns3::Object | |
Object (const Object &o) | |
Copy an Object. More... | |
virtual void | DoDispose (void) |
Destructor implementation. More... | |
virtual void | DoInitialize (void) |
Initialize() implementation. More... | |
virtual void | NotifyNewAggregate (void) |
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 (void) |
Notifier called once the ObjectBase is fully constructed. More... | |
Related Functions inherited from ns3::ObjectBase | |
static TypeId | GetObjectIid (void) |
Ensure the TypeId for ObjectBase gets fully configured to anchor the inheritance tree properly. More... | |
Cosine Antenna Model.
Introspection did not find any typical Config paths.
This class implements the cosine model, similarly to what is described in: Cosine Antenna Element, Mathworks, Phased Array System Toolbox (Sep. 2020) Available online: https://www.mathworks.com/help/phased/ug/cosine-antenna-element.html
The power pattern of the element is equal to: P(az,el) = cos(az/2)^2m * cos(pi/2 - incl/2)^2n, where az is the azimuth angle, and incl is the inclination angle.
Differently from the source, the response is defined for azimuth and elevation angles between –180 and 180 degrees and is always positive. There is no response at the backside of a cosine antenna. The cosine response pattern achieves a maximum value of 1 (0 dB) at 0 degrees azimuth and 90 degrees inclination. An extra settable gain is added to the original model, to improve its generality.
No TraceSources are defined for this type.
Size of this type is 64 bytes (on a 64-bit architecture).
Definition at line 50 of file cosine-antenna-model.h.
|
staticprivate |
Compute the beamwidth of the cosine antenna model from the exponent.
exponent | the exponent |
Definition at line 97 of file cosine-antenna-model.cc.
References NS_LOG_FUNCTION, and ns3::RadiansToDegrees().
Referenced by GetHorizontalBeamwidth(), and GetVerticalBeamwidth().
|
staticprivate |
Compute the exponent of the cosine antenna model from the beamwidth.
beamwidthDegrees | the beamwidth in degrees |
Definition at line 73 of file cosine-antenna-model.cc.
References ns3::DegreesToRadians(), and NS_LOG_FUNCTION.
Referenced by SetHorizontalBeamwidth(), and SetVerticalBeamwidth().
|
virtual |
this method is expected to be re-implemented by each antenna model
a | the spherical angles at which the radiation pattern should be evaluated |
Implements ns3::AntennaModel.
Definition at line 155 of file cosine-antenna-model.cc.
References ns3::Angles::GetAzimuth(), ns3::Angles::GetInclination(), m_horizontalExponent, m_maxGain, m_orientationRadians, m_verticalExponent, NS_LOG_FUNCTION, NS_LOG_LOGIC, and ns3::Angles::SetAzimuth().
double ns3::CosineAntennaModel::GetHorizontalBeamwidth | ( | void | ) | const |
Get the horizontal 3 dB beamwidth of the cosine antenna model.
Definition at line 133 of file cosine-antenna-model.cc.
References GetBeamwidthFromExponent(), and m_horizontalExponent.
Referenced by GetTypeId().
double ns3::CosineAntennaModel::GetOrientation | ( | void | ) | const |
Get the horizontal orientation of the antenna element.
Definition at line 148 of file cosine-antenna-model.cc.
References m_orientationRadians, and ns3::RadiansToDegrees().
Referenced by GetTypeId().
|
static |
Get the type ID.
Definition at line 38 of file cosine-antenna-model.cc.
References GetHorizontalBeamwidth(), GetOrientation(), GetVerticalBeamwidth(), m_maxGain, ns3::MakeDoubleAccessor(), SetHorizontalBeamwidth(), SetOrientation(), ns3::TypeId::SetParent(), and SetVerticalBeamwidth().
double ns3::CosineAntennaModel::GetVerticalBeamwidth | ( | void | ) | const |
Get the vertical 3 dB beamwidth of the cosine antenna model.
Definition at line 126 of file cosine-antenna-model.cc.
References GetBeamwidthFromExponent(), and m_verticalExponent.
Referenced by GetTypeId().
|
private |
Set the horizontal 3 dB beamwidth (bilateral) of the cosine antenna model.
horizontalBeamwidthDegrees | the horizontal beamwidth in degrees |
Definition at line 118 of file cosine-antenna-model.cc.
References GetExponentFromBeamwidth(), m_horizontalExponent, and NS_LOG_FUNCTION.
Referenced by GetTypeId().
|
private |
Set the horizontal orientation of the antenna element.
orientationDegrees | the horizontal orientation in degrees |
Definition at line 140 of file cosine-antenna-model.cc.
References ns3::DegreesToRadians(), m_orientationRadians, and NS_LOG_FUNCTION.
Referenced by GetTypeId().
|
private |
Set the vertical 3 dB beamwidth (bilateral) of the cosine antenna model.
verticalBeamwidthDegrees | the vertical beamwidth in degrees |
Definition at line 110 of file cosine-antenna-model.cc.
References GetExponentFromBeamwidth(), m_verticalExponent, and NS_LOG_FUNCTION.
Referenced by GetTypeId().
|
private |
exponent of the horizontal direction
Definition at line 115 of file cosine-antenna-model.h.
Referenced by GetGainDb(), GetHorizontalBeamwidth(), and SetHorizontalBeamwidth().
|
private |
antenna gain in dB towards the main orientation
Definition at line 117 of file cosine-antenna-model.h.
Referenced by GetGainDb(), and GetTypeId().
|
private |
orientation in radians in the horizontal direction (bearing)
Definition at line 116 of file cosine-antenna-model.h.
Referenced by GetGainDb(), GetOrientation(), and SetOrientation().
|
private |
exponent of the vertical direction
Definition at line 114 of file cosine-antenna-model.h.
Referenced by GetGainDb(), GetVerticalBeamwidth(), and SetVerticalBeamwidth().