Example #1
0
def SetPosition(node, position):
    mobility = node.GetObject(ns.mobility.MobilityModel.GetTypeId())
    mobility.SetPosition(position)
def main(argv):

    cmd = ns.core.CommandLine()

    cmd.NumNodesSide = None
    cmd.AddValue(
        "NumNodesSide",
        "Grid side number of nodes (total number of nodes will be this number squared)"
    )

    cmd.Results = None
    cmd.AddValue("Results", "Write XML results to file")

    cmd.Plot = None
    cmd.AddValue("Plot", "Plot the results using the matplotlib python module")

    cmd.Parse(argv)

    wifi = ns.wifi.WifiHelper.Default()
    wifiMac = ns.wifi.NqosWifiMacHelper.Default()
    wifiPhy = ns.wifi.YansWifiPhyHelper.Default()
    wifiChannel = ns.wifi.YansWifiChannelHelper.Default()
    wifiPhy.SetChannel(wifiChannel.Create())
    ssid = ns.wifi.Ssid("wifi-default")
    wifi.SetRemoteStationManager("ns3::ArfWifiManager")
    wifiMac.SetType("ns3::AdhocWifiMac", "Ssid", ns.wifi.SsidValue(ssid))

    internet = ns.internet.InternetStackHelper()
    list_routing = ns.internet.Ipv4ListRoutingHelper()
    olsr_routing = ns.olsr.OlsrHelper()
    static_routing = ns.internet.Ipv4StaticRoutingHelper()
    list_routing.Add(static_routing, 0)
    list_routing.Add(olsr_routing, 100)
    internet.SetRoutingHelper(list_routing)

    ipv4Addresses = ns.internet.Ipv4AddressHelper()
    ipv4Addresses.SetBase(ns.network.Ipv4Address("10.0.0.0"),
                          ns.network.Ipv4Mask("255.255.255.0"))

    port = 9  # Discard port(RFC 863)
    onOffHelper = ns.applications.OnOffHelper(
        "ns3::UdpSocketFactory",
        ns.network.Address(
            ns.network.InetSocketAddress(ns.network.Ipv4Address("10.0.0.1"),
                                         port)))
    onOffHelper.SetAttribute(
        "DataRate", ns.network.DataRateValue(ns.network.DataRate("100kbps")))
    onOffHelper.SetAttribute(
        "OnTime",
        ns.core.StringValue("ns3::ConstantRandomVariable[Constant=1]"))
    onOffHelper.SetAttribute(
        "OffTime",
        ns.core.StringValue("ns3::ConstantRandomVariable[Constant=0]"))

    addresses = []
    nodes = []

    if cmd.NumNodesSide is None:
        num_nodes_side = NUM_NODES_SIDE
    else:
        num_nodes_side = int(cmd.NumNodesSide)

    for xi in range(num_nodes_side):
        for yi in range(num_nodes_side):

            node = ns.network.Node()
            nodes.append(node)

            internet.Install(ns.network.NodeContainer(node))

            mobility = ns.mobility.ConstantPositionMobilityModel()
            mobility.SetPosition(
                ns.core.Vector(xi * DISTANCE, yi * DISTANCE, 0))
            node.AggregateObject(mobility)

            devices = wifi.Install(wifiPhy, wifiMac, node)
            ipv4_interfaces = ipv4Addresses.Assign(devices)
            addresses.append(ipv4_interfaces.GetAddress(0))

    for i, node in enumerate(nodes):
        destaddr = addresses[(len(addresses) - 1 - i) % len(addresses)]
        #print i, destaddr
        onOffHelper.SetAttribute(
            "Remote",
            ns.network.AddressValue(
                ns.network.InetSocketAddress(destaddr, port)))
        app = onOffHelper.Install(ns.network.NodeContainer(node))
        urv = ns.core.UniformRandomVariable()
        app.Start(ns.core.Seconds(urv.GetValue(20, 30)))

    #internet.EnablePcapAll("wifi-olsr")
    flowmon_helper = ns.flow_monitor.FlowMonitorHelper()
    #flowmon_helper.SetMonitorAttribute("StartTime", ns.core.TimeValue(ns.core.Seconds(31)))
    monitor = flowmon_helper.InstallAll()
    monitor = flowmon_helper.GetMonitor()
    monitor.SetAttribute("DelayBinWidth", ns.core.DoubleValue(0.001))
    monitor.SetAttribute("JitterBinWidth", ns.core.DoubleValue(0.001))
    monitor.SetAttribute("PacketSizeBinWidth", ns.core.DoubleValue(20))

    ns.core.Simulator.Stop(ns.core.Seconds(44.0))
    ns.core.Simulator.Run()

    def print_stats(os, st):
        print >> os, "  Tx Bytes: ", st.txBytes
        print >> os, "  Rx Bytes: ", st.rxBytes
        print >> os, "  Tx Packets: ", st.txPackets
        print >> os, "  Rx Packets: ", st.rxPackets
        print >> os, "  Lost Packets: ", st.lostPackets
        if st.rxPackets > 0:
            print >> os, "  Mean{Delay}: ", (st.delaySum.GetSeconds() /
                                             st.rxPackets)
            print >> os, "  Mean{Jitter}: ", (st.jitterSum.GetSeconds() /
                                              (st.rxPackets - 1))
            print >> os, "  Mean{Hop Count}: ", float(
                st.timesForwarded) / st.rxPackets + 1

        if 0:
            print >> os, "Delay Histogram"
            for i in range(st.delayHistogram.GetNBins()):
                print >> os, " ",i,"(", st.delayHistogram.GetBinStart (i), "-", \
                    st.delayHistogram.GetBinEnd (i), "): ", st.delayHistogram.GetBinCount (i)
            print >> os, "Jitter Histogram"
            for i in range(st.jitterHistogram.GetNBins()):
                print >> os, " ",i,"(", st.jitterHistogram.GetBinStart (i), "-", \
                    st.jitterHistogram.GetBinEnd (i), "): ", st.jitterHistogram.GetBinCount (i)
            print >> os, "PacketSize Histogram"
            for i in range(st.packetSizeHistogram.GetNBins()):
                print >> os, " ",i,"(", st.packetSizeHistogram.GetBinStart (i), "-", \
                    st.packetSizeHistogram.GetBinEnd (i), "): ", st.packetSizeHistogram.GetBinCount (i)

        for reason, drops in enumerate(st.packetsDropped):
            print "  Packets dropped by reason %i: %i" % (reason, drops)
        #for reason, drops in enumerate(st.bytesDropped):
        #    print "Bytes dropped by reason %i: %i" % (reason, drops)

    monitor.CheckForLostPackets()
    classifier = flowmon_helper.GetClassifier()

    if cmd.Results is None:
        for flow_id, flow_stats in monitor.GetFlowStats():
            t = classifier.FindFlow(flow_id)
            proto = {6: 'TCP', 17: 'UDP'}[t.protocol]
            print "FlowID: %i (%s %s/%s --> %s/%i)" % \
                (flow_id, proto, t.sourceAddress, t.sourcePort, t.destinationAddress, t.destinationPort)
            print_stats(sys.stdout, flow_stats)
    else:
        print monitor.SerializeToXmlFile(cmd.Results, True, True)

    if cmd.Plot is not None:
        import pylab
        delays = []
        for flow_id, flow_stats in monitor.GetFlowStats():
            tupl = classifier.FindFlow(flow_id)
            if tupl.protocol == 17 and tupl.sourcePort == 698:
                continue
            delays.append(flow_stats.delaySum.GetSeconds() /
                          flow_stats.rxPackets)
        pylab.hist(delays, 20)
        pylab.xlabel("Delay (s)")
        pylab.ylabel("Number of Flows")
        pylab.show()

    return 0
