blob: 6c6ab18b0195e26187005203e7143deba708357d [file] [log] [blame]
akmhoque3d06e792014-05-27 16:23:20 -05001/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2/**
Nick Gordonc6a85222017-01-03 16:54:34 -06003 * Copyright (c) 2014-2017, The University of Memphis,
Nick Gordonf8b5bcd2016-08-11 15:06:50 -05004 * Regents of the University of California
akmhoque3d06e792014-05-27 16:23:20 -05005 *
6 * This file is part of NLSR (Named-data Link State Routing).
7 * See AUTHORS.md for complete list of NLSR authors and contributors.
8 *
9 * NLSR is free software: you can redistribute it and/or modify it under the terms
10 * of the GNU General Public License as published by the Free Software Foundation,
11 * either version 3 of the License, or (at your option) any later version.
12 *
13 * NLSR is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
14 * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15 * PURPOSE. See the GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License along with
18 * NLSR, e.g., in COPYING.md file. If not, see <http://www.gnu.org/licenses/>.
19 *
20 * \author A K M Mahmudul Hoque <ahoque1@memphis.edu>
21 *
22 **/
akmhoquefdbddb12014-05-02 18:35:19 -050023#ifndef NLSR_ROUTING_TABLE_CALCULATOR_HPP
24#define NLSR_ROUTING_TABLE_CALCULATOR_HPP
akmhoque53353462014-04-22 08:43:45 -050025
26#include <list>
27#include <iostream>
akmhoquefdbddb12014-05-02 18:35:19 -050028#include <boost/cstdint.hpp>
akmhoque53353462014-04-22 08:43:45 -050029
Vince Lehman9a709032014-09-13 16:28:07 -050030#include <ndn-cxx/name.hpp>
31
akmhoque53353462014-04-22 08:43:45 -050032namespace nlsr {
33
34class Map;
35class RoutingTable;
36class Nlsr;
37
38class RoutingTableCalculator
39{
40public:
41 RoutingTableCalculator()
42 {
43 }
Vince Lehman9a709032014-09-13 16:28:07 -050044 RoutingTableCalculator(size_t nRouters)
akmhoque53353462014-04-22 08:43:45 -050045 {
Vince Lehman9a709032014-09-13 16:28:07 -050046 m_nRouters = nRouters;
akmhoque53353462014-04-22 08:43:45 -050047 }
48protected:
Nick G97e34942016-07-11 14:46:27 -050049 /*! \brief Allocate the space needed for the adj. matrix. */
akmhoque53353462014-04-22 08:43:45 -050050 void
51 allocateAdjMatrix();
52
Nick G97e34942016-07-11 14:46:27 -050053 /*! \brief Zero every cell of the matrix to ensure that the memory is safe. */
akmhoque53353462014-04-22 08:43:45 -050054 void
55 initMatrix();
56
Nick G97e34942016-07-11 14:46:27 -050057 /*! \brief Constructs an adj. matrix to calculate with.
58 \param pnlsr The NLSR object that contains the LSAs that we need to iterate
59 over.
60 \param pMap The map to populate with the adj. data.
61 */
akmhoque53353462014-04-22 08:43:45 -050062 void
63 makeAdjMatrix(Nlsr& pnlsr, Map pMap);
Vince Lehman9a709032014-09-13 16:28:07 -050064
akmhoque2f423352014-06-03 11:49:35 -050065 void
66 writeAdjMatrixLog();
akmhoque53353462014-04-22 08:43:45 -050067
Nick G97e34942016-07-11 14:46:27 -050068 /*! \brief Returns how many links a router in the matrix has.
69 \param sRouter The router to count the links of.
70 */
akmhoque53353462014-04-22 08:43:45 -050071 int
72 getNumOfLinkfromAdjMatrix(int sRouter);
73
74 void
75 freeAdjMatrix();
Nick G97e34942016-07-11 14:46:27 -050076 /*! \brief Adjust a link cost in the adj. matrix
77 \param source The source router whose adjacency to adjust.
78 \param link The adjacency of the source to adjust.
79 \param linkCost The cost to change to.
80 */
akmhoque53353462014-04-22 08:43:45 -050081 void
82 adjustAdMatrix(int source, int link, double linkCost);
83
Nick G97e34942016-07-11 14:46:27 -050084 /*! \brief Populates temp. variables with the link costs for some router.
85 \param source The router whose values are to be adjusted.
86 \param links An integer pointer array for the link mappingNos.
87 \param linkCosts A double pointer array that stores the link costs.
88
89 Obtains a sparse list of adjacencies and link costs for some
90 router. Since this is sparse, that means while generating these
91 arrays, if there is no adjacency at i in the matrix, these
92 temporary variables will not contain a 0 at i, but rather will
93 contain the values for the next valid adjacency.
94 */
akmhoque53353462014-04-22 08:43:45 -050095 void
96 getLinksFromAdjMatrix(int* links, double* linkCosts, int source);
97
Nick G97e34942016-07-11 14:46:27 -050098 /*! Allocates an array large enough to hold multipath calculation temps. */
akmhoque53353462014-04-22 08:43:45 -050099 void
100 allocateLinks();
101
102 void
103 allocateLinkCosts();
104
105 void
106 freeLinks();
107
108 void
109 freeLinksCosts();
110
111 void
112 setNoLink(int nl)
113 {
114 vNoLink = nl;
115 }
116
117protected:
118 double** adjMatrix;
Vince Lehman9a709032014-09-13 16:28:07 -0500119 size_t m_nRouters;
akmhoque53353462014-04-22 08:43:45 -0500120
121 int vNoLink;
122 int* links;
123 double* linkCosts;
124};
125
126class LinkStateRoutingTableCalculator: public RoutingTableCalculator
127{
128public:
Vince Lehman9a709032014-09-13 16:28:07 -0500129 LinkStateRoutingTableCalculator(size_t nRouters)
130 : RoutingTableCalculator(nRouters)
131 , EMPTY_PARENT(-12345)
akmhoque53353462014-04-22 08:43:45 -0500132 , INF_DISTANCE(2147483647)
133 , NO_MAPPING_NUM(-1)
134 , NO_NEXT_HOP(-12345)
135 {
akmhoque53353462014-04-22 08:43:45 -0500136 }
137
akmhoque53353462014-04-22 08:43:45 -0500138 void
139 calculatePath(Map& pMap, RoutingTable& rt, Nlsr& pnlsr);
140
akmhoque53353462014-04-22 08:43:45 -0500141private:
Nick G97e34942016-07-11 14:46:27 -0500142 /*! \brief Performs a Dijkstra's calculation over the adjacency matrix.
143 \param sourceRouter The origin router to compute paths from.
144 */
akmhoque53353462014-04-22 08:43:45 -0500145 void
146 doDijkstraPathCalculation(int sourceRouter);
147
Nick G97e34942016-07-11 14:46:27 -0500148 /*! \brief Sort the elements of a list.
149 \param Q The array that contains the elements to sort.
150 \param dist The array that contains the distances.
151 \param start The first element in the list to sort.
152 \param element The last element in the list to sort through.
153
154 Sorts the list based on distance. The distances are indexed by
155 their mappingNo in dist. Currently uses an insertion sort.
156 */
akmhoque53353462014-04-22 08:43:45 -0500157 void
158 sortQueueByDistance(int* Q, double* dist, int start, int element);
159
Nick G97e34942016-07-11 14:46:27 -0500160 /*! \brief Returns whether an element has been visited yet.
161 \param Q The list of elements to look through.
162 \param u The element to check.
163 \param start The start of list to look through.
164 \param element The end of the list to look through.
165 */
akmhoque53353462014-04-22 08:43:45 -0500166 int
167 isNotExplored(int* Q, int u, int start, int element);
168
169 void
akmhoque53353462014-04-22 08:43:45 -0500170 addAllLsNextHopsToRoutingTable(Nlsr& pnlsr, RoutingTable& rt,
Vince Lehman9a709032014-09-13 16:28:07 -0500171 Map& pMap, uint32_t sourceRouter);
akmhoque53353462014-04-22 08:43:45 -0500172
Nick G97e34942016-07-11 14:46:27 -0500173 /*! \brief Determines a destination's next hop.
174 \param dest The router whose next hop we want to determine.
175 \param source The router to determine a next path to.
176 */
akmhoque53353462014-04-22 08:43:45 -0500177 int
178 getLsNextHop(int dest, int source);
179
180 void
181 allocateParent();
182
183 void
184 allocateDistance();
185
186 void
187 freeParent();
188
189 void
190 freeDistance();
191
akmhoque53353462014-04-22 08:43:45 -0500192private:
193 int* m_parent;
194 double* m_distance;
195
akmhoque53353462014-04-22 08:43:45 -0500196 const int EMPTY_PARENT;
197 const double INF_DISTANCE;
198 const int NO_MAPPING_NUM;
199 const int NO_NEXT_HOP;
200
201};
202
Vince Lehman9a709032014-09-13 16:28:07 -0500203class AdjacencyList;
204class Lsdb;
205
206class HyperbolicRoutingCalculator
akmhoque53353462014-04-22 08:43:45 -0500207{
208public:
Vince Lehman9a709032014-09-13 16:28:07 -0500209 HyperbolicRoutingCalculator(size_t nRouters, bool isDryRun, ndn::Name thisRouterName)
210 : m_nRouters(nRouters)
211 , m_isDryRun(isDryRun)
212 , m_thisRouterName(thisRouterName)
akmhoque53353462014-04-22 08:43:45 -0500213 {
akmhoque53353462014-04-22 08:43:45 -0500214 }
215
216 void
Vince Lehman9a709032014-09-13 16:28:07 -0500217 calculatePaths(Map& map, RoutingTable& rt, Lsdb& lsdb, AdjacencyList& adjacencies);
akmhoque53353462014-04-22 08:43:45 -0500218
219private:
akmhoque53353462014-04-22 08:43:45 -0500220 double
Vince Lehman9a709032014-09-13 16:28:07 -0500221 getHyperbolicDistance(Map& map, Lsdb& lsdb, ndn::Name src, ndn::Name dest);
akmhoque53353462014-04-22 08:43:45 -0500222
223 void
Vince Lehman9a709032014-09-13 16:28:07 -0500224 addNextHop(ndn::Name destinationRouter, std::string faceUri, double cost, RoutingTable& rt);
akmhoque53353462014-04-22 08:43:45 -0500225
Muktadir R Chowdhuryb00dc2a2016-11-05 10:48:58 -0600226 double
227 calculateHyperbolicDistance(double rI, double rJ, double deltaTheta);
228
229 double
230 calculateAngularDistance(std::vector<double> angleVectorI,
231 std::vector<double> angleVectorJ);
232
akmhoque53353462014-04-22 08:43:45 -0500233private:
Vince Lehman9a709032014-09-13 16:28:07 -0500234 const size_t m_nRouters;
235 const bool m_isDryRun;
236 const ndn::Name m_thisRouterName;
akmhoque53353462014-04-22 08:43:45 -0500237
Vince Lehman9a709032014-09-13 16:28:07 -0500238 static const double MATH_PI;
239 static const double UNKNOWN_DISTANCE;
240 static const double UNKNOWN_RADIUS;
241 static const int32_t ROUTER_NOT_FOUND;
akmhoque53353462014-04-22 08:43:45 -0500242};
243
Nick Gordonfad8e252016-08-11 14:21:38 -0500244} // namespace nlsr
akmhoque53353462014-04-22 08:43:45 -0500245
Muktadir R Chowdhuryb00dc2a2016-11-05 10:48:58 -0600246#endif // NLSR_ROUTING_TABLE_CALCULATOR_HPP