|
17 |
* |
17 |
* |
18 |
* Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr> |
18 |
* Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr> |
19 |
* Contributions: Timo Bingmann <timo.bingmann@student.kit.edu> |
19 |
* Contributions: Timo Bingmann <timo.bingmann@student.kit.edu> |
|
|
20 |
* Contributions: Tom Hewer <t.hewer@cs.ucl.ac.uk> for Two Ray Ground Model |
20 |
*/ |
21 |
*/ |
21 |
|
22 |
|
22 |
#include "propagation-loss-model.h" |
23 |
#include "propagation-loss-model.h" |
|
29 |
NS_LOG_COMPONENT_DEFINE ("PropagationLossModel"); |
30 |
NS_LOG_COMPONENT_DEFINE ("PropagationLossModel"); |
30 |
|
31 |
|
31 |
namespace ns3 { |
32 |
namespace ns3 { |
32 |
|
33 |
|
33 |
// ------------------------------------------------------------------------- // |
34 |
// ------------------------------------------------------------------------- // |
34 |
|
35 |
|
35 |
NS_OBJECT_ENSURE_REGISTERED (PropagationLossModel); |
36 |
NS_OBJECT_ENSURE_REGISTERED (PropagationLossModel); |
36 |
|
37 |
|
37 |
TypeId |
38 |
TypeId |
38 |
PropagationLossModel::GetTypeId (void) |
39 |
PropagationLossModel::GetTypeId (void) |
39 |
{ |
40 |
{ |
40 |
static TypeId tid = TypeId ("ns3::PropagationLossModel") |
41 |
static TypeId tid = TypeId ("ns3::PropagationLossModel") |
41 |
.SetParent<Object> () |
42 |
.SetParent<Object> () |
42 |
; |
43 |
; |
43 |
return tid; |
44 |
return tid; |
44 |
} |
45 |
} |
45 |
|
46 |
|
46 |
PropagationLossModel::PropagationLossModel () |
47 |
PropagationLossModel::PropagationLossModel () |
47 |
: m_next (0) |
48 |
: m_next (0) |
48 |
{} |
49 |
{} |
49 |
|
50 |
|
50 |
PropagationLossModel::~PropagationLossModel () |
51 |
PropagationLossModel::~PropagationLossModel () |
51 |
{} |
52 |
{} |
52 |
|
53 |
|
53 |
void |
54 |
void |
54 |
PropagationLossModel::SetNext (Ptr<PropagationLossModel> next) |
55 |
PropagationLossModel::SetNext (Ptr<PropagationLossModel> next) |
55 |
{ |
56 |
{ |
56 |
m_next = next; |
57 |
m_next = next; |
57 |
} |
58 |
} |
58 |
|
59 |
|
59 |
double |
60 |
double |
60 |
PropagationLossModel::CalcRxPower (double txPowerDbm, |
61 |
PropagationLossModel::CalcRxPower (double txPowerDbm, |
61 |
Ptr<MobilityModel> a, |
62 |
Ptr<MobilityModel> a, |
62 |
Ptr<MobilityModel> b) const |
63 |
Ptr<MobilityModel> b) const |
63 |
{ |
64 |
{ |
64 |
double self = DoCalcRxPower (txPowerDbm, a, b); |
65 |
double self = DoCalcRxPower (txPowerDbm, a, b); |
65 |
if (m_next != 0) |
66 |
if (m_next != 0) |
66 |
{ |
67 |
{ |
67 |
self = m_next->CalcRxPower (self, a, b); |
68 |
self = m_next->CalcRxPower (self, a, b); |
68 |
} |
69 |
} |
69 |
return self; |
70 |
return self; |
70 |
} |
71 |
} |
71 |
|
72 |
|
72 |
// ------------------------------------------------------------------------- // |
73 |
// ------------------------------------------------------------------------- // |
73 |
|
74 |
|
74 |
NS_OBJECT_ENSURE_REGISTERED (RandomPropagationLossModel); |
75 |
NS_OBJECT_ENSURE_REGISTERED (RandomPropagationLossModel); |
75 |
|
76 |
|
76 |
TypeId |
77 |
TypeId |
77 |
RandomPropagationLossModel::GetTypeId (void) |
78 |
RandomPropagationLossModel::GetTypeId (void) |
78 |
{ |
79 |
{ |
79 |
static TypeId tid = TypeId ("ns3::RandomPropagationLossModel") |
80 |
static TypeId tid = TypeId ("ns3::RandomPropagationLossModel") |
80 |
.SetParent<PropagationLossModel> () |
81 |
.SetParent<PropagationLossModel> () |
81 |
.AddConstructor<RandomPropagationLossModel> () |
82 |
.AddConstructor<RandomPropagationLossModel> () |
82 |
.AddAttribute ("Variable", "The random variable used to pick a loss everytime CalcRxPower is invoked.", |
83 |
.AddAttribute ("Variable", "The random variable used to pick a loss everytime CalcRxPower is invoked.", |
83 |
RandomVariableValue (ConstantVariable (1.0)), |
84 |
RandomVariableValue (ConstantVariable (1.0)), |
84 |
MakeRandomVariableAccessor (&RandomPropagationLossModel::m_variable), |
85 |
MakeRandomVariableAccessor (&RandomPropagationLossModel::m_variable), |
85 |
MakeRandomVariableChecker ()) |
86 |
MakeRandomVariableChecker ()) |
86 |
; |
87 |
; |
87 |
return tid; |
88 |
return tid; |
88 |
} |
89 |
} |
89 |
RandomPropagationLossModel::RandomPropagationLossModel () |
90 |
RandomPropagationLossModel::RandomPropagationLossModel () |
90 |
: PropagationLossModel () |
91 |
: PropagationLossModel () |
91 |
{} |
92 |
{} |
92 |
|
93 |
|
93 |
RandomPropagationLossModel::~RandomPropagationLossModel () |
94 |
RandomPropagationLossModel::~RandomPropagationLossModel () |
94 |
{} |
95 |
{} |
95 |
|
96 |
|
96 |
double |
97 |
double |
97 |
RandomPropagationLossModel::DoCalcRxPower (double txPowerDbm, |
98 |
RandomPropagationLossModel::DoCalcRxPower (double txPowerDbm, |
98 |
Ptr<MobilityModel> a, |
99 |
Ptr<MobilityModel> a, |
99 |
Ptr<MobilityModel> b) const |
100 |
Ptr<MobilityModel> b) const |
100 |
{ |
101 |
{ |
101 |
double rxc = -m_variable.GetValue (); |
102 |
double rxc = -m_variable.GetValue (); |
102 |
NS_LOG_DEBUG ("attenuation coefficent="<<rxc<<"Db"); |
103 |
NS_LOG_DEBUG ("attenuation coefficent="<<rxc<<"Db"); |
103 |
return txPowerDbm + rxc; |
104 |
return txPowerDbm + rxc; |
104 |
} |
105 |
} |
105 |
|
106 |
|
106 |
// ------------------------------------------------------------------------- // |
107 |
// ------------------------------------------------------------------------- // |
107 |
|
108 |
|
108 |
NS_OBJECT_ENSURE_REGISTERED (FriisPropagationLossModel); |
109 |
NS_OBJECT_ENSURE_REGISTERED (FriisPropagationLossModel); |
109 |
|
110 |
|
110 |
const double FriisPropagationLossModel::PI = 3.14159265358979323846; |
111 |
const double FriisPropagationLossModel::PI = 3.14159265358979323846; |
111 |
|
112 |
|
112 |
TypeId |
113 |
TypeId |
113 |
FriisPropagationLossModel::GetTypeId (void) |
114 |
FriisPropagationLossModel::GetTypeId (void) |
114 |
{ |
115 |
{ |
115 |
static TypeId tid = TypeId ("ns3::FriisPropagationLossModel") |
116 |
static TypeId tid = TypeId ("ns3::FriisPropagationLossModel") |
116 |
.SetParent<PropagationLossModel> () |
117 |
.SetParent<PropagationLossModel> () |
117 |
.AddConstructor<FriisPropagationLossModel> () |
118 |
.AddConstructor<FriisPropagationLossModel> () |
118 |
.AddAttribute ("Lambda", |
119 |
.AddAttribute ("Lambda", |
119 |
"The wavelength (default is 5.15 GHz at 300 000 km/s).", |
120 |
"The wavelength (default is 5.15 GHz at 300 000 km/s).", |
120 |
DoubleValue (300000000.0 / 5.150e9), |
121 |
DoubleValue (300000000.0 / 5.150e9), |
121 |
MakeDoubleAccessor (&FriisPropagationLossModel::m_lambda), |
122 |
MakeDoubleAccessor (&FriisPropagationLossModel::m_lambda), |
122 |
MakeDoubleChecker<double> ()) |
123 |
MakeDoubleChecker<double> ()) |
123 |
.AddAttribute ("SystemLoss", "The system loss", |
124 |
.AddAttribute ("SystemLoss", "The system loss", |
124 |
DoubleValue (1.0), |
125 |
DoubleValue (1.0), |
125 |
MakeDoubleAccessor (&FriisPropagationLossModel::m_systemLoss), |
126 |
MakeDoubleAccessor (&FriisPropagationLossModel::m_systemLoss), |
126 |
MakeDoubleChecker<double> ()) |
127 |
MakeDoubleChecker<double> ()) |
127 |
.AddAttribute ("MinDistance", |
128 |
.AddAttribute ("MinDistance", |
128 |
"The distance under which the propagation model refuses to give results (m)", |
129 |
"The distance under which the propagation model refuses to give results (m)", |
129 |
DoubleValue (0.5), |
130 |
DoubleValue (0.5), |
130 |
MakeDoubleAccessor (&FriisPropagationLossModel::SetMinDistance, |
131 |
MakeDoubleAccessor (&FriisPropagationLossModel::SetMinDistance, |
131 |
&FriisPropagationLossModel::GetMinDistance), |
132 |
&FriisPropagationLossModel::GetMinDistance), |
132 |
MakeDoubleChecker<double> ()) |
133 |
MakeDoubleChecker<double> ()) |
133 |
; |
134 |
; |
134 |
return tid; |
135 |
return tid; |
135 |
} |
136 |
} |
136 |
|
137 |
|
137 |
FriisPropagationLossModel::FriisPropagationLossModel () |
138 |
FriisPropagationLossModel::FriisPropagationLossModel () |
138 |
{} |
139 |
{} |
139 |
void |
140 |
void |
140 |
FriisPropagationLossModel::SetSystemLoss (double systemLoss) |
141 |
FriisPropagationLossModel::SetSystemLoss (double systemLoss) |
141 |
{ |
142 |
{ |
142 |
m_systemLoss = systemLoss; |
143 |
m_systemLoss = systemLoss; |
143 |
} |
144 |
} |
144 |
double |
145 |
double |
145 |
FriisPropagationLossModel::GetSystemLoss (void) const |
146 |
FriisPropagationLossModel::GetSystemLoss (void) const |
146 |
{ |
147 |
{ |
147 |
return m_systemLoss; |
148 |
return m_systemLoss; |
148 |
} |
149 |
} |
149 |
void |
150 |
void |
150 |
FriisPropagationLossModel::SetMinDistance (double minDistance) |
151 |
FriisPropagationLossModel::SetMinDistance (double minDistance) |
151 |
{ |
152 |
{ |
152 |
m_minDistance = minDistance; |
153 |
m_minDistance = minDistance; |
153 |
} |
154 |
} |
154 |
double |
155 |
double |
155 |
FriisPropagationLossModel::GetMinDistance (void) const |
156 |
FriisPropagationLossModel::GetMinDistance (void) const |
156 |
{ |
157 |
{ |
157 |
return m_minDistance; |
158 |
return m_minDistance; |
158 |
} |
159 |
} |
159 |
void |
160 |
void |
160 |
FriisPropagationLossModel::SetLambda (double frequency, double speed) |
161 |
FriisPropagationLossModel::SetLambda (double frequency, double speed) |
161 |
{ |
162 |
{ |
162 |
m_lambda = speed / frequency; |
163 |
m_lambda = speed / frequency; |
163 |
} |
164 |
} |
164 |
void |
165 |
void |
165 |
FriisPropagationLossModel::SetLambda (double lambda) |
166 |
FriisPropagationLossModel::SetLambda (double lambda) |
166 |
{ |
167 |
{ |
167 |
m_lambda = lambda; |
168 |
m_lambda = lambda; |
168 |
} |
169 |
} |
169 |
double |
170 |
double |
170 |
FriisPropagationLossModel::GetLambda (void) const |
171 |
FriisPropagationLossModel::GetLambda (void) const |
171 |
{ |
172 |
{ |
172 |
return m_lambda; |
173 |
return m_lambda; |
173 |
} |
174 |
} |
174 |
|
175 |
|
175 |
double |
176 |
double |
176 |
FriisPropagationLossModel::DbmToW (double dbm) const |
177 |
FriisPropagationLossModel::DbmToW (double dbm) const |
177 |
{ |
178 |
{ |
178 |
double mw = pow(10.0,dbm/10.0); |
179 |
double mw = pow(10.0,dbm/10.0); |
179 |
return mw / 1000.0; |
180 |
return mw / 1000.0; |
180 |
} |
181 |
} |
181 |
|
182 |
|
182 |
double |
183 |
double |
183 |
FriisPropagationLossModel::DbmFromW (double w) const |
184 |
FriisPropagationLossModel::DbmFromW (double w) const |
184 |
{ |
185 |
{ |
185 |
double dbm = log10 (w * 1000.0) * 10.0; |
186 |
double dbm = log10 (w * 1000.0) * 10.0; |
186 |
return dbm; |
187 |
return dbm; |
187 |
} |
188 |
} |
188 |
|
189 |
|
189 |
double |
190 |
double |
190 |
FriisPropagationLossModel::DoCalcRxPower (double txPowerDbm, |
191 |
FriisPropagationLossModel::DoCalcRxPower (double txPowerDbm, |
191 |
Ptr<MobilityModel> a, |
192 |
Ptr<MobilityModel> a, |
192 |
Ptr<MobilityModel> b) const |
193 |
Ptr<MobilityModel> b) const |
193 |
{ |
194 |
{ |
194 |
/* |
195 |
/* |
195 |
* Friis free space equation: |
196 |
* Friis free space equation: |
196 |
* where Pt, Gr, Gr and P are in Watt units |
197 |
* where Pt, Gr, Gr and P are in Watt units |
197 |
* L is in meter units. |
198 |
* L is in meter units. |
198 |
* |
199 |
* |
199 |
* P Gt * Gr * (lambda^2) |
200 |
* P Gt * Gr * (lambda^2) |
200 |
* --- = --------------------- |
201 |
* --- = --------------------- |
201 |
* Pt (4 * pi * d)^2 * L |
202 |
* Pt (4 * pi * d)^2 * L |
202 |
* |
203 |
* |
203 |
* Gt: tx gain (unit-less) |
204 |
* Gt: tx gain (unit-less) |
204 |
* Gr: rx gain (unit-less) |
205 |
* Gr: rx gain (unit-less) |
205 |
* Pt: tx power (W) |
206 |
* Pt: tx power (W) |
206 |
* d: distance (m) |
207 |
* d: distance (m) |
207 |
* L: system loss |
208 |
* L: system loss |
208 |
* lambda: wavelength (m) |
209 |
* lambda: wavelength (m) |
209 |
* |
210 |
* |
210 |
* Here, we ignore tx and rx gain and the input and output values |
211 |
* Here, we ignore tx and rx gain and the input and output values |
211 |
* are in dB or dBm: |
212 |
* are in dB or dBm: |
212 |
* |
213 |
* |
213 |
* lambda^2 |
214 |
* lambda^2 |
214 |
* rx = tx + 10 log10 (-------------------) |
215 |
* rx = tx + 10 log10 (-------------------) |
215 |
* (4 * pi * d)^2 * L |
216 |
* (4 * pi * d)^2 * L |
216 |
* |
217 |
* |
217 |
* rx: rx power (dB) |
218 |
* rx: rx power (dB) |
218 |
* tx: tx power (dB) |
219 |
* tx: tx power (dB) |
219 |
* d: distance (m) |
220 |
* d: distance (m) |
220 |
* L: system loss (unit-less) |
221 |
* L: system loss (unit-less) |
221 |
* lambda: wavelength (m) |
222 |
* lambda: wavelength (m) |
222 |
*/ |
223 |
*/ |
223 |
double distance = a->GetDistanceFrom (b); |
224 |
double distance = a->GetDistanceFrom (b); |
224 |
if (distance <= m_minDistance) |
225 |
if (distance <= m_minDistance) |
225 |
{ |
226 |
{ |
226 |
return txPowerDbm; |
227 |
return txPowerDbm; |
227 |
} |
228 |
} |
228 |
double numerator = m_lambda * m_lambda; |
229 |
double numerator = m_lambda * m_lambda; |
229 |
double denominator = 16 * PI * PI * distance * distance * m_systemLoss; |
230 |
double denominator = 16 * PI * PI * distance * distance * m_systemLoss; |
230 |
double pr = 10 * log10 (numerator / denominator); |
231 |
double pr = 10 * log10 (numerator / denominator); |
231 |
NS_LOG_DEBUG ("distance="<<distance<<"m, attenuation coefficient="<<pr<<"dB"); |
232 |
NS_LOG_DEBUG ("distance="<<distance<<"m, attenuation coefficient="<<pr<<"dB"); |
232 |
return txPowerDbm + pr; |
233 |
return txPowerDbm + pr; |
233 |
} |
234 |
} |
234 |
|
235 |
|
235 |
// ------------------------------------------------------------------------- // |
236 |
// ------------------------------------------------------------------------- // |
236 |
|
237 |
// -- Two-Ray Ground Model ported from NS-2 -- T.Hewer@cs.ucl.ac.uk -- Nov09 // |
237 |
NS_OBJECT_ENSURE_REGISTERED (LogDistancePropagationLossModel); |
238 |
|
238 |
|
239 |
NS_OBJECT_ENSURE_REGISTERED (TwoRayGroundPropagationLossModel); |
239 |
TypeId |
240 |
|
240 |
LogDistancePropagationLossModel::GetTypeId (void) |
241 |
const double TwoRayGroundPropagationLossModel::PI = 3.14159265358979323846; |
241 |
{ |
242 |
|
242 |
static TypeId tid = TypeId ("ns3::LogDistancePropagationLossModel") |
243 |
TypeId |
243 |
.SetParent<PropagationLossModel> () |
244 |
TwoRayGroundPropagationLossModel::GetTypeId (void) |
244 |
.AddConstructor<LogDistancePropagationLossModel> () |
245 |
{ |
245 |
.AddAttribute ("Exponent", |
246 |
static TypeId tid = TypeId ("ns3::TwoRayGroundPropagationLossModel") |
246 |
"The exponent of the Path Loss propagation model", |
247 |
.SetParent<PropagationLossModel> () |
247 |
DoubleValue (3.0), |
248 |
.AddConstructor<TwoRayGroundPropagationLossModel> () |
248 |
MakeDoubleAccessor (&LogDistancePropagationLossModel::m_exponent), |
249 |
.AddAttribute ("Lambda", |
249 |
MakeDoubleChecker<double> ()) |
250 |
"The wavelength (default is 5.15 GHz at 300 000 km/s).", |
250 |
.AddAttribute ("ReferenceDistance", |
251 |
DoubleValue (300000000.0 / 5.150e9), |
251 |
"The distance at which the reference loss is calculated (m)", |
252 |
MakeDoubleAccessor (&TwoRayGroundPropagationLossModel::m_lambda), |
252 |
DoubleValue (1.0), |
253 |
MakeDoubleChecker<double> ()) |
253 |
MakeDoubleAccessor (&LogDistancePropagationLossModel::m_referenceDistance), |
254 |
.AddAttribute ("SystemLoss", "The system loss", |
254 |
MakeDoubleChecker<double> ()) |
255 |
DoubleValue (1.0), |
255 |
.AddAttribute ("ReferenceLoss", |
256 |
MakeDoubleAccessor (&TwoRayGroundPropagationLossModel::m_systemLoss), |
256 |
"The reference loss at reference distance (dB). (Default is Friis at 1m with 5.15 GHz)", |
257 |
MakeDoubleChecker<double> ()) |
257 |
DoubleValue (46.6777), |
258 |
.AddAttribute ("MinDistance", |
258 |
MakeDoubleAccessor (&LogDistancePropagationLossModel::m_referenceLoss), |
259 |
"The distance under which the propagation model refuses to give results (m)", |
259 |
MakeDoubleChecker<double> ()) |
260 |
DoubleValue (0.5), |
260 |
; |
261 |
MakeDoubleAccessor (&TwoRayGroundPropagationLossModel::SetMinDistance, |
261 |
return tid; |
262 |
&TwoRayGroundPropagationLossModel::GetMinDistance), |
262 |
|
263 |
MakeDoubleChecker<double> ()) |
263 |
} |
264 |
.AddAttribute ("TxAntHeight", |
264 |
|
265 |
"The height of the transmitting antenna (m)", |
265 |
LogDistancePropagationLossModel::LogDistancePropagationLossModel () |
266 |
DoubleValue (1.5), |
266 |
{} |
267 |
MakeDoubleAccessor (&TwoRayGroundPropagationLossModel::m_txAntHeight), |
267 |
|
268 |
MakeDoubleChecker<double> ()) |
268 |
void |
269 |
.AddAttribute ("RxAntHeight", |
269 |
LogDistancePropagationLossModel::SetPathLossExponent (double n) |
270 |
"The height of the receiving antenna (m)", |
270 |
{ |
271 |
DoubleValue (1.5), |
271 |
m_exponent = n; |
272 |
MakeDoubleAccessor (&TwoRayGroundPropagationLossModel::m_rxAntHeight), |
272 |
} |
273 |
MakeDoubleChecker<double> ()) |
273 |
void |
274 |
; |
274 |
LogDistancePropagationLossModel::SetReference (double referenceDistance, double referenceLoss) |
275 |
return tid; |
275 |
{ |
276 |
} |
276 |
m_referenceDistance = referenceDistance; |
277 |
|
277 |
m_referenceLoss = referenceLoss; |
278 |
TwoRayGroundPropagationLossModel::TwoRayGroundPropagationLossModel () |
278 |
} |
279 |
{} |
279 |
double |
280 |
void |
280 |
LogDistancePropagationLossModel::GetPathLossExponent (void) const |
281 |
TwoRayGroundPropagationLossModel::SetSystemLoss (double systemLoss) |
281 |
{ |
282 |
{ |
282 |
return m_exponent; |
283 |
m_systemLoss = systemLoss; |
283 |
} |
284 |
} |
284 |
|
285 |
double |
285 |
double |
286 |
TwoRayGroundPropagationLossModel::GetSystemLoss (void) const |
286 |
LogDistancePropagationLossModel::DoCalcRxPower (double txPowerDbm, |
287 |
{ |
287 |
Ptr<MobilityModel> a, |
288 |
return m_systemLoss; |
288 |
Ptr<MobilityModel> b) const |
289 |
} |
289 |
{ |
290 |
void |
290 |
double distance = a->GetDistanceFrom (b); |
291 |
TwoRayGroundPropagationLossModel::SetMinDistance (double minDistance) |
291 |
if (distance <= m_referenceDistance) |
292 |
{ |
292 |
{ |
293 |
m_minDistance = minDistance; |
293 |
return txPowerDbm; |
294 |
} |
294 |
} |
295 |
double |
295 |
/** |
296 |
TwoRayGroundPropagationLossModel::GetMinDistance (void) const |
296 |
* The formula is: |
297 |
{ |
297 |
* rx = 10 * log (Pr0(tx)) - n * 10 * log (d/d0) |
298 |
return m_minDistance; |
298 |
* |
299 |
} |
299 |
* Pr0: rx power at reference distance d0 (W) |
300 |
void |
300 |
* d0: reference distance: 1.0 (m) |
301 |
TwoRayGroundPropagationLossModel::SetTxAntHeight (double txAntHeight) |
301 |
* d: distance (m) |
302 |
{ |
302 |
* tx: tx power (dB) |
303 |
m_txAntHeight = txAntHeight; |
303 |
* rx: dB |
304 |
} |
304 |
* |
305 |
void |
305 |
* Which, in our case is: |
306 |
TwoRayGroundPropagationLossModel::SetRxAntHeight (double rxAntHeight) |
306 |
* |
307 |
{ |
307 |
* rx = rx0(tx) - 10 * n * log (d/d0) |
308 |
m_rxAntHeight = rxAntHeight; |
308 |
*/ |
309 |
} |
309 |
double pathLossDb = 10 * m_exponent * log10 (distance / m_referenceDistance); |
310 |
double |
310 |
double rxc = -m_referenceLoss - pathLossDb; |
311 |
TwoRayGroundPropagationLossModel::GetTxAntHeight (void) const |
311 |
NS_LOG_DEBUG ("distance="<<distance<<"m, reference-attenuation="<<-m_referenceLoss<<"dB, "<< |
312 |
{ |
312 |
"attenuation coefficient="<<rxc<<"db"); |
313 |
return m_txAntHeight; |
313 |
return txPowerDbm + rxc; |
314 |
} |
314 |
} |
315 |
double |
315 |
|
316 |
TwoRayGroundPropagationLossModel::GetRxAntHeight (void) const |
316 |
// ------------------------------------------------------------------------- // |
317 |
{ |
317 |
|
318 |
return m_rxAntHeight; |
318 |
NS_OBJECT_ENSURE_REGISTERED (ThreeLogDistancePropagationLossModel); |
319 |
} |
319 |
|
320 |
void |
320 |
TypeId |
321 |
TwoRayGroundPropagationLossModel::SetLambda (double frequency, double speed) |
321 |
ThreeLogDistancePropagationLossModel::GetTypeId (void) |
322 |
{ |
322 |
{ |
323 |
m_lambda = speed / frequency; |
323 |
static TypeId tid = TypeId ("ns3::ThreeLogDistancePropagationLossModel") |
324 |
} |
324 |
.SetParent<PropagationLossModel> () |
325 |
void |
325 |
.AddConstructor<ThreeLogDistancePropagationLossModel> () |
326 |
TwoRayGroundPropagationLossModel::SetLambda (double lambda) |
326 |
.AddAttribute ("Distance0", |
327 |
{ |
327 |
"Beginning of the first (near) distance field", |
328 |
m_lambda = lambda; |
328 |
DoubleValue (1.0), |
329 |
} |
329 |
MakeDoubleAccessor (&ThreeLogDistancePropagationLossModel::m_distance0), |
330 |
double |
330 |
MakeDoubleChecker<double> ()) |
331 |
TwoRayGroundPropagationLossModel::GetLambda (void) const |
331 |
.AddAttribute ("Distance1", |
332 |
{ |
332 |
"Beginning of the second (middle) distance field.", |
333 |
return m_lambda; |
333 |
DoubleValue (200.0), |
334 |
} |
334 |
MakeDoubleAccessor (&ThreeLogDistancePropagationLossModel::m_distance1), |
335 |
|
335 |
MakeDoubleChecker<double> ()) |
336 |
double |
336 |
.AddAttribute ("Distance2", |
337 |
TwoRayGroundPropagationLossModel::DbmToW (double dbm) const |
337 |
"Beginning of the third (far) distance field.", |
338 |
{ |
338 |
DoubleValue (500.0), |
339 |
double mw = pow(10.0,dbm/10.0); |
339 |
MakeDoubleAccessor (&ThreeLogDistancePropagationLossModel::m_distance2), |
340 |
return mw / 1000.0; |
340 |
MakeDoubleChecker<double> ()) |
341 |
} |
341 |
.AddAttribute ("Exponent0", |
342 |
|
342 |
"The exponent for the first field.", |
343 |
double |
343 |
DoubleValue (1.9), |
344 |
TwoRayGroundPropagationLossModel::DbmFromW (double w) const |
344 |
MakeDoubleAccessor (&ThreeLogDistancePropagationLossModel::m_exponent0), |
345 |
{ |
345 |
MakeDoubleChecker<double> ()) |
346 |
double dbm = log10 (w * 1000.0) * 10.0; |
346 |
.AddAttribute ("Exponent1", |
347 |
return dbm; |
347 |
"The exponent for the second field.", |
348 |
} |
348 |
DoubleValue (3.8), |
349 |
|
349 |
MakeDoubleAccessor (&ThreeLogDistancePropagationLossModel::m_exponent1), |
350 |
double |
350 |
MakeDoubleChecker<double> ()) |
351 |
TwoRayGroundPropagationLossModel::DoCalcRxPower (double txPowerDbm, |
351 |
.AddAttribute ("Exponent2", |
352 |
Ptr<MobilityModel> a, |
352 |
"The exponent for the third field.", |
353 |
Ptr<MobilityModel> b) const |
353 |
DoubleValue (3.8), |
354 |
{ |
354 |
MakeDoubleAccessor (&ThreeLogDistancePropagationLossModel::m_exponent2), |
355 |
/* |
355 |
MakeDoubleChecker<double> ()) |
356 |
* Two-Ray Ground equation: |
356 |
.AddAttribute ("ReferenceLoss", |
357 |
* |
357 |
"The reference loss at distance d0 (dB). (Default is Friis at 1m with 5.15 GHz)", |
358 |
* where Pt, Gt and Gr are in dBm units |
358 |
DoubleValue (46.6777), |
359 |
* L, Ht and Hr are in meter units. |
359 |
MakeDoubleAccessor (&ThreeLogDistancePropagationLossModel::m_referenceLoss), |
360 |
* |
360 |
MakeDoubleChecker<double> ()) |
361 |
* Pr Gt * Gr * (Ht^2 * Hr^2) |
361 |
; |
362 |
* -- = (-------------------------) |
362 |
return tid; |
363 |
* Pt d^4 * L |
363 |
|
364 |
* |
364 |
} |
365 |
* Gt: tx gain (unit-less) |
365 |
|
366 |
* Gr: rx gain (unit-less) |
366 |
ThreeLogDistancePropagationLossModel::ThreeLogDistancePropagationLossModel () |
367 |
* Pt: tx power (dBm) |
367 |
{ |
368 |
* d: distance (m) |
368 |
} |
369 |
* L: system loss |
369 |
|
370 |
* Ht: Tx antenna height (m) |
370 |
double |
371 |
* Hr: Rx antenna height (m) |
371 |
ThreeLogDistancePropagationLossModel::DoCalcRxPower (double txPowerDbm, |
372 |
* lambda: wavelength (m) |
372 |
Ptr<MobilityModel> a, |
373 |
* |
373 |
Ptr<MobilityModel> b) const |
374 |
* As with the Friis model we ignore tx and rx gain and output values |
374 |
{ |
375 |
* are in dB or dBm |
375 |
double distance = a->GetDistanceFrom (b); |
376 |
* |
376 |
NS_ASSERT(distance >= 0); |
377 |
* (Ht * Ht) * (Hr * Hr) |
377 |
|
378 |
* rx = tx + 10 log10 (-----------------------) |
378 |
// See doxygen comments for the formula and explanation |
379 |
* (d * d * d * d) * L |
379 |
|
380 |
*/ |
380 |
double pathLossDb; |
381 |
double distance = a->GetDistanceFrom (b); |
381 |
|
382 |
if (distance <= m_minDistance) |
382 |
if (distance < m_distance0) |
383 |
{ |
383 |
{ |
384 |
return txPowerDbm; |
384 |
pathLossDb = 0; |
385 |
} |
385 |
} |
386 |
|
386 |
else if (distance < m_distance1) |
387 |
// Calculate a crossover distance, under which we use Friis |
387 |
{ |
388 |
/* |
388 |
pathLossDb = m_referenceLoss |
389 |
* |
389 |
+ 10 * m_exponent0 * log10(distance / m_distance0); |
390 |
* dCross = (4 * pi * Ht * Hr) / lambda |
390 |
} |
391 |
* |
391 |
else if (distance < m_distance2) |
392 |
*/ |
392 |
{ |
393 |
|
393 |
pathLossDb = m_referenceLoss |
394 |
double dCross = (4 * PI * m_txAntHeight * m_rxAntHeight) / GetLambda(); |
394 |
+ 10 * m_exponent0 * log10(m_distance1 / m_distance0) |
395 |
|
395 |
+ 10 * m_exponent1 * log10(distance / m_distance1); |
396 |
if (distance <= dCross) { |
396 |
} |
397 |
// We use Friis |
397 |
else |
398 |
double numerator = m_lambda * m_lambda; |
398 |
{ |
399 |
double denominator = 16 * PI * PI * distance * distance * m_systemLoss; |
399 |
pathLossDb = m_referenceLoss |
400 |
double pr = 10 * log10 (numerator / denominator); |
400 |
+ 10 * m_exponent0 * log10(m_distance1 / m_distance0) |
401 |
NS_LOG_DEBUG ("Receiver within crossover ("<<dCross<<"m) for Two_ray path; using Friis"); |
401 |
+ 10 * m_exponent1 * log10(m_distance2 / m_distance1) |
402 |
NS_LOG_DEBUG ("distance="<<distance<<"m, attenuation coefficient="<<pr<<"dB"); |
402 |
+ 10 * m_exponent2 * log10(distance / m_distance2); |
403 |
return txPowerDbm + pr; |
403 |
} |
404 |
} |
404 |
|
405 |
else { // Use Two-Ray Pathloss |
405 |
NS_LOG_DEBUG ("ThreeLogDistance distance=" << distance << "m, " << |
406 |
double rayNumerator = (m_txAntHeight * m_txAntHeight) * |
406 |
"attenuation=" << pathLossDb << "dB"); |
407 |
(m_rxAntHeight * m_rxAntHeight); |
407 |
|
408 |
double rayDenominator = (distance * distance * distance * distance) * m_systemLoss; |
408 |
return txPowerDbm - pathLossDb; |
409 |
double rayPr = 10 * log10 (rayNumerator / rayDenominator); |
409 |
} |
410 |
NS_LOG_DEBUG ("distance="<<distance<<"m, attenuation coefficient="<<rayPr<<"dB"); |
410 |
|
411 |
return txPowerDbm + rayPr; |
411 |
// ------------------------------------------------------------------------- // |
412 |
} |
412 |
|
413 |
} |
413 |
NS_OBJECT_ENSURE_REGISTERED (NakagamiPropagationLossModel); |
414 |
|
414 |
|
415 |
// ------------------------------------------------------------------------- // |
415 |
TypeId |
416 |
|
416 |
NakagamiPropagationLossModel::GetTypeId (void) |
417 |
NS_OBJECT_ENSURE_REGISTERED (LogDistancePropagationLossModel); |
417 |
{ |
418 |
|
418 |
static TypeId tid = TypeId ("ns3::NakagamiPropagationLossModel") |
419 |
TypeId |
419 |
.SetParent<PropagationLossModel> () |
420 |
LogDistancePropagationLossModel::GetTypeId (void) |
420 |
.AddConstructor<NakagamiPropagationLossModel> () |
421 |
{ |
421 |
.AddAttribute ("Distance1", |
422 |
static TypeId tid = TypeId ("ns3::LogDistancePropagationLossModel") |
422 |
"Beginning of the second distance field. Default is 80m.", |
423 |
.SetParent<PropagationLossModel> () |
423 |
DoubleValue (80.0), |
424 |
.AddConstructor<LogDistancePropagationLossModel> () |
424 |
MakeDoubleAccessor (&NakagamiPropagationLossModel::m_distance1), |
425 |
.AddAttribute ("Exponent", |
425 |
MakeDoubleChecker<double> ()) |
426 |
"The exponent of the Path Loss propagation model", |
426 |
.AddAttribute ("Distance2", |
427 |
DoubleValue (3.0), |
427 |
"Beginning of the third distance field. Default is 200m.", |
428 |
MakeDoubleAccessor (&LogDistancePropagationLossModel::m_exponent), |
428 |
DoubleValue (200.0), |
429 |
MakeDoubleChecker<double> ()) |
429 |
MakeDoubleAccessor (&NakagamiPropagationLossModel::m_distance2), |
430 |
.AddAttribute ("ReferenceDistance", |
430 |
MakeDoubleChecker<double> ()) |
431 |
"The distance at which the reference loss is calculated (m)", |
431 |
.AddAttribute ("m0", |
432 |
DoubleValue (1.0), |
432 |
"m0 for distances smaller than Distance1. Default is 1.5.", |
433 |
MakeDoubleAccessor (&LogDistancePropagationLossModel::m_referenceDistance), |
433 |
DoubleValue (1.5), |
434 |
MakeDoubleChecker<double> ()) |
434 |
MakeDoubleAccessor (&NakagamiPropagationLossModel::m_m0), |
435 |
.AddAttribute ("ReferenceLoss", |
435 |
MakeDoubleChecker<double> ()) |
436 |
"The reference loss at reference distance (dB). (Default is Friis at 1m with 5.15 GHz)", |
436 |
.AddAttribute ("m1", |
437 |
DoubleValue (46.6777), |
437 |
"m1 for distances smaller than Distance2. Default is 0.75.", |
438 |
MakeDoubleAccessor (&LogDistancePropagationLossModel::m_referenceLoss), |
438 |
DoubleValue (0.75), |
439 |
MakeDoubleChecker<double> ()) |
439 |
MakeDoubleAccessor (&NakagamiPropagationLossModel::m_m1), |
440 |
; |
440 |
MakeDoubleChecker<double> ()) |
441 |
return tid; |
441 |
.AddAttribute ("m2", |
442 |
|
442 |
"m2 for distances greater than Distance2. Default is 0.75.", |
443 |
} |
443 |
DoubleValue (0.75), |
444 |
|
444 |
MakeDoubleAccessor (&NakagamiPropagationLossModel::m_m2), |
445 |
LogDistancePropagationLossModel::LogDistancePropagationLossModel () |
445 |
MakeDoubleChecker<double> ()) |
446 |
{} |
446 |
; |
447 |
|
447 |
return tid; |
448 |
void |
448 |
|
449 |
LogDistancePropagationLossModel::SetPathLossExponent (double n) |
449 |
} |
450 |
{ |
450 |
|
451 |
m_exponent = n; |
451 |
NakagamiPropagationLossModel::NakagamiPropagationLossModel () |
452 |
} |
452 |
{} |
453 |
void |
453 |
|
454 |
LogDistancePropagationLossModel::SetReference (double referenceDistance, double referenceLoss) |
454 |
double |
455 |
{ |
455 |
NakagamiPropagationLossModel::DoCalcRxPower (double txPowerDbm, |
456 |
m_referenceDistance = referenceDistance; |
456 |
Ptr<MobilityModel> a, |
457 |
m_referenceLoss = referenceLoss; |
457 |
Ptr<MobilityModel> b) const |
458 |
} |
458 |
{ |
459 |
double |
459 |
// select m parameter |
460 |
LogDistancePropagationLossModel::GetPathLossExponent (void) const |
460 |
|
461 |
{ |
461 |
double distance = a->GetDistanceFrom (b); |
462 |
return m_exponent; |
462 |
NS_ASSERT(distance >= 0); |
463 |
} |
463 |
|
464 |
|
464 |
double m; |
465 |
double |
465 |
if (distance < m_distance1) |
466 |
LogDistancePropagationLossModel::DoCalcRxPower (double txPowerDbm, |
466 |
{ |
467 |
Ptr<MobilityModel> a, |
467 |
m = m_m0; |
468 |
Ptr<MobilityModel> b) const |
468 |
} |
469 |
{ |
469 |
else if (distance < m_distance2) |
470 |
double distance = a->GetDistanceFrom (b); |
470 |
{ |
471 |
if (distance <= m_referenceDistance) |
471 |
m = m_m1; |
472 |
{ |
472 |
} |
473 |
return txPowerDbm; |
473 |
else |
474 |
} |
474 |
{ |
475 |
/** |
475 |
m = m_m2; |
476 |
* The formula is: |
476 |
} |
477 |
* rx = 10 * log (Pr0(tx)) - n * 10 * log (d/d0) |
477 |
|
478 |
* |
478 |
// the current power unit is dBm, but Watt is put into the Nakagami / |
479 |
* Pr0: rx power at reference distance d0 (W) |
479 |
// Rayleigh distribution. |
480 |
* d0: reference distance: 1.0 (m) |
480 |
double powerW = pow(10, (txPowerDbm - 30) / 10); |
481 |
* d: distance (m) |
481 |
|
482 |
* tx: tx power (dB) |
482 |
double resultPowerW; |
483 |
* rx: dB |
483 |
|
484 |
* |
484 |
// switch between Erlang- and Gamma distributions: this is only for |
485 |
* Which, in our case is: |
485 |
// speed. (Gamma is equal to Erlang for any positive integer m.) |
486 |
* |
486 |
unsigned int int_m = static_cast<unsigned int>(floor(m)); |
487 |
* rx = rx0(tx) - 10 * n * log (d/d0) |
487 |
|
488 |
*/ |
488 |
if (int_m == m) |
489 |
double pathLossDb = 10 * m_exponent * log10 (distance / m_referenceDistance); |
489 |
{ |
490 |
double rxc = -m_referenceLoss - pathLossDb; |
490 |
resultPowerW = m_erlangRandomVariable.GetValue(int_m, powerW / m); |
491 |
NS_LOG_DEBUG ("distance="<<distance<<"m, reference-attenuation="<<-m_referenceLoss<<"dB, "<< |
491 |
} |
492 |
"attenuation coefficient="<<rxc<<"db"); |
492 |
else |
493 |
return txPowerDbm + rxc; |
493 |
{ |
494 |
} |
494 |
resultPowerW = m_gammaRandomVariable.GetValue(m, powerW / m); |
495 |
|
495 |
} |
496 |
// ------------------------------------------------------------------------- // |
496 |
|
497 |
|
497 |
double resultPowerDbm = 10 * log10(resultPowerW) + 30; |
498 |
NS_OBJECT_ENSURE_REGISTERED (ThreeLogDistancePropagationLossModel); |
498 |
|
499 |
|
499 |
NS_LOG_DEBUG ("Nakagami distance=" << distance << "m, " << |
500 |
TypeId |
500 |
"power=" << powerW <<"W, " << |
501 |
ThreeLogDistancePropagationLossModel::GetTypeId (void) |
501 |
"resultPower=" << resultPowerW << "W=" << resultPowerDbm << "dBm"); |
502 |
{ |
502 |
|
503 |
static TypeId tid = TypeId ("ns3::ThreeLogDistancePropagationLossModel") |
503 |
return resultPowerDbm; |
504 |
.SetParent<PropagationLossModel> () |
504 |
} |
505 |
.AddConstructor<ThreeLogDistancePropagationLossModel> () |
505 |
|
506 |
.AddAttribute ("Distance0", |
506 |
// ------------------------------------------------------------------------- // |
507 |
"Beginning of the first (near) distance field", |
507 |
|
508 |
DoubleValue (1.0), |
508 |
NS_OBJECT_ENSURE_REGISTERED (FixedRssLossModel); |
509 |
MakeDoubleAccessor (&ThreeLogDistancePropagationLossModel::m_distance0), |
509 |
|
510 |
MakeDoubleChecker<double> ()) |
510 |
TypeId |
511 |
.AddAttribute ("Distance1", |
511 |
FixedRssLossModel::GetTypeId (void) |
512 |
"Beginning of the second (middle) distance field.", |
512 |
{ |
513 |
DoubleValue (200.0), |
513 |
static TypeId tid = TypeId ("ns3::FixedRssLossModel") |
514 |
MakeDoubleAccessor (&ThreeLogDistancePropagationLossModel::m_distance1), |
514 |
.SetParent<PropagationLossModel> () |
515 |
MakeDoubleChecker<double> ()) |
515 |
.AddConstructor<FixedRssLossModel> () |
516 |
.AddAttribute ("Distance2", |
516 |
.AddAttribute ("Rss", "The fixed receiver Rss.", |
517 |
"Beginning of the third (far) distance field.", |
517 |
DoubleValue (-150.0), |
518 |
DoubleValue (500.0), |
518 |
MakeDoubleAccessor (&FixedRssLossModel::m_rss), |
519 |
MakeDoubleAccessor (&ThreeLogDistancePropagationLossModel::m_distance2), |
519 |
MakeDoubleChecker<double> ()) |
520 |
MakeDoubleChecker<double> ()) |
520 |
; |
521 |
.AddAttribute ("Exponent0", |
521 |
return tid; |
522 |
"The exponent for the first field.", |
522 |
} |
523 |
DoubleValue (1.9), |
523 |
FixedRssLossModel::FixedRssLossModel () |
524 |
MakeDoubleAccessor (&ThreeLogDistancePropagationLossModel::m_exponent0), |
524 |
: PropagationLossModel () |
525 |
MakeDoubleChecker<double> ()) |
525 |
{} |
526 |
.AddAttribute ("Exponent1", |
526 |
|
527 |
"The exponent for the second field.", |
527 |
FixedRssLossModel::~FixedRssLossModel () |
528 |
DoubleValue (3.8), |
528 |
{} |
529 |
MakeDoubleAccessor (&ThreeLogDistancePropagationLossModel::m_exponent1), |
529 |
|
530 |
MakeDoubleChecker<double> ()) |
530 |
void |
531 |
.AddAttribute ("Exponent2", |
531 |
FixedRssLossModel::SetRss (double rss) |
532 |
"The exponent for the third field.", |
532 |
{ |
533 |
DoubleValue (3.8), |
533 |
m_rss = rss; |
534 |
MakeDoubleAccessor (&ThreeLogDistancePropagationLossModel::m_exponent2), |
534 |
} |
535 |
MakeDoubleChecker<double> ()) |
535 |
|
536 |
.AddAttribute ("ReferenceLoss", |
536 |
double |
537 |
"The reference loss at distance d0 (dB). (Default is Friis at 1m with 5.15 GHz)", |
537 |
FixedRssLossModel::DoCalcRxPower (double txPowerDbm, |
538 |
DoubleValue (46.6777), |
538 |
Ptr<MobilityModel> a, |
539 |
MakeDoubleAccessor (&ThreeLogDistancePropagationLossModel::m_referenceLoss), |
539 |
Ptr<MobilityModel> b) const |
540 |
MakeDoubleChecker<double> ()) |
540 |
{ |
541 |
; |
541 |
return m_rss; |
542 |
return tid; |
542 |
} |
543 |
|
543 |
|
544 |
} |
544 |
// ------------------------------------------------------------------------- // |
545 |
|
545 |
|
546 |
ThreeLogDistancePropagationLossModel::ThreeLogDistancePropagationLossModel () |
|
|
547 |
{ |
548 |
} |
549 |
|
550 |
double |
551 |
ThreeLogDistancePropagationLossModel::DoCalcRxPower (double txPowerDbm, |
552 |
Ptr<MobilityModel> a, |
553 |
Ptr<MobilityModel> b) const |
554 |
{ |
555 |
double distance = a->GetDistanceFrom (b); |
556 |
NS_ASSERT(distance >= 0); |
557 |
|
558 |
// See doxygen comments for the formula and explanation |
559 |
|
560 |
double pathLossDb; |
561 |
|
562 |
if (distance < m_distance0) |
563 |
{ |
564 |
pathLossDb = 0; |
565 |
} |
566 |
else if (distance < m_distance1) |
567 |
{ |
568 |
pathLossDb = m_referenceLoss |
569 |
+ 10 * m_exponent0 * log10(distance / m_distance0); |
570 |
} |
571 |
else if (distance < m_distance2) |
572 |
{ |
573 |
pathLossDb = m_referenceLoss |
574 |
+ 10 * m_exponent0 * log10(m_distance1 / m_distance0) |
575 |
+ 10 * m_exponent1 * log10(distance / m_distance1); |
576 |
} |
577 |
else |
578 |
{ |
579 |
pathLossDb = m_referenceLoss |
580 |
+ 10 * m_exponent0 * log10(m_distance1 / m_distance0) |
581 |
+ 10 * m_exponent1 * log10(m_distance2 / m_distance1) |
582 |
+ 10 * m_exponent2 * log10(distance / m_distance2); |
583 |
} |
584 |
|
585 |
NS_LOG_DEBUG ("ThreeLogDistance distance=" << distance << "m, " << |
586 |
"attenuation=" << pathLossDb << "dB"); |
587 |
|
588 |
return txPowerDbm - pathLossDb; |
589 |
} |
590 |
|
591 |
// ------------------------------------------------------------------------- // |
592 |
|
593 |
NS_OBJECT_ENSURE_REGISTERED (NakagamiPropagationLossModel); |
594 |
|
595 |
TypeId |
596 |
NakagamiPropagationLossModel::GetTypeId (void) |
597 |
{ |
598 |
static TypeId tid = TypeId ("ns3::NakagamiPropagationLossModel") |
599 |
.SetParent<PropagationLossModel> () |
600 |
.AddConstructor<NakagamiPropagationLossModel> () |
601 |
.AddAttribute ("Distance1", |
602 |
"Beginning of the second distance field. Default is 80m.", |
603 |
DoubleValue (80.0), |
604 |
MakeDoubleAccessor (&NakagamiPropagationLossModel::m_distance1), |
605 |
MakeDoubleChecker<double> ()) |
606 |
.AddAttribute ("Distance2", |
607 |
"Beginning of the third distance field. Default is 200m.", |
608 |
DoubleValue (200.0), |
609 |
MakeDoubleAccessor (&NakagamiPropagationLossModel::m_distance2), |
610 |
MakeDoubleChecker<double> ()) |
611 |
.AddAttribute ("m0", |
612 |
"m0 for distances smaller than Distance1. Default is 1.5.", |
613 |
DoubleValue (1.5), |
614 |
MakeDoubleAccessor (&NakagamiPropagationLossModel::m_m0), |
615 |
MakeDoubleChecker<double> ()) |
616 |
.AddAttribute ("m1", |
617 |
"m1 for distances smaller than Distance2. Default is 0.75.", |
618 |
DoubleValue (0.75), |
619 |
MakeDoubleAccessor (&NakagamiPropagationLossModel::m_m1), |
620 |
MakeDoubleChecker<double> ()) |
621 |
.AddAttribute ("m2", |
622 |
"m2 for distances greater than Distance2. Default is 0.75.", |
623 |
DoubleValue (0.75), |
624 |
MakeDoubleAccessor (&NakagamiPropagationLossModel::m_m2), |
625 |
MakeDoubleChecker<double> ()) |
626 |
; |
627 |
return tid; |
628 |
|
629 |
} |
630 |
|
631 |
NakagamiPropagationLossModel::NakagamiPropagationLossModel () |
632 |
{} |
633 |
|
634 |
double |
635 |
NakagamiPropagationLossModel::DoCalcRxPower (double txPowerDbm, |
636 |
Ptr<MobilityModel> a, |
637 |
Ptr<MobilityModel> b) const |
638 |
{ |
639 |
// select m parameter |
640 |
|
641 |
double distance = a->GetDistanceFrom (b); |
642 |
NS_ASSERT(distance >= 0); |
643 |
|
644 |
double m; |
645 |
if (distance < m_distance1) |
646 |
{ |
647 |
m = m_m0; |
648 |
} |
649 |
else if (distance < m_distance2) |
650 |
{ |
651 |
m = m_m1; |
652 |
} |
653 |
else |
654 |
{ |
655 |
m = m_m2; |
656 |
} |
657 |
|
658 |
// the current power unit is dBm, but Watt is put into the Nakagami / |
659 |
// Rayleigh distribution. |
660 |
double powerW = pow(10, (txPowerDbm - 30) / 10); |
661 |
|
662 |
double resultPowerW; |
663 |
|
664 |
// switch between Erlang- and Gamma distributions: this is only for |
665 |
// speed. (Gamma is equal to Erlang for any positive integer m.) |
666 |
unsigned int int_m = static_cast<unsigned int>(floor(m)); |
667 |
|
668 |
if (int_m == m) |
669 |
{ |
670 |
resultPowerW = m_erlangRandomVariable.GetValue(int_m, powerW / m); |
671 |
} |
672 |
else |
673 |
{ |
674 |
resultPowerW = m_gammaRandomVariable.GetValue(m, powerW / m); |
675 |
} |
676 |
|
677 |
double resultPowerDbm = 10 * log10(resultPowerW) + 30; |
678 |
|
679 |
NS_LOG_DEBUG ("Nakagami distance=" << distance << "m, " << |
680 |
"power=" << powerW <<"W, " << |
681 |
"resultPower=" << resultPowerW << "W=" << resultPowerDbm << "dBm"); |
682 |
|
683 |
return resultPowerDbm; |
684 |
} |
685 |
|
686 |
// ------------------------------------------------------------------------- // |
687 |
|
688 |
NS_OBJECT_ENSURE_REGISTERED (FixedRssLossModel); |
689 |
|
690 |
TypeId |
691 |
FixedRssLossModel::GetTypeId (void) |
692 |
{ |
693 |
static TypeId tid = TypeId ("ns3::FixedRssLossModel") |
694 |
.SetParent<PropagationLossModel> () |
695 |
.AddConstructor<FixedRssLossModel> () |
696 |
.AddAttribute ("Rss", "The fixed receiver Rss.", |
697 |
DoubleValue (-150.0), |
698 |
MakeDoubleAccessor (&FixedRssLossModel::m_rss), |
699 |
MakeDoubleChecker<double> ()) |
700 |
; |
701 |
return tid; |
702 |
} |
703 |
FixedRssLossModel::FixedRssLossModel () |
704 |
: PropagationLossModel () |
705 |
{} |
706 |
|
707 |
FixedRssLossModel::~FixedRssLossModel () |
708 |
{} |
709 |
|
710 |
void |
711 |
FixedRssLossModel::SetRss (double rss) |
712 |
{ |
713 |
m_rss = rss; |
714 |
} |
715 |
|
716 |
double |
717 |
FixedRssLossModel::DoCalcRxPower (double txPowerDbm, |
718 |
Ptr<MobilityModel> a, |
719 |
Ptr<MobilityModel> b) const |
720 |
{ |
721 |
return m_rss; |
722 |
} |
723 |
|
724 |
// ------------------------------------------------------------------------- // |
725 |
|
546 |
} // namespace ns3 |
726 |
} // namespace ns3 |