A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
a2-a4-rsrq-handover-algorithm.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2011, 2012 Centre Tecnologic de Telecomunicacions de Catalunya (CTTC)
3 * Copyright (c) 2013 Budiarto Herman
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 as
7 * published by the Free Software Foundation;
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17 *
18 * Original work authors (from lte-enb-rrc.cc):
19 * Nicola Baldo <nbaldo@cttc.es>
20 * Marco Miozzo <mmiozzo@cttc.es>
21 * Manuel Requena <manuel.requena@cttc.es>
22 *
23 * Converted to handover algorithm interface by:
24 * Budiarto Herman <budiarto.herman@magister.fi>
25 */
26
27#ifndef A2_A4_RSRQ_HANDOVER_ALGORITHM_H
28#define A2_A4_RSRQ_HANDOVER_ALGORITHM_H
29
32#include "lte-rrc-sap.h"
33
34#include <ns3/ptr.h>
35#include <ns3/simple-ref-count.h>
36
37#include <map>
38
39namespace ns3
40{
41
42/**
43 * \brief Handover algorithm implementation based on RSRQ measurements, Event
44 * A2 and Event A4.
45 *
46 * Handover decision made by this algorithm is primarily based on Event A2
47 * measurements (serving cell's RSRQ becomes worse than threshold). When the
48 * event is triggered, the first condition of handover is fulfilled.
49 *
50 * Event A4 measurements (neighbour cell's RSRQ becomes better than threshold)
51 * are used to detect neighbouring cells and their respective RSRQ. When a
52 * neighbouring cell's RSRQ is higher than the serving cell's RSRQ by a certain
53 * offset, then the second condition of handover is fulfilled.
54 *
55 * When the first and second conditions above are fulfilled, the algorithm
56 * informs the eNodeB RRC to trigger a handover.
57 *
58 * The threshold for Event A2 can be configured in the `ServingCellThreshold`
59 * attribute. The offset used in the second condition can also be configured by
60 * setting the `NeighbourCellOffset` attribute.
61 *
62 * The following code snippet is an example of using and configuring the
63 * handover algorithm in a simulation program:
64 *
65 * Ptr<LteHelper> lteHelper = CreateObject<LteHelper> ();
66 *
67 * NodeContainer enbNodes;
68 * // configure the nodes here...
69 *
70 * lteHelper->SetHandoverAlgorithmType ("ns3::A2A4RsrqHandoverAlgorithm");
71 * lteHelper->SetHandoverAlgorithmAttribute ("ServingCellThreshold",
72 * UintegerValue (30));
73 * lteHelper->SetHandoverAlgorithmAttribute ("NeighbourCellOffset",
74 * UintegerValue (1));
75 * NetDeviceContainer enbLteDevs = lteHelper->InstallEnbDevice (enbNodes);
76 *
77 * \note Setting the handover algorithm type and attributes after the call to
78 * LteHelper::InstallEnbDevice does not have any effect to the devices
79 * that have already been installed.
80 */
82{
83 public:
84 /// Creates an A2-A4-RSRQ handover algorithm instance.
86
88
89 /**
90 * \brief Get the type ID.
91 * \return the object TypeId
92 */
93 static TypeId GetTypeId();
94
95 // inherited from LteHandoverAlgorithm
98
99 /// let the forwarder class access the protected and private members
101
102 protected:
103 // inherited from Object
104 void DoInitialize() override;
105 void DoDispose() override;
106
107 // inherited from LteHandoverAlgorithm as a Handover Management SAP implementation
108 void DoReportUeMeas(uint16_t rnti, LteRrcSap::MeasResults measResults) override;
109
110 private:
111 /**
112 * Called when Event A2 is detected, then trigger a handover if needed.
113 *
114 * \param rnti The RNTI of the UE who reported the event.
115 * \param servingCellRsrq The RSRQ of this cell as reported by the UE.
116 */
117 void EvaluateHandover(uint16_t rnti, uint8_t servingCellRsrq);
118
119 /**
120 * Determines if a neighbour cell is a valid destination for handover.
121 * Currently always return true.
122 *
123 * \param cellId The cell ID of the neighbour cell.
124 * \return True if the cell is a valid destination for handover.
125 */
126 bool IsValidNeighbour(uint16_t cellId);
127
128 /**
129 * Called when Event A4 is reported, then update the measurements table.
130 * If the RNTI and/or cell ID is not found in the table, a corresponding
131 * entry will be created. Only the latest measurements are stored in the
132 * table.
133 *
134 * \param rnti The RNTI of the UE who reported the event.
135 * \param cellId The cell ID of the measured cell.
136 * \param rsrq The RSRQ of the cell as measured by the UE.
137 */
138 void UpdateNeighbourMeasurements(uint16_t rnti, uint16_t cellId, uint8_t rsrq);
139
140 /// The expected measurement identities for A2 measurements.
141 std::vector<uint8_t> m_a2MeasIds;
142 /// The expected measurement identities for A4 measurements.
143 std::vector<uint8_t> m_a4MeasIds;
144
145 /**
146 * Measurements reported by a UE for a cell ID. The values are quantized
147 * according 3GPP TS 36.133 section 9.1.4 and 9.1.7.
148 */
149 class UeMeasure : public SimpleRefCount<UeMeasure>
150 {
151 public:
152 uint16_t m_cellId; ///< Cell ID.
153 uint8_t m_rsrp; ///< RSRP in quantized format. \todo Can be removed?
154 uint8_t m_rsrq; ///< RSRQ in quantized format.
155 };
156
157 /**
158 * Measurements reported by a UE for several cells. The structure is a map
159 * indexed by the cell ID.
160 */
161 typedef std::map<uint16_t, Ptr<UeMeasure>> MeasurementRow_t;
162
163 /**
164 * Measurements reported by several UEs. The structure is a map indexed by
165 * the RNTI of the UE.
166 */
167 typedef std::map<uint16_t, MeasurementRow_t> MeasurementTable_t;
168
169 /// Table of measurement reports from all UEs.
171
172 /**
173 * The `ServingCellThreshold` attribute. If the RSRQ of the serving cell is
174 * worse than this threshold, neighbour cells are consider for handover.
175 * Expressed in quantized range of [0..34] as per Section 9.1.7 of
176 * 3GPP TS 36.133.
177 */
179
180 /**
181 * The `NeighbourCellOffset` attribute. Minimum offset between the serving
182 * and the best neighbour cell to trigger the handover. Expressed in
183 * quantized range of [0..34] as per Section 9.1.7 of 3GPP TS 36.133.
184 */
186
187 /// Interface to the eNodeB RRC instance.
189 /// Receive API calls from the eNodeB RRC instance.
191
192}; // end of class A2A4RsrqHandoverAlgorithm
193
194} // end of namespace ns3
195
196#endif /* A2_A4_RSRQ_HANDOVER_ALGORITHM_H */
Measurements reported by a UE for a cell ID.
Handover algorithm implementation based on RSRQ measurements, Event A2 and Event A4.
static TypeId GetTypeId()
Get the type ID.
LteHandoverManagementSapUser * m_handoverManagementSapUser
Interface to the eNodeB RRC instance.
std::map< uint16_t, MeasurementRow_t > MeasurementTable_t
Measurements reported by several UEs.
std::map< uint16_t, Ptr< UeMeasure > > MeasurementRow_t
Measurements reported by a UE for several cells.
void DoInitialize() override
Initialize() implementation.
A2A4RsrqHandoverAlgorithm()
Creates an A2-A4-RSRQ handover algorithm instance.
LteHandoverManagementSapProvider * GetLteHandoverManagementSapProvider() override
Export the "provider" part of the Handover Management SAP interface.
LteHandoverManagementSapProvider * m_handoverManagementSapProvider
Receive API calls from the eNodeB RRC instance.
bool IsValidNeighbour(uint16_t cellId)
Determines if a neighbour cell is a valid destination for handover.
std::vector< uint8_t > m_a2MeasIds
The expected measurement identities for A2 measurements.
void UpdateNeighbourMeasurements(uint16_t rnti, uint16_t cellId, uint8_t rsrq)
Called when Event A4 is reported, then update the measurements table.
void DoDispose() override
Destructor implementation.
void SetLteHandoverManagementSapUser(LteHandoverManagementSapUser *s) override
Set the "user" part of the Handover Management SAP interface that this handover algorithm instance wi...
void EvaluateHandover(uint16_t rnti, uint8_t servingCellRsrq)
Called when Event A2 is detected, then trigger a handover if needed.
MeasurementTable_t m_neighbourCellMeasures
Table of measurement reports from all UEs.
uint8_t m_servingCellThreshold
The ServingCellThreshold attribute.
void DoReportUeMeas(uint16_t rnti, LteRrcSap::MeasResults measResults) override
Implementation of LteHandoverManagementSapProvider::ReportUeMeas.
std::vector< uint8_t > m_a4MeasIds
The expected measurement identities for A4 measurements.
uint8_t m_neighbourCellOffset
The NeighbourCellOffset attribute.
The abstract base class of a handover algorithm that operates using the Handover Management SAP inter...
Service Access Point (SAP) offered by the handover algorithm instance to the eNodeB RRC instance.
Service Access Point (SAP) offered by the eNodeB RRC instance to the handover algorithm instance.
Template for the implementation of the LteHandoverManagementSapProvider as a member of an owner class...
A template-based reference counting class.
a unique identifier for an interface.
Definition: type-id.h:59
Every class exported by the ns3 library is enclosed in the ns3 namespace.
MeasResults structure.
Definition: lte-rrc-sap.h:717