src/devices/wifi/jakes-propagation-loss-model.cc
author Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
Tue, 06 Jan 2009 15:25:31 +0100
changeset 4042 d5d8f079f3bd
parent 4041 c52c1814bd5e
child 4043 865d27306bdb
permissions -rw-r--r--
fix coding style
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2678
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     1
/* -*-  Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     2
/*
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     3
 * Copyright (c) 2005,2006,2007 INRIA
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     4
 *
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     6
 * it under the terms of the GNU General Public License version 2 as 
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     7
 * published by the Free Software Foundation;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     8
 *
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    12
 * GNU General Public License for more details.
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    13
 *
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    14
 * You should have received a copy of the GNU General Public License
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    15
 * along with this program; if not, write to the Free Software
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    16
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    17
 *
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    18
 * Author: Federico Maguolo <maguolof@dei.unipd.it>
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    19
 */
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    20
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    21
#include "ns3/simulator.h"
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    22
#include "ns3/uinteger.h"
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    23
#include "ns3/double.h"
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    24
#include "ns3/random-variable.h"
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    25
#include "ns3/mobility-model.h"
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    26
#include "ns3/log.h"
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    27
#include "jakes-propagation-loss-model.h"
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    28
#include <math.h>
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    29
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    30
NS_LOG_COMPONENT_DEFINE ("Jakes");
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    31
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    32
namespace ns3 {
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    33
3907
56e477db65b2 add composite capability to PropagationLossModel base class.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2965
diff changeset
    34
class JakesPropagationLossModel::PathCoefficients 
56e477db65b2 add composite capability to PropagationLossModel base class.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2965
diff changeset
    35
{
2678
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    36
public:
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    37
  PathCoefficients (Ptr<const JakesPropagationLossModel> jakes,
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    38
                    Ptr<MobilityModel> receiver, 
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    39
                    uint8_t nRays, 
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    40
                    uint8_t nOscillators);
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    41
  ~PathCoefficients ();
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    42
  double GetLoss (void);
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    43
  Ptr<MobilityModel> GetReceiver (void);
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    44
private:
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    45
  void DoConstruct (void);
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    46
  Ptr<MobilityModel> m_receiver;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    47
  uint8_t m_nOscillators;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    48
  uint8_t m_nRays;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    49
  double **m_phases;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    50
  Time m_lastUpdate;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    51
  Ptr<const JakesPropagationLossModel> m_jakes;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    52
};
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    53
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    54
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    55
JakesPropagationLossModel::PathCoefficients::PathCoefficients (Ptr<const JakesPropagationLossModel> jakes, 
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    56
                                                           Ptr<MobilityModel> receiver, 
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    57
                                                           uint8_t nRays, 
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    58
							   uint8_t nOscillators)
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    59
  : m_receiver (receiver),
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    60
    m_nOscillators (nOscillators),
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    61
    m_nRays (nRays),
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    62
    m_jakes(jakes)
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    63
{
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    64
  DoConstruct ();
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    65
}
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    66
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    67
JakesPropagationLossModel::PathCoefficients::~PathCoefficients ()
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    68
{
4042
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
    69
  for (uint8_t i = 0; i < m_nRays; i++) 
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
    70
    {
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
    71
      delete [] m_phases[i];
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
    72
    }
2678
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    73
  delete [] m_phases;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    74
}
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    75
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    76
void
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    77
JakesPropagationLossModel::PathCoefficients::DoConstruct ()
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    78
{
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    79
  m_phases = new double*[m_nRays];
4042
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
    80
  for (uint8_t i = 0; i < m_nRays; i++) 
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
    81
    {
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
    82
      m_phases[i] = new double[m_nOscillators + 1];
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
    83
      for (uint8_t j = 0; j <= m_nOscillators; j++) 
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
    84
        {
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
    85
          m_phases[i][j] = 2.0 * JakesPropagationLossModel::PI * m_jakes->m_variable.GetValue ();
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
    86
        }
2678
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    87
    }
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    88
  m_lastUpdate = Simulator::Now ();
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    89
}
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    90
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    91
Ptr<MobilityModel>
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    92
JakesPropagationLossModel::PathCoefficients::GetReceiver ()
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    93
{
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    94
  return m_receiver;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    95
}
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    96
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    97
double
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    98
JakesPropagationLossModel::PathCoefficients::GetLoss (void)
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
    99
{
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   100
  uint16_t N = 4 * m_nOscillators + 2;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   101
  Time interval = Simulator::Now () - m_lastUpdate;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   102
  ComplexNumber coef= {0.0, 0.0};
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   103
  ComplexNumber fading;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   104
  double norm = 0.0;
4042
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   105
  for (uint8_t i = 0; i < m_nRays; i++) 
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   106
    {
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   107
      fading.real = 0.0;
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   108
      fading.imag = 0.0;
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   109
      for (uint8_t j = 0; j <= m_nOscillators; j++) 
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   110
        {
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   111
          m_phases[i][j] += 2.0 * JakesPropagationLossModel::PI * 
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   112
            cos (2.0 * JakesPropagationLossModel::PI * j / N) * m_jakes->m_fd * interval.GetSeconds ();
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   113
          m_phases[i][j] -= 2.0 * JakesPropagationLossModel::PI * 
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   114
            floor (m_phases[i][j] / 2.0 / JakesPropagationLossModel::PI);
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   115
          fading.real += m_jakes->m_amp[j].real * cos (m_phases[i][j]);
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   116
          fading.imag += m_jakes->m_amp[j].imag * cos (m_phases[i][j]);
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   117
          norm += sqrt(pow (m_jakes->m_amp[j].real, 2) + pow(m_jakes->m_amp[j].imag, 2));
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   118
        }
2678
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   119
    coef.real += fading.real;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   120
    coef.imag += fading.imag;
4042
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   121
    }
2678
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   122
  m_lastUpdate = Simulator::Now ();
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   123
  double k = sqrt (pow (coef.real, 2) + pow (coef.imag, 2)) / norm;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   124
  NS_LOG_DEBUG ("Jakes coef "<< k << " (" << 10 * log10 (k) << "dB)");
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   125
  return 10 * log10 (k);
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   126
}
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   127
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   128
NS_OBJECT_ENSURE_REGISTERED (JakesPropagationLossModel);
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   129
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   130
const double JakesPropagationLossModel::PI = 3.1415;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   131
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   132
TypeId
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   133
JakesPropagationLossModel::GetTypeId (void)
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   134
{
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   135
  static TypeId tid = TypeId ("ns3::JakesPropagationLossModel")
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   136
    .SetParent<PropagationLossModel> ()
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   137
    .AddConstructor<JakesPropagationLossModel> ()
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   138
    .AddAttribute ("NumberOfRaysPerPath",
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   139
                   "The number of rays to use by default for compute the fading coeficent for a given path (default is 1)",
2965
4b28e9740e3b get rid of Attribute class. Use AttributeValue subclasses directly.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2681
diff changeset
   140
                   UintegerValue (1),
2678
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   141
		   MakeUintegerAccessor (&JakesPropagationLossModel::m_nRays),
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   142
		   MakeUintegerChecker<uint8_t> ())
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   143
    .AddAttribute ("NumberOfOscillatorsPerRay",
4042
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   144
                   "The number of oscillators to use by default for compute the coeficent for a given ray of a given "
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   145
                   "path (default is 4)",
2965
4b28e9740e3b get rid of Attribute class. Use AttributeValue subclasses directly.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2681
diff changeset
   146
                   UintegerValue (4),
2678
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   147
		   MakeUintegerAccessor (&JakesPropagationLossModel::m_nOscillators),
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   148
		   MakeUintegerChecker<uint8_t> ())
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   149
    .AddAttribute ("DopplerFreq",
4041
c52c1814bd5e fix typo
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3907
diff changeset
   150
                   "The doppler frequency in Hz (f_d = v / lambda = v * f / c), the default is 0)",
2965
4b28e9740e3b get rid of Attribute class. Use AttributeValue subclasses directly.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2681
diff changeset
   151
                   DoubleValue (0.0),
2678
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   152
		   MakeDoubleAccessor (&JakesPropagationLossModel::m_fd),
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   153
		   MakeDoubleChecker<double> ())
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   154
    .AddAttribute ("Distribution",
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   155
                   "The distribution to choose the initial phases.",
2965
4b28e9740e3b get rid of Attribute class. Use AttributeValue subclasses directly.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2681
diff changeset
   156
                   RandomVariableValue (ConstantVariable (1.0)),
2678
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   157
                   MakeRandomVariableAccessor (&JakesPropagationLossModel::m_variable),
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   158
                   MakeRandomVariableChecker ())
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   159
    ;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   160
  return tid;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   161
}
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   162
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   163
JakesPropagationLossModel::JakesPropagationLossModel ()
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   164
{
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   165
  DoConstruct ();
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   166
}
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   167
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   168
JakesPropagationLossModel::~JakesPropagationLossModel ()
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   169
{
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   170
  delete [] m_amp;
4042
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   171
  for (PathsList::iterator i = m_paths.end (); i != m_paths.begin (); i--) 
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   172
    {
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   173
      PathsSet *ps = *i;
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   174
      for (DestinationList::iterator r = ps->receivers.begin (); r != ps->receivers.end (); r++) 
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   175
        {
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   176
          PathCoefficients *pc = *r;
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   177
          delete pc;
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   178
        }
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   179
      delete ps;
2678
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   180
    }
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   181
}
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   182
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   183
void
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   184
JakesPropagationLossModel::DoConstruct ()
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   185
{
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   186
  uint16_t N = 4 * m_nOscillators + 2;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   187
  m_amp = new ComplexNumber[m_nOscillators + 1];
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   188
  m_amp[0].real = 2.0 * sqrt(2.0 / N) * cos (PI / 4.0);
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   189
  m_amp[0].imag = 2.0 * sqrt(2.0 / N) * sin (PI / 4.0);
4042
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   190
  for (uint8_t i = 1; i <= m_nOscillators; i++) 
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   191
    {
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   192
      double beta = PI * (double)i / m_nOscillators;
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   193
      m_amp[i].real = 4.0 * cos (beta) / sqrt(N);
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   194
      m_amp[i].imag = 4.0 * sin (beta) / sqrt(N);
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   195
    }
2678
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   196
}
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   197
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   198
void
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   199
JakesPropagationLossModel::SetNRays (uint8_t nRays)
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   200
{
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   201
  m_nRays = nRays;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   202
}
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   203
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   204
void
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   205
JakesPropagationLossModel::SetNOscillators (uint8_t nOscillators)
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   206
{
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   207
  m_nOscillators = nOscillators;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   208
}
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   209
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   210
double
3907
56e477db65b2 add composite capability to PropagationLossModel base class.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2965
diff changeset
   211
JakesPropagationLossModel::DoGetLoss (Ptr<MobilityModel> a,
2678
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   212
				    Ptr<MobilityModel> b) const
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   213
{
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   214
  PathsList::iterator i = m_paths.end ();
4042
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   215
  while (i != m_paths.begin ()) 
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   216
    {
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   217
      i--;
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   218
      PathsSet *ps = *i;
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   219
      if (PeekPointer (ps->sender) == PeekPointer(a)) 
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   220
        {
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   221
          m_paths.erase (i);
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   222
          m_paths.push_back (ps);
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   223
          for (DestinationList::iterator r = ps->receivers.begin (); r != ps->receivers.end (); r++) 
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   224
            {
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   225
              PathCoefficients *pc = *r;
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   226
              if (PeekPointer (pc->GetReceiver ()) == PeekPointer (b)) 
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   227
                {
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   228
                  ps->receivers.erase (r);
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   229
                  ps->receivers.push_back (pc);
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   230
                  return pc->GetLoss ();
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   231
                }
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   232
            }
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   233
          PathCoefficients *pc = new PathCoefficients (this, b, m_nRays, m_nOscillators);
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   234
          ps->receivers.push_back (pc);
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   235
          return pc->GetLoss ();
d5d8f079f3bd fix coding style
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 4041
diff changeset
   236
        }
2678
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   237
    }
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   238
  PathsSet *ps = new PathsSet;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   239
  ps->sender = a;
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   240
  PathCoefficients *pc = new PathCoefficients (this, b, m_nRays, m_nOscillators);
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   241
  ps->receivers.push_back (pc);
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   242
  m_paths.push_back (ps);
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   243
  return pc->GetLoss ();
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   244
}
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   245
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   246
} // namespace ns3
22aa62a108ed Composite and Jakes propagation loss models.
src/devices/wifi/Federico Maguolo <maguolof@dei.unipd.it>
parents:
diff changeset
   247