diff options
| author | Loïc Guégan <loic.guegan@mailbox.org> | 2024-06-30 15:02:42 +0200 |
|---|---|---|
| committer | Loïc Guégan <loic.guegan@mailbox.org> | 2024-06-30 15:02:42 +0200 |
| commit | a8941c964dd56d48a137e8d6c03edff378baca3e (patch) | |
| tree | af8ba70fefb6d9e9890ee717bdd7f2e1abd73623 /run_strategy_sor.sh | |
| parent | 31981883765dfd5198ba8394f13f2f3b51470b04 (diff) | |
Cleaning repository
Diffstat (limited to 'run_strategy_sor.sh')
| -rwxr-xr-x | run_strategy_sor.sh | 136 |
1 files changed, 136 insertions, 0 deletions
diff --git a/run_strategy_sor.sh b/run_strategy_sor.sh new file mode 100755 index 0000000..2f36123 --- /dev/null +++ b/run_strategy_sor.sh @@ -0,0 +1,136 @@ +#!/usr/bin/env bash + +set -e + +wai=$(dirname $(readlink -f "$0")) +scenarios="${wai}/scenarios" +inputs="${wai}/inputs.json" +simulator="make run" +sched="${wai}/analysis/scheduler/analysis.sh" +parser="${wai}/parser.awk" +results="${wai}/results/strategy_sor.csv" # UPDATE HERE TO CHANGE OUTPUT CSV FILE NAME +aheaders="simkey,wireless,wakeupfor" +avalues="none,none,none" +log_file="${wai}/logs/$(date +%s).org" && mkdir -p "${wai}/logs/" +gen_log=0 # Should we generate logs ? + +run-simulation () { + # Generate inputs + $scenarios $seed $simtime $wakeupevery $wakeupfor $n_nodes $extended $hint $poff $pon $prx $ptx $datasize $bitrate $hintsize $latency $shutdown_on_rcv $unschedule_on_rcv $farhint $hintdist > "$inputs" + + # Init logs + [ $gen_log -eq 1 ] && echo -e "* seed=$seed simtime=$simtime wakeupevery=$wakeupevery wakeupfor=$wakeupfor n_nodes=$n_nodes extended=$extended hint=$hint poff=$poff pon=$pon prx=$prx ptx=$ptx datasize=$datasize bitrate=$bitrate \n" >> "${log_file}" + + # Run simulations + tmp=$(mktemp) + $simulator &> $tmp + [ $gen_log -eq 1 ] && cp $tmp "${log_file}" + + # Gen csv + [ ! -e "$results" ] && { cat $tmp | $parser | sed "1 s/$/,${aheaders}/g" | sed "2,\$s/$/,${avalues}/" > "$results"; } + [ -e "$results" ] && { cat $tmp | $parser | sed 1d | sed "s/$/,${avalues}/" >> "$results"; } + + # Gen scheduler analysis + [ $seed -eq 1 ] && $sched $tmp "logs/$(echo ${avalues}|tr ',' '_')_hint${hint}_extended${extended}.png" + + # Clear tmp + rm $tmp +} + +# Default Parameters +seed=0 +simtime=86400 # One day +wakeupevery=3600 +wakeupfor=60 +n_nodes=13 # First node will be the sender so n_receivers=n_nodes-1 +extended="false" +hint="false" +poff=0 +pon=0.4 +prx=0.16 +ptx=0.16 +datasize=1000000 # 1Mb +hintsize=8 # Integer +hintdist=10800 # Hint distance while using farhint +latency=0 # in Seconds +shutdown_on_rcv="true" +unschedule_on_rcv="false" +farhint="false" +bitrate="100kbps" + + +run-scenarios() { + # Configure number of seed per scenarios + nseed=200 + + # Baseline + avalues="baseline,$wireless,$wakeupfor" + for seed in $(seq 1 $nseed) + do + printf "\rBaseline...${seed}" + run-simulation + done + echo + + # Hint + hint="true" + avalues="hint,$wireless,$wakeupfor" + for seed in $(seq 1 $nseed) + do + printf "\rHint...${seed}" + run-simulation + done + hint="false" + echo + + # Extended + extended="true" + avalues="extended,$wireless,$wakeupfor" + for seed in $(seq 1 $nseed) + do + printf "\rExtended...${seed}" + run-simulation + done + extended="false" + echo + + # Hint+Extended + extended="true" + hint="true" + avalues="hintandextended,$wireless,$wakeupfor" + for seed in $(seq 1 $nseed) + do + printf "\rHint + Extended...${seed}" + run-simulation + done + extended="false" + hint="false" + echo +} + +# Clean previous runs +[ -e "${results}" ] && rm "${results}" + +for wakeupfor in 60 180 +do + + # Lora + echo "----- Run Lora (wakeupfor=$wakeupfor) -----" + wireless="lora" + bitrate="50kbps" + pon=0.4 + prx=0.16 + ptx=0.16 + latency=0 + run-scenarios + + # NbIot + echo "----- Run NbIoT (wakeupfor=$wakeupfor) -----" + wireless="nbiot" + bitrate="200kbps" + pon=0.4 + prx=0.65 + ptx=0.65 + latency=0 + run-scenarios +done |
