A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
buildings-channel-condition-model.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2015, NYU WIRELESS, Tandon School of Engineering, New York
3 * University
4 * Copyright (c) 2019 SIGNET Lab, Department of Information Engineering,
5 * University of Padova
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 as
9 * published by the Free Software Foundation;
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
19 */
20
21#ifndef BUILDINGS_CHANNEL_CONDITION_MODEL_H
22#define BUILDINGS_CHANNEL_CONDITION_MODEL_H
23
24#include "ns3/channel-condition-model.h"
25
26namespace ns3
27{
28
29class MobilityModel;
30
31/**
32 * \ingroup buildings
33 * \ingroup propagation
34 *
35 * \brief Determines the channel condition based on the buildings deployed in the
36 * scenario
37 *
38 * Code adapted from MmWave3gppBuildingsPropagationLossModel
39 */
41{
42 public:
43 /**
44 * Get the type ID.
45 * \brief Get the type ID.
46 * \return the object TypeId
47 */
48 static TypeId GetTypeId();
49
50 /**
51 * Constructor for the BuildingsChannelConditionModel class
52 */
54
55 /**
56 * Destructor for the BuildingsChannelConditionModel class
57 */
59
60 /**
61 * Computes the condition of the channel between a and b.
62 *
63 * \param a mobility model
64 * \param b mobility model
65 * \return the condition of the channel between a and b
66 */
68 Ptr<const MobilityModel> b) const override;
69
70 /**
71 * If this model uses objects of type RandomVariableStream,
72 * set the stream numbers to the integers starting with the offset
73 * 'stream'. Return the number of streams (possibly zero) that
74 * have been assigned.
75 *
76 * \param stream
77 * \return the number of stream indices assigned by this model
78 */
79 int64_t AssignStreams(int64_t stream) override;
80
81 private:
82 /**
83 * \brief Checks if the line of sight between position l1 and position l2 is
84 * blocked by a building.
85 *
86 * \param l1 position
87 * \param l2 position
88 * \return true if the line of sight is blocked, false otherwise
89 */
90 bool IsLineOfSightBlocked(const Vector& l1, const Vector& l2) const;
91};
92
93} // namespace ns3
94
95#endif /* BUILDINGS_CHANNEL_CONDITION_MODEL_H */
Determines the channel condition based on the buildings deployed in the scenario.
int64_t AssignStreams(int64_t stream) override
If this model uses objects of type RandomVariableStream, set the stream numbers to the integers start...
Ptr< ChannelCondition > GetChannelCondition(Ptr< const MobilityModel > a, Ptr< const MobilityModel > b) const override
Computes the condition of the channel between a and b.
bool IsLineOfSightBlocked(const Vector &l1, const Vector &l2) const
Checks if the line of sight between position l1 and position l2 is blocked by a building.
BuildingsChannelConditionModel()
Constructor for the BuildingsChannelConditionModel class.
~BuildingsChannelConditionModel() override
Destructor for the BuildingsChannelConditionModel class.
Models the channel condition.
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:77
a unique identifier for an interface.
Definition: type-id.h:59
Every class exported by the ns3 library is enclosed in the ns3 namespace.