From c2e6aad09f893e4c8cb5cb9243c32a0d6d0d1e12 Mon Sep 17 00:00:00 2001 From: Loic Guegan Date: Thu, 9 Jun 2022 21:48:32 +0200 Subject: Init ESDS repository --- tests/mobility_eth0_latency_1s1r/simulator.py | 39 +++++++++++++++++++++++++++ 1 file changed, 39 insertions(+) create mode 100755 tests/mobility_eth0_latency_1s1r/simulator.py (limited to 'tests/mobility_eth0_latency_1s1r/simulator.py') diff --git a/tests/mobility_eth0_latency_1s1r/simulator.py b/tests/mobility_eth0_latency_1s1r/simulator.py new file mode 100755 index 0000000..525bb66 --- /dev/null +++ b/tests/mobility_eth0_latency_1s1r/simulator.py @@ -0,0 +1,39 @@ +#!/usr/bin/env python + +# Load ESDS +import sys +sys.path.append("../../") +import esds +import numpy as np + +########## Scenario ########## +# Notations: +# - Remaining communication duration (last communication ends minus current simulated time) = C +# - Last communication duration (previous row) = U +# - Last remaining data size (previous row) = D +# - Current remaining data (current row) = R +# - Initial data size (first row) = I +# - Bandwidth = BW +# - Latency = L +# |-------------------+------------+----------------+----------------------+--------------------------+-------------------------| +# | Simulated time(s) | Latency(s) | Bandwidth(bps) | Remaining data (bit) | Communcation duration(s) | Communcation ends at(s) | +# |-------------------+------------+----------------+----------------------+--------------------------+-------------------------| +# | 0 | 0 | 8 | 8 | 1 | 1 | +# | 0.5 | 0.5 | 8 | C/U*D = 4 | R/I * L + R/BW = 0.75 | 1.25 | +# | 1 | 1 | 8 | C/U*D = 1.33 | R/I * L + R/BW = 0.33 | 1.33 | +# | 1.33 | 1 | 8 | | | | +# |-------------------+------------+----------------+----------------------+--------------------------+-------------------------| +############################## + +B=np.full((2,2),8) +L=np.full((2,2),0) +s=esds.Simulator(B,L) + +s.create_node("sender") +s.create_node("receiver") + +def callback(simulator): + simulator.log("Network update!") + simulator.update_network(simulator.B,simulator.L+1/2) + +s.run(breakpoints_every=1/2,breakpoint_callback=callback) -- cgit v1.2.3