Example #3
0
def main(argv):

    cmd = ns.core.CommandLine()

    cmd.NumNodesSide = None
    cmd.AddValue(
        "NumNodesSide",
        "Grid side number of nodes (total number of nodes will be this number squared)"
    )

    cmd.Results = None
    cmd.AddValue("Results", "Write XML results to file")

    cmd.Plot = None
    cmd.AddValue("Plot", "Plot the results using the matplotlib python module")

    cmd.Parse(argv)

    wifi = ns.wifi.WifiHelper.Default()
    wifiMac = ns.wifi.NqosWifiMacHelper.Default()
    wifiPhy = ns.wifi.YansWifiPhyHelper.Default()
    wifiChannel = ns.wifi.YansWifiChannelHelper.Default()
    wifiPhy.SetChannel(wifiChannel.Create())
    ssid = ns.wifi.Ssid("wifi-default")
    wifi.SetRemoteStationManager("ns3::ArfWifiManager")
    wifiMac.SetType("ns3::AdhocWifiMac", "Ssid", ns.wifi.SsidValue(ssid))

    internet = ns.internet.InternetStackHelper()
    list_routing = ns.internet.Ipv4ListRoutingHelper()
    olsr_routing = ns.olsr.OlsrHelper()
    static_routing = ns.internet.Ipv4StaticRoutingHelper()
    list_routing.Add(static_routing, 0)
    list_routing.Add(olsr_routing, 100)
    internet.SetRoutingHelper(list_routing)

    ipv4Addresses = ns.internet.Ipv4AddressHelper()
    ipv4Addresses.SetBase(ns.network.Ipv4Address("10.0.0.0"),
                          ns.network.Ipv4Mask("255.255.255.0"))

    port = 9
    onOffHelper = ns.applications.OnOffHelper(
        "ns3::UdpSocketFactory",
        ns.network.Address(
            ns.network.InetSocketAddress(ns.network.Ipv4Address("10.0.0.1"),
                                         port)))
    onOffHelper.SetAttribute(
        "DataRate", ns.network.DataRateValue(ns.network.DataRate("100kbps")))
    onOffHelper.SetAttribute(
        "OnTime",
        ns.core.StringValue("ns3::ConstantRandomVariable[Constant=1]"))
    onOffHelper.SetAttribute(
        "OffTime",
        ns.core.StringValue("ns3::ConstantRandomVariable[Constant=0]"))

    addresses = []
    nodes = []

    num_nodes_side = NUM_NODES_SIDE
    for xi in range(num_nodes_side):
        for yi in range(num_nodes_side):

            node = ns.network.Node()
            nodes.append(node)

            internet.Install(ns.network.NodeContainer(node))

            mobility = ns.mobility.ConstantPositionMobilityModel()
            mobility.SetPosition(
                ns.core.Vector(xi * DISTANCE, yi * DISTANCE, 0))
            node.AggregateObject(mobility)

            devices = wifi.Install(wifiPhy, wifiMac, node)
            ipv4_interfaces = ipv4Addresses.Assign(devices)
            addresses.append(ipv4_interfaces.GetAddress(0))
    for e in range(500):

        for i, node in enumerate(nodes):
            destaddr = addresses[(len(addresses) - 1 - i) % len(addresses)]
            onOffHelper.SetAttribute(
                "Remote",
                ns.network.AddressValue(
                    ns.network.InetSocketAddress(destaddr, port)))
            app = onOffHelper.Install(ns.network.NodeContainer(node))
            urv = ns.core.UniformRandomVariable()
            app.Start(ns.core.Seconds(urv.GetValue(20, 30)))

        flowmon_helper = ns.flow_monitor.FlowMonitorHelper()
        monitor = flowmon_helper.InstallAll()
        monitor = flowmon_helper.GetMonitor()
        monitor.SetAttribute("DelayBinWidth", ns.core.DoubleValue(0.001))
        monitor.SetAttribute("JitterBinWidth", ns.core.DoubleValue(0.001))
        monitor.SetAttribute("PacketSizeBinWidth", ns.core.DoubleValue(20))

        ns.core.Simulator.Stop(ns.core.Seconds(44.0))
        ns.core.Simulator.Run()

        monitor.CheckForLostPackets()
        classifier = flowmon_helper.GetClassifier()
        monitor.SerializeToXmlFile("wififlow.xml", True, True)
        flow_stats_inputs = monitor.GetFlowStats()
        flow_array = [
        ]  # this is original array which store the original inputs to the model
        # this are the inputs to the model which will stored in flow_array
        flow_array.append(flow_stat_inputs.txBytes)
        flow_array.append(flow_stat_inputs.rxBytes)
        flow_array.append(flow_stat_inputs.txPackets)
        flow_array.append(flow_stat_inputs.rxPackets)
        flow_array.append(flow_stat_inputs.lostPackets)
        if st.rxPackets > 0:
            mean_delay = (flow_stat_inputs.delaySum.GetSeconds() /
                          flow_stat_inputs.rxPackets)
            flow_array.append(mean_delay)
        mean_jitter = (flow_stat_inputs.jitterSum.GetSeconds() /
                       (flow_stat_inputs.rxPackets - 1))
        flow_array.append(mean_jitter)
        np.array(
            flow_array
        )  # then convert the flow array to numpy array reason to convert is numpy array will be a matrix and our model will only accept matrix inputs
        # data preprocessing part here we normalized the dataset into range between 1 and 0 and then convert to time sequence dataset since our model is recurrent network it only accept time sequence data
        df = DataFrame(data=d, index=index)
        min_max_scaler = preprocessing.MinMaxScaler()
        np_scaled = min_max_scaler.fit_transform(df)
        df_normalized = pd.DataFrame(np_scaled)
        X_train = sequence.pad_sequences(df_normalized, 10)
        actor = DQNAgent(X_train.shape[1], num_nodes_side)
        for t in range(500):
            action = actor.act(X_train)
            for i, node in enumerate(nodes):
                destaddr = addresses[action]
                onOffHelper.SetAttribute(
                    "Remote",
                    ns.network.AddressValue(
                        ns.network.InetSocketAddress(destaddr, port)))
                app = onOffHelper.Install(ns.network.NodeContainer(node))
                urv = ns.core.UniformRandomVariable()
                app.Start(ns.core.Seconds(urv.GetValue(20, 30)))

            flowmon_helper = ns.flow_monitor.FlowMonitorHelper()
            monitor = flowmon_helper.InstallAll()
            monitor = flowmon_helper.GetMonitor()
            monitor.SetAttribute("DelayBinWidth", ns.core.DoubleValue(0.001))
            monitor.SetAttribute("JitterBinWidth", ns.core.DoubleValue(0.001))
            monitor.SetAttribute("PacketSizeBinWidth", ns.core.DoubleValue(20))

            ns.core.Simulator.Stop(ns.core.Seconds(44.0))
            ns.core.Simulator.Run()

            monitor.CheckForLostPackets()
            classifier = flowmon_helper.GetClassifier()
            monitor.SerializeToXmlFile("wififlow.xml", True, True)
            # similar process describe in ahead happens here inside the loop
            flow_stats_inputs_next = monitor.GetFlowStats()
            flow_array_next = []
            flow_array_next.append(flow_stat_inputs_next.txBytes)
            flow_array_next.append(flow_stat_inputs_next.rxBytes)
            flow_array_next.append(flow_stat_inputs_next.txPackets)
            flow_array_next.append(flow_stat_inputs_next.rxPackets)
            flow_array_next.append(flow_stat_inputs_next.lostPackets)
            if st.rxPackets > 0:
                mean_delay = (flow_stat_inputs_next.delaySum.GetSeconds() /
                              flow_stat_inputs.rxPackets)
                flow_array.append(mean_delay)
            mean_jitter = (flow_stat_inputs_next.jitterSum.GetSeconds() /
                           (flow_stat_inputs.rxPackets - 1))
            flow_array_next.append(mean_jitter)
            np.array(flow_array_next)
            df_next = DataFrame(data=d, index=index)
            min_max_scaler_next = preprocessing.MinMaxScaler()
            np_scaled_next = min_max_scaler_next.fit_transform(df_next)
            df_normalized_next = pd.DataFrame(np_scaled_next)
            X_next = sequence.pad_sequences(df_normalized_next, 10)
            # here we calculate the reward this has to be improve here i calculate the reward based only on loss packets which is not good way another few factors to be added it has to be discussed
            if (flow_stat_inputs_next.lostPackets > 10):
                reward = -10
            else:
                reward = 20
            actor.remember(
                X_train, action, X_next
            )  # finally saved the current step in model memory for experience replay module
            print("episode: {}/{}, score: {}".format(e, 500, t))
        actor.replay(
            32
        )  # after 500 times of training then apply the experiece replay task to use what it learn so far

    import pylab
    delays = []
    for flow_id, flow_stats in monitor.GetFlowStats():
        tupl = classifier.FindFlow(flow_id)
        if tupl.protocol == 17 and tupl.sourcePort == 698:
            continue
        delays.append(flow_stats.delaySum.GetSeconds() / flow_stats.rxPackets)
    pylab.hist(delays, 20)
    pylab.xlabel("Delay (s)")
    pylab.ylabel("Number of Flows")
    pylab.show()
    return 0