/usr/include/ns3/jakes-fading-loss-model.h is in libns3-dev 3.13+dfsg-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 | /* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
/*
* Copyright (c) 2010 TELEMATICS LAB, DEE - Politecnico di Bari
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation;
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* Author: Giuseppe Piro <g.piro@poliba.it>
*/
#ifndef MULTIPATH_LOSS_MODEL_H
#define MULTIPATH_LOSS_MODEL_H
#include "discrete-time-loss-model.h"
#include <list>
#include <ns3/random-variable.h>
namespace ns3 {
class LtePhy;
/**
* \ingroup lte
*
* \brief JakesFadingLossModel class implements a loss model due to the fast fading.
* In particular, the fast fading is modeled using a Jakes Model
*/
class JakesFadingLossModel : public DiscreteTimeLossModel
{
public:
JakesFadingLossModel ();
virtual ~JakesFadingLossModel ();
static TypeId GetTypeId (void);
/**
* \brief Set the value of the considered loss model
*/
void SetValue (void);
/**
* \brief Get the value for a particular sub channel
* \param subChannel the sub channel for which a value is requested
* \return the loss for a particular sub channel
*/
double GetValue (int subChannel);
/**
* \brief Set the physical layer
* \param phy the physical layer
*/
void SetPhy (Ptr<LtePhy> phy);
/**
* \brief Get the physical layer
* \return the pointer to the physical layer
*/
Ptr<LtePhy> GetPhy (void);
/*
* In order to avoid to execute every TTI the Jakes Model, the value
* of the multipath loss is stored into a matrix (MultipathForFrequencyDomain)
* frequency x time.
*
* A MultipathForFrequencyDomain element is build in a way that
* m_multipath.at(i).at(j) represents the loss at the frequency i and time j.
*
* The model is udated every samplingInterval (the default value is 0.5 ms)
*/
/**
* brief a list of multipath values for the time domain
*/
typedef std::vector<double> MultipathForTimeDomain;
/**
* brief a list of multipath values for the frequency domain
*/
typedef std::vector<MultipathForTimeDomain> MultipathForFrequencyDomain;
private:
MultipathForFrequencyDomain m_multipath;
UniformVariable m_nbOfPaths;
UniformVariable m_startJakes;
Ptr<LtePhy> m_phy;
};
}
#endif /* MULTIPATH_LOSS_MODEL_H */
|