A Discrete-Event Network Simulator
Home
Tutorials ▼
English
Documentation ▼
Installation
Manual
Models
Contributing
Wiki
Development ▼
API Docs
Issue Tracker
Merge Requests
API
spectrum-propagation-loss-model.cc
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2010 CTTC
3
*
4
* This program is free software; you can redistribute it and/or modify
5
* it under the terms of the GNU General Public License version 2 as
6
* published by the Free Software Foundation;
7
*
8
* This program is distributed in the hope that it will be useful,
9
* but WITHOUT ANY WARRANTY; without even the implied warranty of
10
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11
* GNU General Public License for more details.
12
*
13
* You should have received a copy of the GNU General Public License
14
* along with this program; if not, write to the Free Software
15
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16
*
17
* Author: Nicola Baldo <nbaldo@cttc.es>
18
*/
19
20
#include "
spectrum-propagation-loss-model.h
"
21
22
#include "
spectrum-signal-parameters.h
"
23
24
#include <ns3/log.h>
25
26
namespace
ns3
27
{
28
29
NS_LOG_COMPONENT_DEFINE
(
"SpectrumPropagationLossModel"
);
30
31
NS_OBJECT_ENSURE_REGISTERED
(SpectrumPropagationLossModel);
32
33
SpectrumPropagationLossModel::SpectrumPropagationLossModel
()
34
: m_next(nullptr)
35
{
36
}
37
38
SpectrumPropagationLossModel::~SpectrumPropagationLossModel
()
39
{
40
}
41
42
void
43
SpectrumPropagationLossModel::DoDispose
()
44
{
45
m_next
=
nullptr
;
46
}
47
48
TypeId
49
SpectrumPropagationLossModel::GetTypeId
()
50
{
51
static
TypeId
tid =
52
TypeId
(
"ns3::SpectrumPropagationLossModel"
).
SetParent
<
Object
>().SetGroupName(
"Spectrum"
);
53
return
tid;
54
}
55
56
void
57
SpectrumPropagationLossModel::SetNext
(
Ptr<SpectrumPropagationLossModel>
next)
58
{
59
m_next
= next;
60
}
61
62
Ptr<SpectrumPropagationLossModel>
63
SpectrumPropagationLossModel::GetNext
()
const
64
{
65
return
m_next
;
66
}
67
68
Ptr<SpectrumValue>
69
SpectrumPropagationLossModel::CalcRxPowerSpectralDensity
(
Ptr<const SpectrumSignalParameters>
params
,
70
Ptr<const MobilityModel>
a,
71
Ptr<const MobilityModel>
b)
const
72
{
73
Ptr<SpectrumValue>
rxPsd =
DoCalcRxPowerSpectralDensity
(
params
, a, b);
74
if
(
m_next
)
75
{
76
rxPsd =
m_next
->CalcRxPowerSpectralDensity(
params
, a, b);
77
}
78
return
rxPsd;
79
}
80
81
int64_t
82
SpectrumPropagationLossModel::AssignStreams
(int64_t stream)
83
{
84
auto
currentStream = stream;
85
currentStream +=
DoAssignStreams
(stream);
86
if
(
m_next
)
87
{
88
currentStream +=
m_next
->AssignStreams(currentStream);
89
}
90
return
(currentStream - stream);
91
}
92
93
}
// namespace ns3
ns3::Object
A base class which provides memory management and object aggregation.
Definition:
object.h:89
ns3::Ptr
Smart pointer class similar to boost::intrusive_ptr.
Definition:
ptr.h:77
ns3::SpectrumPropagationLossModel::SpectrumPropagationLossModel
SpectrumPropagationLossModel()
Definition:
spectrum-propagation-loss-model.cc:33
ns3::SpectrumPropagationLossModel::CalcRxPowerSpectralDensity
Ptr< SpectrumValue > CalcRxPowerSpectralDensity(Ptr< const SpectrumSignalParameters > params, Ptr< const MobilityModel > a, Ptr< const MobilityModel > b) const
This method is to be called to calculate.
Definition:
spectrum-propagation-loss-model.cc:69
ns3::SpectrumPropagationLossModel::DoCalcRxPowerSpectralDensity
virtual Ptr< SpectrumValue > DoCalcRxPowerSpectralDensity(Ptr< const SpectrumSignalParameters > params, Ptr< const MobilityModel > a, Ptr< const MobilityModel > b) const =0
ns3::SpectrumPropagationLossModel::~SpectrumPropagationLossModel
~SpectrumPropagationLossModel() override
Definition:
spectrum-propagation-loss-model.cc:38
ns3::SpectrumPropagationLossModel::SetNext
void SetNext(Ptr< SpectrumPropagationLossModel > next)
Used to chain various instances of SpectrumPropagationLossModel.
Definition:
spectrum-propagation-loss-model.cc:57
ns3::SpectrumPropagationLossModel::m_next
Ptr< SpectrumPropagationLossModel > m_next
SpectrumPropagationLossModel chained to this one.
Definition:
spectrum-propagation-loss-model.h:123
ns3::SpectrumPropagationLossModel::AssignStreams
int64_t AssignStreams(int64_t stream)
If this loss model uses objects of type RandomVariableStream, set the stream numbers to the integers ...
Definition:
spectrum-propagation-loss-model.cc:82
ns3::SpectrumPropagationLossModel::GetTypeId
static TypeId GetTypeId()
Get the type ID.
Definition:
spectrum-propagation-loss-model.cc:49
ns3::SpectrumPropagationLossModel::GetNext
Ptr< SpectrumPropagationLossModel > GetNext() const
Return the pointer to the next SpectrumPropagationLossModel, if any.
Definition:
spectrum-propagation-loss-model.cc:63
ns3::SpectrumPropagationLossModel::DoAssignStreams
virtual int64_t DoAssignStreams(int64_t stream)=0
Assign a fixed random variable stream number to the random variables used by this model.
ns3::SpectrumPropagationLossModel::DoDispose
void DoDispose() override
Destructor implementation.
Definition:
spectrum-propagation-loss-model.cc:43
ns3::TypeId
a unique identifier for an interface.
Definition:
type-id.h:59
ns3::TypeId::SetParent
TypeId SetParent(TypeId tid)
Set the parent TypeId.
Definition:
type-id.cc:931
NS_LOG_COMPONENT_DEFINE
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition:
log.h:202
NS_OBJECT_ENSURE_REGISTERED
#define NS_OBJECT_ENSURE_REGISTERED(type)
Register an Object subclass with the TypeId system.
Definition:
object-base.h:46
ns3
Every class exported by the ns3 library is enclosed in the ns3 namespace.
two-ray-to-three-gpp-ch-calibration.params
params
Fit Fluctuating Two Ray model to the 3GPP TR 38.901 using the Anderson-Darling goodness-of-fit ##.
Definition:
two-ray-to-three-gpp-ch-calibration.py:514
spectrum-propagation-loss-model.h
spectrum-signal-parameters.h
src
spectrum
model
spectrum-propagation-loss-model.cc
Generated on Sun Mar 3 2024 17:11:08 for ns-3 by
1.9.1