-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathoptimization_solvetime.sh
76 lines (69 loc) · 3.06 KB
/
optimization_solvetime.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
#!/bin/bash
proc_num=0
today=$(date +'%Y-%m-%d')
dirname="./data/parallel_experiment/exp-${today}"
paradir=$(julia src/nextpararun.jl --location ${dirname})
## experiment settings
teavar=0.999 # target availability (beta) for teavar
abstract_optical=0 # 1 for weibull failures, 2 for k simutaneous failure, 0 only run TE does not generate tickets
tunnel_type=4 # 4 for failure aware tunnel, 3 for fiber disjoint tunnel, 2 for IP disjoint tunnel, 1 is KSP tunnel, 0 is KSP for PCF
exp_topo="B4" # experiment topology
missing_mode=false
failure_simulation=false
failure_free=false
expand_spectrum=0
generate_ticket_scenario=0 # read all scenarios in a scenario file together
## topology related parameters
if [ $exp_topo = "B4" ]
then
traffic_matrices=$(seq 1 1 30)
option_num=80 # number of lottery tickets
scale_num=4.2 # demand scale
tunnel_count="8" # TE tunnel number per flow
cutoff_value=0.001 # probabilistic scenario cutoff
demand_downscale=12000
topo_index="1"
lotteryticket_set=$(seq 1 1 1; seq 10 10 10; seq 40 40 80)
lotteryticket_set_comma=1,10,40,80
largest_lotteryticket=80
scenario_set=$(seq 1 1 5)
elif [ $exp_topo = "IBM" ]
then
traffic_matrices=$(seq 1 1 30)
option_num=90 # number of lottery tickets
scale_num=5.5 # demand scale
tunnel_count="12" # TE tunnel number per flow
cutoff_value=0.001 # probabilistic scenario cutoff
demand_downscale=12000
topo_index="1"
lotteryticket_set=$(seq 1 1 1; seq 10 10 10; seq 40 40 80; seq 90 30 90)
lotteryticket_set_comma=1,10,40,80,90
largest_lotteryticket=90
scenario_set=$(seq 1 1 3)
fi
julia src/author.jl
startpoint=$1
for traffic_num in ${traffic_matrices}; do
for option_num in ${lotteryticket_set}; do
for scenario_id in ${scenario_set}; do
if ((proc_num == 0))
then
plot_single=true
sleeptime=30
else
plot_single=false
sleeptime=2
fi
((iter_traffic_num=${startpoint}+traffic_num))
julia src/main.jl --topology ${exp_topo} --traffic ${iter_traffic_num} --scale ${scale_num} --te ARROW --verbose false --parallel ${paradir} --downscale ${demand_downscale} --singleplot ${plot_single} --topoindex ${topo_index} --cutoff ${cutoff_value} --tunnel ${tunnel_count} --scenarioID ${scenario_id} --ticketsnum ${option_num} --largeticketsnum ${largest_lotteryticket} --abstractoptical ${abstract_optical} --teavarbeta ${teavar} --tunneltype ${tunnel_type} --missing ${missing_mode} --simulation ${failure_simulation} --failurefree ${failure_free} --expandspectrum ${expand_spectrum} --scenariogeneration ${generate_ticket_scenario} &
pids[proc_num]=$!;
((proc_num=proc_num+1));
sleep 10
done
done
done
for pid in ${pids[*]}; do
wait $pid
done
## plotting results
julia plot_all.jl --location ${paradir} --topology ${exp_topo} --te ARROW --option 0 --scale ${scale_num} --plottype "optimizationtime" --inverselog false --lotteryticketset ${lotteryticket_set_comma}