forked from sisl/Multilane.jl
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcorplot.jl
92 lines (78 loc) · 2.52 KB
/
corplot.jl
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
using PGFPlots
using CSV
using DataFrames
using Missings
using Query
function only(a)
@assert length(a) == 1
return first(a)
end
# filename = Pkg.dir("Multilane", "data/cor_trend_Monday_2_Apr_19_49.csv")
# filename = Pkg.dir("Multilane", "data/cor_trend_Tuesday_3_Apr_07_20.csv")
# filename = Pkg.dir("Multilane", "data/cor_trend_Tuesday_3_Apr_20_35.csv")
filename = Pkg.dir("Multilane", "data/cor_trend_Friday_27_Apr_03_39.csv")
data = CSV.read(filename)
data[:time_to_lane] = data[:steps_to_lane].*data[:dt]
data[:brakes_per_step] = data[:nb_brakes]./data[:n_steps]
data = @from i in data begin
@where i.solver != "outcome"
@select i
@collect DataFrame
end
combined = by(data, [:cor, :solver]) do df
return DataFrame(reached_lane=sum(df[:terminal].=="lane")/nrow(df),
n=nrow(df))
end
@show sort(combined, [:solver])
styles = Dict(
"qmdp" => "blue",
"pomcpow" => "brown",
"meanmpc" => "black",
"baseline" => "blue",
"omniscient" => "red, dashed"
)
marks = Dict(
"qmdp" => "*",
"pomcpow" => "*",
"meanmpc" => "star",
"baseline" => "diamond*",
"omniscient" => "*"
)
names = Dict("qmdp"=>"QMDP",
"outcome"=>"Naive MDP",
"pomcpow"=>"POMCPOW",
"meanmpc"=>"Mean MPC",
"baseline"=>"Assume normal",
"omniscient"=>"Omniscient"
)
plts = Plots.Plot[]
for df in groupby(combined, [:solver])
df = sort(df, [:cor])
name = only(unique(df[:solver]))
# confidence region from Hoeffding Bound
confidence = 0.68
n = only(unique(df[:n]))
confidence_radius = sqrt(log((1.0-confidence)/2)/(-2*n))
plt = Plots.Linear(convert(Vector{Float64}, df[:cor]),
df[:reached_lane],
errorBars=ErrorBars(y=fill(confidence_radius, nrow(df))),
# style="$(styles[name]), mar",
style="$(styles[name]), mark options={fill=$(styles[name])}",
legendentry=names[name],
mark=marks[name],
)
# legendentry=name)
push!(plts, plt)
end
a = Axis(plts,
ylabel="Fraction successful",
xlabel="Correlation",
# legendPos="south west"
style="legend style={at={(0.5,-0.2)}, anchor=north}, legend columns=2, grid=both",
width="3.5in",
height="2.7in"
)
file = "/home/zach/Devel/thesis/media/corplot.tex"
save(file, a, include_preamble=false)
# save(file, a)
# run(`xdg-open $file`)