A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
okumura-hata-propagation-loss-model.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2011, 2012 Centre Tecnologic de Telecomunicacions de Catalunya (CTTC)
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License version 2 as
6 * published by the Free Software Foundation;
7 *
8 * This program is distributed in the hope that it will be useful,
9 * but WITHOUT ANY WARRANTY; without even the implied warranty of
10 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
11 * GNU General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License
14 * along with this program; if not, write to the Free Software
15 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
16 *
17 * Author: Marco Miozzo <marco.miozzo@cttc.es>
18 * Nicola Baldo <nbaldo@cttc.es>
19 *
20 */
21
22#ifndef OKUMURA_HATA_PROPAGATION_LOSS_MODEL_H
23#define OKUMURA_HATA_PROPAGATION_LOSS_MODEL_H
24
27
28namespace ns3
29{
30
31/**
32 * \ingroup propagation
33 *
34 * \brief this class implements the Okumura Hata propagation loss model
35 *
36 * this class implements the Okumura Hata propagation loss model,
37 * which is used to model open area pathloss for distances > 1 Km
38 * and frequencies ranging from 150 MHz to 2.0 GHz.
39 * For more information about the model, please see
40 * the propagation module documentation in .rst format.
41 */
43{
44 public:
45 /**
46 * \brief Get the type ID.
47 * \return the object TypeId
48 */
49 static TypeId GetTypeId();
50
53
54 // Delete copy constructor and assignment operator to avoid misuse
57
58 /**
59 * \param a the first mobility model
60 * \param b the second mobility model
61 *
62 * \return the loss in dBm for the propagation between
63 * the two given mobility models
64 */
66
67 private:
68 double DoCalcRxPower(double txPowerDbm,
70 Ptr<MobilityModel> b) const override;
71 int64_t DoAssignStreams(int64_t stream) override;
72
73 EnvironmentType m_environment; //!< Environment Scenario
74 CitySize m_citySize; //!< Size of the city
75 double m_frequency; //!< frequency in Hz
76};
77
78} // namespace ns3
79
80#endif // OKUMURA_HATA_PROPAGATION_LOSS_MODEL_H
this class implements the Okumura Hata propagation loss model
int64_t DoAssignStreams(int64_t stream) override
Assign a fixed random variable stream number to the random variables used by this model.
EnvironmentType m_environment
Environment Scenario.
double DoCalcRxPower(double txPowerDbm, Ptr< MobilityModel > a, Ptr< MobilityModel > b) const override
PropagationLossModel.
OkumuraHataPropagationLossModel & operator=(const OkumuraHataPropagationLossModel &)=delete
OkumuraHataPropagationLossModel(const OkumuraHataPropagationLossModel &)=delete
double GetLoss(Ptr< MobilityModel > a, Ptr< MobilityModel > b) const
Models the propagation loss through a transmission medium.
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:77
a unique identifier for an interface.
Definition: type-id.h:59
EnvironmentType
The type of propagation environment.
CitySize
The size of the city in which propagation takes place.
Every class exported by the ns3 library is enclosed in the ns3 namespace.