forked from mhinsch/LPMCalib
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain_dist.jl
73 lines (50 loc) · 2.12 KB
/
main_dist.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
# library
using Random
# load main simulation code
include("LPM/mainHelpers.jl")
include("analysis.jl")
include("dist_func.jl")
function runDist(obsDates, args)
simPars, pars = loadParameters(args)
Random.seed!(simPars.seed)
model = setupModel(pars)
time = Rational(pars.poppars.startTime)
unsetVerbose!()
setDelay!(0)
res = Dict{Rational{Int}, Data}()
dates = reverse(obsDates)
while ! isempty(dates)
stepModel!(model, time, pars)
if time == dates[end]
res[time] = observe(Data, model, time, pars)
pop!(dates)
end
time += simPars.dt
end
res, model
end
function distance(args)
obsDates = Rational{Int}[i for i in 1996:2021]
res, _ = runDist(obsDates, args)
dists = Float64[]
push!(dists, dist_pop_pyramid("data/pop_pyramid_2020.tsv", res, 2020//1))
push!(dists, dist_soc_status("data/soc_status_by_age_2011.tsv", res, 2011//1))
push!(dists, dist_hh_size("data/hh_size.tsv", res, obsDates))
push!(dists, dist_maternity_age("data/maternity_by_age.tsv", res, 2020//1))
push!(dists, dist_maternity_age_SES("data/shares_births_by_age_SES.tsv", res, 2020//1))
#push!(dists, dist_couples_age_diff("data/couple_age_diff.tsv", res, 2001//1))
push!(dists, dist_couples_age_diff_fr("data/couple_age_diff_fr.tsv", res, 2017//1))
push!(dists, dist_num_prev_children("data/num_prev_children.tsv", res, 2020//1))
# TODO this produces NaN at the moment
push!(dists, dist_income_deciles("data/income_deciles.tsv", res, 2020//1))
push!(dists, dist_prop_lphh(res, 2021//1))
push!(dists, dist_empl_status_by_age("data/employment_by_age.tsv", res, 2016//1))
push!(dists, dist_empl_by_family_status("data/employment_by_family.tsv", res, 2019//1))
push!(dists, dist_households_by_empl("data/households_by_employment.tsv", res, 2019//1))
push!(dists, dist_unemployment_by_class("data/unemployment_by_SES.tsv", res, 2018//1))
println("dists: ", dists)
sum(dists) / length(dists)
end
if !isinteractive() && abspath(PROGRAM_FILE) == @__FILE__
println(distance(ARGS))
end