author | Mathieu Lacage <mathieu.lacage@sophia.inria.fr> |
Fri, 08 Feb 2008 04:11:48 +0100 | |
changeset 2399 | fd9d94d518d2 |
parent 2383 | a0e0ec096169 |
child 2549 | fe90cf0b2c63 |
permissions | -rw-r--r-- |
2034
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
1 |
/* -*- Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */ |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
2 |
/* |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
3 |
* Copyright (c) 2005,2006,2007 INRIA |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
4 |
* |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
5 |
* This program is free software; you can redistribute it and/or modify |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
6 |
* it under the terms of the GNU General Public License version 2 as |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
7 |
* published by the Free Software Foundation; |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
8 |
* |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
9 |
* This program is distributed in the hope that it will be useful, |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
10 |
* but WITHOUT ANY WARRANTY; without even the implied warranty of |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
11 |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
12 |
* GNU General Public License for more details. |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
13 |
* |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
14 |
* You should have received a copy of the GNU General Public License |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
15 |
* along with this program; if not, write to the Free Software |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
16 |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
17 |
* |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
18 |
* Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr> |
8664ab76ff85
add missing headers
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2031
diff
changeset
|
19 |
*/ |
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
20 |
#include "propagation-loss-model.h" |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
21 |
#include "ns3/default-value.h" |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
22 |
#include "ns3/random-variable-default-value.h" |
1985
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
23 |
#include "ns3/log.h" |
2031
567dbc2475fc
replace distance by a pair of mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1985
diff
changeset
|
24 |
#include "ns3/mobility-model.h" |
567dbc2475fc
replace distance by a pair of mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1985
diff
changeset
|
25 |
#include "ns3/static-mobility-model.h" |
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
26 |
#include <math.h> |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
27 |
|
1985
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
28 |
NS_LOG_COMPONENT_DEFINE ("PropagationLossModel"); |
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
29 |
|
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
30 |
namespace ns3 { |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
31 |
|
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
32 |
enum ModelType { |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
33 |
FRIIS, |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
34 |
RANDOM, |
2063
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
35 |
LOG_DISTANCE |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
36 |
}; |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
37 |
|
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
38 |
static EnumDefaultValue<enum ModelType> g_modelType |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
39 |
("PropagationLossModelType", |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
40 |
"The type of propagation loss model.", |
2063
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
41 |
LOG_DISTANCE, "LogDistance", |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
42 |
FRIIS, "Friis", |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
43 |
RANDOM, "Random", |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
44 |
0, (void *)0); |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
45 |
|
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
46 |
static NumericDefaultValue<double> g_friisLambda |
2044
1ae23139a536
make the default value names more coherent.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2034
diff
changeset
|
47 |
("FriisPropagationLossLambda", |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
48 |
"The wavelength to use by default for every FriisPropagationLossModel (default is 5.15 GHz at 300 000 km/s).", |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
49 |
300000000.0 / 5.150e9); |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
50 |
|
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
51 |
static NumericDefaultValue<double> g_friisSystemLoss |
2044
1ae23139a536
make the default value names more coherent.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2034
diff
changeset
|
52 |
("FriisPropagationLossSystemLoss", |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
53 |
"The system loss to use by default for every FriisPropagationLossModel", |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
54 |
1.0); |
2062
88302488c05b
Document the friis propagation model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2044
diff
changeset
|
55 |
static NumericDefaultValue<double> g_friisPropagationLossMinDistance |
88302488c05b
Document the friis propagation model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2044
diff
changeset
|
56 |
("FriisPropagationLossMinDistance", |
88302488c05b
Document the friis propagation model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2044
diff
changeset
|
57 |
"The distance under which the propagation model refuses to give results (m)", |
88302488c05b
Document the friis propagation model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2044
diff
changeset
|
58 |
0.5); |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
59 |
|
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
60 |
static RandomVariableDefaultValue g_random |
2044
1ae23139a536
make the default value names more coherent.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2034
diff
changeset
|
61 |
("RandomPropagationLossDistribution", |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
62 |
"The distribution (in dbm) to choose the propagation loss.", |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
63 |
"Constant:1.0"); |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
64 |
|
2063
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
65 |
static NumericDefaultValue<double> g_logDistanceExponent |
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
66 |
("LogDistancePropagationLossExponent", |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
67 |
"The exponent of the Path Loss propagation model", |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
68 |
3.0); |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
69 |
|
2063
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
70 |
static NumericDefaultValue<double> g_logDistanceReferenceDistance |
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
71 |
("LogDistancePropagationLossReferenceDistance", |
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
72 |
"The distance at which the reference loss is calculated (m)", |
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
73 |
1.0); |
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
74 |
|
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
75 |
static EnumDefaultValue<enum ModelType> g_logDistanceReferenceType |
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
76 |
("LogDistancePropagationLossReferenceType", |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
77 |
"The type of reference propagation model.", |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
78 |
FRIIS, "Friis", |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
79 |
RANDOM, "Random", |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
80 |
0, (void *)0); |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
81 |
|
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
82 |
const double FriisPropagationLossModel::PI = 3.1415; |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
83 |
|
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
84 |
PropagationLossModel::~PropagationLossModel () |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
85 |
{} |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
86 |
|
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
87 |
Ptr<PropagationLossModel> |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
88 |
PropagationLossModel::CreateDefault (void) |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
89 |
{ |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
90 |
switch (g_modelType.GetValue ()) { |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
91 |
case FRIIS: |
2230
9f13ac3291e0
add CreateObject<> to instanciate subclasses of the Object base class. Replaces Create<>.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2115
diff
changeset
|
92 |
return CreateObject<FriisPropagationLossModel> (); |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
93 |
break; |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
94 |
case RANDOM: |
2230
9f13ac3291e0
add CreateObject<> to instanciate subclasses of the Object base class. Replaces Create<>.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2115
diff
changeset
|
95 |
return CreateObject<RandomPropagationLossModel> (); |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
96 |
break; |
2063
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
97 |
case LOG_DISTANCE: |
2230
9f13ac3291e0
add CreateObject<> to instanciate subclasses of the Object base class. Replaces Create<>.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2115
diff
changeset
|
98 |
return CreateObject<LogDistancePropagationLossModel> (); |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
99 |
break; |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
100 |
default: |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
101 |
NS_ASSERT (false); |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
102 |
return 0; |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
103 |
break; |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
104 |
} |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
105 |
} |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
106 |
RandomPropagationLossModel::RandomPropagationLossModel () |
2383
a0e0ec096169
bug 133: automate RandomVariable memory management.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2230
diff
changeset
|
107 |
: m_variable (g_random.Get ()) |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
108 |
{} |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
109 |
|
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
110 |
RandomPropagationLossModel::RandomPropagationLossModel (const RandomVariable &variable) |
2383
a0e0ec096169
bug 133: automate RandomVariable memory management.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2230
diff
changeset
|
111 |
: m_variable (variable) |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
112 |
{} |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
113 |
RandomPropagationLossModel::~RandomPropagationLossModel () |
2383
a0e0ec096169
bug 133: automate RandomVariable memory management.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2230
diff
changeset
|
114 |
{} |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
115 |
|
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
116 |
double |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
117 |
RandomPropagationLossModel::GetRxPower (double txPowerDbm, |
2031
567dbc2475fc
replace distance by a pair of mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1985
diff
changeset
|
118 |
Ptr<MobilityModel> a, |
567dbc2475fc
replace distance by a pair of mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1985
diff
changeset
|
119 |
Ptr<MobilityModel> b) const |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
120 |
{ |
2383
a0e0ec096169
bug 133: automate RandomVariable memory management.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2230
diff
changeset
|
121 |
double rxPower = txPowerDbm - m_variable.GetValue (); |
1985
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
122 |
NS_LOG_DEBUG ("tx power="<<txPowerDbm<<"dbm, rx power="<<rxPower<<"Dbm"); |
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
123 |
return rxPower; |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
124 |
} |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
125 |
|
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
126 |
FriisPropagationLossModel::FriisPropagationLossModel () |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
127 |
: m_lambda (g_friisLambda.GetValue ()), |
2064
a1adc9960e50
handle min distance for friis model in a saner way
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2063
diff
changeset
|
128 |
m_systemLoss (g_friisSystemLoss.GetValue ()), |
a1adc9960e50
handle min distance for friis model in a saner way
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2063
diff
changeset
|
129 |
m_minDistance (g_friisPropagationLossMinDistance.GetValue ()) |
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
130 |
{} |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
131 |
void |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
132 |
FriisPropagationLossModel::SetSystemLoss (double systemLoss) |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
133 |
{ |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
134 |
m_systemLoss = systemLoss; |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
135 |
} |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
136 |
double |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
137 |
FriisPropagationLossModel::GetSystemLoss (void) const |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
138 |
{ |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
139 |
return m_systemLoss; |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
140 |
} |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
141 |
void |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
142 |
FriisPropagationLossModel::SetLambda (double frequency, double speed) |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
143 |
{ |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
144 |
m_lambda = speed / frequency; |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
145 |
} |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
146 |
void |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
147 |
FriisPropagationLossModel::SetLambda (double lambda) |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
148 |
{ |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
149 |
m_lambda = lambda; |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
150 |
} |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
151 |
double |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
152 |
FriisPropagationLossModel::GetLambda (void) const |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
153 |
{ |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
154 |
return m_lambda; |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
155 |
} |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
156 |
|
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
157 |
double |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
158 |
FriisPropagationLossModel::DbmToW (double dbm) const |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
159 |
{ |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
160 |
double mw = pow(10.0,dbm/10.0); |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
161 |
return mw / 1000.0; |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
162 |
} |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
163 |
|
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
164 |
double |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
165 |
FriisPropagationLossModel::DbmFromW (double w) const |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
166 |
{ |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
167 |
double dbm = log10 (w * 1000.0) * 10.0; |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
168 |
return dbm; |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
169 |
} |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
170 |
|
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
171 |
|
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
172 |
double |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
173 |
FriisPropagationLossModel::GetRxPower (double txPowerDbm, |
2031
567dbc2475fc
replace distance by a pair of mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1985
diff
changeset
|
174 |
Ptr<MobilityModel> a, |
567dbc2475fc
replace distance by a pair of mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1985
diff
changeset
|
175 |
Ptr<MobilityModel> b) const |
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
176 |
{ |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
177 |
/* |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
178 |
* Friis free space equation: |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
179 |
* where Pt, Gr, Gr and P are in Watt units |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
180 |
* L is in meter units. |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
181 |
* |
2070
377898b9c6f5
clarify the formulas
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2065
diff
changeset
|
182 |
* Gt * Gr * (lambda^2) |
377898b9c6f5
clarify the formulas
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2065
diff
changeset
|
183 |
* P = Pt --------------------- |
377898b9c6f5
clarify the formulas
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2065
diff
changeset
|
184 |
* (4 * pi * d)^2 * L |
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
185 |
* |
2070
377898b9c6f5
clarify the formulas
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2065
diff
changeset
|
186 |
* Gt: tx gain (unit-less) |
377898b9c6f5
clarify the formulas
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2065
diff
changeset
|
187 |
* Gr: rx gain (unit-less) |
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
188 |
* Pt: tx power (W) |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
189 |
* d: distance (m) |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
190 |
* L: system loss |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
191 |
* lambda: wavelength (m) |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
192 |
* |
1985
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
193 |
* Here, we ignore tx and rx gain and the input and output values |
2070
377898b9c6f5
clarify the formulas
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2065
diff
changeset
|
194 |
* are in dbm: |
1985
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
195 |
* |
2073
6e1e046b323a
simplify the code a bit. Make sure we handle correctly the calculation of the reference rx power
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2070
diff
changeset
|
196 |
* lambda^2 |
6e1e046b323a
simplify the code a bit. Make sure we handle correctly the calculation of the reference rx power
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2070
diff
changeset
|
197 |
* rx = tx + 10 log10 (-------------------) |
6e1e046b323a
simplify the code a bit. Make sure we handle correctly the calculation of the reference rx power
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2070
diff
changeset
|
198 |
* (4 * pi * d)^2 * L |
1985
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
199 |
* |
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
200 |
* rx: rx power (dbm) |
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
201 |
* tx: tx power (dbm) |
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
202 |
* d: distance (m) |
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
203 |
* L: system loss |
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
204 |
* lambda: wavelength (m) |
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
205 |
*/ |
2031
567dbc2475fc
replace distance by a pair of mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1985
diff
changeset
|
206 |
double distance = a->GetDistanceFrom (b); |
2064
a1adc9960e50
handle min distance for friis model in a saner way
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2063
diff
changeset
|
207 |
if (distance <= m_minDistance) |
2062
88302488c05b
Document the friis propagation model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2044
diff
changeset
|
208 |
{ |
2064
a1adc9960e50
handle min distance for friis model in a saner way
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2063
diff
changeset
|
209 |
return txPowerDbm; |
2062
88302488c05b
Document the friis propagation model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2044
diff
changeset
|
210 |
} |
1985
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
211 |
double numerator = m_lambda * m_lambda; |
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
212 |
double denominator = 16 * PI * PI * distance * distance * m_systemLoss; |
2073
6e1e046b323a
simplify the code a bit. Make sure we handle correctly the calculation of the reference rx power
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2070
diff
changeset
|
213 |
double pr = 10 * log10 (numerator / denominator); |
1985
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
214 |
double rxPowerDbm = txPowerDbm + pr; |
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
215 |
NS_LOG_DEBUG ("distance="<<distance<<"m, tx power="<<txPowerDbm<<"dbm, rx power="<<rxPowerDbm<<"dbm"); |
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
216 |
return rxPowerDbm; |
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
217 |
} |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
218 |
|
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
219 |
|
2063
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
220 |
LogDistancePropagationLossModel::LogDistancePropagationLossModel () |
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
221 |
: m_exponent (g_logDistanceExponent.GetValue ()), |
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
222 |
m_referenceDistance (g_logDistanceReferenceDistance.GetValue ()), |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
223 |
m_reference (CreateDefaultReference ()) |
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
224 |
{} |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
225 |
|
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
226 |
void |
2063
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
227 |
LogDistancePropagationLossModel::SetPathLossExponent (double n) |
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
228 |
{ |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
229 |
m_exponent = n; |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
230 |
} |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
231 |
void |
2063
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
232 |
LogDistancePropagationLossModel::SetReferenceDistance (double referenceDistance) |
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
233 |
{ |
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
234 |
m_referenceDistance = referenceDistance; |
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
235 |
} |
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
236 |
void |
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
237 |
LogDistancePropagationLossModel::SetReferenceModel (Ptr<PropagationLossModel> model) |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
238 |
{ |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
239 |
m_reference = model; |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
240 |
} |
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
241 |
double |
2063
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
242 |
LogDistancePropagationLossModel::GetPathLossExponent (void) const |
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
243 |
{ |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
244 |
return m_exponent; |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
245 |
} |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
246 |
|
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
247 |
Ptr<PropagationLossModel> |
2063
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
248 |
LogDistancePropagationLossModel::CreateDefaultReference (void) |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
249 |
{ |
2063
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
250 |
switch (g_logDistanceReferenceType.GetValue ()) { |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
251 |
case RANDOM: |
2230
9f13ac3291e0
add CreateObject<> to instanciate subclasses of the Object base class. Replaces Create<>.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2115
diff
changeset
|
252 |
return CreateObject<RandomPropagationLossModel> (); |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
253 |
break; |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
254 |
case FRIIS: |
2230
9f13ac3291e0
add CreateObject<> to instanciate subclasses of the Object base class. Replaces Create<>.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2115
diff
changeset
|
255 |
return CreateObject<FriisPropagationLossModel> (); |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
256 |
break; |
2063
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
257 |
case LOG_DISTANCE: |
1959
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
258 |
default: |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
259 |
NS_ASSERT (false); |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
260 |
return 0; |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
261 |
break; |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
262 |
} |
f64684973ea8
support DefaultValue
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1882
diff
changeset
|
263 |
} |
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
264 |
|
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
265 |
double |
2063
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
266 |
LogDistancePropagationLossModel::GetRxPower (double txPowerDbm, |
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
267 |
Ptr<MobilityModel> a, |
8663fe258bce
document log distance propagation loss model.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2062
diff
changeset
|
268 |
Ptr<MobilityModel> b) const |
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
269 |
{ |
2031
567dbc2475fc
replace distance by a pair of mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1985
diff
changeset
|
270 |
double distance = a->GetDistanceFrom (b); |
2073
6e1e046b323a
simplify the code a bit. Make sure we handle correctly the calculation of the reference rx power
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2070
diff
changeset
|
271 |
if (distance <= m_referenceDistance) |
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
272 |
{ |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
273 |
return txPowerDbm; |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
274 |
} |
1985
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
275 |
/** |
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
276 |
* The formula is: |
2070
377898b9c6f5
clarify the formulas
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2065
diff
changeset
|
277 |
* rx = 10 * log (Pr0(tx)) - n * 10 * log (d/d0) |
1985
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
278 |
* |
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
279 |
* Pr0: rx power at reference distance d0 (W) |
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
280 |
* d0: reference distance: 1.0 (m) |
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
281 |
* d: distance (m) |
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
282 |
* tx: tx power (db) |
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
283 |
* rx: db |
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
284 |
* |
2073
6e1e046b323a
simplify the code a bit. Make sure we handle correctly the calculation of the reference rx power
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2070
diff
changeset
|
285 |
* Which, in our case is: |
1985
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
286 |
* |
2073
6e1e046b323a
simplify the code a bit. Make sure we handle correctly the calculation of the reference rx power
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2070
diff
changeset
|
287 |
* rx = rx0(tx) - 10 * n * log (d/d0) |
1985
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
288 |
*/ |
2399
fd9d94d518d2
convert Mobility subsystem to Value framework
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2383
diff
changeset
|
289 |
static Ptr<StaticMobilityModel> zero = |
fd9d94d518d2
convert Mobility subsystem to Value framework
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2383
diff
changeset
|
290 |
CreateObjectWith<StaticMobilityModel> ("position", |
fd9d94d518d2
convert Mobility subsystem to Value framework
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2383
diff
changeset
|
291 |
Vector (0.0, 0.0, 0.0)); |
fd9d94d518d2
convert Mobility subsystem to Value framework
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2383
diff
changeset
|
292 |
static Ptr<StaticMobilityModel> reference = |
fd9d94d518d2
convert Mobility subsystem to Value framework
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2383
diff
changeset
|
293 |
CreateObjectWith<StaticMobilityModel> ("position", |
fd9d94d518d2
convert Mobility subsystem to Value framework
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2383
diff
changeset
|
294 |
Vector (m_referenceDistance, 0.0, 0.0)); |
2073
6e1e046b323a
simplify the code a bit. Make sure we handle correctly the calculation of the reference rx power
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2070
diff
changeset
|
295 |
double rx0 = m_reference->GetRxPower (txPowerDbm, zero, reference); |
6e1e046b323a
simplify the code a bit. Make sure we handle correctly the calculation of the reference rx power
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2070
diff
changeset
|
296 |
double pathLossDb = 10 * m_exponent * log10 (distance / m_referenceDistance); |
6e1e046b323a
simplify the code a bit. Make sure we handle correctly the calculation of the reference rx power
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2070
diff
changeset
|
297 |
double rxPowerDbm = rx0 - pathLossDb; |
2065
962441fa9c06
calculate correctly rx power
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2064
diff
changeset
|
298 |
NS_LOG_DEBUG ("distance="<<distance<<"m, tx-power="<<txPowerDbm<<"dbm, "<< |
962441fa9c06
calculate correctly rx power
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2064
diff
changeset
|
299 |
"reference-rx-power="<<rx0<<"dbm, "<< |
962441fa9c06
calculate correctly rx power
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
2064
diff
changeset
|
300 |
"rx-power="<<rxPowerDbm<<"dbm"); |
1985
623a90f3fe07
use dbms consistently in the propagation loss models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
1959
diff
changeset
|
301 |
return rxPowerDbm; |
1882
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
302 |
} |
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
303 |
|
061f7f7f9992
start of work towards port of wifi code
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff
changeset
|
304 |
} // namespace ns3 |