A Discrete-Event Network Simulator
API
tap-wifi-virtual-machine.py
Go to the documentation of this file.
1 # -*- Mode: Python; -*-
2 #
3 # Copyright 2010 University of Washington
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 
19 import sys
20 
21 try:
22  from ns import ns
23 except ModuleNotFoundError:
24  raise SystemExit(
25  "Error: ns3 Python module not found;"
26  " Python bindings may not be enabled"
27  " or your PYTHONPATH might not be properly configured"
28  )
29 
30 
31 def main(argv):
32  ns.core.CommandLine().Parse(argv)
33 
34  #
35  # We are interacting with the outside, real, world. This means we have to
36  # interact in real-time and therefore we have to use the real-time simulator
37  # and take the time to calculate checksums.
38  #
39  ns.core.GlobalValue.Bind(
40  "SimulatorImplementationType", ns.core.StringValue("ns3::RealtimeSimulatorImpl")
41  )
42  ns.core.GlobalValue.Bind("ChecksumEnabled", ns.core.BooleanValue(True))
43 
44  #
45  # Create two ghost nodes. The first will represent the virtual machine host
46  # on the left side of the network; and the second will represent the VM on
47  # the right side.
48  #
49  nodes = ns.network.NodeContainer()
50  nodes.Create(2)
51 
52  #
53  # We're going to use 802.11 A so set up a wifi helper to reflect that.
54  #
55  wifi = ns.wifi.WifiHelper()
56  wifi.SetStandard(ns.wifi.WIFI_STANDARD_80211a)
57  wifi.SetRemoteStationManager(
58  "ns3::ConstantRateWifiManager", "DataMode", ns.core.StringValue("OfdmRate54Mbps")
59  )
60 
61  #
62  # No reason for pesky access points, so we'll use an ad-hoc network.
63  #
64  wifiMac = ns.wifi.WifiMacHelper()
65  wifiMac.SetType("ns3::AdhocWifiMac")
66 
67  #
68  # Configure the physical layer.
69  #
70  wifiChannel = ns.wifi.YansWifiChannelHelper.Default()
71  wifiPhy = ns.wifi.YansWifiPhyHelper()
72  wifiPhy.SetChannel(wifiChannel.Create())
73 
74  #
75  # Install the wireless devices onto our ghost nodes.
76  #
77  devices = wifi.Install(wifiPhy, wifiMac, nodes)
78 
79  #
80  # We need location information since we are talking about wifi, so add a
81  # constant position to the ghost nodes.
82  #
83  mobility = ns.mobility.MobilityHelper()
84  positionAlloc = ns.mobility.ListPositionAllocator()
85  positionAlloc.Add(ns.core.Vector(0.0, 0.0, 0.0))
86  positionAlloc.Add(ns.core.Vector(5.0, 0.0, 0.0))
87  mobility.SetPositionAllocator(positionAlloc)
88  mobility.SetMobilityModel("ns3::ConstantPositionMobilityModel")
89  mobility.Install(nodes)
90 
91  #
92  # Use the TapBridgeHelper to connect to the pre-configured tap devices for
93  # the left side. We go with "UseLocal" mode since the wifi devices do not
94  # support promiscuous mode (because of their natures0. This is a special
95  # case mode that allows us to extend a linux bridge into ns-3 IFF we will
96  # only see traffic from one other device on that bridge. That is the case
97  # for this configuration.
98  #
99  tapBridge = ns.tap_bridge.TapBridgeHelper()
100  tapBridge.SetAttribute("Mode", ns.core.StringValue("UseLocal"))
101  tapBridge.SetAttribute("DeviceName", ns.core.StringValue("tap-left"))
102  tapBridge.Install(nodes.Get(0), devices.Get(0))
103 
104  #
105  # Connect the right side tap to the right side wifi device on the right-side
106  # ghost node.
107  #
108  tapBridge.SetAttribute("DeviceName", ns.core.StringValue("tap-right"))
109  tapBridge.Install(nodes.Get(1), devices.Get(1))
110 
111  #
112  # Run the simulation for ten minutes to give the user time to play around
113  #
114  ns.core.Simulator.Stop(ns.core.Seconds(600))
115  ns.core.Simulator.Run() # signal_check_frequency = -1
116  ns.core.Simulator.Destroy()
117  return 0
118 
119 
120 if __name__ == "__main__":
121  sys.exit(main(sys.argv))