A Discrete-Event Network Simulator
API
Loading...
Searching...
No Matches
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
19import sys
20
21try:
22 from ns import ns
23except 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
31def 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
120if __name__ == "__main__":
121 sys.exit(main(sys.argv))