A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
lena-ipv6-ue-rh.cc
Go to the documentation of this file.
1/*
2 * Copyright (c) 2017 Jadavpur University, India
3 *
4 * SPDX-License-Identifier: GPL-2.0-only
5 *
6 * Author: Manoj Kumar Rana <manoj24.rana@gmail.com>
7 */
8
9#include "ns3/applications-module.h"
10#include "ns3/core-module.h"
11#include "ns3/epc-helper.h"
12#include "ns3/internet-module.h"
13#include "ns3/ipv4-global-routing-helper.h"
14#include "ns3/ipv6-static-routing.h"
15#include "ns3/lte-helper.h"
16#include "ns3/lte-module.h"
17#include "ns3/mobility-module.h"
18#include "ns3/network-module.h"
19#include "ns3/point-to-point-helper.h"
20
21using namespace ns3;
22
23/**
24 * Sample simulation script for LTE+EPC. It instantiates several eNodeB,
25 * attaches one UE per eNodeB starts a flow for each UE to and from a remote host.
26 */
27
28NS_LOG_COMPONENT_DEFINE("EpcFirstExampleForIpv6");
29
30int
31main(int argc, char* argv[])
32{
34 cmd.Parse(argc, argv);
35
38 lteHelper->SetEpcHelper(epcHelper);
39
40 Ptr<Node> pgw = epcHelper->GetPgwNode();
41
42 // Create a single RemoteHost
48
49 // Create the Internet
51 p2ph.SetDeviceAttribute("DataRate", DataRateValue(DataRate("100Gb/s")));
52 p2ph.SetDeviceAttribute("Mtu", UintegerValue(1500));
53 p2ph.SetChannelAttribute("Delay", TimeValue(Seconds(0.010)));
55
59 ueNodes.Create(2);
60
61 // Install Mobility Model
63 for (uint16_t i = 0; i < 2; i++)
64 {
65 positionAlloc->Add(Vector(60.0 * i, 0, 0));
66 }
68 mobility.SetMobilityModel("ns3::ConstantPositionMobilityModel");
69 mobility.SetPositionAllocator(positionAlloc);
70 mobility.Install(enbNodes);
71 mobility.Install(ueNodes);
72
73 // Install the IP stack on the UEs
74 internet.Install(ueNodes);
75
76 // Install LTE Devices to the nodes
79
81
82 // Assign IP address to UEs
83 ueIpIface = epcHelper->AssignUeIpv6Address(NetDeviceContainer(ueLteDevs));
84
86
87 for (uint32_t u = 0; u < ueNodes.GetN(); ++u)
88 {
90 // Set the default gateway for the UEs
92 ipv6RoutingHelper.GetStaticRouting(ueNode->GetObject<Ipv6>());
93 ueStaticRouting->SetDefaultRoute(epcHelper->GetUeDefaultGatewayAddress6(), 1);
94 }
95
96 // Attach one UE per eNodeB
97 for (uint16_t i = 0; i < 2; i++)
98 {
99 lteHelper->Attach(ueLteDevs.Get(i), enbLteDevs.Get(i));
100 // side effect: the default EPS bearer will be activated
101 }
102
104 ipv6h.SetBase(Ipv6Address("6001:db80::"), Ipv6Prefix(64));
106
108 internetIpIfaces.SetDefaultRouteInAllNodes(0);
109
111 ipv6RoutingHelper.GetStaticRouting(remoteHost->GetObject<Ipv6>());
113 ->AddNetworkRouteTo("7777:f00d::", Ipv6Prefix(64), internetIpIfaces.GetAddress(0, 1), 1, 0);
114
115 // interface 0 is localhost, 1 is the p2p device
117
118 // Start applications on UEs and remote host
120
122
123 serverApps.Start(Seconds(1));
124 serverApps.Stop(Seconds(20));
125
128
129 echoClient1.SetAttribute("MaxPackets", UintegerValue(1000));
130 echoClient1.SetAttribute("Interval", TimeValue(Seconds(1)));
131 echoClient1.SetAttribute("PacketSize", UintegerValue(1024));
132
133 echoClient2.SetAttribute("MaxPackets", UintegerValue(1000));
134 echoClient2.SetAttribute("Interval", TimeValue(Seconds(1)));
135 echoClient2.SetAttribute("PacketSize", UintegerValue(1024));
136
139
141 clientApps1.Stop(Seconds(14));
142
143 clientApps2.Start(Seconds(1.5));
144 clientApps2.Stop(Seconds(14.5));
145
146 LogComponentEnable("UdpEchoClientApplication", LOG_LEVEL_ALL);
147 LogComponentEnable("UdpEchoServerApplication", LOG_LEVEL_ALL);
148
149 // PcapHelperForIpv6::EnablePcapIpv6 (std::string prefix, uint32_t nodeid, uint32_t interface,
150 // bool explicitFilename)
151
152 internet.EnablePcapIpv6("LenaIpv6-Ue-Rh-Ue0.pcap", ueNodes.Get(0)->GetId(), 1, true);
153 internet.EnablePcapIpv6("LenaIpv6-Ue-Rh-Ue1.pcap", ueNodes.Get(1)->GetId(), 1, true);
154 internet.EnablePcapIpv6("LenaIpv6-Ue-Rh-RH.pcap", remoteHostContainer.Get(0)->GetId(), 1, true);
155 internet.EnablePcapIpv6("LenaIpv6-Ue-Rh-Pgw-Iface1.pcap", pgw->GetId(), 1, true);
156 internet.EnablePcapIpv6("LenaIpv6-Ue-Rh-Pgw-Iface2.pcap", pgw->GetId(), 2, true);
157
160
162 return 0;
163}
holds a vector of ns3::Application pointers.
void Start(Time start) const
Start all of the Applications in this container at the start time given as a parameter.
Parse command-line arguments.
Class for representing data rates.
Definition data-rate.h:78
AttributeValue implementation for DataRate.
Definition data-rate.h:285
aggregate IP/TCP/UDP functionality to existing Nodes.
Helper class to auto-assign global IPv6 unicast addresses.
void SetBase(Ipv6Address network, Ipv6Prefix prefix, Ipv6Address base=Ipv6Address("::1"))
Set the base network number, network prefix, and base interface ID.
Describes an IPv6 address.
Access to the IPv6 forwarding table, interfaces, and configuration.
Definition ipv6.h:71
Keep track of a set of IPv6 interfaces.
void SetForwarding(uint32_t i, bool state)
Set the state of the stack (act as a router or as an host) for the specified index.
Describes an IPv6 prefix.
Helper class that adds ns3::Ipv6StaticRouting objects.
Helper class used to assign positions and mobility models to nodes.
holds a vector of ns3::NetDevice pointers
keep track of a set of node pointers.
void Create(uint32_t n)
Create n nodes and append pointers to them to the end of this NodeContainer.
Build a set of PointToPointNetDevice objects.
void SetDeviceAttribute(std::string name, const AttributeValue &value)
Set an attribute value to be propagated to each NetDevice created by the helper.
Smart pointer class similar to boost::intrusive_ptr.
Definition ptr.h:66
static void Destroy()
Execute the events scheduled with ScheduleDestroy().
Definition simulator.cc:131
static void Run()
Run the simulation.
Definition simulator.cc:167
static void Stop()
Tell the Simulator the calling event should be the last one executed.
Definition simulator.cc:175
AttributeValue implementation for Time.
Definition nstime.h:1431
Create an application which sends a UDP packet and waits for an echo of this packet.
Create a server application which waits for input UDP packets and sends them back to the original sen...
Hold an unsigned integer type.
Definition uinteger.h:34
#define NS_LOG_COMPONENT_DEFINE(name)
Define a Log component with a specific name.
Definition log.h:191
Ptr< T > Create(Ts &&... args)
Create class instances by constructors with varying numbers of arguments and return them by Ptr.
Definition ptr.h:436
Time Seconds(double value)
Construct a Time in the indicated unit.
Definition nstime.h:1344
serverApps
Definition first.py:43
echoServer
Definition first.py:41
Every class exported by the ns3 library is enclosed in the ns3 namespace.
void LogComponentEnable(const std::string &name, LogLevel level)
Enable the logging output associated with that log component.
Definition log.cc:291
@ LOG_LEVEL_ALL
Print everything.
Definition log.h:105
mobility
Definition third.py:92