Skip to main content

Pareto On/Off Traffic Generator

 The Pareto On/Off Traffic Generator (POO_Traffic) is a traffic generator (an application) embodied in the OTcl class Application/Traffic/Pareto. POO_Traffic generates traffic according to a Pareto On/Off distribution. Packets are sent at a fixed rate during on periods, and no packets are sent during off periods. Both on and off periods are taken from a Pareto distribution with constant size packets. These sources can be used to generate aggregate traffic that exhibits long range dependency. For other traffic generators, refer to the NS manual.


  • Usage Example
  • A new Pareto On/Off traffic generator can be created as follows:

            set p [new Application/Traffic/Pareto]
            $p set burst_time_ 500ms
            $p set idle_time_ 500ms
            $p set rate_ 200k
            $p set packetSize_ 210
            $p set shape_ 1.5
    


  • Detailed Explanation
    1. Input parameters:
    2.   burst_time_ : Mean On (burst) time
        idle_time_  : Mean Off (idle) time
        rate_       : Send rate during burst
        packetSize_ : Packet size (fixed application frame size)
        shape_      : Pareto shape parameter
        
    3. Initial computation:
    4.   interval = packetSize_ * 8 / rate_
        burstlen = burst_time_ / interval (in packets of given packetSize_)
        
    5. In each On/Off round, the following two (independent) Pareto random variables are computed:
        next_burstlen  : # of packets to be transmitted in the next burst period
                         (ex: next Web object size in packets of given packetSize_)
        next_idle_time : next idle period length in seconds
                         (ex: next think time)
        
    6. Pareto Traffic Generator algorithm:
       
      1. Compute next_burstlen given the mean burstlen and the Pareto shape_ parameter.
      2. Send all next_burstlen packets (each packet transmission interval is interval seconds).
      3. Compute the next_idle_time using the mean idle_time_ and the Pareto shape_ parameter.
      4. Go to sleep for next_idle_time and go back to step 1.
         
    7. Pareto Distribution:


    8. In general, if X is a random variable from a Pareto distribution
      (let f be the pdf, and E be the expected value)

        f(x) = a *ba / xa + 1 for x ≥ b

        E(X) = b *a / (a − 1) if a > 1

      where, a is called the Pareto "shape parameter" (shape_) and b is called the Pareto "scale parameter".

    9. How Pareto is used in the Pareto Traffic Generator:
      (The Pareto shape_ parameter is denoted as a in the following equations.)
      • burstlen    = E(X) = b1 *a / (a − 1)
        idle_time_ = E(Y) = b2 *a / (a − 1)

      Therefore:

        b1 = burstlen * (a − 1) / a
        b2 = idle_time_ * (a − 1) / a

      NS has a Pareto random number generator that takes the scale and shape parameter:

            double pareto(double scale, double shape)
        
      When the Pareto traffic generator needs to compute next_burstlen, it does:
            int next_burstlen = int(pareto(b1, a) + 0.5);
            /* next_burstlen should be at least 1 packet */
            if(next_burstlen == 0) next_burstlen = 1;
        
      When the Pareto traffic generator needs to compute next_idle_time, it does:
            double next_idle_time = pareto(b2, a);
        

  • Discussion
  • The Pareto traffic generator can be used as a Web traffic generator assuming that Web object sizes form a Pareto distribution. The NS default Pareto shape_ parameter (or a) is 1.5. However, it is uncertain if that 1.5 makes sense for Web object size distribution.

    To find a reasonable Pareto shape_ parameter for Web object sizes, one should sample Web object sizes during transmissions (or borrow the results other research), draw the pdf of the samples and compute the mean object size (i.e., E(X)). Since E(X) can be computed from the collected data, the theoretical f(x) should be:

      f(x) = g(xa)

    Then, one should be able to find a that makes the f(x) closest to the pdf of the measured Web object samples.

    Comments

    Popular posts from this blog

    NS2 INSTALLATION IN UBUNTU 21.04

      Hello, this post explains how to install ns2 in Ubuntu 21.04.  1) First you have to download ns2 all-in-one package from following link;    http://sourceforge.net/projects/nsnam/files/allinone/ns-allinone-2.35/ns-allinone-2.35.tar.gz/download 2) Extract the downloaded zip file 'ns-allinone-2.35.tar.gz file' to home folder. 3)  Now you need to download some essential packages for ns2,these packages can be downloaded by using the following commands :  applications>accessories>terminal or dashhome>terminal   and   then type the below lines one by one on the terminal window sudo apt-get update sudo apt-get dist-upgrade sudo apt-get update 4) Install the basic libraries; sudo apt install build-essential autoconf automake libxmu-dev 5) Install gcc and g++ and for that please do following; open the file using sudo mode sudo nano /etc/apt/sources.list Include the following line in list;  deb http://in.archive.ubuntu.com/ubuntu bionic main universe then open terminal and exec

    Link State Routing Protocol

    Link state routing is a method in which each router shares its neighborhood’s knowledge with every other router on the internetwork. In this algorithm, each router in the network understands the network topology and then makes a routing table depending on this topology. Each router will share data about its connection to its neighbor, who will, consecutively, reproduce the data to its neighbors, etc. This appears just before all routers have constructed a topology of the network. In LSP, each node transmits its IP address and the MAC to its neighbor with its signature. Neighbors determine the signature and maintain a record of the combining IP address and the MAC. The Neighbor Lookup Protocol (NLP) of LSP derives and maintains the MAC and IP address of every network frame accepted by a node. The extracted data can support the mapping of MACs and IP addresses. The link-state flooding algorithm prevents the general issues of broadcast in the existence of loops by having every node mainta

    HP NETWORK SIMULATOR: A COMWARE OS LEARNING TOOL

      Comware v7 is a network operating system that runs on HP high-end network devices. The HP Network Simulator is an ideal Comware v7 learning tool, which allows users to create, configure, and connect simulated networks. Benefits Beginners  – The HP Network Simulator tool is helpful for users who are new to networking and want to learn how to configure network devices (switches, routers), various topologies, or different routing and switching protocols and features. Experienced users  – The HP Network Simulator learning tool is helpful for users who have experience with non-HP networking devices and want to learn the Comware CLI and features. Extra devices  – Users can create devices using the HP Network Simulator and use them with their physical devices to configure and test topologies that aren’t configurable with just the physical devices they have. For example – A user wants to configure OSPF using 3 or more devices but has only 1 physical router. User can create 2 or more routers