Skip to content

Latest commit

 

History

History
106 lines (73 loc) · 6.11 KB

README.md

File metadata and controls

106 lines (73 loc) · 6.11 KB

On the Benefits of Traffic “Reprofiling” the Multiple Hops Case—Part I

overview

Overview

This repository provides a Python implementation for:

Jiaming Qiu, Jiayi Song, Roch Guérin, and Henry Sariowan, "On the Benefits of Traffic “Reprofiling” the Multiple Hops Case—Part I" [paper]

This work is an extension of "On the Benefits of Traffic “Reprofiling” the Single Hop Case" [paper]

Requirements

We recommend a recent Python 3.7+ distribution of Anaconda. To run the algorithm based on solving non-linear programs (NLPs) you also need to install the community edition of Octeract v3.6.0. We do not have particular operating system requirements, so you should be able to run the scripts either with Linux, Windows, or macOS.

To keep a local copy of our code, clone this repository and navigate into the cloned directory. You should then be ready to run the scripts once you installed all the pre-requisite packages.

# First navigate to the directory where you want to keep a copy of the code.
git clone https://github.com/qiujiaming315/traffic-reprofiling.git
# Navigate into the cloned directory to get started.
cd traffic-reprofiling

Usage

Generating Network and Flow Profile

Our algorithm takes network topology, flow profile, and optional link weights as inputs. Before running the algorithm, you need to first generate some input data.

We provide scripts that facilitate generating network profile, flow profile, and link weights available through create_network.py, create_flow.py, and create_weight.py respectively in the input/ sub-directory. Each script allows you to either specify your own profile or generate profile using the build-in functions. You can try these different options by modifying the __main__ function (with example code snippets for each option) of each script.

Once you modified the __main__ function according to the desired configurations, you can directly run those scripts through command lines.

# Navigate into the input/ sub-directory.
cd input
# Generate network profile, flow profile, and (optional) link weights.
python create_network.py
python create_flow.py
python create_weight.py

Network Profile

We use network profile to specify network topology as well as the route of each flow in the network. The network profile is represented as an m × n matrix, with m and n being the number of traffic flows and network nodes respectively.

The matrix may either be of type bool for feed-forward network or int for cyclic network. The following figure demonstrates an example of retrieving network profile matrices given the graph representations of the networks.

network_profile

Flow Profile

We use flow profile to specify the token bucket parameters (rate, burst size) as well as the end-to-end latency target of each flow in the network. The flow profile is represented as an m × 3 matrix, where m is the number of flows. The three columns stand for rate, burst size, and latency target respectively.

Link Weight

The link weights are presented as an array of l non-negative float, one for each link, with l being the number of links inside the network.

Bandwidth Minimization

The main script for running the minimization algorithm is optimization.py. Running it with -h gives you a detailed description over a list of parameters you can control:

  • net: path to the input network profile.
  • flow: path to the input flow profile.
  • out: directory to save the output file.
  • file_name: name of the file to save results.
  • --scheduler: type of scheduler applied to each hop of the network. 0 for FIFO and 1 for SCED.
  • --objective: type of the objective function to minimize. Available choices include: 0 for the sum of link bandwidth, 1 for weighted sum of link bandwidth, 2 for maximum link bandwidth.
  • --weight: path to the link weights if the objective function is selected to be a weighted sum of link bandwidth.
  • --mode: bandwidth minimization algorithm to run, 0 for NLP-based algorithm, 1 for the greedy algorithm. Greedy algorithm is applied by default.

For example, to compute the minimum required sum of link bandwidth with SCED schedulers using the greedy algorithm with network profile saved in input/network/3/net1.npy and flow profile saved in input/flow/3/flow1.npz, and save the results to output/ under the name result.npz, you should use

# Make sure you are in the root directory of this repo,
# where optimization.py is stored.
python optimization.py input/network/3/net1.npy input/flow/3/flow1.npz output result --scheduler 1 --objective 0 --mode 1

Library

We factor various parts of the code into different modules in the lib/ directory. You can begin by looking at the main optimization script to see how to make use of these modules.

  • utils.py: Implement various utility functions (e.g., function to load input data).
  • network_parser.py: Helper functions that faciliate parsing the inputs and the solutions of the optimization.
  • genetic.py: A parent class that provides a generic implementation of the genetic algorithm.
  • genetic_fifo.py: Implement a genetic algorithm that performs guided random search to find the best solution based on solving multiple non-linear programs, for networks with FIFO schedulers.
  • genetic_sced.py: Similar to genetic_fifo.py, but for networks with SCED schedulers.
  • heuristic_fifo.py: Implement Greedy and the baseline solutions for networks with FIFO schedulers.
  • heuristic_sced.py: Similar to heuristic_fifo.py, but for networks with SCED schedulers.
  • order_generator.py: Implement various functions that handle flow orderings.
  • octeract.py: Formulate the minimization problem into NLPs and call the Octeract engine to solve the generated NLPs.

License

This code is being released under the MIT License.