examples/wireless/wifi-blockack.cc
author Tom Henderson <tomh@tomh.org>
Fri, 20 Aug 2010 12:17:19 -0700
changeset 6589 9c325569fb01
parent 6309 8d46400b959e
permissions -rw-r--r--
Help waf to guess release versions of nsc and pybindgen
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
5966
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
     1
/* -*-  Mode: C++; c-file-style: "gnu"; indent-tabs-mode:nil; -*- */
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
     2
/*
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
     3
 * Copyright (c) 2009 MIRKO BANCHI
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
     4
 *
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
     6
 * it under the terms of the GNU General Public License version 2 as 
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
     7
 * published by the Free Software Foundation;
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
     8
 *
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    12
 * GNU General Public License for more details.
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    13
 *
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    14
 * You should have received a copy of the GNU General Public License
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    15
 * along with this program; if not, write to the Free Software
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    16
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    17
 *
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    18
 * Author: Mirko Banchi <mk.banchi@gmail.com>
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    19
 */
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    20
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    21
/**
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    22
 * This is a simple example in order to show how 802.11n compressed block ack mechanism could be used.
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    23
 *
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    24
 * Network topology:
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    25
 * 
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    26
 *  Wifi 192.168.1.0
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    27
 * 
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    28
 *        AP
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    29
 *   *    *
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    30
 *   |    |
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    31
 *   n1   n2 
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    32
 *
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    33
 * In this example a QoS sta sends UDP datagram packets to access point. On the access point
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    34
 * there is no application installed so it replies to every packet with an ICMP frame. However
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    35
 * our attention is on originator sta n1. We have set blockAckThreshold (mininum number of packets to use
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    36
 * block ack) to 2 so if there are in the BestEffort queue more than 2 packets a block ack will be
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    37
 * negotiated. We also set a timeout for block ack inactivity to 3 blocks of 1024 microseconds. This timer is
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    38
 * reset when:
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    39
 *    - the originator receives a block ack frame.
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    40
 *    - the recipient receives a block ack request or a MPDU with ack policy Block Ack. 
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    41
 */
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    42
#include "ns3/core-module.h"
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    43
#include "ns3/simulator-module.h"
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    44
#include "ns3/node-module.h"
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    45
#include "ns3/helper-module.h"
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    46
#include "ns3/global-routing-module.h"
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    47
#include "ns3/wifi-module.h"
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    48
#include "ns3/mobility-module.h"
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    49
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    50
using namespace ns3;
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    51
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    52
NS_LOG_COMPONENT_DEFINE ("Test-block-ack");
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    53
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    54
int main (int argc, char const* argv[])
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    55
{
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    56
  LogComponentEnable ("EdcaTxopN", LOG_LEVEL_DEBUG);
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    57
  LogComponentEnable ("BlockAckManager", LOG_LEVEL_INFO);
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    58
 
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    59
  Ptr<Node> sta = CreateObject<Node> ();
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    60
  Ptr<Node> ap = CreateObject<Node> ();
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    61
  
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    62
  YansWifiChannelHelper channel = YansWifiChannelHelper::Default ();
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    63
  YansWifiPhyHelper phy = YansWifiPhyHelper::Default ();
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    64
  phy.SetChannel (channel.Create ());
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    65
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    66
  WifiHelper wifi = WifiHelper::Default ();
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    67
  QosWifiMacHelper mac = QosWifiMacHelper::Default ();
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    68
  /* disable fragmentation */
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    69
  wifi.SetRemoteStationManager ("ns3::AarfWifiManager", "FragmentationThreshold", UintegerValue (2500));
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    70
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    71
  Ssid ssid ("My-network");
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    72
  
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    73
  mac.SetType ("ns3::QstaWifiMac", "Ssid" , SsidValue (ssid), "ActiveProbing", BooleanValue (false));
6294
6cefb3c0696a add methods in QosWifiMacHelper for block ack parameters setup
Mirko Banchi <mk.banchi@gmail.com>
parents: 5966
diff changeset
    74
  /* setting blockack threshold for sta's BE queue */
6cefb3c0696a add methods in QosWifiMacHelper for block ack parameters setup
Mirko Banchi <mk.banchi@gmail.com>
parents: 5966
diff changeset
    75
  mac.SetBlockAckThresholdForAc (AC_BE, 2);
6cefb3c0696a add methods in QosWifiMacHelper for block ack parameters setup
Mirko Banchi <mk.banchi@gmail.com>
parents: 5966
diff changeset
    76
  /* setting block inactivity timeout to 3*1024 = 3072 microseconds */ 
6cefb3c0696a add methods in QosWifiMacHelper for block ack parameters setup
Mirko Banchi <mk.banchi@gmail.com>
parents: 5966
diff changeset
    77
  //mac.SetBlockAckInactivityTimeoutForAc (AC_BE, 3);
5966
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    78
  NetDeviceContainer staDevice = wifi.Install (phy, mac, sta);
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    79
6309
8d46400b959e fixed bug 843
Nicola Baldo <nbaldo@cttc.es>
parents: 6294
diff changeset
    80
  mac.SetType ("ns3::QapWifiMac", "Ssid", SsidValue (ssid));
6294
6cefb3c0696a add methods in QosWifiMacHelper for block ack parameters setup
Mirko Banchi <mk.banchi@gmail.com>
parents: 5966
diff changeset
    81
  mac.SetBlockAckThresholdForAc (AC_BE, 0);
5966
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    82
  NetDeviceContainer apDevice = wifi.Install (phy, mac, ap);
6294
6cefb3c0696a add methods in QosWifiMacHelper for block ack parameters setup
Mirko Banchi <mk.banchi@gmail.com>
parents: 5966
diff changeset
    83
  
5966
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    84
  /* Setting mobility model */
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    85
  MobilityHelper mobility;
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    86
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    87
  mobility.SetPositionAllocator ("ns3::GridPositionAllocator",
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    88
    "MinX", DoubleValue (0.0),
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    89
    "MinY", DoubleValue (0.0),
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    90
    "DeltaX", DoubleValue (5.0),
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    91
    "DeltaY", DoubleValue (10.0),
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    92
    "GridWidth", UintegerValue (3),
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    93
    "LayoutType", StringValue ("RowFirst"));
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    94
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    95
  mobility.SetMobilityModel ("ns3::RandomWalk2dMobilityModel",
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    96
    "Bounds", RectangleValue (Rectangle (-50, 50, -50, 50)));
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    97
  mobility.Install (sta);
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    98
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
    99
  mobility.SetMobilityModel ("ns3::ConstantPositionMobilityModel");
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   100
  mobility.Install (ap);
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   101
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   102
  /* Internet stack*/
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   103
  InternetStackHelper stack;
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   104
  stack.Install (sta);
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   105
  stack.Install (ap);
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   106
  
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   107
  Ipv4AddressHelper address;
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   108
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   109
  address.SetBase ("192.168.1.0", "255.255.255.0");
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   110
  Ipv4InterfaceContainer staIf;
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   111
  Ipv4InterfaceContainer apIf;
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   112
  staIf = address.Assign (staDevice);
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   113
  apIf = address.Assign (apDevice);
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   114
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   115
  /* Setting applications */
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   116
  
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   117
  uint16_t port = 9;
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   118
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   119
  DataRate dataRate ("1Mb/s");
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   120
  OnOffHelper onOff ("ns3::UdpSocketFactory", Address (InetSocketAddress (apIf.GetAddress (0), port)));
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   121
  onOff.SetAttribute ("DataRate", DataRateValue (dataRate));
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   122
  onOff.SetAttribute ("OnTime", RandomVariableValue (ConstantVariable (0.01)));
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   123
  onOff.SetAttribute ("OffTime", RandomVariableValue (ConstantVariable (8)));
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   124
  onOff.SetAttribute ("PacketSize", UintegerValue (50));
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   125
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   126
  ApplicationContainer staApps = onOff.Install (sta);
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   127
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   128
  staApps.Start (Seconds (1.0));
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   129
  staApps.Stop (Seconds (10.0));
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   130
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   131
  Ipv4GlobalRoutingHelper::PopulateRoutingTables ();
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   132
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   133
  Simulator::Stop (Seconds (10.0));
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   134
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   135
  phy.EnablePcap ("test-blockack-2", ap->GetId (), 0);
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   136
  Simulator::Run ();
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   137
  Simulator::Destroy ();
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   138
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   139
  return 0;
bd34322d49c1 add a block ack example
Mirko Banchi <mk.banchi@gmail.com>
parents:
diff changeset
   140
}