A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
point-to-point-dumbbell.h
Go to the documentation of this file.
1/*
2 * This program is free software; you can redistribute it and/or modify
3 * it under the terms of the GNU General Public License version 2 as
4 * published by the Free Software Foundation;
5 *
6 * This program is distributed in the hope that it will be useful,
7 * but WITHOUT ANY WARRANTY; without even the implied warranty of
8 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
9 * GNU General Public License for more details.
10 *
11 * You should have received a copy of the GNU General Public License
12 * along with this program; if not, write to the Free Software
13 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
14 *
15 * Author: George F. Riley<riley@ece.gatech.edu>
16 */
17
18// Define an object to create a dumbbell topology.
19
20#ifndef POINT_TO_POINT_DUMBBELL_HELPER_H
21#define POINT_TO_POINT_DUMBBELL_HELPER_H
22
23#include "ns3/internet-stack-helper.h"
24#include "ns3/ipv4-address-helper.h"
25#include "ns3/ipv4-interface-container.h"
26#include "ns3/ipv6-address-helper.h"
27#include "ns3/ipv6-interface-container.h"
28#include "ns3/point-to-point-helper.h"
29
30#include <string>
31
32namespace ns3
33{
34
35/**
36 * \ingroup point-to-point-layout
37 *
38 * \brief A helper to make it easier to create a dumbbell topology
39 * with p2p links
40 */
42{
43 public:
44 /**
45 * Create a PointToPointDumbbellHelper in order to easily create
46 * dumbbell topologies using p2p links
47 *
48 * \param nLeftLeaf number of left side leaf nodes in the dumbbell
49 *
50 * \param leftHelper PointToPointHelper used to install the links
51 * between the left leaf nodes and the left-most
52 * router
53 *
54 * \param nRightLeaf number of right side leaf nodes in the dumbbell
55 *
56 * \param rightHelper PointToPointHelper used to install the links
57 * between the right leaf nodes and the right-most
58 * router
59 *
60 * \param bottleneckHelper PointToPointHelper used to install the link
61 * between the inner-routers, usually known as
62 * the bottleneck link
63 */
65 PointToPointHelper leftHelper,
66 uint32_t nRightLeaf,
67 PointToPointHelper rightHelper,
68 PointToPointHelper bottleneckHelper);
69
71
72 public:
73 /**
74 * \returns pointer to the node of the left side bottleneck
75 * router
76 */
77 Ptr<Node> GetLeft() const;
78
79 /**
80 * \returns pointer to the i'th left side leaf node
81 * \param i node number
82 */
83 Ptr<Node> GetLeft(uint32_t i) const;
84
85 /**
86 * \returns pointer to the node of the right side bottleneck
87 * router
88 */
89 Ptr<Node> GetRight() const;
90
91 /**
92 * \returns pointer to the i'th right side leaf node
93 * \param i node number
94 */
96
97 /**
98 * \returns an Ipv4Address of the i'th left leaf
99 * \param i node number
100 */
101 Ipv4Address GetLeftIpv4Address(uint32_t i) const; // Get left leaf address
102
103 /**
104 * \returns an Ipv4Address of the i'th right leaf
105 * \param i node number
106 */
107 Ipv4Address GetRightIpv4Address(uint32_t i) const; // Get right leaf address
108
109 /**
110 * \returns an Ipv6Address of the i'th left leaf
111 * \param i node number
112 */
113 Ipv6Address GetLeftIpv6Address(uint32_t i) const; // Get left leaf address
114
115 /**
116 * \returns an Ipv6Address of the i'th right leaf
117 * \param i node number
118 */
119 Ipv6Address GetRightIpv6Address(uint32_t i) const; // Get right leaf address
120
121 /**
122 * \returns total number of left side leaf nodes
123 */
124 uint32_t LeftCount() const;
125
126 /**
127 * \returns total number of right side leaf nodes
128 */
129 uint32_t RightCount() const;
130
131 /**
132 * \param stack an InternetStackHelper which is used to install
133 * on every node in the dumbbell
134 */
136
137 /**
138 * \param leftIp Ipv4AddressHelper to assign Ipv4 addresses to the
139 * interfaces on the left side of the dumbbell
140 *
141 * \param rightIp Ipv4AddressHelper to assign Ipv4 addresses to the
142 * interfaces on the right side of the dumbbell
143 *
144 * \param routerIp Ipv4AddressHelper to assign Ipv4 addresses to the
145 * interfaces on the bottleneck link
146 */
148 Ipv4AddressHelper rightIp,
149 Ipv4AddressHelper routerIp);
150
151 /**
152 * \param network an IPv6 address representing the network portion
153 * of the IPv6 Address
154 * \param prefix the prefix length
155 */
156 void AssignIpv6Addresses(Ipv6Address network, Ipv6Prefix prefix);
157
158 /**
159 * Sets up the node canvas locations for every node in the dumbbell.
160 * This is needed for use with the animation interface
161 *
162 * \param ulx upper left x value
163 * \param uly upper left y value
164 * \param lrx lower right x value
165 * \param lry lower right y value
166 */
167 void BoundingBox(double ulx, double uly, double lrx, double lry) const;
168
169 private:
170 NodeContainer m_leftLeaf; //!< Left Leaf nodes
171 NetDeviceContainer m_leftLeafDevices; //!< Left Leaf NetDevices
172 NodeContainer m_rightLeaf; //!< Right Leaf nodes
173 NetDeviceContainer m_rightLeafDevices; //!< Right Leaf NetDevices
175 NetDeviceContainer m_routerDevices; //!< Routers NetDevices
176 NetDeviceContainer m_leftRouterDevices; //!< Left router NetDevices
177 NetDeviceContainer m_rightRouterDevices; //!< Right router NetDevices
178 Ipv4InterfaceContainer m_leftLeafInterfaces; //!< Left Leaf interfaces (IPv4)
179 Ipv4InterfaceContainer m_leftRouterInterfaces; //!< Left router interfaces (IPv4)
180 Ipv4InterfaceContainer m_rightLeafInterfaces; //!< Right Leaf interfaces (IPv4)
181 Ipv4InterfaceContainer m_rightRouterInterfaces; //!< Right router interfaces (IPv4)
182 Ipv4InterfaceContainer m_routerInterfaces; //!< Router interfaces (IPv4)
183 Ipv6InterfaceContainer m_leftLeafInterfaces6; //!< Left Leaf interfaces (IPv6)
184 Ipv6InterfaceContainer m_leftRouterInterfaces6; //!< Left router interfaces (IPv6)
185 Ipv6InterfaceContainer m_rightLeafInterfaces6; //!< Right Leaf interfaces (IPv6)
186 Ipv6InterfaceContainer m_rightRouterInterfaces6; //!< Right router interfaces (IPv6)
187 Ipv6InterfaceContainer m_routerInterfaces6; //!< Router interfaces (IPv6)
188};
189
190} // namespace ns3
191
192#endif /* POINT_TO_POINT_DUMBBELL_HELPER_H */
aggregate IP/TCP/UDP functionality to existing Nodes.
A helper class to make life easier while doing simple IPv4 address assignment in scripts.
Ipv4 addresses are stored in host order in this class.
Definition: ipv4-address.h:42
holds a vector of std::pair of Ptr<Ipv4> and interface index.
Describes an IPv6 address.
Definition: ipv6-address.h:49
Keep track of a set of IPv6 interfaces.
Describes an IPv6 prefix.
Definition: ipv6-address.h:455
holds a vector of ns3::NetDevice pointers
keep track of a set of node pointers.
A helper to make it easier to create a dumbbell topology with p2p links.
Ipv6InterfaceContainer m_leftLeafInterfaces6
Left Leaf interfaces (IPv6)
Ipv6InterfaceContainer m_rightLeafInterfaces6
Right Leaf interfaces (IPv6)
Ipv4InterfaceContainer m_rightRouterInterfaces
Right router interfaces (IPv4)
NetDeviceContainer m_leftRouterDevices
Left router NetDevices.
Ipv6InterfaceContainer m_rightRouterInterfaces6
Right router interfaces (IPv6)
Ipv4InterfaceContainer m_routerInterfaces
Router interfaces (IPv4)
void AssignIpv4Addresses(Ipv4AddressHelper leftIp, Ipv4AddressHelper rightIp, Ipv4AddressHelper routerIp)
NetDeviceContainer m_routerDevices
Routers NetDevices.
NetDeviceContainer m_rightRouterDevices
Right router NetDevices.
NodeContainer m_rightLeaf
Right Leaf nodes.
Ipv4InterfaceContainer m_leftRouterInterfaces
Left router interfaces (IPv4)
Ipv4Address GetRightIpv4Address(uint32_t i) const
Ipv6Address GetLeftIpv6Address(uint32_t i) const
Ipv4Address GetLeftIpv4Address(uint32_t i) const
void InstallStack(InternetStackHelper stack)
Ipv6InterfaceContainer m_leftRouterInterfaces6
Left router interfaces (IPv6)
NetDeviceContainer m_leftLeafDevices
Left Leaf NetDevices.
Ipv6Address GetRightIpv6Address(uint32_t i) const
Ipv6InterfaceContainer m_routerInterfaces6
Router interfaces (IPv6)
Ipv4InterfaceContainer m_rightLeafInterfaces
Right Leaf interfaces (IPv4)
void AssignIpv6Addresses(Ipv6Address network, Ipv6Prefix prefix)
NodeContainer m_leftLeaf
Left Leaf nodes.
NetDeviceContainer m_rightLeafDevices
Right Leaf NetDevices.
void BoundingBox(double ulx, double uly, double lrx, double lry) const
Sets up the node canvas locations for every node in the dumbbell.
Ipv4InterfaceContainer m_leftLeafInterfaces
Left Leaf interfaces (IPv4)
Build a set of PointToPointNetDevice objects.
Smart pointer class similar to boost::intrusive_ptr.
Definition: ptr.h:77
Every class exported by the ns3 library is enclosed in the ns3 namespace.