diff --git a/README.md b/README.md new file mode 100644 index 0000000000000000000000000000000000000000..e43eb231b097109ee0c5e178ff5dc6dcb22a9fc4 --- /dev/null +++ b/README.md @@ -0,0 +1,8 @@ +This repository is related to project 19449 with the [Bioinformatics & Biostatistics Hub](https://research.pasteur.fr/fr/team/bioinformatics-and-biostatistics-hub/) and [Cyril Savin](https://research.pasteur.fr/fr/member/cyril-savin/). + +Olivier Mirabeau also contributed to this project, via another channel. + +Two notebooks are available, with html exports: + +* [snp_chisq_tests](https://flaurent.pages.pasteur.fr/project19449/snp_chisq_tests.html) +* [genes_chisq_tests](https://flaurent.pages.pasteur.fr/project19449/genes_chisq_tests.html) diff --git a/doc/genes_chisq_tests.html b/doc/genes_chisq_tests.html index 6b6f88971e3e764335144c66caf7b09bc8444390..f3baba327be6d743d2cfe2cddcda61fcbc27e725 100644 --- a/doc/genes_chisq_tests.html +++ b/doc/genes_chisq_tests.html @@ -3,11 +3,11 @@ <meta name="theme-color" media="(prefers-color-scheme: light)" content="white"><meta name="theme-color" media="(prefers-color-scheme: dark)" content="#2a2928"><meta name="color-scheme" content="light dark"><link rel="icon" type="image/png" sizes="16x16" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/favicon-16x16.347d2855.png" integrity="sha384-3qsGeVLdddzV9oIkj3PhXXQX2CZCjOD/CiyrPQOX6InOWw3HAHClrsQhPfX9uRAj" crossorigin="anonymous"><link rel="icon" type="image/png" sizes="32x32" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/favicon-32x32.8789add4.png" integrity="sha384-cOe5vSoBIgKNgkUL27p9RpsGVY0uBg9PejLccDy+fR8ZD1Iv5dF1MGHjIZAIZwm6" crossorigin="anonymous"><link rel="icon" type="image/png" sizes="96x96" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/favicon-96x96.48689391.png" integrity="sha384-TN49cYb8GyNmrZT14bsYXXo4l1x1NJeJ/EHuVAauAKsNPopPHLojijs9jFT4Vs8c" crossorigin="anonymous"><link rel="pluto-logo-big" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/logo.004c1d7c.svg" integrity="sha384-GkQkODcGxsrSRJCkeakBXihum0GUM44cwBgKyutDimectXCbCgj6Vu3jlrueqEcN" crossorigin="anonymous"><link rel="pluto-logo-small" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/favicon_unsaturated.d1387b25.svg" integrity="sha384-omwjH+Qy3hpAVf5FYd/pkaDBuVAfsEDRN7eBxEA8Ek00OAWP+aiV+GpEYk3I7lyo" crossorigin="anonymous"><script type="module" src="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.4d2be9f0.js" integrity="sha384-CuFAr2AFtrPmN0FVO2PrGqg83e0KHFguP+4bn4V96uoNA6iydUywNAMKS3FYP5bU" crossorigin="anonymous"></script><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/juliamono.c6034ab4.css" integrity="sha384-n0za6lUXlyf4XC+nGkZWj3TLDnRbNpAcoi4PZGSlQMPoyqGa9kGY+ZXkUgZGIhQt" crossorigin="anonymous"><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.9402a72e.css" integrity="sha384-NJUInpSDijrLS5DfgY1ITvzJ/8HJmHa62lN/13hYf8FknsJEMJdwqQWtyreOFUZ3" crossorigin="anonymous"><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/vollkorn.089565a8.css" integrity="sha384-jnV/84VtSgBLF70H+s2rxJcOUZIMDR+X/ElFZA83i9ZtZSWiIMFAgPyrWkOJV08q" crossorigin="anonymous"><script defer="">console.log("Pluto.jl, by Fons van der Plas (https://github.com/fonsp), MikoÅ‚aj Bochenski (https://github.com/malyvsen), Michiel Dral (https://github.com/dralletje) and friends 🌈");</script><script src="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.4b96dd74.js" defer="" integrity="sha384-Y+UtWANyXLeovyghpAI8j9/VZXWboD6G5ZCckOsJO99PawAh/utJxFikf62WBaSu" crossorigin="anonymous"></script><script src="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.9f9dc874.js" defer="" integrity="sha384-tkFo1EK72I9JvoTmHFa199dfRzW8mkXPUkHb/N7UhYI+bxKzX3Kh8LNCZz1ltsFF" crossorigin="anonymous"></script><script src="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.90ede145.js" defer="" integrity="sha384-CuNU9gQg6fa/yynNqNWjHWzPm4nj+d7O6+HXsNGSqClhs/bYQIbBC3Lw/kh8Ukui" crossorigin="anonymous"></script><script src="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.dbeed08a.js" defer="" integrity="sha384-1BEdQwXfZi4ZpsNV8w1X8pQcVK1/DS/+/M8OTo3gol7mdEspSN7nT6llX57NQCSt" crossorigin="anonymous"></script><script id="iframe-resizer-content-window-script" src="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.6386bd9d.js" crossorigin="anonymous" defer="" integrity="sha384-tgN2a0VDi/lCYwZuDqT7L+A/Y/9kpxf3HV7zv2BJ5Fu7zW0EClq0nM4crfK3TRPs"></script><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.20c99564.css" type="text/css" integrity="sha384-ZeUE8EilG635rOn5WI6cu08sHKMkb04kTkNSWBN8oKlADao2MBRWNIn9Yhaddbi6" crossorigin="anonymous"><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.14f23ca4.css" type="text/css" media="all" data-pluto-file="hide-ui" integrity="sha384-++EDAMZbJynENol9onosKuuWP4ex4rhT9Rl/oELs6oVltwZdU9DC0W1nYT4Ttb9V" crossorigin="anonymous"><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.99402935.css" type="text/css" integrity="sha384-Wl7QT6vOzvYxGbF4LKAXVRihsch7DCr4GeiXwOS273IU4E5g7HMSBkrbI9GFP+qI" crossorigin="anonymous"><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.1f4cf2ca.css" type="text/css" integrity="sha384-lBSBsn8FT1UzGOsNVudfV8RSHQEuNWqrCb6xQnF10uvF9AiCzYsCRXvKlhtQvV3c" crossorigin="anonymous"><link rel="preload" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/juliamono.c6034ab4.css" as="style" integrity="sha384-n0za6lUXlyf4XC+nGkZWj3TLDnRbNpAcoi4PZGSlQMPoyqGa9kGY+ZXkUgZGIhQt" crossorigin="anonymous"><link rel="preload" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/vollkorn.089565a8.css" as="style" integrity="sha384-jnV/84VtSgBLF70H+s2rxJcOUZIMDR+X/ElFZA83i9ZtZSWiIMFAgPyrWkOJV08q" crossorigin="anonymous"><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.e82e08bd.css" type="text/css" integrity="sha384-7YN+h8b6N4N65qk8TG/J2KPF95D8z3sGNd06rokz4CX9oWu0KnRAF5cVWu3BkkaN" crossorigin="anonymous"><script data-pluto-file="launch-parameters"> window.pluto_notebook_id = undefined; window.pluto_isolated_cell_ids = undefined; -window.pluto_notebookfile = "data:text/julia;charset=utf-8;base64,### A Pluto.jl notebook ###
# v0.19.26

using Markdown
using InteractiveUtils

# ╔═╡ 11ac5f6a-0f6a-11ee-2598-11c7a0064b43
using StatsBase, HypothesisTests, XLSX, SparseArrays, MultipleTesting

# ╔═╡ 8dd5d4b9-5a32-4a95-8f38-7f3e5b98e2d9
md"""
We first load the count data.

!!!
	The notebook is assumed to run from a child directory (*e.g.* `notebooks`) of the project root, and the data files are expected to be found in `data/raw`, from the project root.
"""

# ╔═╡ 5e94a517-db46-4864-b717-5b4543884dff
data = XLSX.openxlsx("../data/raw/genes_specifiques.xlsx")

# ╔═╡ a5e61a48-e07e-49dc-8c61-1224d1c47d13
counts = Int.(data["nb gènes spé"]["B3:U25"])

# ╔═╡ a25eecd6-f58d-493d-a5cf-94218319849d
md"""
For further reference, we also load the labels of the rows (`categories`) and columns (`genotypes`).
"""

# ╔═╡ 9c3b8eb2-a160-4246-a5c7-596a86c73d62
begin
	genotypes = vec(data["nb gènes spé"]["B2:U2"]) # columns
	categories = vec(data["nb gènes spé"]["A3:A25"]) # rows
end

# ╔═╡ 3eb9d39c-2ca1-430e-b13b-05c809a80d5b
md"""
First, we exclude the rows and columns of zeros only.
"""

# ╔═╡ e3febec7-b84c-45f9-8f65-5a158b0ae933
begin
	row_ok = vec(any(!=(0), counts; dims=2))
	col_ok = vec(any(!=(0), counts; dims=1))
	clean_counts = counts[row_ok, col_ok]
	nrows, ncols = size(clean_counts)
end

# ╔═╡ f2825d3c-577b-4b61-8c8c-c869a9ec9f07
md"""
To test whether a genotype exhibits a different partition into categories of genes, or equivalently whether it is enriched in some category, we first derive an expected partition averaging the category frequencies across all genotypes.
"""

# ╔═╡ 72cf8d55-a423-4c28-a370-377f9ef6a70e
begin
	col_total = sum(clean_counts; dims=1)
	expected_frequencies = mean(clean_counts ./ col_total; dims=2)
	@assert sum(expected_frequencies) ≈ 1
end

# ╔═╡ b8adc566-5893-402a-a35d-11c06460fb62
md"""
Due to the presence of zeros in most columns, we have to group the low-frequency cells into single cells on a per-column basis. The information in low-frequency cells is already accounted for by the other cells.

We can also individually test each count `observed_n` _equal to or greater than 5_ in a contingency table with:
```
+------------+------------------------+
| observed_n | col_total - observed_n |
+------------+------------------------+
| expected_n | col_total - expected_n |
+------------+------------------------+
```
This second approach is less powerful, though.

Let us begin with this second approach:
"""

# ╔═╡ 3df39484-e07a-48d8-90ae-09da0050b3ce
begin
	observed_counts = clean_counts
	# in theory, we could also use real-valued counts instead
	expected_counts = @. round(Int, expected_frequencies * col_total)
	observed_remainder = col_total .- observed_counts
	expected_remainder = col_total .- expected_counts

	pvalues = spzeros(nrows, ncols)
	for row in 1:nrows
		for col in 1:ncols
			
			# build the contingency table
			a = observed_counts[row, col]
			b = observed_remainder[row, col]
			c = expected_counts[row, col]
			d = expected_remainder[row, col]
			contingency_table = [ a b ; c d ]
			
			# perform a χ² test of homogeneity
			if all(>=(5), contingency_table)
				pval = pvalue(ChisqTest(contingency_table))
				# note: FisherExactTest(a, b, c, d) gives very similar results
				#pval = pvalue(FisherExactTest(a, b, c, d); method=:minlike)
				
				pvalues[row, col] = pval
			end
		end
	end
	pvalues
end

# ╔═╡ b314add7-a6f5-42f0-bc9a-bba748543fa2
md"""
Out of curiosity, with no correction for multiple comparisons, we find a few p-values below 0.05:
"""

# ╔═╡ 7e383967-26de-49bd-a106-d215241ffdb1
begin
	uncorrected_pvalues_below_threshold = copy(pvalues)
	uncorrected_pvalues_below_threshold.nzval[.05 .< pvalues.nzval] .= 0
	dropzeros(uncorrected_pvalues_below_threshold)
end

# ╔═╡ c09b771c-aab1-40cf-a273-14aa6c857510
md"""
Correcting for all the comparisons, no differences survive:
"""

# ╔═╡ 46c9be07-3bb4-499c-a819-7a87c73b6e42
# with correction, no differences survive
begin
	# see https://github.com/juliangehring/MultipleTesting.jl#holm
	corrected_pvalues = adjust(pvalues.nzval, Holm())
	significant = corrected_pvalues .<= .05
	significant_pvalues = copy(pvalues)
	significant_pvalues.nzval .= 0
	significant_pvalues.nzval[significant] = corrected_pvalues[significant]
	significant_pvalues = dropzeros(significant_pvalues)
end

# ╔═╡ 128668c3-282d-4453-84a6-cf2c29d7140f
md"""
Had we found differences, we could get the corresponding category-genotype pairs as follows:
"""

# ╔═╡ 548ca244-de4c-47c2-a69e-0ca7a449028f
begin
	row, col = findnz(significant_pvalues)
	category = categories[row_ok][row]
	genotype = genotypes[col_ok][col]
	collect(zip(category, genotype))
end

# ╔═╡ 884a7299-8418-45e4-82f3-65204d48e55b
md"""
Correcting for all comparisons is probably unfair. Frequencies are bound within each column and row (one less degree of freedom).

Anyway, the sample size is far too low for the number of cells, and we need a more powerful test.

Let us now compare each genotype with the "average" genotype grouping the low-frequency cells together. We already know the post-hoc tests fail, and we won't have category-level resolution, but a significant difference may be an argument for increasing the sample size, or rethinking the categories. 

An elaborate approach can be found in [Kass, 1980](https://www4.stat.ncsu.edu/~dickey/analytics/datamine/Reference%20Papers/kass80.pdf).

The simpler approach followed here consists in grouping all observed counts below 5 into a single synthetic category, for each column separately. Expected counts are similarly grouped, based on the observed counts. If some expected count is below 5 (included the synthetic category), we carry on unless this count is 0.
"""

# ╔═╡ 9342e489-a297-4c67-8324-cb41801af713
begin
	per_genotype_pvalues = spzeros(ncols)
	for col in 1:ncols
		ok = observed_counts[:, col] .>= 5
		any(ok) || continue
		observed_counts′ = observed_counts[ok, col]
		if !all(ok)
			synthetic_count = sum(observed_counts[(!).(ok), col])
			push!(observed_counts′, synthetic_count)
		end
		expected_counts′ = expected_counts[ok, col]
		if !all(ok)
			synthetic_count = sum(expected_counts[(!).(ok), col])
			push!(expected_counts′, synthetic_count)
		end
		contingency_table = hcat(observed_counts′, expected_counts′)
		if any(expected_counts′ .< 5)
			#continue # to get significant results...
			if any(expected_counts′ .== 0)
				@warn "Expected counts are too low; skipping" contingency_table
				continue
			else
				#@warn "Expected counts are low" contingency_table
			end
		end
		pval = pvalue(ChisqTest(contingency_table))
		per_genotype_pvalues[col] = pval
	end
	per_genotype_pvalues
end

# ╔═╡ 31dc58db-5a4e-47dc-bdb8-fe6e9bb47204
begin
	corrected_per_genotype_pvalues = adjust(per_genotype_pvalues.nzval, Holm())
	minimum(corrected_per_genotype_pvalues)
end

# ╔═╡ 6d768ec2-f9ad-4cc7-a2df-4eeb1a72cd44
md"""
We fail by a little margin. Too many columns here.

Actually, if we had chosen to reject the columns with `any(expected_counts′ .< 5)`, we would have at least one significantly different genotype. This notebook shows the original approach, with no iterations.

More can be done.
"""

# ╔═╡ 00000000-0000-0000-0000-000000000001
PLUTO_PROJECT_TOML_CONTENTS = """
[deps]
HypothesisTests = "09f84164-cd44-5f33-b23f-e6b0d136a0d5"
MultipleTesting = "f8716d33-7c4a-5097-896f-ce0ecbd3ef6b"
SparseArrays = "2f01184e-e22b-5df5-ae63-d93ebab69eaf"
StatsBase = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91"
XLSX = "fdbf4ff8-1666-58a4-91e7-1b58723a45e0"

[compat]
HypothesisTests = "~0.11.0"
MultipleTesting = "~0.5.1"
StatsBase = "~0.33.21"
XLSX = "~0.9.0"
"""

# ╔═╡ 00000000-0000-0000-0000-000000000002
PLUTO_MANIFEST_TOML_CONTENTS = """
# This file is machine-generated - editing it directly is not advised

julia_version = "1.9.0"
manifest_format = "2.0"
project_hash = "d9da7e97863fee97b88704272749d1c852674499"

[[deps.ArgTools]]
uuid = "0dad84c5-d112-42e6-8d28-ef12dabb789f"
version = "1.1.1"

[[deps.Artifacts]]
uuid = "56f22d72-fd6d-98f1-02f0-08ddc0907c33"

[[deps.Base64]]
uuid = "2a0f44e3-6c83-55bd-87e4-b1978d98bd5f"

[[deps.Calculus]]
deps = ["LinearAlgebra"]
git-tree-sha1 = "f641eb0a4f00c343bbc32346e1217b86f3ce9dad"
uuid = "49dc2e85-a5d0-5ad3-a950-438e2897f1b9"
version = "0.5.1"

[[deps.ChainRulesCore]]
deps = ["Compat", "LinearAlgebra", "SparseArrays"]
git-tree-sha1 = "e30f2f4e20f7f186dc36529910beaedc60cfa644"
uuid = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4"
version = "1.16.0"

[[deps.Combinatorics]]
git-tree-sha1 = "08c8b6831dc00bfea825826be0bc8336fc369860"
uuid = "861a8166-3701-5b0c-9a16-15d98fcdc6aa"
version = "1.0.2"

[[deps.CommonSolve]]
git-tree-sha1 = "0eee5eb66b1cf62cd6ad1b460238e60e4b09400c"
uuid = "38540f10-b2f7-11e9-35d8-d573e4eb0ff2"
version = "0.2.4"

[[deps.Compat]]
deps = ["UUIDs"]
git-tree-sha1 = "7a60c856b9fa189eb34f5f8a6f6b5529b7942957"
uuid = "34da2185-b29b-5c13-b0c7-acf172513d20"
version = "4.6.1"
weakdeps = ["Dates", "LinearAlgebra"]

    [deps.Compat.extensions]
    CompatLinearAlgebraExt = "LinearAlgebra"

[[deps.CompilerSupportLibraries_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "e66e0078-7015-5450-92f7-15fbd957f2ae"
version = "1.0.2+0"

[[deps.ConstructionBase]]
deps = ["LinearAlgebra"]
git-tree-sha1 = "738fec4d684a9a6ee9598a8bfee305b26831f28c"
uuid = "187b0558-2788-49d3-abe0-74a17ed4e7c9"
version = "1.5.2"

    [deps.ConstructionBase.extensions]
    ConstructionBaseIntervalSetsExt = "IntervalSets"
    ConstructionBaseStaticArraysExt = "StaticArrays"

    [deps.ConstructionBase.weakdeps]
    IntervalSets = "8197267c-284f-5f27-9208-e0e47529a953"
    StaticArrays = "90137ffa-7385-5640-81b9-e52037218182"

[[deps.DataAPI]]
git-tree-sha1 = "8da84edb865b0b5b0100c0666a9bc9a0b71c553c"
uuid = "9a962f9c-6df0-11e9-0e5d-c546b8b5ee8a"
version = "1.15.0"

[[deps.DataStructures]]
deps = ["Compat", "InteractiveUtils", "OrderedCollections"]
git-tree-sha1 = "d1fff3a548102f48987a52a2e0d114fa97d730f0"
uuid = "864edb3b-99cc-5e75-8d2d-829cb0a9cfe8"
version = "0.18.13"

[[deps.DataValueInterfaces]]
git-tree-sha1 = "bfc1187b79289637fa0ef6d4436ebdfe6905cbd6"
uuid = "e2d170a0-9d28-54be-80f0-106bbe20a464"
version = "1.0.0"

[[deps.Dates]]
deps = ["Printf"]
uuid = "ade2ca70-3891-5945-98fb-dc099432e06a"

[[deps.Distributions]]
deps = ["FillArrays", "LinearAlgebra", "PDMats", "Printf", "QuadGK", "Random", "SparseArrays", "SpecialFunctions", "Statistics", "StatsAPI", "StatsBase", "StatsFuns", "Test"]
git-tree-sha1 = "4ed4a6df2548a72f66e03f3a285cd1f3b573035d"
uuid = "31c24e10-a181-5473-b8eb-7969acd0382f"
version = "0.25.96"

    [deps.Distributions.extensions]
    DistributionsChainRulesCoreExt = "ChainRulesCore"
    DistributionsDensityInterfaceExt = "DensityInterface"

    [deps.Distributions.weakdeps]
    ChainRulesCore = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4"
    DensityInterface = "b429d917-457f-4dbc-8f4c-0cc954292b1d"

[[deps.DocStringExtensions]]
deps = ["LibGit2"]
git-tree-sha1 = "2fb1e02f2b635d0845df5d7c167fec4dd739b00d"
uuid = "ffbed154-4ef7-542d-bbb7-c09d3a79fcae"
version = "0.9.3"

[[deps.Downloads]]
deps = ["ArgTools", "FileWatching", "LibCURL", "NetworkOptions"]
uuid = "f43a241f-c20a-4ad4-852c-f6b1247861c6"
version = "1.6.0"

[[deps.DualNumbers]]
deps = ["Calculus", "NaNMath", "SpecialFunctions"]
git-tree-sha1 = "5837a837389fccf076445fce071c8ddaea35a566"
uuid = "fa6b7ba4-c1ee-5f82-b5fc-ecf0adba8f74"
version = "0.6.8"

[[deps.EzXML]]
deps = ["Printf", "XML2_jll"]
git-tree-sha1 = "0fa3b52a04a4e210aeb1626def9c90df3ae65268"
uuid = "8f5d6c58-4d21-5cfd-889c-e3ad7ee6a615"
version = "1.1.0"

[[deps.FileWatching]]
uuid = "7b1f6079-737a-58dc-b8bc-7a2ca5c1b5ee"

[[deps.FillArrays]]
deps = ["LinearAlgebra", "Random", "SparseArrays", "Statistics"]
git-tree-sha1 = "e17cc4dc2d0b0b568e80d937de8ed8341822de67"
uuid = "1a297f60-69ca-5386-bcde-b61e274b549b"
version = "1.2.0"

[[deps.Future]]
deps = ["Random"]
uuid = "9fa8497b-333b-5362-9e8d-4d0656e87820"

[[deps.HypergeometricFunctions]]
deps = ["DualNumbers", "LinearAlgebra", "OpenLibm_jll", "SpecialFunctions"]
git-tree-sha1 = "0ec02c648befc2f94156eaef13b0f38106212f3f"
uuid = "34004b35-14d8-5ef3-9330-4cdb6864b03a"
version = "0.3.17"

[[deps.HypothesisTests]]
deps = ["Combinatorics", "Distributions", "LinearAlgebra", "Printf", "Random", "Rmath", "Roots", "Statistics", "StatsAPI", "StatsBase"]
git-tree-sha1 = "4b5d5ba51f5f473737ed9de6d8a7aa190ad8c72f"
uuid = "09f84164-cd44-5f33-b23f-e6b0d136a0d5"
version = "0.11.0"

[[deps.InteractiveUtils]]
deps = ["Markdown"]
uuid = "b77e0a4c-d291-57a0-90e8-8db25a27a240"

[[deps.IrrationalConstants]]
git-tree-sha1 = "630b497eafcc20001bba38a4651b327dcfc491d2"
uuid = "92d709cd-6900-40b7-9082-c6be49f344b6"
version = "0.2.2"

[[deps.IteratorInterfaceExtensions]]
git-tree-sha1 = "a3f24677c21f5bbe9d2a714f95dcd58337fb2856"
uuid = "82899510-4779-5014-852e-03e436cf321d"
version = "1.0.0"

[[deps.JLLWrappers]]
deps = ["Preferences"]
git-tree-sha1 = "abc9885a7ca2052a736a600f7fa66209f96506e1"
uuid = "692b3bcd-3c85-4b1f-b108-f13ce0eb3210"
version = "1.4.1"

[[deps.LibCURL]]
deps = ["LibCURL_jll", "MozillaCACerts_jll"]
uuid = "b27032c2-a3e7-50c8-80cd-2d36dbcbfd21"
version = "0.6.3"

[[deps.LibCURL_jll]]
deps = ["Artifacts", "LibSSH2_jll", "Libdl", "MbedTLS_jll", "Zlib_jll", "nghttp2_jll"]
uuid = "deac9b47-8bc7-5906-a0fe-35ac56dc84c0"
version = "7.84.0+0"

[[deps.LibGit2]]
deps = ["Base64", "NetworkOptions", "Printf", "SHA"]
uuid = "76f85450-5226-5b5a-8eaa-529ad045b433"

[[deps.LibSSH2_jll]]
deps = ["Artifacts", "Libdl", "MbedTLS_jll"]
uuid = "29816b5a-b9ab-546f-933c-edad1886dfa8"
version = "1.10.2+0"

[[deps.Libdl]]
uuid = "8f399da3-3557-5675-b5ff-fb832c97cbdb"

[[deps.Libiconv_jll]]
deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"]
git-tree-sha1 = "c7cb1f5d892775ba13767a87c7ada0b980ea0a71"
uuid = "94ce4f54-9a6c-5748-9c1c-f9c7231a4531"
version = "1.16.1+2"

[[deps.LinearAlgebra]]
deps = ["Libdl", "OpenBLAS_jll", "libblastrampoline_jll"]
uuid = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e"

[[deps.LogExpFunctions]]
deps = ["DocStringExtensions", "IrrationalConstants", "LinearAlgebra"]
git-tree-sha1 = "c3ce8e7420b3a6e071e0fe4745f5d4300e37b13f"
uuid = "2ab3a3ac-af41-5b50-aa03-7779005ae688"
version = "0.3.24"

    [deps.LogExpFunctions.extensions]
    LogExpFunctionsChainRulesCoreExt = "ChainRulesCore"
    LogExpFunctionsChangesOfVariablesExt = "ChangesOfVariables"
    LogExpFunctionsInverseFunctionsExt = "InverseFunctions"

    [deps.LogExpFunctions.weakdeps]
    ChainRulesCore = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4"
    ChangesOfVariables = "9e997f8a-9a97-42d5-a9f1-ce6bfc15e2c0"
    InverseFunctions = "3587e190-3f89-42d0-90ee-14403ec27112"

[[deps.Logging]]
uuid = "56ddb016-857b-54e1-b83d-db4d58db5568"

[[deps.MacroTools]]
deps = ["Markdown", "Random"]
git-tree-sha1 = "42324d08725e200c23d4dfb549e0d5d89dede2d2"
uuid = "1914dd2f-81c6-5fcd-8719-6d5c9610ff09"
version = "0.5.10"

[[deps.Markdown]]
deps = ["Base64"]
uuid = "d6f4376e-aef5-505a-96c1-9c027394607a"

[[deps.MbedTLS_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "c8ffd9c3-330d-5841-b78e-0817d7145fa1"
version = "2.28.2+0"

[[deps.Missings]]
deps = ["DataAPI"]
git-tree-sha1 = "f66bdc5de519e8f8ae43bdc598782d35a25b1272"
uuid = "e1d29d7a-bbdc-5cf2-9ac0-f12de2c33e28"
version = "1.1.0"

[[deps.MozillaCACerts_jll]]
uuid = "14a3606d-f60d-562e-9121-12d972cd8159"
version = "2022.10.11"

[[deps.MultipleTesting]]
deps = ["Distributions", "SpecialFunctions", "StatsBase"]
git-tree-sha1 = "94df14d821baa34662a1492b10615125cbebd47b"
uuid = "f8716d33-7c4a-5097-896f-ce0ecbd3ef6b"
version = "0.5.1"

[[deps.NaNMath]]
deps = ["OpenLibm_jll"]
git-tree-sha1 = "0877504529a3e5c3343c6f8b4c0381e57e4387e4"
uuid = "77ba4419-2d1f-58cd-9bb1-8ffee604a2e3"
version = "1.0.2"

[[deps.NetworkOptions]]
uuid = "ca575930-c2e3-43a9-ace4-1e988b2c1908"
version = "1.2.0"

[[deps.OpenBLAS_jll]]
deps = ["Artifacts", "CompilerSupportLibraries_jll", "Libdl"]
uuid = "4536629a-c528-5b80-bd46-f80d51c5b363"
version = "0.3.21+4"

[[deps.OpenLibm_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "05823500-19ac-5b8b-9628-191a04bc5112"
version = "0.8.1+0"

[[deps.OpenSpecFun_jll]]
deps = ["Artifacts", "CompilerSupportLibraries_jll", "JLLWrappers", "Libdl", "Pkg"]
git-tree-sha1 = "13652491f6856acfd2db29360e1bbcd4565d04f1"
uuid = "efe28fd5-8261-553b-a9e1-b2916fc3738e"
version = "0.5.5+0"

[[deps.OrderedCollections]]
git-tree-sha1 = "d321bf2de576bf25ec4d3e4360faca399afca282"
uuid = "bac558e1-5e72-5ebc-8fee-abe8a469f55d"
version = "1.6.0"

[[deps.PDMats]]
deps = ["LinearAlgebra", "SparseArrays", "SuiteSparse"]
git-tree-sha1 = "67eae2738d63117a196f497d7db789821bce61d1"
uuid = "90014a1f-27ba-587c-ab20-58faa44d9150"
version = "0.11.17"

[[deps.Pkg]]
deps = ["Artifacts", "Dates", "Downloads", "FileWatching", "LibGit2", "Libdl", "Logging", "Markdown", "Printf", "REPL", "Random", "SHA", "Serialization", "TOML", "Tar", "UUIDs", "p7zip_jll"]
uuid = "44cfe95a-1eb2-52ea-b672-e2afdf69b78f"
version = "1.9.0"

[[deps.Preferences]]
deps = ["TOML"]
git-tree-sha1 = "7eb1686b4f04b82f96ed7a4ea5890a4f0c7a09f1"
uuid = "21216c6a-2e73-6563-6e65-726566657250"
version = "1.4.0"

[[deps.Printf]]
deps = ["Unicode"]
uuid = "de0858da-6303-5e67-8744-51eddeeeb8d7"

[[deps.QuadGK]]
deps = ["DataStructures", "LinearAlgebra"]
git-tree-sha1 = "6ec7ac8412e83d57e313393220879ede1740f9ee"
uuid = "1fd47b50-473d-5c70-9696-f719f8f3bcdc"
version = "2.8.2"

[[deps.REPL]]
deps = ["InteractiveUtils", "Markdown", "Sockets", "Unicode"]
uuid = "3fa0cd96-eef1-5676-8a61-b3b8758bbffb"

[[deps.Random]]
deps = ["SHA", "Serialization"]
uuid = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c"

[[deps.Reexport]]
git-tree-sha1 = "45e428421666073eab6f2da5c9d310d99bb12f9b"
uuid = "189a3867-3050-52da-a836-e630ba90ab69"
version = "1.2.2"

[[deps.Rmath]]
deps = ["Random", "Rmath_jll"]
git-tree-sha1 = "f65dcb5fa46aee0cf9ed6274ccbd597adc49aa7b"
uuid = "79098fc4-a85e-5d69-aa6a-4863f24498fa"
version = "0.7.1"

[[deps.Rmath_jll]]
deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"]
git-tree-sha1 = "6ed52fdd3382cf21947b15e8870ac0ddbff736da"
uuid = "f50d1b31-88e8-58de-be2c-1cc44531875f"
version = "0.4.0+0"

[[deps.Roots]]
deps = ["ChainRulesCore", "CommonSolve", "Printf", "Setfield"]
git-tree-sha1 = "de432823e8aab4dd1a985be4be768f95acf152d4"
uuid = "f2b01f46-fcfa-551c-844a-d8ac1e96c665"
version = "2.0.17"

    [deps.Roots.extensions]
    RootsForwardDiffExt = "ForwardDiff"
    RootsIntervalRootFindingExt = "IntervalRootFinding"
    RootsSymPyExt = "SymPy"

    [deps.Roots.weakdeps]
    ForwardDiff = "f6369f11-7733-5829-9624-2563aa707210"
    IntervalRootFinding = "d2bf35a9-74e0-55ec-b149-d360ff49b807"
    SymPy = "24249f21-da20-56a4-8eb1-6a02cf4ae2e6"

[[deps.SHA]]
uuid = "ea8e919c-243c-51af-8825-aaa63cd721ce"
version = "0.7.0"

[[deps.Serialization]]
uuid = "9e88b42a-f829-5b0c-bbe9-9e923198166b"

[[deps.Setfield]]
deps = ["ConstructionBase", "Future", "MacroTools", "StaticArraysCore"]
git-tree-sha1 = "e2cc6d8c88613c05e1defb55170bf5ff211fbeac"
uuid = "efcf1570-3423-57d1-acb7-fd33fddbac46"
version = "1.1.1"

[[deps.Sockets]]
uuid = "6462fe0b-24de-5631-8697-dd941f90decc"

[[deps.SortingAlgorithms]]
deps = ["DataStructures"]
git-tree-sha1 = "c60ec5c62180f27efea3ba2908480f8055e17cee"
uuid = "a2af1166-a08f-5f64-846c-94a0d3cef48c"
version = "1.1.1"

[[deps.SparseArrays]]
deps = ["Libdl", "LinearAlgebra", "Random", "Serialization", "SuiteSparse_jll"]
uuid = "2f01184e-e22b-5df5-ae63-d93ebab69eaf"

[[deps.SpecialFunctions]]
deps = ["IrrationalConstants", "LogExpFunctions", "OpenLibm_jll", "OpenSpecFun_jll"]
git-tree-sha1 = "ef28127915f4229c971eb43f3fc075dd3fe91880"
uuid = "276daf66-3868-5448-9aa4-cd146d93841b"
version = "2.2.0"
weakdeps = ["ChainRulesCore"]

    [deps.SpecialFunctions.extensions]
    SpecialFunctionsChainRulesCoreExt = "ChainRulesCore"

[[deps.StaticArraysCore]]
git-tree-sha1 = "6b7ba252635a5eff6a0b0664a41ee140a1c9e72a"
uuid = "1e83bf80-4336-4d27-bf5d-d5a4f845583c"
version = "1.4.0"

[[deps.Statistics]]
deps = ["LinearAlgebra", "SparseArrays"]
uuid = "10745b16-79ce-11e8-11f9-7d13ad32a3b2"
version = "1.9.0"

[[deps.StatsAPI]]
deps = ["LinearAlgebra"]
git-tree-sha1 = "45a7769a04a3cf80da1c1c7c60caf932e6f4c9f7"
uuid = "82ae8749-77ed-4fe6-ae5f-f523153014b0"
version = "1.6.0"

[[deps.StatsBase]]
deps = ["DataAPI", "DataStructures", "LinearAlgebra", "LogExpFunctions", "Missings", "Printf", "Random", "SortingAlgorithms", "SparseArrays", "Statistics", "StatsAPI"]
git-tree-sha1 = "d1bf48bfcc554a3761a133fe3a9bb01488e06916"
uuid = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91"
version = "0.33.21"

[[deps.StatsFuns]]
deps = ["HypergeometricFunctions", "IrrationalConstants", "LogExpFunctions", "Reexport", "Rmath", "SpecialFunctions"]
git-tree-sha1 = "f625d686d5a88bcd2b15cd81f18f98186fdc0c9a"
uuid = "4c63d2b9-4356-54db-8cca-17b64c39e42c"
version = "1.3.0"

    [deps.StatsFuns.extensions]
    StatsFunsChainRulesCoreExt = "ChainRulesCore"
    StatsFunsInverseFunctionsExt = "InverseFunctions"

    [deps.StatsFuns.weakdeps]
    ChainRulesCore = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4"
    InverseFunctions = "3587e190-3f89-42d0-90ee-14403ec27112"

[[deps.SuiteSparse]]
deps = ["Libdl", "LinearAlgebra", "Serialization", "SparseArrays"]
uuid = "4607b0f0-06f3-5cda-b6b1-a6196a1729e9"

[[deps.SuiteSparse_jll]]
deps = ["Artifacts", "Libdl", "Pkg", "libblastrampoline_jll"]
uuid = "bea87d4a-7f5b-5778-9afe-8cc45184846c"
version = "5.10.1+6"

[[deps.TOML]]
deps = ["Dates"]
uuid = "fa267f1f-6049-4f14-aa54-33bafae1ed76"
version = "1.0.3"

[[deps.TableTraits]]
deps = ["IteratorInterfaceExtensions"]
git-tree-sha1 = "c06b2f539df1c6efa794486abfb6ed2022561a39"
uuid = "3783bdb8-4a98-5b6b-af9a-565f29a5fe9c"
version = "1.0.1"

[[deps.Tables]]
deps = ["DataAPI", "DataValueInterfaces", "IteratorInterfaceExtensions", "LinearAlgebra", "OrderedCollections", "TableTraits", "Test"]
git-tree-sha1 = "1544b926975372da01227b382066ab70e574a3ec"
uuid = "bd369af6-aec1-5ad0-b16a-f7cc5008161c"
version = "1.10.1"

[[deps.Tar]]
deps = ["ArgTools", "SHA"]
uuid = "a4e569a6-e804-4fa4-b0f3-eef7a1d5b13e"
version = "1.10.0"

[[deps.Test]]
deps = ["InteractiveUtils", "Logging", "Random", "Serialization"]
uuid = "8dfed614-e22c-5e08-85e1-65c5234f0b40"

[[deps.UUIDs]]
deps = ["Random", "SHA"]
uuid = "cf7118a7-6976-5b1a-9a39-7adc72f591a4"

[[deps.Unicode]]
uuid = "4ec0a83e-493e-50e2-b9ac-8f72acf5a8f5"

[[deps.XLSX]]
deps = ["Artifacts", "Dates", "EzXML", "Printf", "Tables", "ZipFile"]
git-tree-sha1 = "d6af50e2e15d32aff416b7e219885976dc3d870f"
uuid = "fdbf4ff8-1666-58a4-91e7-1b58723a45e0"
version = "0.9.0"

[[deps.XML2_jll]]
deps = ["Artifacts", "JLLWrappers", "Libdl", "Libiconv_jll", "Pkg", "Zlib_jll"]
git-tree-sha1 = "93c41695bc1c08c46c5899f4fe06d6ead504bb73"
uuid = "02c8fc9c-b97f-50b9-bbe4-9be30ff0a78a"
version = "2.10.3+0"

[[deps.ZipFile]]
deps = ["Libdl", "Printf", "Zlib_jll"]
git-tree-sha1 = "f492b7fe1698e623024e873244f10d89c95c340a"
uuid = "a5390f91-8eb1-5f08-bee0-b1d1ffed6cea"
version = "0.10.1"

[[deps.Zlib_jll]]
deps = ["Libdl"]
uuid = "83775a58-1f1d-513f-b197-d71354ab007a"
version = "1.2.13+0"

[[deps.libblastrampoline_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "8e850b90-86db-534c-a0d3-1478176c7d93"
version = "5.7.0+0"

[[deps.nghttp2_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "8e850ede-7688-5339-a07c-302acd2aaf8d"
version = "1.48.0+0"

[[deps.p7zip_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "3f19e933-33d8-53b3-aaab-bd5110c3b7a0"
version = "17.4.0+0"
"""

# ╔═╡ Cell order:
# ╠═11ac5f6a-0f6a-11ee-2598-11c7a0064b43
# ╟─8dd5d4b9-5a32-4a95-8f38-7f3e5b98e2d9
# ╠═5e94a517-db46-4864-b717-5b4543884dff
# ╠═a5e61a48-e07e-49dc-8c61-1224d1c47d13
# ╟─a25eecd6-f58d-493d-a5cf-94218319849d
# ╠═9c3b8eb2-a160-4246-a5c7-596a86c73d62
# ╟─3eb9d39c-2ca1-430e-b13b-05c809a80d5b
# ╠═e3febec7-b84c-45f9-8f65-5a158b0ae933
# ╟─f2825d3c-577b-4b61-8c8c-c869a9ec9f07
# ╠═72cf8d55-a423-4c28-a370-377f9ef6a70e
# ╟─b8adc566-5893-402a-a35d-11c06460fb62
# ╠═3df39484-e07a-48d8-90ae-09da0050b3ce
# ╟─b314add7-a6f5-42f0-bc9a-bba748543fa2
# ╠═7e383967-26de-49bd-a106-d215241ffdb1
# ╟─c09b771c-aab1-40cf-a273-14aa6c857510
# ╠═46c9be07-3bb4-499c-a819-7a87c73b6e42
# ╟─128668c3-282d-4453-84a6-cf2c29d7140f
# ╠═548ca244-de4c-47c2-a69e-0ca7a449028f
# ╟─884a7299-8418-45e4-82f3-65204d48e55b
# ╠═9342e489-a297-4c67-8324-cb41801af713
# ╠═31dc58db-5a4e-47dc-bdb8-fe6e9bb47204
# ╟─6d768ec2-f9ad-4cc7-a2df-4eeb1a72cd44
# ╟─00000000-0000-0000-0000-000000000001
# ╟─00000000-0000-0000-0000-000000000002
"; +window.pluto_notebookfile = "data:text/julia;charset=utf-8;base64,### A Pluto.jl notebook ###
# v0.19.26

using Markdown
using InteractiveUtils

# ╔═╡ 11ac5f6a-0f6a-11ee-2598-11c7a0064b43
using StatsBase, HypothesisTests, XLSX, SparseArrays, MultipleTesting

# ╔═╡ 01fbf1c9-1cea-4593-a2c5-03854dee2473
md"""
This document is a Pluto notebook (or an html rendered version of it) and requires [Julia](https://computationalthinking.mit.edu/Spring21/installation/).
"""

# ╔═╡ 8dd5d4b9-5a32-4a95-8f38-7f3e5b98e2d9
md"""
We first load the count data.

Note the notebook is assumed to run from a child directory (*e.g.* `notebooks`) of the project root, and the data files are expected to be found in `data/raw`, again from the project root.
"""

# ╔═╡ 5e94a517-db46-4864-b717-5b4543884dff
data = XLSX.openxlsx("../data/raw/genes_specifiques.xlsx")

# ╔═╡ a5e61a48-e07e-49dc-8c61-1224d1c47d13
counts = Int.(data["nb gènes spé"]["B3:U25"])

# ╔═╡ a25eecd6-f58d-493d-a5cf-94218319849d
md"""
For further reference, we also load the labels of the rows (`categories`) and columns (`genotypes`).
"""

# ╔═╡ 9c3b8eb2-a160-4246-a5c7-596a86c73d62
begin
	genotypes = vec(data["nb gènes spé"]["B2:U2"]) # columns
	categories = vec(data["nb gènes spé"]["A3:A25"]) # rows
end

# ╔═╡ 3eb9d39c-2ca1-430e-b13b-05c809a80d5b
md"""
First, we exclude the rows and columns of zeros only.
"""

# ╔═╡ e3febec7-b84c-45f9-8f65-5a158b0ae933
begin
	row_ok = vec(any(!=(0), counts; dims=2))
	col_ok = vec(any(!=(0), counts; dims=1))
	clean_counts = counts[row_ok, col_ok]
	nrows, ncols = size(clean_counts)
end

# ╔═╡ f2825d3c-577b-4b61-8c8c-c869a9ec9f07
md"""
To test whether a genotype exhibits a different partition into categories of genes, or equivalently whether it is enriched in some category, we first derive an expected partition averaging the category frequencies across all genotypes.
"""

# ╔═╡ 72cf8d55-a423-4c28-a370-377f9ef6a70e
begin
	col_total = sum(clean_counts; dims=1)
	expected_frequencies = mean(clean_counts ./ col_total; dims=2)
	@assert sum(expected_frequencies) ≈ 1
	# print the frequencies with the corresponding category names
	Dict(zip(categories[row_ok], expected_frequencies))
end

# ╔═╡ b8adc566-5893-402a-a35d-11c06460fb62
md"""
Due to the presence of zeros in most columns, we have to group the low-frequency cells into single cells on a per-column basis. The information in low-frequency cells is already accounted for by the other cells.

We can also individually test each count `observed_n` _equal to or greater than 5_ in a contingency table with:
```
+------------+------------------------+
| observed_n | col_total - observed_n |
+------------+------------------------+
| expected_n | col_total - expected_n |
+------------+------------------------+
```
This second approach is less powerful, though.

Let us begin with this second approach:
"""

# ╔═╡ 3df39484-e07a-48d8-90ae-09da0050b3ce
begin
	observed_counts = clean_counts
	# in theory, we could also use real-valued counts instead
	expected_counts = @. round(Int, expected_frequencies * col_total)
	observed_remainder = col_total .- observed_counts
	expected_remainder = col_total .- expected_counts

	pvalues = spzeros(nrows, ncols)
	for row in 1:nrows
		for col in 1:ncols
			
			# build the contingency table
			a = observed_counts[row, col]
			b = observed_remainder[row, col]
			c = expected_counts[row, col]
			d = expected_remainder[row, col]
			contingency_table = [ a b ; c d ]
			
			# perform a χ² test of homogeneity
			if all(>=(5), contingency_table)
				pval = pvalue(ChisqTest(contingency_table))
				# note: FisherExactTest(a, b, c, d) gives very similar results
				#pval = pvalue(FisherExactTest(a, b, c, d); method=:minlike)
				
				pvalues[row, col] = pval
			end
		end
	end
	pvalues
end

# ╔═╡ b314add7-a6f5-42f0-bc9a-bba748543fa2
md"""
Out of curiosity, with no correction for multiple comparisons, we find a few p-values below 0.05:
"""

# ╔═╡ 7e383967-26de-49bd-a106-d215241ffdb1
begin
	uncorrected_pvalues_below_threshold = copy(pvalues)
	uncorrected_pvalues_below_threshold.nzval[.05 .< pvalues.nzval] .= 0
	dropzeros(uncorrected_pvalues_below_threshold)
end

# ╔═╡ c09b771c-aab1-40cf-a273-14aa6c857510
md"""
Correcting for all the comparisons, no differences survive:
"""

# ╔═╡ 46c9be07-3bb4-499c-a819-7a87c73b6e42
begin
	# see https://github.com/juliangehring/MultipleTesting.jl#two-step
	corrected_pvalues = adjust(pvalues.nzval, BenjaminiHochbergAdaptive(TwoStep()))
	
	significant = corrected_pvalues .<= .05
	significant_pvalues = copy(pvalues)
	significant_pvalues.nzval .= 0
	significant_pvalues.nzval[significant] = corrected_pvalues[significant]
	significant_pvalues = dropzeros(significant_pvalues)
end

# ╔═╡ 128668c3-282d-4453-84a6-cf2c29d7140f
md"""
Had we found differences, we could get the corresponding category-genotype pairs as follows:
"""

# ╔═╡ 548ca244-de4c-47c2-a69e-0ca7a449028f
begin
	row, col = findnz(significant_pvalues)
	category = categories[row_ok][row]
	genotype = genotypes[col_ok][col]
	collect(zip(category, genotype))
end

# ╔═╡ 884a7299-8418-45e4-82f3-65204d48e55b
md"""
The sample size is too low if we consider the large number of cells, and we need a more powerful test.
Let us now compare each genotype with the "average" genotype, grouping the low-frequency cells together.

We already know the post-hoc tests fail, therefore we won't have category-level resolution. However, a significant difference is still possible here as the test will cumulate the differences for the different categories. The individual differences should be detectable increasing the sample size.

# Disclaimer

The following analysis is a second iteration motivated by an error in the first iteration. The history of the present notebook can be found [here](https://gitlab.pasteur.fr/flaurent/project19449/-/blob/main/notebooks/genes_chisq_tests.jl).

The categories were grouped based on the observed counts, whereas the minimum-5 criterion actually applies to the expected counts. This is fixed in this version of the analysis.

In addition, from the first iteration of the analysis, we know that controlling the family-wise error rate would not allow to reject any null hypothesis. We therefore consider controlling the false discovery rate instead, as described in [Benjamini *et al.*, 2006](https://doi.org/10.1093/biomet/93.3.491).

# Grouping procedure

An elaborate grouping approach can be found in [Kass, 1980](https://www4.stat.ncsu.edu/~dickey/analytics/datamine/Reference%20Papers/kass80.pdf).

The simpler approach followed here consists in grouping all the categories with an expected count below 5 into a single synthetic category, for each column separately. Observed counts are similarly grouped, based on the expected counts.
"""

# ╔═╡ 9342e489-a297-4c67-8324-cb41801af713
begin
	per_genotype_pvalues = Dict{String, Float64}()
	for col in 1:ncols
		# identify cells to be grouped
		ok = expected_counts[:, col] .>= 5
		any(ok) || continue
		# group cells
		expected_counts′ = expected_counts[ok, col]
		if !all(ok)
			synthetic_count = sum(expected_counts[(!).(ok), col])
			push!(expected_counts′, synthetic_count)
		end
		observed_counts′ = observed_counts[ok, col]
		if !all(ok)
			synthetic_count = sum(observed_counts[(!).(ok), col])
			push!(observed_counts′, synthetic_count)
		end
		# perform the test
		contingency_table = hcat(observed_counts′, expected_counts′)
		pval = pvalue(ChisqTest(contingency_table))
		# record the resulting pvalue
		genotype = genotypes[col_ok][col]
		per_genotype_pvalues[genotype] = pval
	end
	per_genotype_pvalues
end

# ╔═╡ 31dc58db-5a4e-47dc-bdb8-fe6e9bb47204
begin
	corrected_per_genotype_pvalues = adjust(
		collect(values(per_genotype_pvalues)),
		BenjaminiHochbergAdaptive(TwoStep()),
	)
	corrected_per_genotype_pvalues = Dict(zip(
		keys(per_genotype_pvalues),
		corrected_per_genotype_pvalues,
	))
end

# ╔═╡ 6d768ec2-f9ad-4cc7-a2df-4eeb1a72cd44
md"""
Genotypes G10 and G14 significantly differ from the average genotype.
"""

# ╔═╡ 00000000-0000-0000-0000-000000000001
PLUTO_PROJECT_TOML_CONTENTS = """
[deps]
HypothesisTests = "09f84164-cd44-5f33-b23f-e6b0d136a0d5"
MultipleTesting = "f8716d33-7c4a-5097-896f-ce0ecbd3ef6b"
SparseArrays = "2f01184e-e22b-5df5-ae63-d93ebab69eaf"
StatsBase = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91"
XLSX = "fdbf4ff8-1666-58a4-91e7-1b58723a45e0"

[compat]
HypothesisTests = "~0.11.0"
MultipleTesting = "~0.5.1"
StatsBase = "~0.33.21"
XLSX = "~0.9.0"
"""

# ╔═╡ 00000000-0000-0000-0000-000000000002
PLUTO_MANIFEST_TOML_CONTENTS = """
# This file is machine-generated - editing it directly is not advised

julia_version = "1.9.0"
manifest_format = "2.0"
project_hash = "d9da7e97863fee97b88704272749d1c852674499"

[[deps.ArgTools]]
uuid = "0dad84c5-d112-42e6-8d28-ef12dabb789f"
version = "1.1.1"

[[deps.Artifacts]]
uuid = "56f22d72-fd6d-98f1-02f0-08ddc0907c33"

[[deps.Base64]]
uuid = "2a0f44e3-6c83-55bd-87e4-b1978d98bd5f"

[[deps.Calculus]]
deps = ["LinearAlgebra"]
git-tree-sha1 = "f641eb0a4f00c343bbc32346e1217b86f3ce9dad"
uuid = "49dc2e85-a5d0-5ad3-a950-438e2897f1b9"
version = "0.5.1"

[[deps.ChainRulesCore]]
deps = ["Compat", "LinearAlgebra", "SparseArrays"]
git-tree-sha1 = "e30f2f4e20f7f186dc36529910beaedc60cfa644"
uuid = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4"
version = "1.16.0"

[[deps.Combinatorics]]
git-tree-sha1 = "08c8b6831dc00bfea825826be0bc8336fc369860"
uuid = "861a8166-3701-5b0c-9a16-15d98fcdc6aa"
version = "1.0.2"

[[deps.CommonSolve]]
git-tree-sha1 = "0eee5eb66b1cf62cd6ad1b460238e60e4b09400c"
uuid = "38540f10-b2f7-11e9-35d8-d573e4eb0ff2"
version = "0.2.4"

[[deps.Compat]]
deps = ["UUIDs"]
git-tree-sha1 = "7a60c856b9fa189eb34f5f8a6f6b5529b7942957"
uuid = "34da2185-b29b-5c13-b0c7-acf172513d20"
version = "4.6.1"
weakdeps = ["Dates", "LinearAlgebra"]

    [deps.Compat.extensions]
    CompatLinearAlgebraExt = "LinearAlgebra"

[[deps.CompilerSupportLibraries_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "e66e0078-7015-5450-92f7-15fbd957f2ae"
version = "1.0.2+0"

[[deps.ConstructionBase]]
deps = ["LinearAlgebra"]
git-tree-sha1 = "738fec4d684a9a6ee9598a8bfee305b26831f28c"
uuid = "187b0558-2788-49d3-abe0-74a17ed4e7c9"
version = "1.5.2"

    [deps.ConstructionBase.extensions]
    ConstructionBaseIntervalSetsExt = "IntervalSets"
    ConstructionBaseStaticArraysExt = "StaticArrays"

    [deps.ConstructionBase.weakdeps]
    IntervalSets = "8197267c-284f-5f27-9208-e0e47529a953"
    StaticArrays = "90137ffa-7385-5640-81b9-e52037218182"

[[deps.DataAPI]]
git-tree-sha1 = "8da84edb865b0b5b0100c0666a9bc9a0b71c553c"
uuid = "9a962f9c-6df0-11e9-0e5d-c546b8b5ee8a"
version = "1.15.0"

[[deps.DataStructures]]
deps = ["Compat", "InteractiveUtils", "OrderedCollections"]
git-tree-sha1 = "d1fff3a548102f48987a52a2e0d114fa97d730f0"
uuid = "864edb3b-99cc-5e75-8d2d-829cb0a9cfe8"
version = "0.18.13"

[[deps.DataValueInterfaces]]
git-tree-sha1 = "bfc1187b79289637fa0ef6d4436ebdfe6905cbd6"
uuid = "e2d170a0-9d28-54be-80f0-106bbe20a464"
version = "1.0.0"

[[deps.Dates]]
deps = ["Printf"]
uuid = "ade2ca70-3891-5945-98fb-dc099432e06a"

[[deps.Distributions]]
deps = ["FillArrays", "LinearAlgebra", "PDMats", "Printf", "QuadGK", "Random", "SparseArrays", "SpecialFunctions", "Statistics", "StatsAPI", "StatsBase", "StatsFuns", "Test"]
git-tree-sha1 = "4ed4a6df2548a72f66e03f3a285cd1f3b573035d"
uuid = "31c24e10-a181-5473-b8eb-7969acd0382f"
version = "0.25.96"

    [deps.Distributions.extensions]
    DistributionsChainRulesCoreExt = "ChainRulesCore"
    DistributionsDensityInterfaceExt = "DensityInterface"

    [deps.Distributions.weakdeps]
    ChainRulesCore = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4"
    DensityInterface = "b429d917-457f-4dbc-8f4c-0cc954292b1d"

[[deps.DocStringExtensions]]
deps = ["LibGit2"]
git-tree-sha1 = "2fb1e02f2b635d0845df5d7c167fec4dd739b00d"
uuid = "ffbed154-4ef7-542d-bbb7-c09d3a79fcae"
version = "0.9.3"

[[deps.Downloads]]
deps = ["ArgTools", "FileWatching", "LibCURL", "NetworkOptions"]
uuid = "f43a241f-c20a-4ad4-852c-f6b1247861c6"
version = "1.6.0"

[[deps.DualNumbers]]
deps = ["Calculus", "NaNMath", "SpecialFunctions"]
git-tree-sha1 = "5837a837389fccf076445fce071c8ddaea35a566"
uuid = "fa6b7ba4-c1ee-5f82-b5fc-ecf0adba8f74"
version = "0.6.8"

[[deps.EzXML]]
deps = ["Printf", "XML2_jll"]
git-tree-sha1 = "0fa3b52a04a4e210aeb1626def9c90df3ae65268"
uuid = "8f5d6c58-4d21-5cfd-889c-e3ad7ee6a615"
version = "1.1.0"

[[deps.FileWatching]]
uuid = "7b1f6079-737a-58dc-b8bc-7a2ca5c1b5ee"

[[deps.FillArrays]]
deps = ["LinearAlgebra", "Random", "SparseArrays", "Statistics"]
git-tree-sha1 = "e17cc4dc2d0b0b568e80d937de8ed8341822de67"
uuid = "1a297f60-69ca-5386-bcde-b61e274b549b"
version = "1.2.0"

[[deps.Future]]
deps = ["Random"]
uuid = "9fa8497b-333b-5362-9e8d-4d0656e87820"

[[deps.HypergeometricFunctions]]
deps = ["DualNumbers", "LinearAlgebra", "OpenLibm_jll", "SpecialFunctions"]
git-tree-sha1 = "0ec02c648befc2f94156eaef13b0f38106212f3f"
uuid = "34004b35-14d8-5ef3-9330-4cdb6864b03a"
version = "0.3.17"

[[deps.HypothesisTests]]
deps = ["Combinatorics", "Distributions", "LinearAlgebra", "Printf", "Random", "Rmath", "Roots", "Statistics", "StatsAPI", "StatsBase"]
git-tree-sha1 = "4b5d5ba51f5f473737ed9de6d8a7aa190ad8c72f"
uuid = "09f84164-cd44-5f33-b23f-e6b0d136a0d5"
version = "0.11.0"

[[deps.InteractiveUtils]]
deps = ["Markdown"]
uuid = "b77e0a4c-d291-57a0-90e8-8db25a27a240"

[[deps.IrrationalConstants]]
git-tree-sha1 = "630b497eafcc20001bba38a4651b327dcfc491d2"
uuid = "92d709cd-6900-40b7-9082-c6be49f344b6"
version = "0.2.2"

[[deps.IteratorInterfaceExtensions]]
git-tree-sha1 = "a3f24677c21f5bbe9d2a714f95dcd58337fb2856"
uuid = "82899510-4779-5014-852e-03e436cf321d"
version = "1.0.0"

[[deps.JLLWrappers]]
deps = ["Preferences"]
git-tree-sha1 = "abc9885a7ca2052a736a600f7fa66209f96506e1"
uuid = "692b3bcd-3c85-4b1f-b108-f13ce0eb3210"
version = "1.4.1"

[[deps.LibCURL]]
deps = ["LibCURL_jll", "MozillaCACerts_jll"]
uuid = "b27032c2-a3e7-50c8-80cd-2d36dbcbfd21"
version = "0.6.3"

[[deps.LibCURL_jll]]
deps = ["Artifacts", "LibSSH2_jll", "Libdl", "MbedTLS_jll", "Zlib_jll", "nghttp2_jll"]
uuid = "deac9b47-8bc7-5906-a0fe-35ac56dc84c0"
version = "7.84.0+0"

[[deps.LibGit2]]
deps = ["Base64", "NetworkOptions", "Printf", "SHA"]
uuid = "76f85450-5226-5b5a-8eaa-529ad045b433"

[[deps.LibSSH2_jll]]
deps = ["Artifacts", "Libdl", "MbedTLS_jll"]
uuid = "29816b5a-b9ab-546f-933c-edad1886dfa8"
version = "1.10.2+0"

[[deps.Libdl]]
uuid = "8f399da3-3557-5675-b5ff-fb832c97cbdb"

[[deps.Libiconv_jll]]
deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"]
git-tree-sha1 = "c7cb1f5d892775ba13767a87c7ada0b980ea0a71"
uuid = "94ce4f54-9a6c-5748-9c1c-f9c7231a4531"
version = "1.16.1+2"

[[deps.LinearAlgebra]]
deps = ["Libdl", "OpenBLAS_jll", "libblastrampoline_jll"]
uuid = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e"

[[deps.LogExpFunctions]]
deps = ["DocStringExtensions", "IrrationalConstants", "LinearAlgebra"]
git-tree-sha1 = "c3ce8e7420b3a6e071e0fe4745f5d4300e37b13f"
uuid = "2ab3a3ac-af41-5b50-aa03-7779005ae688"
version = "0.3.24"

    [deps.LogExpFunctions.extensions]
    LogExpFunctionsChainRulesCoreExt = "ChainRulesCore"
    LogExpFunctionsChangesOfVariablesExt = "ChangesOfVariables"
    LogExpFunctionsInverseFunctionsExt = "InverseFunctions"

    [deps.LogExpFunctions.weakdeps]
    ChainRulesCore = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4"
    ChangesOfVariables = "9e997f8a-9a97-42d5-a9f1-ce6bfc15e2c0"
    InverseFunctions = "3587e190-3f89-42d0-90ee-14403ec27112"

[[deps.Logging]]
uuid = "56ddb016-857b-54e1-b83d-db4d58db5568"

[[deps.MacroTools]]
deps = ["Markdown", "Random"]
git-tree-sha1 = "42324d08725e200c23d4dfb549e0d5d89dede2d2"
uuid = "1914dd2f-81c6-5fcd-8719-6d5c9610ff09"
version = "0.5.10"

[[deps.Markdown]]
deps = ["Base64"]
uuid = "d6f4376e-aef5-505a-96c1-9c027394607a"

[[deps.MbedTLS_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "c8ffd9c3-330d-5841-b78e-0817d7145fa1"
version = "2.28.2+0"

[[deps.Missings]]
deps = ["DataAPI"]
git-tree-sha1 = "f66bdc5de519e8f8ae43bdc598782d35a25b1272"
uuid = "e1d29d7a-bbdc-5cf2-9ac0-f12de2c33e28"
version = "1.1.0"

[[deps.MozillaCACerts_jll]]
uuid = "14a3606d-f60d-562e-9121-12d972cd8159"
version = "2022.10.11"

[[deps.MultipleTesting]]
deps = ["Distributions", "SpecialFunctions", "StatsBase"]
git-tree-sha1 = "94df14d821baa34662a1492b10615125cbebd47b"
uuid = "f8716d33-7c4a-5097-896f-ce0ecbd3ef6b"
version = "0.5.1"

[[deps.NaNMath]]
deps = ["OpenLibm_jll"]
git-tree-sha1 = "0877504529a3e5c3343c6f8b4c0381e57e4387e4"
uuid = "77ba4419-2d1f-58cd-9bb1-8ffee604a2e3"
version = "1.0.2"

[[deps.NetworkOptions]]
uuid = "ca575930-c2e3-43a9-ace4-1e988b2c1908"
version = "1.2.0"

[[deps.OpenBLAS_jll]]
deps = ["Artifacts", "CompilerSupportLibraries_jll", "Libdl"]
uuid = "4536629a-c528-5b80-bd46-f80d51c5b363"
version = "0.3.21+4"

[[deps.OpenLibm_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "05823500-19ac-5b8b-9628-191a04bc5112"
version = "0.8.1+0"

[[deps.OpenSpecFun_jll]]
deps = ["Artifacts", "CompilerSupportLibraries_jll", "JLLWrappers", "Libdl", "Pkg"]
git-tree-sha1 = "13652491f6856acfd2db29360e1bbcd4565d04f1"
uuid = "efe28fd5-8261-553b-a9e1-b2916fc3738e"
version = "0.5.5+0"

[[deps.OrderedCollections]]
git-tree-sha1 = "d321bf2de576bf25ec4d3e4360faca399afca282"
uuid = "bac558e1-5e72-5ebc-8fee-abe8a469f55d"
version = "1.6.0"

[[deps.PDMats]]
deps = ["LinearAlgebra", "SparseArrays", "SuiteSparse"]
git-tree-sha1 = "67eae2738d63117a196f497d7db789821bce61d1"
uuid = "90014a1f-27ba-587c-ab20-58faa44d9150"
version = "0.11.17"

[[deps.Pkg]]
deps = ["Artifacts", "Dates", "Downloads", "FileWatching", "LibGit2", "Libdl", "Logging", "Markdown", "Printf", "REPL", "Random", "SHA", "Serialization", "TOML", "Tar", "UUIDs", "p7zip_jll"]
uuid = "44cfe95a-1eb2-52ea-b672-e2afdf69b78f"
version = "1.9.0"

[[deps.Preferences]]
deps = ["TOML"]
git-tree-sha1 = "7eb1686b4f04b82f96ed7a4ea5890a4f0c7a09f1"
uuid = "21216c6a-2e73-6563-6e65-726566657250"
version = "1.4.0"

[[deps.Printf]]
deps = ["Unicode"]
uuid = "de0858da-6303-5e67-8744-51eddeeeb8d7"

[[deps.QuadGK]]
deps = ["DataStructures", "LinearAlgebra"]
git-tree-sha1 = "6ec7ac8412e83d57e313393220879ede1740f9ee"
uuid = "1fd47b50-473d-5c70-9696-f719f8f3bcdc"
version = "2.8.2"

[[deps.REPL]]
deps = ["InteractiveUtils", "Markdown", "Sockets", "Unicode"]
uuid = "3fa0cd96-eef1-5676-8a61-b3b8758bbffb"

[[deps.Random]]
deps = ["SHA", "Serialization"]
uuid = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c"

[[deps.Reexport]]
git-tree-sha1 = "45e428421666073eab6f2da5c9d310d99bb12f9b"
uuid = "189a3867-3050-52da-a836-e630ba90ab69"
version = "1.2.2"

[[deps.Rmath]]
deps = ["Random", "Rmath_jll"]
git-tree-sha1 = "f65dcb5fa46aee0cf9ed6274ccbd597adc49aa7b"
uuid = "79098fc4-a85e-5d69-aa6a-4863f24498fa"
version = "0.7.1"

[[deps.Rmath_jll]]
deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"]
git-tree-sha1 = "6ed52fdd3382cf21947b15e8870ac0ddbff736da"
uuid = "f50d1b31-88e8-58de-be2c-1cc44531875f"
version = "0.4.0+0"

[[deps.Roots]]
deps = ["ChainRulesCore", "CommonSolve", "Printf", "Setfield"]
git-tree-sha1 = "de432823e8aab4dd1a985be4be768f95acf152d4"
uuid = "f2b01f46-fcfa-551c-844a-d8ac1e96c665"
version = "2.0.17"

    [deps.Roots.extensions]
    RootsForwardDiffExt = "ForwardDiff"
    RootsIntervalRootFindingExt = "IntervalRootFinding"
    RootsSymPyExt = "SymPy"

    [deps.Roots.weakdeps]
    ForwardDiff = "f6369f11-7733-5829-9624-2563aa707210"
    IntervalRootFinding = "d2bf35a9-74e0-55ec-b149-d360ff49b807"
    SymPy = "24249f21-da20-56a4-8eb1-6a02cf4ae2e6"

[[deps.SHA]]
uuid = "ea8e919c-243c-51af-8825-aaa63cd721ce"
version = "0.7.0"

[[deps.Serialization]]
uuid = "9e88b42a-f829-5b0c-bbe9-9e923198166b"

[[deps.Setfield]]
deps = ["ConstructionBase", "Future", "MacroTools", "StaticArraysCore"]
git-tree-sha1 = "e2cc6d8c88613c05e1defb55170bf5ff211fbeac"
uuid = "efcf1570-3423-57d1-acb7-fd33fddbac46"
version = "1.1.1"

[[deps.Sockets]]
uuid = "6462fe0b-24de-5631-8697-dd941f90decc"

[[deps.SortingAlgorithms]]
deps = ["DataStructures"]
git-tree-sha1 = "c60ec5c62180f27efea3ba2908480f8055e17cee"
uuid = "a2af1166-a08f-5f64-846c-94a0d3cef48c"
version = "1.1.1"

[[deps.SparseArrays]]
deps = ["Libdl", "LinearAlgebra", "Random", "Serialization", "SuiteSparse_jll"]
uuid = "2f01184e-e22b-5df5-ae63-d93ebab69eaf"

[[deps.SpecialFunctions]]
deps = ["IrrationalConstants", "LogExpFunctions", "OpenLibm_jll", "OpenSpecFun_jll"]
git-tree-sha1 = "ef28127915f4229c971eb43f3fc075dd3fe91880"
uuid = "276daf66-3868-5448-9aa4-cd146d93841b"
version = "2.2.0"
weakdeps = ["ChainRulesCore"]

    [deps.SpecialFunctions.extensions]
    SpecialFunctionsChainRulesCoreExt = "ChainRulesCore"

[[deps.StaticArraysCore]]
git-tree-sha1 = "6b7ba252635a5eff6a0b0664a41ee140a1c9e72a"
uuid = "1e83bf80-4336-4d27-bf5d-d5a4f845583c"
version = "1.4.0"

[[deps.Statistics]]
deps = ["LinearAlgebra", "SparseArrays"]
uuid = "10745b16-79ce-11e8-11f9-7d13ad32a3b2"
version = "1.9.0"

[[deps.StatsAPI]]
deps = ["LinearAlgebra"]
git-tree-sha1 = "45a7769a04a3cf80da1c1c7c60caf932e6f4c9f7"
uuid = "82ae8749-77ed-4fe6-ae5f-f523153014b0"
version = "1.6.0"

[[deps.StatsBase]]
deps = ["DataAPI", "DataStructures", "LinearAlgebra", "LogExpFunctions", "Missings", "Printf", "Random", "SortingAlgorithms", "SparseArrays", "Statistics", "StatsAPI"]
git-tree-sha1 = "d1bf48bfcc554a3761a133fe3a9bb01488e06916"
uuid = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91"
version = "0.33.21"

[[deps.StatsFuns]]
deps = ["HypergeometricFunctions", "IrrationalConstants", "LogExpFunctions", "Reexport", "Rmath", "SpecialFunctions"]
git-tree-sha1 = "f625d686d5a88bcd2b15cd81f18f98186fdc0c9a"
uuid = "4c63d2b9-4356-54db-8cca-17b64c39e42c"
version = "1.3.0"

    [deps.StatsFuns.extensions]
    StatsFunsChainRulesCoreExt = "ChainRulesCore"
    StatsFunsInverseFunctionsExt = "InverseFunctions"

    [deps.StatsFuns.weakdeps]
    ChainRulesCore = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4"
    InverseFunctions = "3587e190-3f89-42d0-90ee-14403ec27112"

[[deps.SuiteSparse]]
deps = ["Libdl", "LinearAlgebra", "Serialization", "SparseArrays"]
uuid = "4607b0f0-06f3-5cda-b6b1-a6196a1729e9"

[[deps.SuiteSparse_jll]]
deps = ["Artifacts", "Libdl", "Pkg", "libblastrampoline_jll"]
uuid = "bea87d4a-7f5b-5778-9afe-8cc45184846c"
version = "5.10.1+6"

[[deps.TOML]]
deps = ["Dates"]
uuid = "fa267f1f-6049-4f14-aa54-33bafae1ed76"
version = "1.0.3"

[[deps.TableTraits]]
deps = ["IteratorInterfaceExtensions"]
git-tree-sha1 = "c06b2f539df1c6efa794486abfb6ed2022561a39"
uuid = "3783bdb8-4a98-5b6b-af9a-565f29a5fe9c"
version = "1.0.1"

[[deps.Tables]]
deps = ["DataAPI", "DataValueInterfaces", "IteratorInterfaceExtensions", "LinearAlgebra", "OrderedCollections", "TableTraits", "Test"]
git-tree-sha1 = "1544b926975372da01227b382066ab70e574a3ec"
uuid = "bd369af6-aec1-5ad0-b16a-f7cc5008161c"
version = "1.10.1"

[[deps.Tar]]
deps = ["ArgTools", "SHA"]
uuid = "a4e569a6-e804-4fa4-b0f3-eef7a1d5b13e"
version = "1.10.0"

[[deps.Test]]
deps = ["InteractiveUtils", "Logging", "Random", "Serialization"]
uuid = "8dfed614-e22c-5e08-85e1-65c5234f0b40"

[[deps.UUIDs]]
deps = ["Random", "SHA"]
uuid = "cf7118a7-6976-5b1a-9a39-7adc72f591a4"

[[deps.Unicode]]
uuid = "4ec0a83e-493e-50e2-b9ac-8f72acf5a8f5"

[[deps.XLSX]]
deps = ["Artifacts", "Dates", "EzXML", "Printf", "Tables", "ZipFile"]
git-tree-sha1 = "d6af50e2e15d32aff416b7e219885976dc3d870f"
uuid = "fdbf4ff8-1666-58a4-91e7-1b58723a45e0"
version = "0.9.0"

[[deps.XML2_jll]]
deps = ["Artifacts", "JLLWrappers", "Libdl", "Libiconv_jll", "Pkg", "Zlib_jll"]
git-tree-sha1 = "93c41695bc1c08c46c5899f4fe06d6ead504bb73"
uuid = "02c8fc9c-b97f-50b9-bbe4-9be30ff0a78a"
version = "2.10.3+0"

[[deps.ZipFile]]
deps = ["Libdl", "Printf", "Zlib_jll"]
git-tree-sha1 = "f492b7fe1698e623024e873244f10d89c95c340a"
uuid = "a5390f91-8eb1-5f08-bee0-b1d1ffed6cea"
version = "0.10.1"

[[deps.Zlib_jll]]
deps = ["Libdl"]
uuid = "83775a58-1f1d-513f-b197-d71354ab007a"
version = "1.2.13+0"

[[deps.libblastrampoline_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "8e850b90-86db-534c-a0d3-1478176c7d93"
version = "5.7.0+0"

[[deps.nghttp2_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "8e850ede-7688-5339-a07c-302acd2aaf8d"
version = "1.48.0+0"

[[deps.p7zip_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "3f19e933-33d8-53b3-aaab-bd5110c3b7a0"
version = "17.4.0+0"
"""

# ╔═╡ Cell order:
# ╟─01fbf1c9-1cea-4593-a2c5-03854dee2473
# ╠═11ac5f6a-0f6a-11ee-2598-11c7a0064b43
# ╟─8dd5d4b9-5a32-4a95-8f38-7f3e5b98e2d9
# ╠═5e94a517-db46-4864-b717-5b4543884dff
# ╠═a5e61a48-e07e-49dc-8c61-1224d1c47d13
# ╟─a25eecd6-f58d-493d-a5cf-94218319849d
# ╠═9c3b8eb2-a160-4246-a5c7-596a86c73d62
# ╟─3eb9d39c-2ca1-430e-b13b-05c809a80d5b
# ╠═e3febec7-b84c-45f9-8f65-5a158b0ae933
# ╟─f2825d3c-577b-4b61-8c8c-c869a9ec9f07
# ╠═72cf8d55-a423-4c28-a370-377f9ef6a70e
# ╟─b8adc566-5893-402a-a35d-11c06460fb62
# ╠═3df39484-e07a-48d8-90ae-09da0050b3ce
# ╟─b314add7-a6f5-42f0-bc9a-bba748543fa2
# ╠═7e383967-26de-49bd-a106-d215241ffdb1
# ╟─c09b771c-aab1-40cf-a273-14aa6c857510
# ╠═46c9be07-3bb4-499c-a819-7a87c73b6e42
# ╟─128668c3-282d-4453-84a6-cf2c29d7140f
# ╠═548ca244-de4c-47c2-a69e-0ca7a449028f
# ╟─884a7299-8418-45e4-82f3-65204d48e55b
# ╠═9342e489-a297-4c67-8324-cb41801af713
# ╠═31dc58db-5a4e-47dc-bdb8-fe6e9bb47204
# ╟─6d768ec2-f9ad-4cc7-a2df-4eeb1a72cd44
# ╟─00000000-0000-0000-0000-000000000001
# ╟─00000000-0000-0000-0000-000000000002
"; window.pluto_disable_ui = true; window.pluto_slider_server_url = undefined; window.pluto_binder_url = "https://mybinder.org/v2/gh/fonsp/pluto-on-binder/v0.19.26"; -window.pluto_statefile = "data:;base64,3gARpWJvbmRzgKxjZWxsX3Jlc3VsdHPeABbZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MoqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHmFpnByZWZpeKNBbnmoZWxlbWVudHPcABeSAZKjIkQiqnRleHQvcGxhaW6SApKjIk0iqnRleHQvcGxhaW6SA5KjIk4iqnRleHQvcGxhaW6SBJKjIk8iqnRleHQvcGxhaW6SBZKjIlQiqnRleHQvcGxhaW6SBpKjIlUiqnRleHQvcGxhaW6SB5KjIlYiqnRleHQvcGxhaW6SCJKjIlciqnRleHQvcGxhaW6SCZKjIkEiqnRleHQvcGxhaW6SCpKjIkIiqnRleHQvcGxhaW6SC5KjIkoiqnRleHQvcGxhaW6SDJKjIksiqnRleHQvcGxhaW6SDZKjIkwiqnRleHQvcGxhaW6SDpKjIkMiqnRleHQvcGxhaW6SD5KjIkUiqnRleHQvcGxhaW6SEJKjIkYiqnRleHQvcGxhaW6SEZKjIkciqnRleHQvcGxhaW6SEpKjIkgiqnRleHQvcGxhaW6SE5KjIkkiqnRleHQvcGxhaW6SFJKjIlAiqnRleHQvcGxhaW6SFZKjIlEiqnRleHQvcGxhaW6SFpKjIlMiqnRleHQvcGxhaW6SF5KoIkF1Y3VuZSKqdGV4dC9wbGFpbqR0eXBlpUFycmF5rHByZWZpeF9zaG9ydKCob2JqZWN0aWSwNTNjOGE0Nzc4ODZmODgwMKRtaW1l2SFhcHBsaWNhdGlvbi92bmQucGx1dG8udHJlZStvYmplY3Sscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkkfdWOH/OwcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MrlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgAEfna1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTOKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R5haZwcmVmaXjZK1NwYXJzZUFycmF5cy5TcGFyc2VWZWN0b3J7RmxvYXQ2NCwgSW50NjR9OiCoZWxlbWVudHPcABSSAZKnMC43MTI1Nqp0ZXh0L3BsYWlukgKSqTAuMDA0MDA2M6p0ZXh0L3BsYWlukgOSqDAuMzM4OTM5qnRleHQvcGxhaW6SBJKoMC44MjA0MzmqdGV4dC9wbGFpbpIFkqgwLjUxMzM0Nqp0ZXh0L3BsYWlukgaSqDAuNjE5MjQzqnRleHQvcGxhaW6SB5KpMC4wNjE3NTYyqnRleHQvcGxhaW6SCJKpMC4wNDM2NTc4qnRleHQvcGxhaW6SCZKnMC4yMDkzOKp0ZXh0L3BsYWlukgqSozAuMKp0ZXh0L3BsYWlukguSqDAuODg3OTMxqnRleHQvcGxhaW6SDJKqMC4wMDQ3ODk1N6p0ZXh0L3BsYWlukg2SozAuMKp0ZXh0L3BsYWlukg6SozAuMKp0ZXh0L3BsYWlukg+SqDAuNTU2OTgyqnRleHQvcGxhaW6SEJKoMC44Njk5NziqdGV4dC9wbGFpbpIRkqgwLjk1MzAwNqp0ZXh0L3BsYWlukhKSqDAuMTgxMDI3qnRleHQvcGxhaW6SE5KoMC44NDIxNTGqdGV4dC9wbGFpbpIUkqcwLjU5Nzg2qnRleHQvcGxhaW6kdHlwZaVBcnJheaxwcmVmaXhfc2hvcnTZK1NwYXJzZUFycmF5cy5TcGFyc2VWZWN0b3J7RmxvYXQ2NCwgSW50NjR9OiCob2JqZWN0aWSwOWMyNWY2NDljNzMzNDI4N6RtaW1l2SFhcHBsaWNhdGlvbi92bmQucGx1dG8udHJlZStvYmplY3Sscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkkfzP7Y9ywcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDkzNDJlNDg5LWEyOTctNGM2Ny04MzI0LWNiNDE4MDFhZjcxM7lkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgASzQG1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQ2ZDc2OGVjMi1mOWFkLTRjYzctYTJkZi00ZWViMWE3MmNkNDSKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R52gFePGRpdiBjbGFzcz0ibWFya2Rvd24iPjxwPldlIGZhaWwgYnkgYSBsaXR0bGUgbWFyZ2luLiBUb28gbWFueSBjb2x1bW5zIGhlcmUuPC9wPgo8cD5BY3R1YWxseSwgaWYgd2UgaGFkIGNob3NlbiB0byByZWplY3QgdGhlIGNvbHVtbnMgd2l0aCA8Y29kZT5hbnkmIzQwO2V4cGVjdGVkX2NvdW50c+KAsiAuJmx0OyA1JiM0MTs8L2NvZGU+LCB3ZSB3b3VsZCBoYXZlIGF0IGxlYXN0IG9uZSBzaWduaWZpY2FudGx5IGRpZmZlcmVudCBnZW5vdHlwZS4gVGhpcyBub3RlYm9vayBzaG93cyB0aGUgb3JpZ2luYWwgYXBwcm9hY2gsIHdpdGggbm8gaXRlcmF0aW9ucy48L3A+CjxwPk1vcmUgY2FuIGJlIGRvbmUuPC9wPgo8L2Rpdj6kbWltZal0ZXh0L2h0bWyscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkkfy7DeiWwcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDZkNzY4ZWMyLWY5YWQtNGNjNy1hMmRmLTRlZWIxYTcyY2Q0NLlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgADuPO1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQ3ZTM4Mzk2Ny0yNmRlLTQ5YmQtYTEwNi1kMjE1MjQxZmZkYjGKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R52fYyMMOXMjAgU3BhcnNlTWF0cml4Q1NDe0Zsb2F0NjQsIEludDY0fSB3aXRoIDMgc3RvcmVkIGVudHJpZXM6CuKOoeKggOKggOKggOKggOKggOKggOKggOKggOKggOKggOKOpArijqLioIDioIDioIDioIDioIDioIDioIDioIDioIDioIDijqUK4o6i4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4o6lCuKOouKggOKggOKggOKggOKggOKggOKggOKggOKggOKggOKOpQrijqPioIDioIDioIDioaDioIDiooDioIDioIDioIDioIDijqakbWltZap0ZXh0L3BsYWlurHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3VLTYRsHBlcnNpc3RfanNfc3RhdGXDt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQ3ZTM4Mzk2Ny0yNmRlLTQ5YmQtYTEwNi1kMjE1MjQxZmZkYjG5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc0i4rVwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJDNlYjlkMzljLTJjYTEtNDMwZS1iMTNiLTA1YzgwOWE4MGQ1YoqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHnZWTxkaXYgY2xhc3M9Im1hcmtkb3duIj48cD5GaXJzdCwgd2UgZXhjbHVkZSB0aGUgcm93cyBhbmQgY29sdW1ucyBvZiB6ZXJvcyBvbmx5LjwvcD4KPC9kaXY+pG1pbWWpdGV4dC9odG1srHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3Khd8isHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQzZWI5ZDM5Yy0yY2ExLTQzMGUtYjEzYi0wNWM4MDlhODBkNWK5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4AAhZNtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkNTQ4Y2EyNDQtZGU0Yy00N2MyLWE2OWUtMGNhN2E0NDkwMjhmiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9keYWmcHJlZml4r1R1cGxle0FueSwgQW55fahlbGVtZW50c5CkdHlwZaVBcnJheaxwcmVmaXhfc2hvcnSgqG9iamVjdGlksGM4NjQwMDU3M2I3MDNkMzWkbWltZdkhYXBwbGljYXRpb24vdm5kLnBsdXRvLnRyZWUrb2JqZWN0rHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3Vjj8lsHBlcnNpc3RfanNfc3RhdGXDt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQ1NDhjYTI0NC1kZTRjLTQ3YzItYTY5ZS0wY2E3YTQ0OTAyOGa5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc0HsbVwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJDg4NGE3Mjk5LTg0MTgtNDVlNC04MmYzLTY1MjA0ZDQ4ZTU1YoqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHnaBEY8ZGl2IGNsYXNzPSJtYXJrZG93biI+PHA+Q29ycmVjdGluZyBmb3IgYWxsIGNvbXBhcmlzb25zIGlzIHByb2JhYmx5IHVuZmFpci4gRnJlcXVlbmNpZXMgYXJlIGJvdW5kIHdpdGhpbiBlYWNoIGNvbHVtbiBhbmQgcm93ICYjNDA7b25lIGxlc3MgZGVncmVlIG9mIGZyZWVkb20mIzQxOy48L3A+CjxwPkFueXdheSwgdGhlIHNhbXBsZSBzaXplIGlzIGZhciB0b28gbG93IGZvciB0aGUgbnVtYmVyIG9mIGNlbGxzLCBhbmQgd2UgbmVlZCBhIG1vcmUgcG93ZXJmdWwgdGVzdC48L3A+CjxwPkxldCB1cyBub3cgY29tcGFyZSBlYWNoIGdlbm90eXBlIHdpdGggdGhlICZxdW90O2F2ZXJhZ2UmcXVvdDsgZ2Vub3R5cGUgZ3JvdXBpbmcgdGhlIGxvdy1mcmVxdWVuY3kgY2VsbHMgdG9nZXRoZXIuIFdlIGFscmVhZHkga25vdyB0aGUgcG9zdC1ob2MgdGVzdHMgZmFpbCwgYW5kIHdlIHdvbiYjMzk7dCBoYXZlIGNhdGVnb3J5LWxldmVsIHJlc29sdXRpb24sIGJ1dCBhIHNpZ25pZmljYW50IGRpZmZlcmVuY2UgbWF5IGJlIGFuIGFyZ3VtZW50IGZvciBpbmNyZWFzaW5nIHRoZSBzYW1wbGUgc2l6ZSwgb3IgcmV0aGlua2luZyB0aGUgY2F0ZWdvcmllcy4gPC9wPgo8cD5BbiBlbGFib3JhdGUgYXBwcm9hY2ggY2FuIGJlIGZvdW5kIGluIDxhIGhyZWY9Imh0dHBzOi8vd3d3NC5zdGF0Lm5jc3UuZWR1L35kaWNrZXkvYW5hbHl0aWNzL2RhdGFtaW5lL1JlZmVyZW5jZSYjMzc7MjBQYXBlcnMva2FzczgwLnBkZiI+S2FzcywgMTk4MDwvYT4uPC9wPgo8cD5UaGUgc2ltcGxlciBhcHByb2FjaCBmb2xsb3dlZCBoZXJlIGNvbnNpc3RzIGluIGdyb3VwaW5nIGFsbCBvYnNlcnZlZCBjb3VudHMgYmVsb3cgNSBpbnRvIGEgc2luZ2xlIHN5bnRoZXRpYyBjYXRlZ29yeSwgZm9yIGVhY2ggY29sdW1uIHNlcGFyYXRlbHkuIEV4cGVjdGVkIGNvdW50cyBhcmUgc2ltaWxhcmx5IGdyb3VwZWQsIGJhc2VkIG9uIHRoZSBvYnNlcnZlZCBjb3VudHMuIElmIHNvbWUgZXhwZWN0ZWQgY291bnQgaXMgYmVsb3cgNSAmIzQwO2luY2x1ZGVkIHRoZSBzeW50aGV0aWMgY2F0ZWdvcnkmIzQxOywgd2UgY2Fycnkgb24gdW5sZXNzIHRoaXMgY291bnQgaXMgMC48L3A+CjwvZGl2PqRtaW1lqXRleHQvaHRtbKxyb290YXNzaWduZWXAsmxhc3RfcnVuX3RpbWVzdGFtcMtB2SR9yoZa3rBwZXJzaXN0X2pzX3N0YXRlwrdoYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkODg0YTcyOTktODQxOC00NWU0LTgyZjMtNjUyMDRkNDhlNTViuWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXOAAefhLVwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJGI4YWRjNTY2LTU4OTMtNDAyYS1hMzVkLTExYzA2NDYwZmI2MoqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHnaAuk8ZGl2IGNsYXNzPSJtYXJrZG93biI+PHA+RHVlIHRvIHRoZSBwcmVzZW5jZSBvZiB6ZXJvcyBpbiBtb3N0IGNvbHVtbnMsIHdlIGhhdmUgdG8gZ3JvdXAgdGhlIGxvdy1mcmVxdWVuY3kgY2VsbHMgaW50byBzaW5nbGUgY2VsbHMgb24gYSBwZXItY29sdW1uIGJhc2lzLiBUaGUgaW5mb3JtYXRpb24gaW4gbG93LWZyZXF1ZW5jeSBjZWxscyBpcyBhbHJlYWR5IGFjY291bnRlZCBmb3IgYnkgdGhlIG90aGVyIGNlbGxzLjwvcD4KPHA+V2UgY2FuIGFsc28gaW5kaXZpZHVhbGx5IHRlc3QgZWFjaCBjb3VudCA8Y29kZT5vYnNlcnZlZF9uPC9jb2RlPiA8ZW0+ZXF1YWwgdG8gb3IgZ3JlYXRlciB0aGFuIDU8L2VtPiBpbiBhIGNvbnRpbmdlbmN5IHRhYmxlIHdpdGg6PC9wPgo8cHJlPjxjb2RlPiYjNDM7LS0tLS0tLS0tLS0tJiM0MzstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0mIzQzOwp8IG9ic2VydmVkX24gfCBjb2xfdG90YWwgLSBvYnNlcnZlZF9uIHwKJiM0MzstLS0tLS0tLS0tLS0mIzQzOy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSYjNDM7CnwgZXhwZWN0ZWRfbiB8IGNvbF90b3RhbCAtIGV4cGVjdGVkX24gfAomIzQzOy0tLS0tLS0tLS0tLSYjNDM7LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tJiM0Mzs8L2NvZGU+PC9wcmU+CjxwPlRoaXMgc2Vjb25kIGFwcHJvYWNoIGlzIGxlc3MgcG93ZXJmdWwsIHRob3VnaC48L3A+CjxwPkxldCB1cyBiZWdpbiB3aXRoIHRoaXMgc2Vjb25kIGFwcHJvYWNoOjwvcD4KPC9kaXY+pG1pbWWpdGV4dC9odG1srHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3KhgZksHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SRiOGFkYzU2Ni01ODkzLTQwMmEtYTM1ZC0xMWMwNjQ2MGZiNjK5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4ABH1XtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMziqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9keYOoZWxlbWVudHOSkgGSojIwqnRleHQvcGxhaW6SApKiMjCqdGV4dC9wbGFpbqR0eXBlpVR1cGxlqG9iamVjdGlksDZlMjY0ZjdkYjg5NTlmYmakbWltZdkhYXBwbGljYXRpb24vdm5kLnBsdXRvLnRyZWUrb2JqZWN0rHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3VLNAYsHBlcnNpc3RfanNfc3RhdGXDt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzO5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc0W2rVwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJGEyNWVlY2Q2LWY1OGQtNDkzZC1hNWNmLTk0MjE4MzE5ODQ5ZIqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHnZrjxkaXYgY2xhc3M9Im1hcmtkb3duIj48cD5Gb3IgZnVydGhlciByZWZlcmVuY2UsIHdlIGFsc28gbG9hZCB0aGUgbGFiZWxzIG9mIHRoZSByb3dzICYjNDA7PGNvZGU+Y2F0ZWdvcmllczwvY29kZT4mIzQxOyBhbmQgY29sdW1ucyAmIzQwOzxjb2RlPmdlbm90eXBlczwvY29kZT4mIzQxOy48L3A+CjwvZGl2PqRtaW1lqXRleHQvaHRtbKxyb290YXNzaWduZWXAsmxhc3RfcnVuX3RpbWVzdGFtcMtB2SR9yoXNzbBwZXJzaXN0X2pzX3N0YXRlwrdoYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkYTI1ZWVjZDYtZjU4ZC00OTNkLWE1Y2YtOTQyMTgzMTk4NDlkuWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXOAAO6grVwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJGMwOWI3NzFjLWFhYjEtNDBjZi1hMjczLTE0YWE2Yzg1NzUxMIqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHnZXzxkaXYgY2xhc3M9Im1hcmtkb3duIj48cD5Db3JyZWN0aW5nIGZvciBhbGwgdGhlIGNvbXBhcmlzb25zLCBubyBkaWZmZXJlbmNlcyBzdXJ2aXZlOjwvcD4KPC9kaXY+pG1pbWWpdGV4dC9odG1srHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3Khio9sHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SRjMDliNzcxYy1hYWIxLTQwY2YtYTI3My0xNGFhNmM4NTc1MTC5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4AAi00tXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkYTVlNjFhNDgtZTA3ZS00OWRjLThjNjEtMTIyNGQxYzQ3ZDEziqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedoD/TIzw5cyMCBNYXRyaXh7SW50NjR9OgogIDEgICAxICAwICAgMiAgIDAgICAxICAgMiAgIDAgIDEgIDEgIDAgICAxICAwICAwICAwICAwICAwICAgMCAgIDEgICAzCiAgMiAgIDQgIDAgICA4ICAgMSAgIDEgICAzICAgNCAgMyAgMiAgMyAgIDMgIDAgIDAgIDAgIDAgIDAgICAwICAgMyAgIDMKICAwICAgMCAgMCAgIDEgICAzICAgMSAgIDAgICAwICAwICAxICAwICAgNiAgMCAgMCAgMCAgMiAgMSAgIDUgICAwICAgNAogIDAgICAwICAwICAgMCAgIDAgICAwICAgMSAgIDIgIDAgIDAgIDAgICAzICAxICAwICAwICAwICAyICAgMCAgIDEgICAzCiAgMCAgIDEgIDAgICAxICAgMSAgIDAgICAxICAgMCAgMSAgMSAgMCAgIDMgIDAgIDAgIDAgIDEgIDAgICAwICAgMiAgIDUKICAwICAgMCAgMCAgIDUgICAwICAgMSAgIDIgICAyICAzICAwICAxICAxMiAgMCAgMCAgMCAgMSAgMCAgIDEgICAwICAgOAogIDEgICA0ICAwICAgMCAgIDAgICAyICAgMSAgIDAgIDEgIDEgIDAgICAwICAxICAwICAwICAwICAxICAgMCAgIDEgICAxCiAg4ouuICAgICAgICAgICAgICAgICAg4ouuICAgICAgICAgICAgICAgIOKLriAgICAgICAgICAgICAgIOKLriAgICAgICAgICAgICAKICAxICAgMCAgMCAgIDIgICAwICAgMCAgIDAgICAwICAxICAwICAwICAgMSAgMCAgMCAgMCAgMCAgMCAgIDAgICAyICAgMAogIDEgICAyICAwICAgMSAgIDAgICAwICAgMCAgIDAgIDAgIDAgIDAgICAyICAwICAwICAwICAwICAwICAgMCAgIDEgICAxCiAgMCAgIDIgIDAgICA0ICAgMSAgIDIgICAwICAgNCAgNSAgMCAgMCAgIDMgIDAgIDAgIDAgIDAgIDAgICAwICAgNCAgIDIKICAwICAgMSAgMCAgIDIgICAwICAgMCAgIDAgICAwICAwICAwICAwICAgMSAgMCAgMCAgMCAgMCAgMCAgIDAgICAwICAgMAogIDkgIDUyICAzICAzOSAgMjAgIDE5ICAzMyAgMzQgIDUgIDIgIDYgIDI3ICAxICAwICA3ICAzICA3ICAgNyAgMTcgIDQ5CiAxMiAgNTAgIDYgIDI0ICAxNyAgMTYgIDM2ICAxNiAgNSAgMiAgMyAgIDcgIDIgIDAgIDQgIDUgIDcgIDExICAyNCAgNDWkbWltZap0ZXh0L3BsYWlurHJvb3Rhc3NpZ25lZaZjb3VudHOybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3VLKg7sHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SRhNWU2MWE0OC1lMDdlLTQ5ZGMtOGM2MS0xMjI0ZDFjNDdkMTO5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4AHvzOtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkMTFhYzVmNmEtMGY2YS0xMWVlLTI1OTgtMTFjN2EwMDY0YjQziqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9keaCkbWltZap0ZXh0L3BsYWlurHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3OLG4RsHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQxMWFjNWY2YS0wZjZhLTExZWUtMjU5OC0xMWM3YTAwNjRiNDO5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4q1CKutXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkZjI4MjVkM2MtNTc3Yi00YjYxLThjOGMtYzg2OWE5ZWM5ZjA3iqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedoBDzxkaXYgY2xhc3M9Im1hcmtkb3duIj48cD5UbyB0ZXN0IHdoZXRoZXIgYSBnZW5vdHlwZSBleGhpYml0cyBhIGRpZmZlcmVudCBwYXJ0aXRpb24gaW50byBjYXRlZ29yaWVzIG9mIGdlbmVzLCBvciBlcXVpdmFsZW50bHkgd2hldGhlciBpdCBpcyBlbnJpY2hlZCBpbiBzb21lIGNhdGVnb3J5LCB3ZSBmaXJzdCBkZXJpdmUgYW4gZXhwZWN0ZWQgcGFydGl0aW9uIGF2ZXJhZ2luZyB0aGUgY2F0ZWdvcnkgZnJlcXVlbmNpZXMgYWNyb3NzIGFsbCBnZW5vdHlwZXMuPC9wPgo8L2Rpdj6kbWltZal0ZXh0L2h0bWyscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkkfcqF8BewcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJGYyODI1ZDNjLTU3N2ItNGI2MS04YzhjLWM4NjlhOWVjOWYwN7lkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgACmBi1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQzMWRjNThkYi01YTRlLTQ3ZGMtYmRiOC1mZTZlOWJiNDcyMDSKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R5szAuMDY4MTA3MDg4NDE3ODU3ODOkbWltZap0ZXh0L3BsYWlurHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZJH8z+50bsHBlcnNpc3RfanNfc3RhdGXDt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQzMWRjNThkYi01YTRlLTQ3ZGMtYmRiOC1mZTZlOWJiNDcyMDS5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc0NLbVwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJDcyY2Y4ZDU1LWE0MjMtNGMyOC1hMzcwLTM3N2Y5ZWY2YTcwZYqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHmgpG1pbWWqdGV4dC9wbGFpbqxyb290YXNzaWduZWXAsmxhc3RfcnVuX3RpbWVzdGFtcMtB2SR91Szy9bBwZXJzaXN0X2pzX3N0YXRlw7doYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkNzJjZjhkNTUtYTQyMy00YzI4LWEzNzAtMzc3ZjllZjZhNzBluWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXOAAfhdbVwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZYqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHnZ9zIww5cyMCBTcGFyc2VNYXRyaXhDU0N7RmxvYXQ2NCwgSW50NjR9IHdpdGggNTEgc3RvcmVkIGVudHJpZXM6CuKOoeKggOKgkOKggOKggOKggOKggOKggOKggOKggOKggOKOpArijqLioIDioIDioIDioIDioIDioIDioIDioIDioIDioIDijqUK4o6i4qCa4qCY4qCb4qCL4qCC4qCY4qCA4qCA4qCC4qCb4o6lCuKOouKggOKggOKggOKggOKggOKggOKggOKggOKggOKgkOKOpQrijqPio6TioqDio6Tio6TioYTioqTioIDiooTio6Tio6TijqakbWltZap0ZXh0L3BsYWlurHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3VLR5UsHBlcnNpc3RfanNfc3RhdGXDt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2W5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4ABSJ4tXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkNDZjOWJlMDctM2JiNC00OTljLWE4MTktN2E4N2M3M2I2ZTQyiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedn2MjDDlzIwIFNwYXJzZU1hdHJpeENTQ3tGbG9hdDY0LCBJbnQ2NH0gd2l0aCAwIHN0b3JlZCBlbnRyaWVzOgrijqHioIDioIDioIDioIDioIDioIDioIDioIDioIDioIDijqQK4o6i4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4o6lCuKOouKggOKggOKggOKggOKggOKggOKggOKggOKggOKggOKOpQrijqLioIDioIDioIDioIDioIDioIDioIDioIDioIDioIDijqUK4o6j4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4o6mpG1pbWWqdGV4dC9wbGFpbqxyb290YXNzaWduZWXAsmxhc3RfcnVuX3RpbWVzdGFtcMtB2SR91S1TKrBwZXJzaXN0X2pzX3N0YXRlw7doYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkNDZjOWJlMDctM2JiNC00OTljLWE4MTktN2E4N2M3M2I2ZTQyuWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXNMEO1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQxMjg2NjhjMy0yODJkLTQ0NTMtODRhNi1jZjJjMjlkNzE0MGaKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R52YA8ZGl2IGNsYXNzPSJtYXJrZG93biI+PHA+SGFkIHdlIGZvdW5kIGRpZmZlcmVuY2VzLCB3ZSBjb3VsZCBnZXQgdGhlIGNvcnJlc3BvbmRpbmcgY2F0ZWdvcnktZ2Vub3R5cGUgcGFpcnMgYXMgZm9sbG93czo8L3A+CjwvZGl2PqRtaW1lqXRleHQvaHRtbKxyb290YXNzaWduZWXAsmxhc3RfcnVuX3RpbWVzdGFtcMtB2SR9yoY+87BwZXJzaXN0X2pzX3N0YXRlwrdoYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkMTI4NjY4YzMtMjgyZC00NDUzLTg0YTYtY2YyYzI5ZDcxNDBmuWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXOAAKO27VwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJDVlOTRhNTE3LWRiNDYtNDg2NC1iNzE3LTViNDU0Mzg4NGRmZoqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHnaARFYTFNYRmlsZSgiLi4vZGF0YS9yYXcvZ2VuZXNfc3BlY2lmaXF1ZXMueGxzeCIpIGNvbnRhaW5pbmcgMiBXb3Jrc2hlZXRzCiAgICAgICAgICAgIHNoZWV0bmFtZSBzaXplICAgICAgICAgIHJhbmdlICAgICAgICAKLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogICAgICAgICBuYiBnw6huZXMgc3DDqSAyNngyMiAgICAgICAgIEExOlYyNiAgICAgICAKICAgICAgICAgIHBvdXJjZW50YWdlIDI3eDIxICAgICAgICAgQTE6VTI3ICAgICAgIAqkbWltZap0ZXh0L3BsYWlurHJvb3Rhc3NpZ25lZaRkYXRhsmxhc3RfcnVuX3RpbWVzdGFtcMtB2SR91IpGX7BwZXJzaXN0X2pzX3N0YXRlwrdoYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZmuWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXOAAm9m7VwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJDhkZDVkNGI5LTVhMzItNGE5NS04ZjM4LTdmM2U1Yjk4ZTJkOYqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHnaATA8ZGl2IGNsYXNzPSJtYXJrZG93biI+PHA+V2UgZmlyc3QgbG9hZCB0aGUgY291bnQgZGF0YS48L3A+CjxwPiYjMzM7JiMzMzsmIzMzOyAJVGhlIG5vdGVib29rIGlzIGFzc3VtZWQgdG8gcnVuIGZyb20gYSBjaGlsZCBkaXJlY3RvcnkgJiM0MDs8ZW0+ZS5nLjwvZW0+IDxjb2RlPm5vdGVib29rczwvY29kZT4mIzQxOyBvZiB0aGUgcHJvamVjdCByb290LCBhbmQgdGhlIGRhdGEgZmlsZXMgYXJlIGV4cGVjdGVkIHRvIGJlIGZvdW5kIGluIDxjb2RlPmRhdGEvcmF3PC9jb2RlPiwgZnJvbSB0aGUgcHJvamVjdCByb290LjwvcD4KPC9kaXY+pG1pbWWpdGV4dC9odG1srHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3KhbhrsHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQ4ZGQ1ZDRiOS01YTMyLTRhOTUtOGYzOC03ZjNlNWI5OGUyZDm5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4AA1T0tXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkYjMxNGFkZDctYTZmNS00MmYwLWJjOWEtYmJhNzQ4NTQzZmEyiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedmFPGRpdiBjbGFzcz0ibWFya2Rvd24iPjxwPk91dCBvZiBjdXJpb3NpdHksIHdpdGggbm8gY29ycmVjdGlvbiBmb3IgbXVsdGlwbGUgY29tcGFyaXNvbnMsIHdlIGZpbmQgYSBmZXcgcC12YWx1ZXMgYmVsb3cgMC4wNTo8L3A+CjwvZGl2PqRtaW1lqXRleHQvaHRtbKxyb290YXNzaWduZWXAsmxhc3RfcnVuX3RpbWVzdGFtcMtB2SR92jN/QbBwZXJzaXN0X2pzX3N0YXRlwrdoYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkYjMxNGFkZDctYTZmNS00MmYwLWJjOWEtYmJhNzQ4NTQzZmEyuWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXOAEu337VwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMKrc3RhdHVzX3RyZWWEpG5hbWWobm90ZWJvb2uoc3VidGFza3OEpnNhdmluZ4SkbmFtZaZzYXZpbmeoc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZJH8z6JGfqnN0YXJ0ZWRfYXTLQdkkfzPojLmpd29ya3NwYWNlhKRuYW1lqXdvcmtzcGFjZahzdWJ0YXNrc4KsaW5pdF9wcm9jZXNzhKRuYW1lrGluaXRfcHJvY2Vzc6hzdWJ0YXNrc4ShNISkbmFtZaE0qHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2SR9zOrnFKpzdGFydGVkX2F0y0HZJH3MUIf9oTGEpG5hbWWhMahzdWJ0YXNrc4CrZmluaXNoZWRfYXTLQdkkfcxLM/2qc3RhcnRlZF9hdMtB2SR9y/h5jqEyhKRuYW1loTKoc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZJH3MT4JNqnN0YXJ0ZWRfYXTLQdkkfcxLQMChM4SkbmFtZaEzqHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2SR9zFCH8KpzdGFydGVkX2F0y0HZJH3MT5DFq2ZpbmlzaGVkX2F0y0HZJH3M6vUjqnN0YXJ0ZWRfYXTLQdkkfcv4eWiuY3JlYXRlX3Byb2Nlc3OEpG5hbWWuY3JlYXRlX3Byb2Nlc3Ooc3VidGFza3OCoTGEpG5hbWWhMahzdWJ0YXNrc4CrZmluaXNoZWRfYXTLQdkkfcs8Qbeqc3RhcnRlZF9hdMtB2SR9yombhKEyhKRuYW1loTKoc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZJH3L+Hk1qnN0YXJ0ZWRfYXTLQdkkfcs8UGWrZmluaXNoZWRfYXTLQdkkfcv4aDCqc3RhcnRlZF9hdMtB2SR9yomba6tmaW5pc2hlZF9hdMtB2SR9zOr1J6pzdGFydGVkX2F0y0HZJH3KiZtOo3BrZ4SkbmFtZaNwa2eoc3VidGFza3OBqGFuYWx5c2lzhKRuYW1lqGFuYWx5c2lzqHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2SR/M+ej/apzdGFydGVkX2F0y0HZJH8z54o3q2ZpbmlzaGVkX2F0y0HZJH8z56QBqnN0YXJ0ZWRfYXTLQdkkfzPnigmjcnVuhKRuYW1lo3J1bqhzdWJ0YXNrc4KwcmVzb2x2ZV90b3BvbG9neYSkbmFtZbByZXNvbHZlX3RvcG9sb2d5qHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2SR/M+iRsKpzdGFydGVkX2F0y0HZJH8z580cqGV2YWx1YXRlhKRuYW1lqGV2YWx1YXRlqHN1YnRhc2tzgqExhKRuYW1loTGoc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZJH8z+2QGqnN0YXJ0ZWRfYXTLQdkkfzPorSGhMoSkbmFtZaEyqHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2SR/M/udOapzdGFydGVkX2F0y0HZJH8z+3GPq2ZpbmlzaGVkX2F0y0HZJH8z+6k7qnN0YXJ0ZWRfYXTLQdkkfzPokbCrZmluaXNoZWRfYXTLQdkkfzP7qTuqc3RhcnRlZF9hdMtB2SR/M+fM/6tmaW5pc2hlZF9hdMCqc3RhcnRlZF9hdMtB2SR9yn/z4LFjZWxsX2RlcGVuZGVuY2llc94AFtkkOWMzYjhlYjItYTE2MC00MjQ2LWE1YzctNTk2YTg2YzczZDYyhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkOWMzYjhlYjItYTE2MC00MjQ2LWE1YzctNTk2YTg2YzczZDYytGRvd25zdHJlYW1fY2VsbHNfbWFwgqlnZW5vdHlwZXOR2SQ1NDhjYTI0NC1kZTRjLTQ3YzItYTY5ZS0wY2E3YTQ0OTAyOGaqY2F0ZWdvcmllc5HZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZrJ1cHN0cmVhbV9jZWxsc19tYXCCo3ZlY5CkZGF0YZHZJDVlOTRhNTE3LWRiNDYtNDg2NC1iNzE3LTViNDU0Mzg4NGRmZtkkOTM0MmU0ODktYTI5Ny00YzY3LTgzMjQtY2I0MTgwMWFmNzEzhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkOTM0MmU0ODktYTI5Ny00YzY3LTgzMjQtY2I0MTgwMWFmNzEztGRvd25zdHJlYW1fY2VsbHNfbWFwgbRwZXJfZ2Vub3R5cGVfcHZhbHVlc5HZJDMxZGM1OGRiLTVhNGUtNDdkYy1iZGI4LWZlNmU5YmI0NzIwNLJ1cHN0cmVhbV9jZWxsc19tYXDeAB+kQ29yZZCjc3VtkK9vYnNlcnZlZF9jb3VudHOR2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2Wnc3B6ZXJvc5ChIZCjYW55kKZpc2xlc3OQ2SdCYXNlLkNvcmVMb2dnaW5nLkJhc2UuZml4dXBfc3RkbGliX3BhdGiQskJhc2UuQ29yZUxvZ2dpbmcuIZClQHdhcm6QoTyQr2V4cGVjdGVkX2NvdW50c5HZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZaZwdmFsdWWQsUJhc2UuaW52b2tlbGF0ZXN0kNknQmFzZS5Db3JlTG9nZ2luZy5jdXJyZW50X2xvZ2dlcl9mb3JfZW52kKI9PZC4QmFzZS5Db3JlTG9nZ2luZy5jb252ZXJ0kL1CYXNlLkNvcmVMb2dnaW5nLmludm9rZWxhdGVzdJCyQ29yZS5VbmRlZlZhckVycm9ykLRCYXNlLkNvcmVMb2dnaW5nLj09PZChOpCkaGNhdJC6I19fX3RoaXNfcGx1dG9fbW9kdWxlX25hbWWQpW5jb2xzkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzo2FsbJCkQmFzZZClcHVzaCGQtEJhc2UuQ29yZUxvZ2dpbmcuaXNhkKI+PZCzQmFzZS5Db3JlTG9nZ2luZy4+PZCpQ2hpc3FUZXN0kNkkNmQ3NjhlYzItZjlhZC00Y2M3LWEyZGYtNGVlYjFhNzJjZDQ0hLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkNmQ3NjhlYzItZjlhZC00Y2M3LWEyZGYtNGVlYjFhNzJjZDQ0tGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkN2UzODM5NjctMjZkZS00OWJkLWExMDYtZDIxNTI0MWZmZGIxhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkN2UzODM5NjctMjZkZS00OWJkLWExMDYtZDIxNTI0MWZmZGIxtGRvd25zdHJlYW1fY2VsbHNfbWFwgdkjdW5jb3JyZWN0ZWRfcHZhbHVlc19iZWxvd190aHJlc2hvbGSQsnVwc3RyZWFtX2NlbGxzX21hcIWhPJCpZHJvcHplcm9zkKdwdmFsdWVzkdkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2NlpmlzbGVzc5CkY29weZDZJDNlYjlkMzljLTJjYTEtNDMwZS1iMTNiLTA1YzgwOWE4MGQ1YoS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDNlYjlkMzljLTJjYTEtNDMwZS1iMTNiLTA1YzgwOWE4MGQ1YrRkb3duc3RyZWFtX2NlbGxzX21hcICydXBzdHJlYW1fY2VsbHNfbWFwgqdAbWRfc3RykKhnZXRpbmRleJDZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZoS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZrRkb3duc3RyZWFtX2NlbGxzX21hcISjcm93kKhnZW5vdHlwZZCjY29skKhjYXRlZ29yeZCydXBzdHJlYW1fY2VsbHNfbWFwiKlnZW5vdHlwZXOR2SQ5YzNiOGViMi1hMTYwLTQyNDYtYTVjNy01OTZhODZjNzNkNjKmcm93X29rkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzpmZpbmRuepCnY29sbGVjdJCmY29sX29rkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzo3ppcJCqY2F0ZWdvcmllc5HZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MrNzaWduaWZpY2FudF9wdmFsdWVzkdkkNDZjOWJlMDctM2JiNC00OTljLWE4MTktN2E4N2M3M2I2ZTQy2SQ4ODRhNzI5OS04NDE4LTQ1ZTQtODJmMy02NTIwNGQ0OGU1NWKEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SQ4ODRhNzI5OS04NDE4LTQ1ZTQtODJmMy02NTIwNGQ0OGU1NWK0ZG93bnN0cmVhbV9jZWxsc19tYXCAsnVwc3RyZWFtX2NlbGxzX21hcIKnQG1kX3N0cpCoZ2V0aW5kZXiQ2SRiOGFkYzU2Ni01ODkzLTQwMmEtYTM1ZC0xMWMwNjQ2MGZiNjKEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SRiOGFkYzU2Ni01ODkzLTQwMmEtYTM1ZC0xMWMwNjQ2MGZiNjK0ZG93bnN0cmVhbV9jZWxsc19tYXCAsnVwc3RyZWFtX2NlbGxzX21hcIKnQG1kX3N0cpCoZ2V0aW5kZXiQ2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzOEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzO0ZG93bnN0cmVhbV9jZWxsc19tYXCFpnJvd19va5HZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZqxjbGVhbl9jb3VudHOS2SQ3MmNmOGQ1NS1hNDIzLTRjMjgtYTM3MC0zNzdmOWVmNmE3MGXZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZaVucm93c5HZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZaZjb2xfb2uR2SQ1NDhjYTI0NC1kZTRjLTQ3YzItYTY5ZS0wY2E3YTQ0OTAyOGalbmNvbHOS2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2XZJDkzNDJlNDg5LWEyOTctNGM2Ny04MzI0LWNiNDE4MDFhZjcxM7J1cHN0cmVhbV9jZWxsc19tYXCGo3ZlY5CjYW55kKIhPZCkc2l6ZZCiPT2QpmNvdW50c5HZJGE1ZTYxYTQ4LWUwN2UtNDlkYy04YzYxLTEyMjRkMWM0N2QxM9kkYTI1ZWVjZDYtZjU4ZC00OTNkLWE1Y2YtOTQyMTgzMTk4NDlkhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkYTI1ZWVjZDYtZjU4ZC00OTNkLWE1Y2YtOTQyMTgzMTk4NDlktGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkYzA5Yjc3MWMtYWFiMS00MGNmLWEyNzMtMTRhYTZjODU3NTEwhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkYzA5Yjc3MWMtYWFiMS00MGNmLWEyNzMtMTRhYTZjODU3NTEwtGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkYTVlNjFhNDgtZTA3ZS00OWRjLThjNjEtMTIyNGQxYzQ3ZDEzhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkYTVlNjFhNDgtZTA3ZS00OWRjLThjNjEtMTIyNGQxYzQ3ZDEztGRvd25zdHJlYW1fY2VsbHNfbWFwgaZjb3VudHOR2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzOydXBzdHJlYW1fY2VsbHNfbWFwgqNJbnSQpGRhdGGR2SQ1ZTk0YTUxNy1kYjQ2LTQ4NjQtYjcxNy01YjQ1NDM4ODRkZmbZJDExYWM1ZjZhLTBmNmEtMTFlZS0yNTk4LTExYzdhMDA2NGI0M4S0cHJlY2VkZW5jZV9oZXVyaXN0aWMHp2NlbGxfaWTZJDExYWM1ZjZhLTBmNmEtMTFlZS0yNTk4LTExYzdhMDA2NGI0M7Rkb3duc3RyZWFtX2NlbGxzX21hcIWpU3RhdHNCYXNlkKRYTFNYkdkkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZmr011bHRpcGxlVGVzdGluZ5CsU3BhcnNlQXJyYXlzkK9IeXBvdGhlc2lzVGVzdHOQsnVwc3RyZWFtX2NlbGxzX21hcIDZJGYyODI1ZDNjLTU3N2ItNGI2MS04YzhjLWM4NjlhOWVjOWYwN4S0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJGYyODI1ZDNjLTU3N2ItNGI2MS04YzhjLWM4NjlhOWVjOWYwN7Rkb3duc3RyZWFtX2NlbGxzX21hcICydXBzdHJlYW1fY2VsbHNfbWFwgqdAbWRfc3RykKhnZXRpbmRleJDZJDMxZGM1OGRiLTVhNGUtNDdkYy1iZGI4LWZlNmU5YmI0NzIwNIS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDMxZGM1OGRiLTVhNGUtNDdkYy1iZGI4LWZlNmU5YmI0NzIwNLRkb3duc3RyZWFtX2NlbGxzX21hcIG+Y29ycmVjdGVkX3Blcl9nZW5vdHlwZV9wdmFsdWVzkLJ1cHN0cmVhbV9jZWxsc19tYXCEp21pbmltdW2QpmFkanVzdJC0cGVyX2dlbm90eXBlX3B2YWx1ZXOR2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTOkSG9sbZDZJDcyY2Y4ZDU1LWE0MjMtNGMyOC1hMzcwLTM3N2Y5ZWY2YTcwZYS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDcyY2Y4ZDU1LWE0MjMtNGMyOC1hMzcwLTM3N2Y5ZWY2YTcwZbRkb3duc3RyZWFtX2NlbGxzX21hcIK0ZXhwZWN0ZWRfZnJlcXVlbmNpZXOR2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2WpY29sX3RvdGFskdkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2NlsnVwc3RyZWFtX2NlbGxzX21hcIij4omIkKNzdW2QrGNsZWFuX2NvdW50c5HZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM6dAYXNzZXJ0kKV0aHJvd5ChL5CuQXNzZXJ0aW9uRXJyb3KQpG1lYW6Q2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2WEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2W0ZG93bnN0cmVhbV9jZWxsc19tYXCFr29ic2VydmVkX2NvdW50c5HZJDkzNDJlNDg5LWEyOTctNGM2Ny04MzI0LWNiNDE4MDFhZjcxM69leHBlY3RlZF9jb3VudHOR2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTOncHZhbHVlc5LZJDdlMzgzOTY3LTI2ZGUtNDliZC1hMTA2LWQyMTUyNDFmZmRiMdkkNDZjOWJlMDctM2JiNC00OTljLWE4MTktN2E4N2M3M2I2ZTQysm9ic2VydmVkX3JlbWFpbmRlcpCyZXhwZWN0ZWRfcmVtYWluZGVykLJ1cHN0cmVhbV9jZWxsc19tYXDeABC0ZXhwZWN0ZWRfZnJlcXVlbmNpZXOR2SQ3MmNmOGQ1NS1hNDIzLTRjMjgtYTM3MC0zNzdmOWVmNmE3MGWnc3B6ZXJvc5CsY2xlYW5fY291bnRzkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzpW5yb3dzkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzoTqQqWNvbF90b3RhbJHZJDcyY2Y4ZDU1LWE0MjMtNGMyOC1hMzcwLTM3N2Y5ZWY2YTcwZahAX19kb3RfX5ClbmNvbHOR2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzOjYWxskKEtkKZwdmFsdWWQo0ludJCiPj2QoSqQpXJvdW5kkKlDaGlzcVRlc3SQ2SQ0NmM5YmUwNy0zYmI0LTQ5OWMtYTgxOS03YTg3YzczYjZlNDKEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SQ0NmM5YmUwNy0zYmI0LTQ5OWMtYTgxOS03YTg3YzczYjZlNDK0ZG93bnN0cmVhbV9jZWxsc19tYXCDq3NpZ25pZmljYW50kLFjb3JyZWN0ZWRfcHZhbHVlc5Czc2lnbmlmaWNhbnRfcHZhbHVlc5HZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZrJ1cHN0cmVhbV9jZWxsc19tYXCGpmFkanVzdJCiPD2QqWRyb3B6ZXJvc5CncHZhbHVlc5HZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZaRIb2xtkKRjb3B5kNkkMTI4NjY4YzMtMjgyZC00NDUzLTg0YTYtY2YyYzI5ZDcxNDBmhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkMTI4NjY4YzMtMjgyZC00NDUzLTg0YTYtY2YyYzI5ZDcxNDBmtGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZmhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZmtGRvd25zdHJlYW1fY2VsbHNfbWFwgaRkYXRhktkkYTVlNjFhNDgtZTA3ZS00OWRjLThjNjEtMTIyNGQxYzQ3ZDEz2SQ5YzNiOGViMi1hMTYwLTQyNDYtYTVjNy01OTZhODZjNzNkNjKydXBzdHJlYW1fY2VsbHNfbWFwgqRYTFNYkdkkMTFhYzVmNmEtMGY2YS0xMWVlLTI1OTgtMTFjN2EwMDY0YjQzrVhMU1gub3Blbnhsc3iQ2SQ4ZGQ1ZDRiOS01YTMyLTRhOTUtOGYzOC03ZjNlNWI5OGUyZDmEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SQ4ZGQ1ZDRiOS01YTMyLTRhOTUtOGYzOC03ZjNlNWI5OGUyZDm0ZG93bnN0cmVhbV9jZWxsc19tYXCAsnVwc3RyZWFtX2NlbGxzX21hcIKnQG1kX3N0cpCoZ2V0aW5kZXiQ2SRiMzE0YWRkNy1hNmY1LTQyZjAtYmM5YS1iYmE3NDg1NDNmYTKEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SRiMzE0YWRkNy1hNmY1LTQyZjAtYmM5YS1iYmE3NDg1NDNmYTK0ZG93bnN0cmVhbV9jZWxsc19tYXCAsnVwc3RyZWFtX2NlbGxzX21hcIKnQG1kX3N0cpCoZ2V0aW5kZXiQtGNlbGxfZXhlY3V0aW9uX29yZGVy3AAW2SQxMWFjNWY2YS0wZjZhLTExZWUtMjU5OC0xMWM3YTAwNjRiNDPZJDhkZDVkNGI5LTVhMzItNGE5NS04ZjM4LTdmM2U1Yjk4ZTJkOdkkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZm2SRhNWU2MWE0OC1lMDdlLTQ5ZGMtOGM2MS0xMjI0ZDFjNDdkMTPZJGEyNWVlY2Q2LWY1OGQtNDkzZC1hNWNmLTk0MjE4MzE5ODQ5ZNkkOWMzYjhlYjItYTE2MC00MjQ2LWE1YzctNTk2YTg2YzczZDYy2SQzZWI5ZDM5Yy0yY2ExLTQzMGUtYjEzYi0wNWM4MDlhODBkNWLZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM9kkZjI4MjVkM2MtNTc3Yi00YjYxLThjOGMtYzg2OWE5ZWM5ZjA32SQ3MmNmOGQ1NS1hNDIzLTRjMjgtYTM3MC0zNzdmOWVmNmE3MGXZJGI4YWRjNTY2LTU4OTMtNDAyYS1hMzVkLTExYzA2NDYwZmI2MtkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2Nl2SRiMzE0YWRkNy1hNmY1LTQyZjAtYmM5YS1iYmE3NDg1NDNmYTLZJDdlMzgzOTY3LTI2ZGUtNDliZC1hMTA2LWQyMTUyNDFmZmRiMdkkYzA5Yjc3MWMtYWFiMS00MGNmLWEyNzMtMTRhYTZjODU3NTEw2SQ0NmM5YmUwNy0zYmI0LTQ5OWMtYTgxOS03YTg3YzczYjZlNDLZJDEyODY2OGMzLTI4MmQtNDQ1My04NGE2LWNmMmMyOWQ3MTQwZtkkNTQ4Y2EyNDQtZGU0Yy00N2MyLWE2OWUtMGNhN2E0NDkwMjhm2SQ4ODRhNzI5OS04NDE4LTQ1ZTQtODJmMy02NTIwNGQ0OGU1NWLZJDkzNDJlNDg5LWEyOTctNGM2Ny04MzI0LWNiNDE4MDFhZjcxM9kkMzFkYzU4ZGItNWE0ZS00N2RjLWJkYjgtZmU2ZTliYjQ3MjA02SQ2ZDc2OGVjMi1mOWFkLTRjYzctYTJkZi00ZWViMWE3MmNkNDS0bGFzdF9ob3RfcmVsb2FkX3RpbWXLAAAAAAAAAACpc2hvcnRwYXRotGdlbmVzX2NoaXNxX3Rlc3RzLmpsrnByb2Nlc3Nfc3RhdHVzpXJlYWR5pHBhdGjZWi9ob21lL2ZsYXVyZW50L0JveGVzL3R1bWJsZXdlZWQtMS9Qcm9qZWN0cy9zdGF0cy9DeXJpbFNhdmluL25vdGVib29rcy9nZW5lc19jaGlzcV90ZXN0cy5qbK5sYXN0X3NhdmVfdGltZctB2SR/M+iMsKpjZWxsX29yZGVy3AAW2SQxMWFjNWY2YS0wZjZhLTExZWUtMjU5OC0xMWM3YTAwNjRiNDPZJDhkZDVkNGI5LTVhMzItNGE5NS04ZjM4LTdmM2U1Yjk4ZTJkOdkkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZm2SRhNWU2MWE0OC1lMDdlLTQ5ZGMtOGM2MS0xMjI0ZDFjNDdkMTPZJGEyNWVlY2Q2LWY1OGQtNDkzZC1hNWNmLTk0MjE4MzE5ODQ5ZNkkOWMzYjhlYjItYTE2MC00MjQ2LWE1YzctNTk2YTg2YzczZDYy2SQzZWI5ZDM5Yy0yY2ExLTQzMGUtYjEzYi0wNWM4MDlhODBkNWLZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM9kkZjI4MjVkM2MtNTc3Yi00YjYxLThjOGMtYzg2OWE5ZWM5ZjA32SQ3MmNmOGQ1NS1hNDIzLTRjMjgtYTM3MC0zNzdmOWVmNmE3MGXZJGI4YWRjNTY2LTU4OTMtNDAyYS1hMzVkLTExYzA2NDYwZmI2MtkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2Nl2SRiMzE0YWRkNy1hNmY1LTQyZjAtYmM5YS1iYmE3NDg1NDNmYTLZJDdlMzgzOTY3LTI2ZGUtNDliZC1hMTA2LWQyMTUyNDFmZmRiMdkkYzA5Yjc3MWMtYWFiMS00MGNmLWEyNzMtMTRhYTZjODU3NTEw2SQ0NmM5YmUwNy0zYmI0LTQ5OWMtYTgxOS03YTg3YzczYjZlNDLZJDEyODY2OGMzLTI4MmQtNDQ1My04NGE2LWNmMmMyOWQ3MTQwZtkkNTQ4Y2EyNDQtZGU0Yy00N2MyLWE2OWUtMGNhN2E0NDkwMjhm2SQ4ODRhNzI5OS04NDE4LTQ1ZTQtODJmMy02NTIwNGQ0OGU1NWLZJDkzNDJlNDg5LWEyOTctNGM2Ny04MzI0LWNiNDE4MDFhZjcxM9kkMzFkYzU4ZGItNWE0ZS00N2RjLWJkYjgtZmU2ZTliYjQ3MjA02SQ2ZDc2OGVjMi1mOWFkLTRjYzctYTJkZi00ZWViMWE3MmNkNDSxcHVibGlzaGVkX29iamVjdHOApW5icGtniLJpbnN0YWxsZWRfdmVyc2lvbnOFqVN0YXRzQmFzZacwLjMzLjIxpFhMU1ilMC45LjCvTXVsdGlwbGVUZXN0aW5npTAuNS4xrFNwYXJzZUFycmF5c6ZzdGRsaWKvSHlwb3RoZXNpc1Rlc3RzpjAuMTEuMLB0ZXJtaW5hbF9vdXRwdXRzhqlTdGF0c0Jhc2XaASdXYWl0aW5nIGZvciBvdGhlciBub3RlYm9va3MgdG8gZmluaXNoIFBrZyBvcGVyYXRpb25zLi4uCgpJbnN0YW50aWF0aW5nLi4uCgpSZXNvbHZpbmcuLi4KG1szMm0bWzFtICBObyBDaGFuZ2VzG1syMm0bWzM5bSB0byBgL3RtcC9qbF9aOHNIUWwvUHJvamVjdC50b21sYAobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psX1o4c0hRbC9NYW5pZmVzdC50b21sYAoKUHJlY29tcGlsaW5nLi4uChtbMzJtG1sxbSAgQWN0aXZhdGluZxtbMjJtG1szOW0gcHJvamVjdCBhdCBgL3RtcC9qbF9aOHNIUWxgpFhMU1jaASdXYWl0aW5nIGZvciBvdGhlciBub3RlYm9va3MgdG8gZmluaXNoIFBrZyBvcGVyYXRpb25zLi4uCgpJbnN0YW50aWF0aW5nLi4uCgpSZXNvbHZpbmcuLi4KG1szMm0bWzFtICBObyBDaGFuZ2VzG1syMm0bWzM5bSB0byBgL3RtcC9qbF9aOHNIUWwvUHJvamVjdC50b21sYAobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psX1o4c0hRbC9NYW5pZmVzdC50b21sYAoKUHJlY29tcGlsaW5nLi4uChtbMzJtG1sxbSAgQWN0aXZhdGluZxtbMjJtG1szOW0gcHJvamVjdCBhdCBgL3RtcC9qbF9aOHNIUWxgqm5icGtnX3N5bmPaASdXYWl0aW5nIGZvciBvdGhlciBub3RlYm9va3MgdG8gZmluaXNoIFBrZyBvcGVyYXRpb25zLi4uCgpJbnN0YW50aWF0aW5nLi4uCgpSZXNvbHZpbmcuLi4KG1szMm0bWzFtICBObyBDaGFuZ2VzG1syMm0bWzM5bSB0byBgL3RtcC9qbF9aOHNIUWwvUHJvamVjdC50b21sYAobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psX1o4c0hRbC9NYW5pZmVzdC50b21sYAoKUHJlY29tcGlsaW5nLi4uChtbMzJtG1sxbSAgQWN0aXZhdGluZxtbMjJtG1szOW0gcHJvamVjdCBhdCBgL3RtcC9qbF9aOHNIUWxgr011bHRpcGxlVGVzdGluZ9oBJ1dhaXRpbmcgZm9yIG90aGVyIG5vdGVib29rcyB0byBmaW5pc2ggUGtnIG9wZXJhdGlvbnMuLi4KCkluc3RhbnRpYXRpbmcuLi4KClJlc29sdmluZy4uLgobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psX1o4c0hRbC9Qcm9qZWN0LnRvbWxgChtbMzJtG1sxbSAgTm8gQ2hhbmdlcxtbMjJtG1szOW0gdG8gYC90bXAvamxfWjhzSFFsL01hbmlmZXN0LnRvbWxgCgpQcmVjb21waWxpbmcuLi4KG1szMm0bWzFtICBBY3RpdmF0aW5nG1syMm0bWzM5bSBwcm9qZWN0IGF0IGAvdG1wL2psX1o4c0hRbGCsU3BhcnNlQXJyYXlz2gEnV2FpdGluZyBmb3Igb3RoZXIgbm90ZWJvb2tzIHRvIGZpbmlzaCBQa2cgb3BlcmF0aW9ucy4uLgoKSW5zdGFudGlhdGluZy4uLgoKUmVzb2x2aW5nLi4uChtbMzJtG1sxbSAgTm8gQ2hhbmdlcxtbMjJtG1szOW0gdG8gYC90bXAvamxfWjhzSFFsL1Byb2plY3QudG9tbGAKG1szMm0bWzFtICBObyBDaGFuZ2VzG1syMm0bWzM5bSB0byBgL3RtcC9qbF9aOHNIUWwvTWFuaWZlc3QudG9tbGAKClByZWNvbXBpbGluZy4uLgobWzMybRtbMW0gIEFjdGl2YXRpbmcbWzIybRtbMzltIHByb2plY3QgYXQgYC90bXAvamxfWjhzSFFsYK9IeXBvdGhlc2lzVGVzdHPaASdXYWl0aW5nIGZvciBvdGhlciBub3RlYm9va3MgdG8gZmluaXNoIFBrZyBvcGVyYXRpb25zLi4uCgpJbnN0YW50aWF0aW5nLi4uCgpSZXNvbHZpbmcuLi4KG1szMm0bWzFtICBObyBDaGFuZ2VzG1syMm0bWzM5bSB0byBgL3RtcC9qbF9aOHNIUWwvUHJvamVjdC50b21sYAobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psX1o4c0hRbC9NYW5pZmVzdC50b21sYAoKUHJlY29tcGlsaW5nLi4uChtbMzJtG1sxbSAgQWN0aXZhdGluZxtbMjJtG1szOW0gcHJvamVjdCBhdCBgL3RtcC9qbF9aOHNIUWxgp2VuYWJsZWTDt3Jlc3RhcnRfcmVjb21tZW5kZWRfbXNnwLRyZXN0YXJ0X3JlcXVpcmVkX21zZ8CtYnVzeV9wYWNrYWdlc5CvaW5zdGFsbF90aW1lX25zzsp9mV+saW5zdGFudGlhdGVkw6tjZWxsX2lucHV0c94AFtkkOWMzYjhlYjItYTE2MC00MjQ2LWE1YzctNTk2YTg2YzczZDYyhKdjZWxsX2lk2SQ5YzNiOGViMi1hMTYwLTQyNDYtYTVjNy01OTZhODZjNzNkNjKkY29kZdmAYmVnaW4KCWdlbm90eXBlcyA9IHZlYyhkYXRhWyJuYiBnw6huZXMgc3DDqSJdWyJCMjpVMiJdKSAjIGNvbHVtbnMKCWNhdGVnb3JpZXMgPSB2ZWMoZGF0YVsibmIgZ8OobmVzIHNww6kiXVsiQTM6QTI1Il0pICMgcm93cwplbmSobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMLZJDkzNDJlNDg5LWEyOTctNGM2Ny04MzI0LWNiNDE4MDFhZjcxM4SnY2VsbF9pZNkkOTM0MmU0ODktYTI5Ny00YzY3LTgzMjQtY2I0MTgwMWFmNzEzpGNvZGXaA5RiZWdpbgoJcGVyX2dlbm90eXBlX3B2YWx1ZXMgPSBzcHplcm9zKG5jb2xzKQoJZm9yIGNvbCBpbiAxOm5jb2xzCgkJb2sgPSBvYnNlcnZlZF9jb3VudHNbOiwgY29sXSAuPj0gNQoJCWFueShvaykgfHwgY29udGludWUKCQlvYnNlcnZlZF9jb3VudHPigLIgPSBvYnNlcnZlZF9jb3VudHNbb2ssIGNvbF0KCQlpZiAhYWxsKG9rKQoJCQlzeW50aGV0aWNfY291bnQgPSBzdW0ob2JzZXJ2ZWRfY291bnRzWyghKS4ob2spLCBjb2xdKQoJCQlwdXNoIShvYnNlcnZlZF9jb3VudHPigLIsIHN5bnRoZXRpY19jb3VudCkKCQllbmQKCQlleHBlY3RlZF9jb3VudHPigLIgPSBleHBlY3RlZF9jb3VudHNbb2ssIGNvbF0KCQlpZiAhYWxsKG9rKQoJCQlzeW50aGV0aWNfY291bnQgPSBzdW0oZXhwZWN0ZWRfY291bnRzWyghKS4ob2spLCBjb2xdKQoJCQlwdXNoIShleHBlY3RlZF9jb3VudHPigLIsIHN5bnRoZXRpY19jb3VudCkKCQllbmQKCQljb250aW5nZW5jeV90YWJsZSA9IGhjYXQob2JzZXJ2ZWRfY291bnRz4oCyLCBleHBlY3RlZF9jb3VudHPigLIpCgkJaWYgYW55KGV4cGVjdGVkX2NvdW50c+KAsiAuPCA1KQoJCQkjY29udGludWUgIyB0byBnZXQgc2lnbmlmaWNhbnQgcmVzdWx0cy4uLgoJCQlpZiBhbnkoZXhwZWN0ZWRfY291bnRz4oCyIC49PSAwKQoJCQkJQHdhcm4gIkV4cGVjdGVkIGNvdW50cyBhcmUgdG9vIGxvdzsgc2tpcHBpbmciIGNvbnRpbmdlbmN5X3RhYmxlCgkJCQljb250aW51ZQoJCQllbHNlCgkJCQkjQHdhcm4gIkV4cGVjdGVkIGNvdW50cyBhcmUgbG93IiBjb250aW5nZW5jeV90YWJsZQoJCQllbmQKCQllbmQKCQlwdmFsID0gcHZhbHVlKENoaXNxVGVzdChjb250aW5nZW5jeV90YWJsZSkpCgkJcGVyX2dlbm90eXBlX3B2YWx1ZXNbY29sXSA9IHB2YWwKCWVuZAoJcGVyX2dlbm90eXBlX3B2YWx1ZXMKZW5kqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTC2SQ2ZDc2OGVjMi1mOWFkLTRjYzctYTJkZi00ZWViMWE3MmNkNDSEp2NlbGxfaWTZJDZkNzY4ZWMyLWY5YWQtNGNjNy1hMmRmLTRlZWIxYTcyY2Q0NKRjb2Rl2gEibWQiIiIKV2UgZmFpbCBieSBhIGxpdHRsZSBtYXJnaW4uIFRvbyBtYW55IGNvbHVtbnMgaGVyZS4KCkFjdHVhbGx5LCBpZiB3ZSBoYWQgY2hvc2VuIHRvIHJlamVjdCB0aGUgY29sdW1ucyB3aXRoIGBhbnkoZXhwZWN0ZWRfY291bnRz4oCyIC48IDUpYCwgd2Ugd291bGQgaGF2ZSBhdCBsZWFzdCBvbmUgc2lnbmlmaWNhbnRseSBkaWZmZXJlbnQgZ2Vub3R5cGUuIFRoaXMgbm90ZWJvb2sgc2hvd3MgdGhlIG9yaWdpbmFsIGFwcHJvYWNoLCB3aXRoIG5vIGl0ZXJhdGlvbnMuCgpNb3JlIGNhbiBiZSBkb25lLgoiIiKobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMPZJDdlMzgzOTY3LTI2ZGUtNDliZC1hMTA2LWQyMTUyNDFmZmRiMYSnY2VsbF9pZNkkN2UzODM5NjctMjZkZS00OWJkLWExMDYtZDIxNTI0MWZmZGIxpGNvZGXZtGJlZ2luCgl1bmNvcnJlY3RlZF9wdmFsdWVzX2JlbG93X3RocmVzaG9sZCA9IGNvcHkocHZhbHVlcykKCXVuY29ycmVjdGVkX3B2YWx1ZXNfYmVsb3dfdGhyZXNob2xkLm56dmFsWy4wNSAuPCBwdmFsdWVzLm56dmFsXSAuPSAwCglkcm9wemVyb3ModW5jb3JyZWN0ZWRfcHZhbHVlc19iZWxvd190aHJlc2hvbGQpCmVuZKhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkwtkkM2ViOWQzOWMtMmNhMS00MzBlLWIxM2ItMDVjODA5YTgwZDVihKdjZWxsX2lk2SQzZWI5ZDM5Yy0yY2ExLTQzMGUtYjEzYi0wNWM4MDlhODBkNWKkY29kZdk/bWQiIiIKRmlyc3QsIHdlIGV4Y2x1ZGUgdGhlIHJvd3MgYW5kIGNvbHVtbnMgb2YgemVyb3Mgb25seS4KIiIiqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTD2SQ1NDhjYTI0NC1kZTRjLTQ3YzItYTY5ZS0wY2E3YTQ0OTAyOGaEp2NlbGxfaWTZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZqRjb2Rl2ZpiZWdpbgoJcm93LCBjb2wgPSBmaW5kbnooc2lnbmlmaWNhbnRfcHZhbHVlcykKCWNhdGVnb3J5ID0gY2F0ZWdvcmllc1tyb3dfb2tdW3Jvd10KCWdlbm90eXBlID0gZ2Vub3R5cGVzW2NvbF9va11bY29sXQoJY29sbGVjdCh6aXAoY2F0ZWdvcnksIGdlbm90eXBlKSkKZW5kqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTC2SQ4ODRhNzI5OS04NDE4LTQ1ZTQtODJmMy02NTIwNGQ0OGU1NWKEp2NlbGxfaWTZJDg4NGE3Mjk5LTg0MTgtNDVlNC04MmYzLTY1MjA0ZDQ4ZTU1YqRjb2Rl2gPnbWQiIiIKQ29ycmVjdGluZyBmb3IgYWxsIGNvbXBhcmlzb25zIGlzIHByb2JhYmx5IHVuZmFpci4gRnJlcXVlbmNpZXMgYXJlIGJvdW5kIHdpdGhpbiBlYWNoIGNvbHVtbiBhbmQgcm93IChvbmUgbGVzcyBkZWdyZWUgb2YgZnJlZWRvbSkuCgpBbnl3YXksIHRoZSBzYW1wbGUgc2l6ZSBpcyBmYXIgdG9vIGxvdyBmb3IgdGhlIG51bWJlciBvZiBjZWxscywgYW5kIHdlIG5lZWQgYSBtb3JlIHBvd2VyZnVsIHRlc3QuCgpMZXQgdXMgbm93IGNvbXBhcmUgZWFjaCBnZW5vdHlwZSB3aXRoIHRoZSAiYXZlcmFnZSIgZ2Vub3R5cGUgZ3JvdXBpbmcgdGhlIGxvdy1mcmVxdWVuY3kgY2VsbHMgdG9nZXRoZXIuIFdlIGFscmVhZHkga25vdyB0aGUgcG9zdC1ob2MgdGVzdHMgZmFpbCwgYW5kIHdlIHdvbid0IGhhdmUgY2F0ZWdvcnktbGV2ZWwgcmVzb2x1dGlvbiwgYnV0IGEgc2lnbmlmaWNhbnQgZGlmZmVyZW5jZSBtYXkgYmUgYW4gYXJndW1lbnQgZm9yIGluY3JlYXNpbmcgdGhlIHNhbXBsZSBzaXplLCBvciByZXRoaW5raW5nIHRoZSBjYXRlZ29yaWVzLiAKCkFuIGVsYWJvcmF0ZSBhcHByb2FjaCBjYW4gYmUgZm91bmQgaW4gW0thc3MsIDE5ODBdKGh0dHBzOi8vd3d3NC5zdGF0Lm5jc3UuZWR1L35kaWNrZXkvYW5hbHl0aWNzL2RhdGFtaW5lL1JlZmVyZW5jZSUyMFBhcGVycy9rYXNzODAucGRmKS4KClRoZSBzaW1wbGVyIGFwcHJvYWNoIGZvbGxvd2VkIGhlcmUgY29uc2lzdHMgaW4gZ3JvdXBpbmcgYWxsIG9ic2VydmVkIGNvdW50cyBiZWxvdyA1IGludG8gYSBzaW5nbGUgc3ludGhldGljIGNhdGVnb3J5LCBmb3IgZWFjaCBjb2x1bW4gc2VwYXJhdGVseS4gRXhwZWN0ZWQgY291bnRzIGFyZSBzaW1pbGFybHkgZ3JvdXBlZCwgYmFzZWQgb24gdGhlIG9ic2VydmVkIGNvdW50cy4gSWYgc29tZSBleHBlY3RlZCBjb3VudCBpcyBiZWxvdyA1IChpbmNsdWRlZCB0aGUgc3ludGhldGljIGNhdGVnb3J5KSwgd2UgY2Fycnkgb24gdW5sZXNzIHRoaXMgY291bnQgaXMgMC4KIiIiqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTD2SRiOGFkYzU2Ni01ODkzLTQwMmEtYTM1ZC0xMWMwNjQ2MGZiNjKEp2NlbGxfaWTZJGI4YWRjNTY2LTU4OTMtNDAyYS1hMzVkLTExYzA2NDYwZmI2MqRjb2Rl2gJ2bWQiIiIKRHVlIHRvIHRoZSBwcmVzZW5jZSBvZiB6ZXJvcyBpbiBtb3N0IGNvbHVtbnMsIHdlIGhhdmUgdG8gZ3JvdXAgdGhlIGxvdy1mcmVxdWVuY3kgY2VsbHMgaW50byBzaW5nbGUgY2VsbHMgb24gYSBwZXItY29sdW1uIGJhc2lzLiBUaGUgaW5mb3JtYXRpb24gaW4gbG93LWZyZXF1ZW5jeSBjZWxscyBpcyBhbHJlYWR5IGFjY291bnRlZCBmb3IgYnkgdGhlIG90aGVyIGNlbGxzLgoKV2UgY2FuIGFsc28gaW5kaXZpZHVhbGx5IHRlc3QgZWFjaCBjb3VudCBgb2JzZXJ2ZWRfbmAgX2VxdWFsIHRvIG9yIGdyZWF0ZXIgdGhhbiA1XyBpbiBhIGNvbnRpbmdlbmN5IHRhYmxlIHdpdGg6CmBgYAorLS0tLS0tLS0tLS0tKy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsKfCBvYnNlcnZlZF9uIHwgY29sX3RvdGFsIC0gb2JzZXJ2ZWRfbiB8CistLS0tLS0tLS0tLS0rLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKwp8IGV4cGVjdGVkX24gfCBjb2xfdG90YWwgLSBleHBlY3RlZF9uIHwKKy0tLS0tLS0tLS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0rCmBgYApUaGlzIHNlY29uZCBhcHByb2FjaCBpcyBsZXNzIHBvd2VyZnVsLCB0aG91Z2guCgpMZXQgdXMgYmVnaW4gd2l0aCB0aGlzIHNlY29uZCBhcHByb2FjaDoKIiIiqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTD2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzOEp2NlbGxfaWTZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM6Rjb2Rl2adiZWdpbgoJcm93X29rID0gdmVjKGFueSghPSgwKSwgY291bnRzOyBkaW1zPTIpKQoJY29sX29rID0gdmVjKGFueSghPSgwKSwgY291bnRzOyBkaW1zPTEpKQoJY2xlYW5fY291bnRzID0gY291bnRzW3Jvd19vaywgY29sX29rXQoJbnJvd3MsIG5jb2xzID0gc2l6ZShjbGVhbl9jb3VudHMpCmVuZKhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkwtkkYTI1ZWVjZDYtZjU4ZC00OTNkLWE1Y2YtOTQyMTgzMTk4NDlkhKdjZWxsX2lk2SRhMjVlZWNkNi1mNThkLTQ5M2QtYTVjZi05NDIxODMxOTg0OWSkY29kZdlubWQiIiIKRm9yIGZ1cnRoZXIgcmVmZXJlbmNlLCB3ZSBhbHNvIGxvYWQgdGhlIGxhYmVscyBvZiB0aGUgcm93cyAoYGNhdGVnb3JpZXNgKSBhbmQgY29sdW1ucyAoYGdlbm90eXBlc2ApLgoiIiKobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMPZJGMwOWI3NzFjLWFhYjEtNDBjZi1hMjczLTE0YWE2Yzg1NzUxMISnY2VsbF9pZNkkYzA5Yjc3MWMtYWFiMS00MGNmLWEyNzMtMTRhYTZjODU3NTEwpGNvZGXZRW1kIiIiCkNvcnJlY3RpbmcgZm9yIGFsbCB0aGUgY29tcGFyaXNvbnMsIG5vIGRpZmZlcmVuY2VzIHN1cnZpdmU6CiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkw9kkYTVlNjFhNDgtZTA3ZS00OWRjLThjNjEtMTIyNGQxYzQ3ZDEzhKdjZWxsX2lk2SRhNWU2MWE0OC1lMDdlLTQ5ZGMtOGM2MS0xMjI0ZDFjNDdkMTOkY29kZdkvY291bnRzID0gSW50LihkYXRhWyJuYiBnw6huZXMgc3DDqSJdWyJCMzpVMjUiXSmobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMLZJDExYWM1ZjZhLTBmNmEtMTFlZS0yNTk4LTExYzdhMDA2NGI0M4SnY2VsbF9pZNkkMTFhYzVmNmEtMGY2YS0xMWVlLTI1OTgtMTFjN2EwMDY0YjQzpGNvZGXZRXVzaW5nIFN0YXRzQmFzZSwgSHlwb3RoZXNpc1Rlc3RzLCBYTFNYLCBTcGFyc2VBcnJheXMsIE11bHRpcGxlVGVzdGluZ6htZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkwtkkZjI4MjVkM2MtNTc3Yi00YjYxLThjOGMtYzg2OWE5ZWM5ZjA3hKdjZWxsX2lk2SRmMjgyNWQzYy01NzdiLTRiNjEtOGM4Yy1jODY5YTllYzlmMDekY29kZdn1bWQiIiIKVG8gdGVzdCB3aGV0aGVyIGEgZ2Vub3R5cGUgZXhoaWJpdHMgYSBkaWZmZXJlbnQgcGFydGl0aW9uIGludG8gY2F0ZWdvcmllcyBvZiBnZW5lcywgb3IgZXF1aXZhbGVudGx5IHdoZXRoZXIgaXQgaXMgZW5yaWNoZWQgaW4gc29tZSBjYXRlZ29yeSwgd2UgZmlyc3QgZGVyaXZlIGFuIGV4cGVjdGVkIHBhcnRpdGlvbiBhdmVyYWdpbmcgdGhlIGNhdGVnb3J5IGZyZXF1ZW5jaWVzIGFjcm9zcyBhbGwgZ2Vub3R5cGVzLgoiIiKobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMPZJDMxZGM1OGRiLTVhNGUtNDdkYy1iZGI4LWZlNmU5YmI0NzIwNISnY2VsbF9pZNkkMzFkYzU4ZGItNWE0ZS00N2RjLWJkYjgtZmU2ZTliYjQ3MjA0pGNvZGXZf2JlZ2luCgljb3JyZWN0ZWRfcGVyX2dlbm90eXBlX3B2YWx1ZXMgPSBhZGp1c3QocGVyX2dlbm90eXBlX3B2YWx1ZXMubnp2YWwsIEhvbG0oKSkKCW1pbmltdW0oY29ycmVjdGVkX3Blcl9nZW5vdHlwZV9wdmFsdWVzKQplbmSobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMLZJDcyY2Y4ZDU1LWE0MjMtNGMyOC1hMzcwLTM3N2Y5ZWY2YTcwZYSnY2VsbF9pZNkkNzJjZjhkNTUtYTQyMy00YzI4LWEzNzAtMzc3ZjllZjZhNzBlpGNvZGXZmWJlZ2luCgljb2xfdG90YWwgPSBzdW0oY2xlYW5fY291bnRzOyBkaW1zPTEpCglleHBlY3RlZF9mcmVxdWVuY2llcyA9IG1lYW4oY2xlYW5fY291bnRzIC4vIGNvbF90b3RhbDsgZGltcz0yKQoJQGFzc2VydCBzdW0oZXhwZWN0ZWRfZnJlcXVlbmNpZXMpIOKJiCAxCmVuZKhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkwtkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2NlhKdjZWxsX2lk2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2WkY29kZdoDbWJlZ2luCglvYnNlcnZlZF9jb3VudHMgPSBjbGVhbl9jb3VudHMKCSMgaW4gdGhlb3J5LCB3ZSBjb3VsZCBhbHNvIHVzZSByZWFsLXZhbHVlZCBjb3VudHMgaW5zdGVhZAoJZXhwZWN0ZWRfY291bnRzID0gQC4gcm91bmQoSW50LCBleHBlY3RlZF9mcmVxdWVuY2llcyAqIGNvbF90b3RhbCkKCW9ic2VydmVkX3JlbWFpbmRlciA9IGNvbF90b3RhbCAuLSBvYnNlcnZlZF9jb3VudHMKCWV4cGVjdGVkX3JlbWFpbmRlciA9IGNvbF90b3RhbCAuLSBleHBlY3RlZF9jb3VudHMKCglwdmFsdWVzID0gc3B6ZXJvcyhucm93cywgbmNvbHMpCglmb3Igcm93IGluIDE6bnJvd3MKCQlmb3IgY29sIGluIDE6bmNvbHMKCQkJCgkJCSMgYnVpbGQgdGhlIGNvbnRpbmdlbmN5IHRhYmxlCgkJCWEgPSBvYnNlcnZlZF9jb3VudHNbcm93LCBjb2xdCgkJCWIgPSBvYnNlcnZlZF9yZW1haW5kZXJbcm93LCBjb2xdCgkJCWMgPSBleHBlY3RlZF9jb3VudHNbcm93LCBjb2xdCgkJCWQgPSBleHBlY3RlZF9yZW1haW5kZXJbcm93LCBjb2xdCgkJCWNvbnRpbmdlbmN5X3RhYmxlID0gWyBhIGIgOyBjIGQgXQoJCQkKCQkJIyBwZXJmb3JtIGEgz4fCsiB0ZXN0IG9mIGhvbW9nZW5laXR5CgkJCWlmIGFsbCg+PSg1KSwgY29udGluZ2VuY3lfdGFibGUpCgkJCQlwdmFsID0gcHZhbHVlKENoaXNxVGVzdChjb250aW5nZW5jeV90YWJsZSkpCgkJCQkjIG5vdGU6IEZpc2hlckV4YWN0VGVzdChhLCBiLCBjLCBkKSBnaXZlcyB2ZXJ5IHNpbWlsYXIgcmVzdWx0cwoJCQkJI3B2YWwgPSBwdmFsdWUoRmlzaGVyRXhhY3RUZXN0KGEsIGIsIGMsIGQpOyBtZXRob2Q9Om1pbmxpa2UpCgkJCQkKCQkJCXB2YWx1ZXNbcm93LCBjb2xdID0gcHZhbAoJCQllbmQKCQllbmQKCWVuZAoJcHZhbHVlcwplbmSobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMLZJDQ2YzliZTA3LTNiYjQtNDk5Yy1hODE5LTdhODdjNzNiNmU0MoSnY2VsbF9pZNkkNDZjOWJlMDctM2JiNC00OTljLWE4MTktN2E4N2M3M2I2ZTQypGNvZGXaAZMjIHdpdGggY29ycmVjdGlvbiwgbm8gZGlmZmVyZW5jZXMgc3Vydml2ZQpiZWdpbgoJIyBzZWUgaHR0cHM6Ly9naXRodWIuY29tL2p1bGlhbmdlaHJpbmcvTXVsdGlwbGVUZXN0aW5nLmpsI2hvbG0KCWNvcnJlY3RlZF9wdmFsdWVzID0gYWRqdXN0KHB2YWx1ZXMubnp2YWwsIEhvbG0oKSkKCXNpZ25pZmljYW50ID0gY29ycmVjdGVkX3B2YWx1ZXMgLjw9IC4wNQoJc2lnbmlmaWNhbnRfcHZhbHVlcyA9IGNvcHkocHZhbHVlcykKCXNpZ25pZmljYW50X3B2YWx1ZXMubnp2YWwgLj0gMAoJc2lnbmlmaWNhbnRfcHZhbHVlcy5uenZhbFtzaWduaWZpY2FudF0gPSBjb3JyZWN0ZWRfcHZhbHVlc1tzaWduaWZpY2FudF0KCXNpZ25pZmljYW50X3B2YWx1ZXMgPSBkcm9wemVyb3Moc2lnbmlmaWNhbnRfcHZhbHVlcykKZW5kqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTC2SQxMjg2NjhjMy0yODJkLTQ0NTMtODRhNi1jZjJjMjlkNzE0MGaEp2NlbGxfaWTZJDEyODY2OGMzLTI4MmQtNDQ1My04NGE2LWNmMmMyOWQ3MTQwZqRjb2Rl2WZtZCIiIgpIYWQgd2UgZm91bmQgZGlmZmVyZW5jZXMsIHdlIGNvdWxkIGdldCB0aGUgY29ycmVzcG9uZGluZyBjYXRlZ29yeS1nZW5vdHlwZSBwYWlycyBhcyBmb2xsb3dzOgoiIiKobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMPZJDVlOTRhNTE3LWRiNDYtNDg2NC1iNzE3LTViNDU0Mzg4NGRmZoSnY2VsbF9pZNkkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZmpGNvZGXZOmRhdGEgPSBYTFNYLm9wZW54bHN4KCIuLi9kYXRhL3Jhdy9nZW5lc19zcGVjaWZpcXVlcy54bHN4IimobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMLZJDhkZDVkNGI5LTVhMzItNGE5NS04ZjM4LTdmM2U1Yjk4ZTJkOYSnY2VsbF9pZNkkOGRkNWQ0YjktNWEzMi00YTk1LThmMzgtN2YzZTViOThlMmQ5pGNvZGXZ321kIiIiCldlIGZpcnN0IGxvYWQgdGhlIGNvdW50IGRhdGEuCgohISEKCVRoZSBub3RlYm9vayBpcyBhc3N1bWVkIHRvIHJ1biBmcm9tIGEgY2hpbGQgZGlyZWN0b3J5ICgqZS5nLiogYG5vdGVib29rc2ApIG9mIHRoZSBwcm9qZWN0IHJvb3QsIGFuZCB0aGUgZGF0YSBmaWxlcyBhcmUgZXhwZWN0ZWQgdG8gYmUgZm91bmQgaW4gYGRhdGEvcmF3YCwgZnJvbSB0aGUgcHJvamVjdCByb290LgoiIiKobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMPZJGIzMTRhZGQ3LWE2ZjUtNDJmMC1iYzlhLWJiYTc0ODU0M2ZhMoSnY2VsbF9pZNkkYjMxNGFkZDctYTZmNS00MmYwLWJjOWEtYmJhNzQ4NTQzZmEypGNvZGXZa21kIiIiCk91dCBvZiBjdXJpb3NpdHksIHdpdGggbm8gY29ycmVjdGlvbiBmb3IgbXVsdGlwbGUgY29tcGFyaXNvbnMsIHdlIGZpbmQgYSBmZXcgcC12YWx1ZXMgYmVsb3cgMC4wNToKIiIiqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTDq25vdGVib29rX2lk2SRhNDNlMGNiNi0wZjljLTExZWUtM2Y0ZS1iNzFhYzEzMzcwYTSraW5fdGVtcF9kaXLCqG1ldGFkYXRhgA=="; +window.pluto_statefile = "data:;base64,3gARpWJvbmRzgKxjZWxsX3Jlc3VsdHPeABfZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MoqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHmFpnByZWZpeKNBbnmoZWxlbWVudHPcABeSAZKjIkQiqnRleHQvcGxhaW6SApKjIk0iqnRleHQvcGxhaW6SA5KjIk4iqnRleHQvcGxhaW6SBJKjIk8iqnRleHQvcGxhaW6SBZKjIlQiqnRleHQvcGxhaW6SBpKjIlUiqnRleHQvcGxhaW6SB5KjIlYiqnRleHQvcGxhaW6SCJKjIlciqnRleHQvcGxhaW6SCZKjIkEiqnRleHQvcGxhaW6SCpKjIkIiqnRleHQvcGxhaW6SC5KjIkoiqnRleHQvcGxhaW6SDJKjIksiqnRleHQvcGxhaW6SDZKjIkwiqnRleHQvcGxhaW6SDpKjIkMiqnRleHQvcGxhaW6SD5KjIkUiqnRleHQvcGxhaW6SEJKjIkYiqnRleHQvcGxhaW6SEZKjIkciqnRleHQvcGxhaW6SEpKjIkgiqnRleHQvcGxhaW6SE5KjIkkiqnRleHQvcGxhaW6SFJKjIlAiqnRleHQvcGxhaW6SFZKjIlEiqnRleHQvcGxhaW6SFpKjIlMiqnRleHQvcGxhaW6SF5KoIkF1Y3VuZSKqdGV4dC9wbGFpbqR0eXBlpUFycmF5rHByZWZpeF9zaG9ydKCob2JqZWN0aWSwY2FiZWJhOGQ4ZjY3Yjk3N6RtaW1l2SFhcHBsaWNhdGlvbi92bmQucGx1dG8udHJlZStvYmplY3Sscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpY/a5P2CwcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MrlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgFndda1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTOKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R5haZwcmVmaXi1RGljdHtTdHJpbmcsIEZsb2F0NjR9qGVsZW1lbnRz3AAQkpKlIkcyMyKqdGV4dC9wbGFpbpKoMC45NTMwMDaqdGV4dC9wbGFpbpKSpSJHMjkiqnRleHQvcGxhaW6SqDAuODQwMTUyqnRleHQvcGxhaW6SkqQiRzUiqnRleHQvcGxhaW6SqDAuODk3Mzg2qnRleHQvcGxhaW6SkqQiRzIiqnRleHQvcGxhaW6SqTAuMDExMzI4Map0ZXh0L3BsYWlukpKlIkcyMiKqdGV4dC9wbGFpbpKoMC4zODQyMjeqdGV4dC9wbGFpbpKSpSJHMTAiqnRleHQvcGxhaW6SqzAuMDAwODAxODQzqnRleHQvcGxhaW6SkqQiRzgiqnRleHQvcGxhaW6SqTAuMDYxNzU2Mqp0ZXh0L3BsYWlukpKlIkcxMyKqdGV4dC9wbGFpbpKoMC44ODc5MzGqdGV4dC9wbGFpbpKSpCJHMSKqdGV4dC9wbGFpbpKnMC43MTI1Nqp0ZXh0L3BsYWlukpKlIkczMCKqdGV4dC9wbGFpbpKoMC44NDIxNTGqdGV4dC9wbGFpbpKSpSJHNzciqnRleHQvcGxhaW6SqDAuODQxNjI1qnRleHQvcGxhaW6SkqUiRzExIqp0ZXh0L3BsYWlukqgwLjE5Mjg1Mqp0ZXh0L3BsYWlukpKlIkcxNyKqdGV4dC9wbGFpbpKoMC44MTA5NTiqdGV4dC9wbGFpbpKSpSJHMTQiqnRleHQvcGxhaW6SqjAuMDAxODc1MzGqdGV4dC9wbGFpbpKSpCJHNyKqdGV4dC9wbGFpbpKoMC42MTkyNDOqdGV4dC9wbGFpbpKSpCJHNiKqdGV4dC9wbGFpbpKoMC41MTMzNDaqdGV4dC9wbGFpbqR0eXBlpERpY3SscHJlZml4X3Nob3J0pERpY3Sob2JqZWN0aWSwNjczMDRmZjVjNDljOWFiYaRtaW1l2SFhcHBsaWNhdGlvbi92bmQucGx1dG8udHJlZStvYmplY3Sscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpaJ0uBFewcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDkzNDJlNDg5LWEyOTctNGM2Ny04MzI0LWNiNDE4MDFhZjcxM7lkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgACWmK1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQ2ZDc2OGVjMi1mOWFkLTRjYzctYTJkZi00ZWViMWE3MmNkNDSKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R52Wk8ZGl2IGNsYXNzPSJtYXJrZG93biI+PHA+R2Vub3R5cGVzIEcxMCBhbmQgRzE0IHNpZ25pZmljYW50bHkgZGlmZmVyIGZyb20gdGhlIGF2ZXJhZ2UgZ2Vub3R5cGUuPC9wPgo8L2Rpdj6kbWltZal0ZXh0L2h0bWyscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpaDejiDOwcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDZkNzY4ZWMyLWY5YWQtNGNjNy1hMmRmLTRlZWIxYTcyY2Q0NLlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgALN6G1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQ3ZTM4Mzk2Ny0yNmRlLTQ5YmQtYTEwNi1kMjE1MjQxZmZkYjGKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R52fYyMMOXMjAgU3BhcnNlTWF0cml4Q1NDe0Zsb2F0NjQsIEludDY0fSB3aXRoIDMgc3RvcmVkIGVudHJpZXM6CuKOoeKggOKggOKggOKggOKggOKggOKggOKggOKggOKggOKOpArijqLioIDioIDioIDioIDioIDioIDioIDioIDioIDioIDijqUK4o6i4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4o6lCuKOouKggOKggOKggOKggOKggOKggOKggOKggOKggOKggOKOpQrijqPioIDioIDioIDioaDioIDiooDioIDioIDioIDioIDijqakbWltZap0ZXh0L3BsYWlurHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZKWP3+jIFsHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQ3ZTM4Mzk2Ny0yNmRlLTQ5YmQtYTEwNi1kMjE1MjQxZmZkYjG5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4GKR9stXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkM2ViOWQzOWMtMmNhMS00MzBlLWIxM2ItMDVjODA5YTgwZDViiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedlZPGRpdiBjbGFzcz0ibWFya2Rvd24iPjxwPkZpcnN0LCB3ZSBleGNsdWRlIHRoZSByb3dzIGFuZCBjb2x1bW5zIG9mIHplcm9zIG9ubHkuPC9wPgo8L2Rpdj6kbWltZal0ZXh0L2h0bWyscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpY/A+j3qwcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDNlYjlkMzljLTJjYTEtNDMwZS1iMTNiLTA1YzgwOWE4MGQ1YrlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgACDn+1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQ1NDhjYTI0NC1kZTRjLTQ3YzItYTY5ZS0wY2E3YTQ0OTAyOGaKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R5haZwcmVmaXivVHVwbGV7QW55LCBBbnl9qGVsZW1lbnRzkKR0eXBlpUFycmF5rHByZWZpeF9zaG9ydKCob2JqZWN0aWSwM2ExMjNmMzJkYzc4Y2U4NKRtaW1l2SFhcHBsaWNhdGlvbi92bmQucGx1dG8udHJlZStvYmplY3Sscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpaJ0gVkuwcGVyc2lzdF9qc19zdGF0ZcO3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZrlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzU8NtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkODg0YTcyOTktODQxOC00NWU0LTgyZjMtNjUyMDRkNDhlNTViiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedoHBDxkaXYgY2xhc3M9Im1hcmtkb3duIj48cD5UaGUgc2FtcGxlIHNpemUgaXMgdG9vIGxvdyBpZiB3ZSBjb25zaWRlciB0aGUgbGFyZ2UgbnVtYmVyIG9mIGNlbGxzLCBhbmQgd2UgbmVlZCBhIG1vcmUgcG93ZXJmdWwgdGVzdC4gTGV0IHVzIG5vdyBjb21wYXJlIGVhY2ggZ2Vub3R5cGUgd2l0aCB0aGUgJnF1b3Q7YXZlcmFnZSZxdW90OyBnZW5vdHlwZSwgZ3JvdXBpbmcgdGhlIGxvdy1mcmVxdWVuY3kgY2VsbHMgdG9nZXRoZXIuPC9wPgo8cD5XZSBhbHJlYWR5IGtub3cgdGhlIHBvc3QtaG9jIHRlc3RzIGZhaWwsIHRoZXJlZm9yZSB3ZSB3b24mIzM5O3QgaGF2ZSBjYXRlZ29yeS1sZXZlbCByZXNvbHV0aW9uLiBIb3dldmVyLCBhIHNpZ25pZmljYW50IGRpZmZlcmVuY2UgaXMgc3RpbGwgcG9zc2libGUgaGVyZSBhcyB0aGUgdGVzdCB3aWxsIGN1bXVsYXRlIHRoZSBkaWZmZXJlbmNlcyBmb3IgdGhlIGRpZmZlcmVudCBjYXRlZ29yaWVzLiBUaGUgaW5kaXZpZHVhbCBkaWZmZXJlbmNlcyBzaG91bGQgYmUgZGV0ZWN0YWJsZSBpbmNyZWFzaW5nIHRoZSBzYW1wbGUgc2l6ZS48L3A+CjxoMT5EaXNjbGFpbWVyPC9oMT4KPHA+VGhlIGZvbGxvd2luZyBhbmFseXNpcyBpcyBhIHNlY29uZCBpdGVyYXRpb24gbW90aXZhdGVkIGJ5IGFuIGVycm9yIGluIHRoZSBmaXJzdCBpdGVyYXRpb24uIFRoZSBoaXN0b3J5IG9mIHRoZSBwcmVzZW50IG5vdGVib29rIGNhbiBiZSBmb3VuZCA8YSBocmVmPSJodHRwczovL2dpdGxhYi5wYXN0ZXVyLmZyL2ZsYXVyZW50L3Byb2plY3QxOTQ0OS8tL2Jsb2IvbWFpbi9ub3RlYm9va3MvZ2VuZXNfY2hpc3FfdGVzdHMuamwiPmhlcmU8L2E+LjwvcD4KPHA+VGhlIGNhdGVnb3JpZXMgd2VyZSBncm91cGVkIGJhc2VkIG9uIHRoZSBvYnNlcnZlZCBjb3VudHMsIHdoZXJlYXMgdGhlIG1pbmltdW0tNSBjcml0ZXJpb24gYWN0dWFsbHkgYXBwbGllcyB0byB0aGUgZXhwZWN0ZWQgY291bnRzLiBUaGlzIGlzIGZpeGVkIGluIHRoaXMgdmVyc2lvbiBvZiB0aGUgYW5hbHlzaXMuPC9wPgo8cD5JbiBhZGRpdGlvbiwgZnJvbSB0aGUgZmlyc3QgaXRlcmF0aW9uIG9mIHRoZSBhbmFseXNpcywgd2Uga25vdyB0aGF0IGNvbnRyb2xsaW5nIHRoZSBmYW1pbHktd2lzZSBlcnJvciByYXRlIHdvdWxkIG5vdCBhbGxvdyB0byByZWplY3QgYW55IG51bGwgaHlwb3RoZXNpcy4gV2UgdGhlcmVmb3JlIGNvbnNpZGVyIGNvbnRyb2xsaW5nIHRoZSBmYWxzZSBkaXNjb3ZlcnkgcmF0ZSBpbnN0ZWFkLCBhcyBkZXNjcmliZWQgaW4gPGEgaHJlZj0iaHR0cHM6Ly9kb2kub3JnLzEwLjEwOTMvYmlvbWV0LzkzLjMuNDkxIj5CZW5qYW1pbmkgPGVtPmV0IGFsLjwvZW0+LCAyMDA2PC9hPi48L3A+CjxoMT5Hcm91cGluZyBwcm9jZWR1cmU8L2gxPgo8cD5BbiBlbGFib3JhdGUgZ3JvdXBpbmcgYXBwcm9hY2ggY2FuIGJlIGZvdW5kIGluIDxhIGhyZWY9Imh0dHBzOi8vd3d3NC5zdGF0Lm5jc3UuZWR1L35kaWNrZXkvYW5hbHl0aWNzL2RhdGFtaW5lL1JlZmVyZW5jZSYjMzc7MjBQYXBlcnMva2FzczgwLnBkZiI+S2FzcywgMTk4MDwvYT4uPC9wPgo8cD5UaGUgc2ltcGxlciBhcHByb2FjaCBmb2xsb3dlZCBoZXJlIGNvbnNpc3RzIGluIGdyb3VwaW5nIGFsbCB0aGUgY2F0ZWdvcmllcyB3aXRoIGFuIGV4cGVjdGVkIGNvdW50IGJlbG93IDUgaW50byBhIHNpbmdsZSBzeW50aGV0aWMgY2F0ZWdvcnksIGZvciBlYWNoIGNvbHVtbiBzZXBhcmF0ZWx5LiBPYnNlcnZlZCBjb3VudHMgYXJlIHNpbWlsYXJseSBncm91cGVkLCBiYXNlZCBvbiB0aGUgZXhwZWN0ZWQgY291bnRzLjwvcD4KPC9kaXY+pG1pbWWpdGV4dC9odG1srHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZKWfvs2g0sHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQ4ODRhNzI5OS04NDE4LTQ1ZTQtODJmMy02NTIwNGQ0OGU1NWK5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4ADqDVtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkYjhhZGM1NjYtNTg5My00MDJhLWEzNWQtMTFjMDY0NjBmYjYyiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedoC6TxkaXYgY2xhc3M9Im1hcmtkb3duIj48cD5EdWUgdG8gdGhlIHByZXNlbmNlIG9mIHplcm9zIGluIG1vc3QgY29sdW1ucywgd2UgaGF2ZSB0byBncm91cCB0aGUgbG93LWZyZXF1ZW5jeSBjZWxscyBpbnRvIHNpbmdsZSBjZWxscyBvbiBhIHBlci1jb2x1bW4gYmFzaXMuIFRoZSBpbmZvcm1hdGlvbiBpbiBsb3ctZnJlcXVlbmN5IGNlbGxzIGlzIGFscmVhZHkgYWNjb3VudGVkIGZvciBieSB0aGUgb3RoZXIgY2VsbHMuPC9wPgo8cD5XZSBjYW4gYWxzbyBpbmRpdmlkdWFsbHkgdGVzdCBlYWNoIGNvdW50IDxjb2RlPm9ic2VydmVkX248L2NvZGU+IDxlbT5lcXVhbCB0byBvciBncmVhdGVyIHRoYW4gNTwvZW0+IGluIGEgY29udGluZ2VuY3kgdGFibGUgd2l0aDo8L3A+CjxwcmU+PGNvZGU+JiM0MzstLS0tLS0tLS0tLS0mIzQzOy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSYjNDM7Cnwgb2JzZXJ2ZWRfbiB8IGNvbF90b3RhbCAtIG9ic2VydmVkX24gfAomIzQzOy0tLS0tLS0tLS0tLSYjNDM7LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tJiM0MzsKfCBleHBlY3RlZF9uIHwgY29sX3RvdGFsIC0gZXhwZWN0ZWRfbiB8CiYjNDM7LS0tLS0tLS0tLS0tJiM0MzstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0mIzQzOzwvY29kZT48L3ByZT4KPHA+VGhpcyBzZWNvbmQgYXBwcm9hY2ggaXMgbGVzcyBwb3dlcmZ1bCwgdGhvdWdoLjwvcD4KPHA+TGV0IHVzIGJlZ2luIHdpdGggdGhpcyBzZWNvbmQgYXBwcm9hY2g6PC9wPgo8L2Rpdj6kbWltZal0ZXh0L2h0bWyscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpY/A//gmwcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJGI4YWRjNTY2LTU4OTMtNDAyYS1hMzVkLTExYzA2NDYwZmI2MrlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgAEStW1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzOKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R5g6hlbGVtZW50c5KSAZKiMjCqdGV4dC9wbGFpbpICkqIyMKp0ZXh0L3BsYWlupHR5cGWlVHVwbGWob2JqZWN0aWSwNmUyNjRmN2RiODk1OWZiZqRtaW1l2SFhcHBsaWNhdGlvbi92bmQucGx1dG8udHJlZStvYmplY3Sscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpY/bo/KiwcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM7lkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzcRStXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkYTI1ZWVjZDYtZjU4ZC00OTNkLWE1Y2YtOTQyMTgzMTk4NDlkiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedmuPGRpdiBjbGFzcz0ibWFya2Rvd24iPjxwPkZvciBmdXJ0aGVyIHJlZmVyZW5jZSwgd2UgYWxzbyBsb2FkIHRoZSBsYWJlbHMgb2YgdGhlIHJvd3MgJiM0MDs8Y29kZT5jYXRlZ29yaWVzPC9jb2RlPiYjNDE7IGFuZCBjb2x1bW5zICYjNDA7PGNvZGU+Z2Vub3R5cGVzPC9jb2RlPiYjNDE7LjwvcD4KPC9kaXY+pG1pbWWpdGV4dC9odG1srHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZKWPwPn+ZsHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SRhMjVlZWNkNi1mNThkLTQ5M2QtYTVjZi05NDIxODMxOTg0OWS5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4AAnextXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkYTVlNjFhNDgtZTA3ZS00OWRjLThjNjEtMTIyNGQxYzQ3ZDEziqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedoD/TIzw5cyMCBNYXRyaXh7SW50NjR9OgogIDEgICAxICAwICAgMiAgIDAgICAxICAgMiAgIDAgIDEgIDEgIDAgICAxICAwICAwICAwICAwICAwICAgMCAgIDEgICAzCiAgMiAgIDQgIDAgICA4ICAgMSAgIDEgICAzICAgNCAgMyAgMiAgMyAgIDMgIDAgIDAgIDAgIDAgIDAgICAwICAgMyAgIDMKICAwICAgMCAgMCAgIDEgICAzICAgMSAgIDAgICAwICAwICAxICAwICAgNiAgMCAgMCAgMCAgMiAgMSAgIDUgICAwICAgNAogIDAgICAwICAwICAgMCAgIDAgICAwICAgMSAgIDIgIDAgIDAgIDAgICAzICAxICAwICAwICAwICAyICAgMCAgIDEgICAzCiAgMCAgIDEgIDAgICAxICAgMSAgIDAgICAxICAgMCAgMSAgMSAgMCAgIDMgIDAgIDAgIDAgIDEgIDAgICAwICAgMiAgIDUKICAwICAgMCAgMCAgIDUgICAwICAgMSAgIDIgICAyICAzICAwICAxICAxMiAgMCAgMCAgMCAgMSAgMCAgIDEgICAwICAgOAogIDEgICA0ICAwICAgMCAgIDAgICAyICAgMSAgIDAgIDEgIDEgIDAgICAwICAxICAwICAwICAwICAxICAgMCAgIDEgICAxCiAg4ouuICAgICAgICAgICAgICAgICAg4ouuICAgICAgICAgICAgICAgIOKLriAgICAgICAgICAgICAgIOKLriAgICAgICAgICAgICAKICAxICAgMCAgMCAgIDIgICAwICAgMCAgIDAgICAwICAxICAwICAwICAgMSAgMCAgMCAgMCAgMCAgMCAgIDAgICAyICAgMAogIDEgICAyICAwICAgMSAgIDAgICAwICAgMCAgIDAgIDAgIDAgIDAgICAyICAwICAwICAwICAwICAwICAgMCAgIDEgICAxCiAgMCAgIDIgIDAgICA0ICAgMSAgIDIgICAwICAgNCAgNSAgMCAgMCAgIDMgIDAgIDAgIDAgIDAgIDAgICAwICAgNCAgIDIKICAwICAgMSAgMCAgIDIgICAwICAgMCAgIDAgICAwICAwICAwICAwICAgMSAgMCAgMCAgMCAgMCAgMCAgIDAgICAwICAgMAogIDkgIDUyICAzICAzOSAgMjAgIDE5ICAzMyAgMzQgIDUgIDIgIDYgIDI3ICAxICAwICA3ICAzICA3ICAgNyAgMTcgIDQ5CiAxMiAgNTAgIDYgIDI0ICAxNyAgMTYgIDM2ICAxNiAgNSAgMiAgMyAgIDcgIDIgIDAgIDQgIDUgIDcgIDExICAyNCAgNDWkbWltZap0ZXh0L3BsYWlurHJvb3Rhc3NpZ25lZaZjb3VudHOybGFzdF9ydW5fdGltZXN0YW1wy0HZKWP2isyrsHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SRhNWU2MWE0OC1lMDdlLTQ5ZGMtOGM2MS0xMjI0ZDFjNDdkMTO5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4RjchPtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkYzA5Yjc3MWMtYWFiMS00MGNmLWEyNzMtMTRhYTZjODU3NTEwiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedlfPGRpdiBjbGFzcz0ibWFya2Rvd24iPjxwPkNvcnJlY3RpbmcgZm9yIGFsbCB0aGUgY29tcGFyaXNvbnMsIG5vIGRpZmZlcmVuY2VzIHN1cnZpdmU6PC9wPgo8L2Rpdj6kbWltZal0ZXh0L2h0bWyscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpY/BAIZKwcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJGMwOWI3NzFjLWFhYjEtNDBjZi1hMjczLTE0YWE2Yzg1NzUxMLlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgACGru1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQxMWFjNWY2YS0wZjZhLTExZWUtMjU5OC0xMWM3YTAwNjRiNDOKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R5oKRtaW1lqnRleHQvcGxhaW6scm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpY/U3ttSwcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDExYWM1ZjZhLTBmNmEtMTFlZS0yNTk4LTExYzdhMDA2NGI0M7lkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lziYHy5a1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SRmMjgyNWQzYy01NzdiLTRiNjEtOGM4Yy1jODY5YTllYzlmMDeKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R52gEPPGRpdiBjbGFzcz0ibWFya2Rvd24iPjxwPlRvIHRlc3Qgd2hldGhlciBhIGdlbm90eXBlIGV4aGliaXRzIGEgZGlmZmVyZW50IHBhcnRpdGlvbiBpbnRvIGNhdGVnb3JpZXMgb2YgZ2VuZXMsIG9yIGVxdWl2YWxlbnRseSB3aGV0aGVyIGl0IGlzIGVucmljaGVkIGluIHNvbWUgY2F0ZWdvcnksIHdlIGZpcnN0IGRlcml2ZSBhbiBleHBlY3RlZCBwYXJ0aXRpb24gYXZlcmFnaW5nIHRoZSBjYXRlZ29yeSBmcmVxdWVuY2llcyBhY3Jvc3MgYWxsIGdlbm90eXBlcy48L3A+CjwvZGl2PqRtaW1lqXRleHQvaHRtbKxyb290YXNzaWduZWXAsmxhc3RfcnVuX3RpbWVzdGFtcMtB2Slj8D6fqbBwZXJzaXN0X2pzX3N0YXRlwrdoYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkZjI4MjVkM2MtNTc3Yi00YjYxLThjOGMtYzg2OWE5ZWM5ZjA3uWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXOAAJAHbVwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJDMxZGM1OGRiLTVhNGUtNDdkYy1iZGI4LWZlNmU5YmI0NzIwNIqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHmFpnByZWZpeLVEaWN0e1N0cmluZywgRmxvYXQ2NH2oZWxlbWVudHPcABCSkqUiRzEzIqp0ZXh0L3BsYWlukqcwLjgzMzg4qnRleHQvcGxhaW6SkqUiRzIzIqp0ZXh0L3BsYWlukqcwLjgzMzg4qnRleHQvcGxhaW6SkqQiRzEiqnRleHQvcGxhaW6SpzAuODMzODiqdGV4dC9wbGFpbpKSpSJHMzAiqnRleHQvcGxhaW6SpzAuODMzODiqdGV4dC9wbGFpbpKSpSJHMjkiqnRleHQvcGxhaW6SpzAuODMzODiqdGV4dC9wbGFpbpKSpSJHNzciqnRleHQvcGxhaW6SpzAuODMzODiqdGV4dC9wbGFpbpKSpCJHNSKqdGV4dC9wbGFpbpKnMC44MzM4OKp0ZXh0L3BsYWlukpKlIkcxMSKqdGV4dC9wbGFpbpKoMC41Mzk5ODWqdGV4dC9wbGFpbpKSpSJHMTciqnRleHQvcGxhaW6SpzAuODMzODiqdGV4dC9wbGFpbpKSpCJHMiKqdGV4dC9wbGFpbpKpMC4wNTI4NjQzqnRleHQvcGxhaW6SkqUiRzIyIqp0ZXh0L3BsYWlukqcwLjgzMzg4qnRleHQvcGxhaW6SkqUiRzEwIqp0ZXh0L3BsYWlukqkwLjAxMTIyNTiqdGV4dC9wbGFpbpKSpSJHMTQiqnRleHQvcGxhaW6SqTAuMDEzMTI3Mqp0ZXh0L3BsYWlukpKkIkc3Iqp0ZXh0L3BsYWlukqcwLjgzMzg4qnRleHQvcGxhaW6SkqQiRzYiqnRleHQvcGxhaW6SpzAuODMzODiqdGV4dC9wbGFpbpKSpCJHOCKqdGV4dC9wbGFpbpKoMC4yMTYxNDeqdGV4dC9wbGFpbqR0eXBlpERpY3SscHJlZml4X3Nob3J0pERpY3Sob2JqZWN0aWSwYmUwOTVlYjc3MWZlYzA5Y6RtaW1l2SFhcHBsaWNhdGlvbi92bmQucGx1dG8udHJlZStvYmplY3Sscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpaJ0uVfOwcGVyc2lzdF9qc19zdGF0ZcO3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDMxZGM1OGRiLTVhNGUtNDdkYy1iZGI4LWZlNmU5YmI0NzIwNLlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzU9ktXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkNzJjZjhkNTUtYTQyMy00YzI4LWEzNzAtMzc3ZjllZjZhNzBliqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9keYWmcHJlZml4skRpY3R7QW55LCBGbG9hdDY0fahlbGVtZW50c9wAFJKSoyJRIqp0ZXh0L3BsYWlukqowLjAwMTU2MjA5qnRleHQvcGxhaW6SkqMiVCKqdGV4dC9wbGFpbpKoMC4wMTMyNTKqdGV4dC9wbGFpbpKSoyJDIqp0ZXh0L3BsYWlukqkwLjAxMjk0MjSqdGV4dC9wbGFpbpKSoyJQIqp0ZXh0L3BsYWlukqkwLjAxODM2NzaqdGV4dC9wbGFpbpKSoyJWIqp0ZXh0L3BsYWlukqkwLjAxNjk3NTiqdGV4dC9wbGFpbpKSoyJMIqp0ZXh0L3BsYWlukqgwLjE4OTQzMqp0ZXh0L3BsYWlukpKjIk8iqnRleHQvcGxhaW6SqTAuMDEyOTE0N6p0ZXh0L3BsYWlukpKjIk0iqnRleHQvcGxhaW6SqTAuMDM1NjUzNqp0ZXh0L3BsYWlukpKjIk4iqnRleHQvcGxhaW6SqTAuMDI1ODQ2NKp0ZXh0L3BsYWlukpKoIkF1Y3VuZSKqdGV4dC9wbGFpbpKoMC4yMjg1MTiqdGV4dC9wbGFpbpKSoyJIIqp0ZXh0L3BsYWlukqowLjAwNTA1MjY1qnRleHQvcGxhaW6SkqMiRCKqdGV4dC9wbGFpbpKpMC4wMTA5MjY2qnRleHQvcGxhaW6SkqMiRyKqdGV4dC9wbGFpbpKpMC4wMzUxMjk5qnRleHQvcGxhaW6SkqMiRSKqdGV4dC9wbGFpbpKpMC4wMTcyMzU0qnRleHQvcGxhaW6SkqMiVSKqdGV4dC9wbGFpbpKpMC4wMjM2NTIzqnRleHQvcGxhaW6SkqMiSiKqdGV4dC9wbGFpbpKpMC4wMTQyODcyqnRleHQvcGxhaW6SkqMiSSKqdGV4dC9wbGFpbpKqMC4wMDQxNjI2OKp0ZXh0L3BsYWlukpKjIlMiqnRleHQvcGxhaW6SqDAuMjQyMDI2qnRleHQvcGxhaW6SkqMiSyKqdGV4dC9wbGFpbpKpMC4wODA4NjIzqnRleHQvcGxhaW6SkqMiRiKqdGV4dC9wbGFpbpKmMC4wMTEyqnRleHQvcGxhaW6kdHlwZaREaWN0rHByZWZpeF9zaG9ydKREaWN0qG9iamVjdGlksGJlMTUyZDU1ZTBiM2Y0OTmkbWltZdkhYXBwbGljYXRpb24vdm5kLnBsdXRvLnRyZWUrb2JqZWN0rHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZKWP3L9NbsHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQ3MmNmOGQ1NS1hNDIzLTRjMjgtYTM3MC0zNzdmOWVmNmE3MGW5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4lH7JwtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2NliqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedn3MjDDlzIwIFNwYXJzZU1hdHJpeENTQ3tGbG9hdDY0LCBJbnQ2NH0gd2l0aCA1MSBzdG9yZWQgZW50cmllczoK4o6h4qCA4qCQ4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4o6kCuKOouKggOKggOKggOKggOKggOKggOKggOKggOKggOKggOKOpQrijqLioJrioJjioJvioIvioILioJjioIDioIDioILioJvijqUK4o6i4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCQ4o6lCuKOo+KjpOKioOKjpOKjpOKhhOKipOKggOKihOKjpOKjpOKOpqRtaW1lqnRleHQvcGxhaW6scm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpY/fndqewcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZblkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzkpNngC1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQ0NmM5YmUwNy0zYmI0LTQ5OWMtYTgxOS03YTg3YzczYjZlNDKKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R52fYyMMOXMjAgU3BhcnNlTWF0cml4Q1NDe0Zsb2F0NjQsIEludDY0fSB3aXRoIDAgc3RvcmVkIGVudHJpZXM6CuKOoeKggOKggOKggOKggOKggOKggOKggOKggOKggOKggOKOpArijqLioIDioIDioIDioIDioIDioIDioIDioIDioIDioIDijqUK4o6i4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4o6lCuKOouKggOKggOKggOKggOKggOKggOKggOKggOKggOKggOKOpQrijqPioIDioIDioIDioIDioIDioIDioIDioIDioIDioIDijqakbWltZap0ZXh0L3BsYWlurHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZKWidICTVsHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQ0NmM5YmUwNy0zYmI0LTQ5OWMtYTgxOS03YTg3YzczYjZlNDK5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4AAdB/tXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkMTI4NjY4YzMtMjgyZC00NDUzLTg0YTYtY2YyYzI5ZDcxNDBmiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedmAPGRpdiBjbGFzcz0ibWFya2Rvd24iPjxwPkhhZCB3ZSBmb3VuZCBkaWZmZXJlbmNlcywgd2UgY291bGQgZ2V0IHRoZSBjb3JyZXNwb25kaW5nIGNhdGVnb3J5LWdlbm90eXBlIHBhaXJzIGFzIGZvbGxvd3M6PC9wPgo8L2Rpdj6kbWltZal0ZXh0L2h0bWyscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpY/BAMXuwcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDEyODY2OGMzLTI4MmQtNDQ1My04NGE2LWNmMmMyOWQ3MTQwZrlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgACHHS1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQwMWZiZjFjOS0xY2VhLTQ1OTMtYTJjNS0wMzg1NGRlZTI0NzOKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R52dA8ZGl2IGNsYXNzPSJtYXJrZG93biI+PHA+VGhpcyBkb2N1bWVudCBpcyBhIFBsdXRvIG5vdGVib29rICYjNDA7b3IgYW4gaHRtbCByZW5kZXJlZCB2ZXJzaW9uIG9mIGl0JiM0MTsgYW5kIHJlcXVpcmVzIDxhIGhyZWY9Imh0dHBzOi8vY29tcHV0YXRpb25hbHRoaW5raW5nLm1pdC5lZHUvU3ByaW5nMjEvaW5zdGFsbGF0aW9uLyI+SnVsaWE8L2E+LjwvcD4KPC9kaXY+pG1pbWWpdGV4dC9odG1srHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZKWPwPFV1sHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQwMWZiZjFjOS0xY2VhLTQ1OTMtYTJjNS0wMzg1NGRlZTI0NzO5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4AAxOEtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZmiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedoBEVhMU1hGaWxlKCIuLi9kYXRhL3Jhdy9nZW5lc19zcGVjaWZpcXVlcy54bHN4IikgY29udGFpbmluZyAyIFdvcmtzaGVldHMKICAgICAgICAgICAgc2hlZXRuYW1lIHNpemUgICAgICAgICAgcmFuZ2UgICAgICAgIAotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICAgICAgIG5iIGfDqG5lcyBzcMOpIDI2eDIyICAgICAgICAgQTE6VjI2ICAgICAgIAogICAgICAgICAgcG91cmNlbnRhZ2UgMjd4MjEgICAgICAgICBBMTpVMjcgICAgICAgCqRtaW1lqnRleHQvcGxhaW6scm9vdGFzc2lnbmVlpGRhdGGybGFzdF9ydW5fdGltZXN0YW1wy0HZKWP2I6z3sHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQ1ZTk0YTUxNy1kYjQ2LTQ4NjQtYjcxNy01YjQ1NDM4ODRkZma5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc50ADhNtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkOGRkNWQ0YjktNWEzMi00YTk1LThmMzgtN2YzZTViOThlMmQ5iqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedoBKjxkaXYgY2xhc3M9Im1hcmtkb3duIj48cD5XZSBmaXJzdCBsb2FkIHRoZSBjb3VudCBkYXRhLjwvcD4KPHA+Tm90ZSB0aGUgbm90ZWJvb2sgaXMgYXNzdW1lZCB0byBydW4gZnJvbSBhIGNoaWxkIGRpcmVjdG9yeSAmIzQwOzxlbT5lLmcuPC9lbT4gPGNvZGU+bm90ZWJvb2tzPC9jb2RlPiYjNDE7IG9mIHRoZSBwcm9qZWN0IHJvb3QsIGFuZCB0aGUgZGF0YSBmaWxlcyBhcmUgZXhwZWN0ZWQgdG8gYmUgZm91bmQgaW4gPGNvZGU+ZGF0YS9yYXc8L2NvZGU+LCBhZ2FpbiBmcm9tIHRoZSBwcm9qZWN0IHJvb3QuPC9wPgo8L2Rpdj6kbWltZal0ZXh0L2h0bWyscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpacrv7UKwcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDhkZDVkNGI5LTVhMzItNGE5NS04ZjM4LTdmM2U1Yjk4ZTJkOblkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgAEl/m1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SRiMzE0YWRkNy1hNmY1LTQyZjAtYmM5YS1iYmE3NDg1NDNmYTKKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R52YU8ZGl2IGNsYXNzPSJtYXJrZG93biI+PHA+T3V0IG9mIGN1cmlvc2l0eSwgd2l0aCBubyBjb3JyZWN0aW9uIGZvciBtdWx0aXBsZSBjb21wYXJpc29ucywgd2UgZmluZCBhIGZldyBwLXZhbHVlcyBiZWxvdyAwLjA1OjwvcD4KPC9kaXY+pG1pbWWpdGV4dC9odG1srHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZKWPwQBDPsHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SRiMzE0YWRkNy1hNmY1LTQyZjAtYmM5YS1iYmE3NDg1NDNmYTK5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4AAlcYtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwqtzdGF0dXNfdHJlZYSkbmFtZahub3RlYm9va6hzdWJ0YXNrc4Smc2F2aW5nhKRuYW1lpnNhdmluZ6hzdWJ0YXNrc4CrZmluaXNoZWRfYXTLQdkpactTtaKqc3RhcnRlZF9hdMtB2Slpy1FLFql3b3Jrc3BhY2WEpG5hbWWpd29ya3NwYWNlqHN1YnRhc2tzgqxpbml0X3Byb2Nlc3OEpG5hbWWsaW5pdF9wcm9jZXNzqHN1YnRhc2tzhKE0hKRuYW1loTSoc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZKWPzqeu8qnN0YXJ0ZWRfYXTLQdkpY/MTW4qhMYSkbmFtZaExqHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2Slj8wxQBapzdGFydGVkX2F0y0HZKWPynPl2oTKEpG5hbWWhMqhzdWJ0YXNrc4CrZmluaXNoZWRfYXTLQdkpY/MRdu6qc3RhcnRlZF9hdMtB2Slj8wxc7qEzhKRuYW1loTOoc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZKWPzE1t1qnN0YXJ0ZWRfYXTLQdkpY/MRh6CrZmluaXNoZWRfYXTLQdkpY/Op/fyqc3RhcnRlZF9hdMtB2Slj8pz5RK5jcmVhdGVfcHJvY2Vzc4SkbmFtZa5jcmVhdGVfcHJvY2Vzc6hzdWJ0YXNrc4KhMYSkbmFtZaExqHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2Slj8eu2A6pzdGFydGVkX2F0y0HZKWPw2BnKoTKEpG5hbWWhMqhzdWJ0YXNrc4CrZmluaXNoZWRfYXTLQdkpY/KczZ+qc3RhcnRlZF9hdMtB2Slj8eu2E6tmaW5pc2hlZF9hdMtB2Slj8pyH5KpzdGFydGVkX2F0y0HZKWPw2Bmsq2ZpbmlzaGVkX2F0y0HZKWPzqf4EqnN0YXJ0ZWRfYXTLQdkpY/DYGY+jcGtnhKRuYW1lo3BrZ6hzdWJ0YXNrc4GoYW5hbHlzaXOEpG5hbWWoYW5hbHlzaXOoc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZKWnK72a6qnN0YXJ0ZWRfYXTLQdkpacrvU7WrZmluaXNoZWRfYXTLQdkpacrvZr6qc3RhcnRlZF9hdMtB2Slpyu9Tk6NydW6EpG5hbWWjcnVuqHN1YnRhc2tzgrByZXNvbHZlX3RvcG9sb2d5hKRuYW1lsHJlc29sdmVfdG9wb2xvZ3moc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZKWnK77d8qnN0YXJ0ZWRfYXTLQdkpacrvkGSoZXZhbHVhdGWEpG5hbWWoZXZhbHVhdGWoc3VidGFza3OBoTGEpG5hbWWhMahzdWJ0YXNrc4CrZmluaXNoZWRfYXTLQdkpacrv7V+qc3RhcnRlZF9hdMtB2Slpyu/Gk6tmaW5pc2hlZF9hdMtB2Slpyu/9wapzdGFydGVkX2F0y0HZKWnK77d8q2ZpbmlzaGVkX2F0y0HZKWnK7/3BqnN0YXJ0ZWRfYXTLQdkpacrvkEerZmluaXNoZWRfYXTAqnN0YXJ0ZWRfYXTLQdkpY++/mw+xY2VsbF9kZXBlbmRlbmNpZXPeABfZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MoS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MrRkb3duc3RyZWFtX2NlbGxzX21hcIKpZ2Vub3R5cGVzktkkNTQ4Y2EyNDQtZGU0Yy00N2MyLWE2OWUtMGNhN2E0NDkwMjhm2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTOqY2F0ZWdvcmllc5LZJDcyY2Y4ZDU1LWE0MjMtNGMyOC1hMzcwLTM3N2Y5ZWY2YTcwZdkkNTQ4Y2EyNDQtZGU0Yy00N2MyLWE2OWUtMGNhN2E0NDkwMjhmsnVwc3RyZWFtX2NlbGxzX21hcIKjdmVjkKRkYXRhkdkkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZm2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTOEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTO0ZG93bnN0cmVhbV9jZWxsc19tYXCBtHBlcl9nZW5vdHlwZV9wdmFsdWVzkdkkMzFkYzU4ZGItNWE0ZS00N2RjLWJkYjgtZmU2ZTliYjQ3MjA0snVwc3RyZWFtX2NlbGxzX21hcN4AEqlnZW5vdHlwZXOR2SQ5YzNiOGViMi1hMTYwLTQyNDYtYTVjNy01OTZhODZjNzNkNjKkRGljdJChOpCvb2JzZXJ2ZWRfY291bnRzkdkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2Nlo3N1bZChIZCkaGNhdJCjYW55kKdGbG9hdDY0kKZTdHJpbmeQpW5jb2xzkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzo2FsbJClcHVzaCGQr2V4cGVjdGVkX2NvdW50c5HZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZaZwdmFsdWWQoj49kKZjb2xfb2uR2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzOpQ2hpc3FUZXN0kNkkNmQ3NjhlYzItZjlhZC00Y2M3LWEyZGYtNGVlYjFhNzJjZDQ0hLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkNmQ3NjhlYzItZjlhZC00Y2M3LWEyZGYtNGVlYjFhNzJjZDQ0tGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkN2UzODM5NjctMjZkZS00OWJkLWExMDYtZDIxNTI0MWZmZGIxhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkN2UzODM5NjctMjZkZS00OWJkLWExMDYtZDIxNTI0MWZmZGIxtGRvd25zdHJlYW1fY2VsbHNfbWFwgdkjdW5jb3JyZWN0ZWRfcHZhbHVlc19iZWxvd190aHJlc2hvbGSQsnVwc3RyZWFtX2NlbGxzX21hcIWhPJCpZHJvcHplcm9zkKdwdmFsdWVzkdkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2NlpmlzbGVzc5CkY29weZDZJDNlYjlkMzljLTJjYTEtNDMwZS1iMTNiLTA1YzgwOWE4MGQ1YoS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDNlYjlkMzljLTJjYTEtNDMwZS1iMTNiLTA1YzgwOWE4MGQ1YrRkb3duc3RyZWFtX2NlbGxzX21hcICydXBzdHJlYW1fY2VsbHNfbWFwgqdAbWRfc3RykKhnZXRpbmRleJDZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZoS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZrRkb3duc3RyZWFtX2NlbGxzX21hcISjcm93kKhnZW5vdHlwZZCjY29skKhjYXRlZ29yeZCydXBzdHJlYW1fY2VsbHNfbWFwiKlnZW5vdHlwZXOR2SQ5YzNiOGViMi1hMTYwLTQyNDYtYTVjNy01OTZhODZjNzNkNjKmcm93X29rkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzpmZpbmRuepCnY29sbGVjdJCmY29sX29rkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzo3ppcJCqY2F0ZWdvcmllc5HZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MrNzaWduaWZpY2FudF9wdmFsdWVzkdkkNDZjOWJlMDctM2JiNC00OTljLWE4MTktN2E4N2M3M2I2ZTQy2SQ4ODRhNzI5OS04NDE4LTQ1ZTQtODJmMy02NTIwNGQ0OGU1NWKEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SQ4ODRhNzI5OS04NDE4LTQ1ZTQtODJmMy02NTIwNGQ0OGU1NWK0ZG93bnN0cmVhbV9jZWxsc19tYXCAsnVwc3RyZWFtX2NlbGxzX21hcIKnQG1kX3N0cpCoZ2V0aW5kZXiQ2SRiOGFkYzU2Ni01ODkzLTQwMmEtYTM1ZC0xMWMwNjQ2MGZiNjKEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SRiOGFkYzU2Ni01ODkzLTQwMmEtYTM1ZC0xMWMwNjQ2MGZiNjK0ZG93bnN0cmVhbV9jZWxsc19tYXCAsnVwc3RyZWFtX2NlbGxzX21hcIKnQG1kX3N0cpCoZ2V0aW5kZXiQ2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzOEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzO0ZG93bnN0cmVhbV9jZWxsc19tYXCFpnJvd19va5LZJDcyY2Y4ZDU1LWE0MjMtNGMyOC1hMzcwLTM3N2Y5ZWY2YTcwZdkkNTQ4Y2EyNDQtZGU0Yy00N2MyLWE2OWUtMGNhN2E0NDkwMjhmrGNsZWFuX2NvdW50c5LZJDcyY2Y4ZDU1LWE0MjMtNGMyOC1hMzcwLTM3N2Y5ZWY2YTcwZdkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2NlpW5yb3dzkdkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2NlpmNvbF9va5LZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZtkkOTM0MmU0ODktYTI5Ny00YzY3LTgzMjQtY2I0MTgwMWFmNzEzpW5jb2xzktkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2Nl2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTOydXBzdHJlYW1fY2VsbHNfbWFwhqN2ZWOQo2FueZCiIT2QpHNpemWQoj09kKZjb3VudHOR2SRhNWU2MWE0OC1lMDdlLTQ5ZGMtOGM2MS0xMjI0ZDFjNDdkMTPZJGEyNWVlY2Q2LWY1OGQtNDkzZC1hNWNmLTk0MjE4MzE5ODQ5ZIS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJGEyNWVlY2Q2LWY1OGQtNDkzZC1hNWNmLTk0MjE4MzE5ODQ5ZLRkb3duc3RyZWFtX2NlbGxzX21hcICydXBzdHJlYW1fY2VsbHNfbWFwgqdAbWRfc3RykKhnZXRpbmRleJDZJGE1ZTYxYTQ4LWUwN2UtNDlkYy04YzYxLTEyMjRkMWM0N2QxM4S0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJGE1ZTYxYTQ4LWUwN2UtNDlkYy04YzYxLTEyMjRkMWM0N2QxM7Rkb3duc3RyZWFtX2NlbGxzX21hcIGmY291bnRzkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzsnVwc3RyZWFtX2NlbGxzX21hcIKjSW50kKRkYXRhkdkkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZm2SRjMDliNzcxYy1hYWIxLTQwY2YtYTI3My0xNGFhNmM4NTc1MTCEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SRjMDliNzcxYy1hYWIxLTQwY2YtYTI3My0xNGFhNmM4NTc1MTC0ZG93bnN0cmVhbV9jZWxsc19tYXCAsnVwc3RyZWFtX2NlbGxzX21hcIKnQG1kX3N0cpCoZ2V0aW5kZXiQ2SQxMWFjNWY2YS0wZjZhLTExZWUtMjU5OC0xMWM3YTAwNjRiNDOEtHByZWNlZGVuY2VfaGV1cmlzdGljB6djZWxsX2lk2SQxMWFjNWY2YS0wZjZhLTExZWUtMjU5OC0xMWM3YTAwNjRiNDO0ZG93bnN0cmVhbV9jZWxsc19tYXCFqVN0YXRzQmFzZZCkWExTWJHZJDVlOTRhNTE3LWRiNDYtNDg2NC1iNzE3LTViNDU0Mzg4NGRmZq9NdWx0aXBsZVRlc3RpbmeQrFNwYXJzZUFycmF5c5CvSHlwb3RoZXNpc1Rlc3RzkLJ1cHN0cmVhbV9jZWxsc19tYXCA2SRmMjgyNWQzYy01NzdiLTRiNjEtOGM4Yy1jODY5YTllYzlmMDeEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SRmMjgyNWQzYy01NzdiLTRiNjEtOGM4Yy1jODY5YTllYzlmMDe0ZG93bnN0cmVhbV9jZWxsc19tYXCAsnVwc3RyZWFtX2NlbGxzX21hcIKnQG1kX3N0cpCoZ2V0aW5kZXiQ2SQzMWRjNThkYi01YTRlLTQ3ZGMtYmRiOC1mZTZlOWJiNDcyMDSEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SQzMWRjNThkYi01YTRlLTQ3ZGMtYmRiOC1mZTZlOWJiNDcyMDS0ZG93bnN0cmVhbV9jZWxsc19tYXCBvmNvcnJlY3RlZF9wZXJfZ2Vub3R5cGVfcHZhbHVlc5CydXBzdHJlYW1fY2VsbHNfbWFwiaREaWN0kLlCZW5qYW1pbmlIb2NoYmVyZ0FkYXB0aXZlkKZhZGp1c3SQpnZhbHVlc5Cka2V5c5CnY29sbGVjdJCnVHdvU3RlcJCjemlwkLRwZXJfZ2Vub3R5cGVfcHZhbHVlc5HZJDkzNDJlNDg5LWEyOTctNGM2Ny04MzI0LWNiNDE4MDFhZjcxM9kkNzJjZjhkNTUtYTQyMy00YzI4LWEzNzAtMzc3ZjllZjZhNzBlhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkNzJjZjhkNTUtYTQyMy00YzI4LWEzNzAtMzc3ZjllZjZhNzBltGRvd25zdHJlYW1fY2VsbHNfbWFwgrRleHBlY3RlZF9mcmVxdWVuY2llc5HZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZaljb2xfdG90YWyR2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2WydXBzdHJlYW1fY2VsbHNfbWFwjKPiiYiQpERpY3SQo3N1bZCsY2xlYW5fY291bnRzkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzp0Bhc3NlcnSQo3ppcJCmcm93X29rkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzpXRocm93kKEvkK5Bc3NlcnRpb25FcnJvcpCqY2F0ZWdvcmllc5HZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MqRtZWFukNkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2NlhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2NltGRvd25zdHJlYW1fY2VsbHNfbWFwha9vYnNlcnZlZF9jb3VudHOR2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTOvZXhwZWN0ZWRfY291bnRzkdkkOTM0MmU0ODktYTI5Ny00YzY3LTgzMjQtY2I0MTgwMWFmNzEzp3B2YWx1ZXOS2SQ3ZTM4Mzk2Ny0yNmRlLTQ5YmQtYTEwNi1kMjE1MjQxZmZkYjHZJDQ2YzliZTA3LTNiYjQtNDk5Yy1hODE5LTdhODdjNzNiNmU0MrJvYnNlcnZlZF9yZW1haW5kZXKQsmV4cGVjdGVkX3JlbWFpbmRlcpCydXBzdHJlYW1fY2VsbHNfbWFw3gAQtGV4cGVjdGVkX2ZyZXF1ZW5jaWVzkdkkNzJjZjhkNTUtYTQyMy00YzI4LWEzNzAtMzc3ZjllZjZhNzBlp3NwemVyb3OQrGNsZWFuX2NvdW50c5HZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM6Vucm93c5HZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM6E6kKljb2xfdG90YWyR2SQ3MmNmOGQ1NS1hNDIzLTRjMjgtYTM3MC0zNzdmOWVmNmE3MGWoQF9fZG90X1+QpW5jb2xzkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzo2FsbJChLZCmcHZhbHVlkKNJbnSQoj49kKEqkKVyb3VuZJCpQ2hpc3FUZXN0kNkkNDZjOWJlMDctM2JiNC00OTljLWE4MTktN2E4N2M3M2I2ZTQyhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkNDZjOWJlMDctM2JiNC00OTljLWE4MTktN2E4N2M3M2I2ZTQytGRvd25zdHJlYW1fY2VsbHNfbWFwg6tzaWduaWZpY2FudJCxY29ycmVjdGVkX3B2YWx1ZXOQs3NpZ25pZmljYW50X3B2YWx1ZXOR2SQ1NDhjYTI0NC1kZTRjLTQ3YzItYTY5ZS0wY2E3YTQ0OTAyOGaydXBzdHJlYW1fY2VsbHNfbWFwh6ZhZGp1c3SQuUJlbmphbWluaUhvY2hiZXJnQWRhcHRpdmWQojw9kKlkcm9wemVyb3OQp3B2YWx1ZXOR2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2WnVHdvU3RlcJCkY29weZDZJDEyODY2OGMzLTI4MmQtNDQ1My04NGE2LWNmMmMyOWQ3MTQwZoS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDEyODY2OGMzLTI4MmQtNDQ1My04NGE2LWNmMmMyOWQ3MTQwZrRkb3duc3RyZWFtX2NlbGxzX21hcICydXBzdHJlYW1fY2VsbHNfbWFwgqdAbWRfc3RykKhnZXRpbmRleJDZJDAxZmJmMWM5LTFjZWEtNDU5My1hMmM1LTAzODU0ZGVlMjQ3M4S0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDAxZmJmMWM5LTFjZWEtNDU5My1hMmM1LTAzODU0ZGVlMjQ3M7Rkb3duc3RyZWFtX2NlbGxzX21hcICydXBzdHJlYW1fY2VsbHNfbWFwgqdAbWRfc3RykKhnZXRpbmRleJDZJDVlOTRhNTE3LWRiNDYtNDg2NC1iNzE3LTViNDU0Mzg4NGRmZoS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDVlOTRhNTE3LWRiNDYtNDg2NC1iNzE3LTViNDU0Mzg4NGRmZrRkb3duc3RyZWFtX2NlbGxzX21hcIGkZGF0YZLZJGE1ZTYxYTQ4LWUwN2UtNDlkYy04YzYxLTEyMjRkMWM0N2QxM9kkOWMzYjhlYjItYTE2MC00MjQ2LWE1YzctNTk2YTg2YzczZDYysnVwc3RyZWFtX2NlbGxzX21hcIKkWExTWJHZJDExYWM1ZjZhLTBmNmEtMTFlZS0yNTk4LTExYzdhMDA2NGI0M61YTFNYLm9wZW54bHN4kNkkOGRkNWQ0YjktNWEzMi00YTk1LThmMzgtN2YzZTViOThlMmQ5hLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkOGRkNWQ0YjktNWEzMi00YTk1LThmMzgtN2YzZTViOThlMmQ5tGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkYjMxNGFkZDctYTZmNS00MmYwLWJjOWEtYmJhNzQ4NTQzZmEyhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkYjMxNGFkZDctYTZmNS00MmYwLWJjOWEtYmJhNzQ4NTQzZmEytGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kLRjZWxsX2V4ZWN1dGlvbl9vcmRlctwAF9kkMTFhYzVmNmEtMGY2YS0xMWVlLTI1OTgtMTFjN2EwMDY0YjQz2SQwMWZiZjFjOS0xY2VhLTQ1OTMtYTJjNS0wMzg1NGRlZTI0NzPZJDhkZDVkNGI5LTVhMzItNGE5NS04ZjM4LTdmM2U1Yjk4ZTJkOdkkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZm2SRhNWU2MWE0OC1lMDdlLTQ5ZGMtOGM2MS0xMjI0ZDFjNDdkMTPZJGEyNWVlY2Q2LWY1OGQtNDkzZC1hNWNmLTk0MjE4MzE5ODQ5ZNkkOWMzYjhlYjItYTE2MC00MjQ2LWE1YzctNTk2YTg2YzczZDYy2SQzZWI5ZDM5Yy0yY2ExLTQzMGUtYjEzYi0wNWM4MDlhODBkNWLZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM9kkZjI4MjVkM2MtNTc3Yi00YjYxLThjOGMtYzg2OWE5ZWM5ZjA32SQ3MmNmOGQ1NS1hNDIzLTRjMjgtYTM3MC0zNzdmOWVmNmE3MGXZJGI4YWRjNTY2LTU4OTMtNDAyYS1hMzVkLTExYzA2NDYwZmI2MtkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2Nl2SRiMzE0YWRkNy1hNmY1LTQyZjAtYmM5YS1iYmE3NDg1NDNmYTLZJDdlMzgzOTY3LTI2ZGUtNDliZC1hMTA2LWQyMTUyNDFmZmRiMdkkYzA5Yjc3MWMtYWFiMS00MGNmLWEyNzMtMTRhYTZjODU3NTEw2SQ0NmM5YmUwNy0zYmI0LTQ5OWMtYTgxOS03YTg3YzczYjZlNDLZJDEyODY2OGMzLTI4MmQtNDQ1My04NGE2LWNmMmMyOWQ3MTQwZtkkNTQ4Y2EyNDQtZGU0Yy00N2MyLWE2OWUtMGNhN2E0NDkwMjhm2SQ4ODRhNzI5OS04NDE4LTQ1ZTQtODJmMy02NTIwNGQ0OGU1NWLZJDkzNDJlNDg5LWEyOTctNGM2Ny04MzI0LWNiNDE4MDFhZjcxM9kkMzFkYzU4ZGItNWE0ZS00N2RjLWJkYjgtZmU2ZTliYjQ3MjA02SQ2ZDc2OGVjMi1mOWFkLTRjYzctYTJkZi00ZWViMWE3MmNkNDS0bGFzdF9ob3RfcmVsb2FkX3RpbWXLAAAAAAAAAACpc2hvcnRwYXRotGdlbmVzX2NoaXNxX3Rlc3RzLmpsrnByb2Nlc3Nfc3RhdHVzpXJlYWR5pHBhdGjZWi9ob21lL2ZsYXVyZW50L0JveGVzL3R1bWJsZXdlZWQtMS9Qcm9qZWN0cy9zdGF0cy9DeXJpbFNhdmluL25vdGVib29rcy9nZW5lc19jaGlzcV90ZXN0cy5qbK5sYXN0X3NhdmVfdGltZctB2Slpy1FLDqpjZWxsX29yZGVy3AAX2SQwMWZiZjFjOS0xY2VhLTQ1OTMtYTJjNS0wMzg1NGRlZTI0NzPZJDExYWM1ZjZhLTBmNmEtMTFlZS0yNTk4LTExYzdhMDA2NGI0M9kkOGRkNWQ0YjktNWEzMi00YTk1LThmMzgtN2YzZTViOThlMmQ52SQ1ZTk0YTUxNy1kYjQ2LTQ4NjQtYjcxNy01YjQ1NDM4ODRkZmbZJGE1ZTYxYTQ4LWUwN2UtNDlkYy04YzYxLTEyMjRkMWM0N2QxM9kkYTI1ZWVjZDYtZjU4ZC00OTNkLWE1Y2YtOTQyMTgzMTk4NDlk2SQ5YzNiOGViMi1hMTYwLTQyNDYtYTVjNy01OTZhODZjNzNkNjLZJDNlYjlkMzljLTJjYTEtNDMwZS1iMTNiLTA1YzgwOWE4MGQ1YtkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMz2SRmMjgyNWQzYy01NzdiLTRiNjEtOGM4Yy1jODY5YTllYzlmMDfZJDcyY2Y4ZDU1LWE0MjMtNGMyOC1hMzcwLTM3N2Y5ZWY2YTcwZdkkYjhhZGM1NjYtNTg5My00MDJhLWEzNWQtMTFjMDY0NjBmYjYy2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2XZJGIzMTRhZGQ3LWE2ZjUtNDJmMC1iYzlhLWJiYTc0ODU0M2ZhMtkkN2UzODM5NjctMjZkZS00OWJkLWExMDYtZDIxNTI0MWZmZGIx2SRjMDliNzcxYy1hYWIxLTQwY2YtYTI3My0xNGFhNmM4NTc1MTDZJDQ2YzliZTA3LTNiYjQtNDk5Yy1hODE5LTdhODdjNzNiNmU0MtkkMTI4NjY4YzMtMjgyZC00NDUzLTg0YTYtY2YyYzI5ZDcxNDBm2SQ1NDhjYTI0NC1kZTRjLTQ3YzItYTY5ZS0wY2E3YTQ0OTAyOGbZJDg4NGE3Mjk5LTg0MTgtNDVlNC04MmYzLTY1MjA0ZDQ4ZTU1YtkkOTM0MmU0ODktYTI5Ny00YzY3LTgzMjQtY2I0MTgwMWFmNzEz2SQzMWRjNThkYi01YTRlLTQ3ZGMtYmRiOC1mZTZlOWJiNDcyMDTZJDZkNzY4ZWMyLWY5YWQtNGNjNy1hMmRmLTRlZWIxYTcyY2Q0NLFwdWJsaXNoZWRfb2JqZWN0c4ClbmJwa2eIsmluc3RhbGxlZF92ZXJzaW9uc4WpU3RhdHNCYXNlpzAuMzMuMjGkWExTWKUwLjkuMK9NdWx0aXBsZVRlc3RpbmelMC41LjGsU3BhcnNlQXJyYXlzpnN0ZGxpYq9IeXBvdGhlc2lzVGVzdHOmMC4xMS4wsHRlcm1pbmFsX291dHB1dHOGqVN0YXRzQmFzZdnvCkluc3RhbnRpYXRpbmcuLi4KClJlc29sdmluZy4uLgobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psXzN4RlR2RC9Qcm9qZWN0LnRvbWxgChtbMzJtG1sxbSAgTm8gQ2hhbmdlcxtbMjJtG1szOW0gdG8gYC90bXAvamxfM3hGVHZEL01hbmlmZXN0LnRvbWxgCgpQcmVjb21waWxpbmcuLi4KG1szMm0bWzFtICBBY3RpdmF0aW5nG1syMm0bWzM5bSBwcm9qZWN0IGF0IGAvdG1wL2psXzN4RlR2RGCkWExTWNnvCkluc3RhbnRpYXRpbmcuLi4KClJlc29sdmluZy4uLgobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psXzN4RlR2RC9Qcm9qZWN0LnRvbWxgChtbMzJtG1sxbSAgTm8gQ2hhbmdlcxtbMjJtG1szOW0gdG8gYC90bXAvamxfM3hGVHZEL01hbmlmZXN0LnRvbWxgCgpQcmVjb21waWxpbmcuLi4KG1szMm0bWzFtICBBY3RpdmF0aW5nG1syMm0bWzM5bSBwcm9qZWN0IGF0IGAvdG1wL2psXzN4RlR2RGCqbmJwa2dfc3luY9nvCkluc3RhbnRpYXRpbmcuLi4KClJlc29sdmluZy4uLgobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psXzN4RlR2RC9Qcm9qZWN0LnRvbWxgChtbMzJtG1sxbSAgTm8gQ2hhbmdlcxtbMjJtG1szOW0gdG8gYC90bXAvamxfM3hGVHZEL01hbmlmZXN0LnRvbWxgCgpQcmVjb21waWxpbmcuLi4KG1szMm0bWzFtICBBY3RpdmF0aW5nG1syMm0bWzM5bSBwcm9qZWN0IGF0IGAvdG1wL2psXzN4RlR2RGCvTXVsdGlwbGVUZXN0aW5n2e8KSW5zdGFudGlhdGluZy4uLgoKUmVzb2x2aW5nLi4uChtbMzJtG1sxbSAgTm8gQ2hhbmdlcxtbMjJtG1szOW0gdG8gYC90bXAvamxfM3hGVHZEL1Byb2plY3QudG9tbGAKG1szMm0bWzFtICBObyBDaGFuZ2VzG1syMm0bWzM5bSB0byBgL3RtcC9qbF8zeEZUdkQvTWFuaWZlc3QudG9tbGAKClByZWNvbXBpbGluZy4uLgobWzMybRtbMW0gIEFjdGl2YXRpbmcbWzIybRtbMzltIHByb2plY3QgYXQgYC90bXAvamxfM3hGVHZEYKxTcGFyc2VBcnJheXPZ7wpJbnN0YW50aWF0aW5nLi4uCgpSZXNvbHZpbmcuLi4KG1szMm0bWzFtICBObyBDaGFuZ2VzG1syMm0bWzM5bSB0byBgL3RtcC9qbF8zeEZUdkQvUHJvamVjdC50b21sYAobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psXzN4RlR2RC9NYW5pZmVzdC50b21sYAoKUHJlY29tcGlsaW5nLi4uChtbMzJtG1sxbSAgQWN0aXZhdGluZxtbMjJtG1szOW0gcHJvamVjdCBhdCBgL3RtcC9qbF8zeEZUdkRgr0h5cG90aGVzaXNUZXN0c9nvCkluc3RhbnRpYXRpbmcuLi4KClJlc29sdmluZy4uLgobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psXzN4RlR2RC9Qcm9qZWN0LnRvbWxgChtbMzJtG1sxbSAgTm8gQ2hhbmdlcxtbMjJtG1szOW0gdG8gYC90bXAvamxfM3hGVHZEL01hbmlmZXN0LnRvbWxgCgpQcmVjb21waWxpbmcuLi4KG1szMm0bWzFtICBBY3RpdmF0aW5nG1syMm0bWzM5bSBwcm9qZWN0IGF0IGAvdG1wL2psXzN4RlR2RGCnZW5hYmxlZMO3cmVzdGFydF9yZWNvbW1lbmRlZF9tc2fAtHJlc3RhcnRfcmVxdWlyZWRfbXNnwK1idXN5X3BhY2thZ2VzkK9pbnN0YWxsX3RpbWVfbnPO+U4U3qxpbnN0YW50aWF0ZWTDq2NlbGxfaW5wdXRz3gAX2SQ5YzNiOGViMi1hMTYwLTQyNDYtYTVjNy01OTZhODZjNzNkNjKEp2NlbGxfaWTZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MqRjb2Rl2YBiZWdpbgoJZ2Vub3R5cGVzID0gdmVjKGRhdGFbIm5iIGfDqG5lcyBzcMOpIl1bIkIyOlUyIl0pICMgY29sdW1ucwoJY2F0ZWdvcmllcyA9IHZlYyhkYXRhWyJuYiBnw6huZXMgc3DDqSJdWyJBMzpBMjUiXSkgIyByb3dzCmVuZKhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkwtkkOTM0MmU0ODktYTI5Ny00YzY3LTgzMjQtY2I0MTgwMWFmNzEzhKdjZWxsX2lk2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTOkY29kZdoDHGJlZ2luCglwZXJfZ2Vub3R5cGVfcHZhbHVlcyA9IERpY3R7U3RyaW5nLCBGbG9hdDY0fSgpCglmb3IgY29sIGluIDE6bmNvbHMKCQkjIGlkZW50aWZ5IGNlbGxzIHRvIGJlIGdyb3VwZWQKCQlvayA9IGV4cGVjdGVkX2NvdW50c1s6LCBjb2xdIC4+PSA1CgkJYW55KG9rKSB8fCBjb250aW51ZQoJCSMgZ3JvdXAgY2VsbHMKCQlleHBlY3RlZF9jb3VudHPigLIgPSBleHBlY3RlZF9jb3VudHNbb2ssIGNvbF0KCQlpZiAhYWxsKG9rKQoJCQlzeW50aGV0aWNfY291bnQgPSBzdW0oZXhwZWN0ZWRfY291bnRzWyghKS4ob2spLCBjb2xdKQoJCQlwdXNoIShleHBlY3RlZF9jb3VudHPigLIsIHN5bnRoZXRpY19jb3VudCkKCQllbmQKCQlvYnNlcnZlZF9jb3VudHPigLIgPSBvYnNlcnZlZF9jb3VudHNbb2ssIGNvbF0KCQlpZiAhYWxsKG9rKQoJCQlzeW50aGV0aWNfY291bnQgPSBzdW0ob2JzZXJ2ZWRfY291bnRzWyghKS4ob2spLCBjb2xdKQoJCQlwdXNoIShvYnNlcnZlZF9jb3VudHPigLIsIHN5bnRoZXRpY19jb3VudCkKCQllbmQKCQkjIHBlcmZvcm0gdGhlIHRlc3QKCQljb250aW5nZW5jeV90YWJsZSA9IGhjYXQob2JzZXJ2ZWRfY291bnRz4oCyLCBleHBlY3RlZF9jb3VudHPigLIpCgkJcHZhbCA9IHB2YWx1ZShDaGlzcVRlc3QoY29udGluZ2VuY3lfdGFibGUpKQoJCSMgcmVjb3JkIHRoZSByZXN1bHRpbmcgcHZhbHVlCgkJZ2Vub3R5cGUgPSBnZW5vdHlwZXNbY29sX29rXVtjb2xdCgkJcGVyX2dlbm90eXBlX3B2YWx1ZXNbZ2Vub3R5cGVdID0gcHZhbAoJZW5kCglwZXJfZ2Vub3R5cGVfcHZhbHVlcwplbmSobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMLZJDZkNzY4ZWMyLWY5YWQtNGNjNy1hMmRmLTRlZWIxYTcyY2Q0NISnY2VsbF9pZNkkNmQ3NjhlYzItZjlhZC00Y2M3LWEyZGYtNGVlYjFhNzJjZDQ0pGNvZGXZT21kIiIiCkdlbm90eXBlcyBHMTAgYW5kIEcxNCBzaWduaWZpY2FudGx5IGRpZmZlciBmcm9tIHRoZSBhdmVyYWdlIGdlbm90eXBlLgoiIiKobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMPZJDdlMzgzOTY3LTI2ZGUtNDliZC1hMTA2LWQyMTUyNDFmZmRiMYSnY2VsbF9pZNkkN2UzODM5NjctMjZkZS00OWJkLWExMDYtZDIxNTI0MWZmZGIxpGNvZGXZtGJlZ2luCgl1bmNvcnJlY3RlZF9wdmFsdWVzX2JlbG93X3RocmVzaG9sZCA9IGNvcHkocHZhbHVlcykKCXVuY29ycmVjdGVkX3B2YWx1ZXNfYmVsb3dfdGhyZXNob2xkLm56dmFsWy4wNSAuPCBwdmFsdWVzLm56dmFsXSAuPSAwCglkcm9wemVyb3ModW5jb3JyZWN0ZWRfcHZhbHVlc19iZWxvd190aHJlc2hvbGQpCmVuZKhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkwtkkM2ViOWQzOWMtMmNhMS00MzBlLWIxM2ItMDVjODA5YTgwZDVihKdjZWxsX2lk2SQzZWI5ZDM5Yy0yY2ExLTQzMGUtYjEzYi0wNWM4MDlhODBkNWKkY29kZdk/bWQiIiIKRmlyc3QsIHdlIGV4Y2x1ZGUgdGhlIHJvd3MgYW5kIGNvbHVtbnMgb2YgemVyb3Mgb25seS4KIiIiqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTD2SQ1NDhjYTI0NC1kZTRjLTQ3YzItYTY5ZS0wY2E3YTQ0OTAyOGaEp2NlbGxfaWTZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZqRjb2Rl2ZpiZWdpbgoJcm93LCBjb2wgPSBmaW5kbnooc2lnbmlmaWNhbnRfcHZhbHVlcykKCWNhdGVnb3J5ID0gY2F0ZWdvcmllc1tyb3dfb2tdW3Jvd10KCWdlbm90eXBlID0gZ2Vub3R5cGVzW2NvbF9va11bY29sXQoJY29sbGVjdCh6aXAoY2F0ZWdvcnksIGdlbm90eXBlKSkKZW5kqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTC2SQ4ODRhNzI5OS04NDE4LTQ1ZTQtODJmMy02NTIwNGQ0OGU1NWKEp2NlbGxfaWTZJDg4NGE3Mjk5LTg0MTgtNDVlNC04MmYzLTY1MjA0ZDQ4ZTU1YqRjb2Rl2gaAbWQiIiIKVGhlIHNhbXBsZSBzaXplIGlzIHRvbyBsb3cgaWYgd2UgY29uc2lkZXIgdGhlIGxhcmdlIG51bWJlciBvZiBjZWxscywgYW5kIHdlIG5lZWQgYSBtb3JlIHBvd2VyZnVsIHRlc3QuCkxldCB1cyBub3cgY29tcGFyZSBlYWNoIGdlbm90eXBlIHdpdGggdGhlICJhdmVyYWdlIiBnZW5vdHlwZSwgZ3JvdXBpbmcgdGhlIGxvdy1mcmVxdWVuY3kgY2VsbHMgdG9nZXRoZXIuCgpXZSBhbHJlYWR5IGtub3cgdGhlIHBvc3QtaG9jIHRlc3RzIGZhaWwsIHRoZXJlZm9yZSB3ZSB3b24ndCBoYXZlIGNhdGVnb3J5LWxldmVsIHJlc29sdXRpb24uIEhvd2V2ZXIsIGEgc2lnbmlmaWNhbnQgZGlmZmVyZW5jZSBpcyBzdGlsbCBwb3NzaWJsZSBoZXJlIGFzIHRoZSB0ZXN0IHdpbGwgY3VtdWxhdGUgdGhlIGRpZmZlcmVuY2VzIGZvciB0aGUgZGlmZmVyZW50IGNhdGVnb3JpZXMuIFRoZSBpbmRpdmlkdWFsIGRpZmZlcmVuY2VzIHNob3VsZCBiZSBkZXRlY3RhYmxlIGluY3JlYXNpbmcgdGhlIHNhbXBsZSBzaXplLgoKIyBEaXNjbGFpbWVyCgpUaGUgZm9sbG93aW5nIGFuYWx5c2lzIGlzIGEgc2Vjb25kIGl0ZXJhdGlvbiBtb3RpdmF0ZWQgYnkgYW4gZXJyb3IgaW4gdGhlIGZpcnN0IGl0ZXJhdGlvbi4gVGhlIGhpc3Rvcnkgb2YgdGhlIHByZXNlbnQgbm90ZWJvb2sgY2FuIGJlIGZvdW5kIFtoZXJlXShodHRwczovL2dpdGxhYi5wYXN0ZXVyLmZyL2ZsYXVyZW50L3Byb2plY3QxOTQ0OS8tL2Jsb2IvbWFpbi9ub3RlYm9va3MvZ2VuZXNfY2hpc3FfdGVzdHMuamwpLgoKVGhlIGNhdGVnb3JpZXMgd2VyZSBncm91cGVkIGJhc2VkIG9uIHRoZSBvYnNlcnZlZCBjb3VudHMsIHdoZXJlYXMgdGhlIG1pbmltdW0tNSBjcml0ZXJpb24gYWN0dWFsbHkgYXBwbGllcyB0byB0aGUgZXhwZWN0ZWQgY291bnRzLiBUaGlzIGlzIGZpeGVkIGluIHRoaXMgdmVyc2lvbiBvZiB0aGUgYW5hbHlzaXMuCgpJbiBhZGRpdGlvbiwgZnJvbSB0aGUgZmlyc3QgaXRlcmF0aW9uIG9mIHRoZSBhbmFseXNpcywgd2Uga25vdyB0aGF0IGNvbnRyb2xsaW5nIHRoZSBmYW1pbHktd2lzZSBlcnJvciByYXRlIHdvdWxkIG5vdCBhbGxvdyB0byByZWplY3QgYW55IG51bGwgaHlwb3RoZXNpcy4gV2UgdGhlcmVmb3JlIGNvbnNpZGVyIGNvbnRyb2xsaW5nIHRoZSBmYWxzZSBkaXNjb3ZlcnkgcmF0ZSBpbnN0ZWFkLCBhcyBkZXNjcmliZWQgaW4gW0JlbmphbWluaSAqZXQgYWwuKiwgMjAwNl0oaHR0cHM6Ly9kb2kub3JnLzEwLjEwOTMvYmlvbWV0LzkzLjMuNDkxKS4KCiMgR3JvdXBpbmcgcHJvY2VkdXJlCgpBbiBlbGFib3JhdGUgZ3JvdXBpbmcgYXBwcm9hY2ggY2FuIGJlIGZvdW5kIGluIFtLYXNzLCAxOTgwXShodHRwczovL3d3dzQuc3RhdC5uY3N1LmVkdS9+ZGlja2V5L2FuYWx5dGljcy9kYXRhbWluZS9SZWZlcmVuY2UlMjBQYXBlcnMva2FzczgwLnBkZikuCgpUaGUgc2ltcGxlciBhcHByb2FjaCBmb2xsb3dlZCBoZXJlIGNvbnNpc3RzIGluIGdyb3VwaW5nIGFsbCB0aGUgY2F0ZWdvcmllcyB3aXRoIGFuIGV4cGVjdGVkIGNvdW50IGJlbG93IDUgaW50byBhIHNpbmdsZSBzeW50aGV0aWMgY2F0ZWdvcnksIGZvciBlYWNoIGNvbHVtbiBzZXBhcmF0ZWx5LiBPYnNlcnZlZCBjb3VudHMgYXJlIHNpbWlsYXJseSBncm91cGVkLCBiYXNlZCBvbiB0aGUgZXhwZWN0ZWQgY291bnRzLgoiIiKobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMPZJGI4YWRjNTY2LTU4OTMtNDAyYS1hMzVkLTExYzA2NDYwZmI2MoSnY2VsbF9pZNkkYjhhZGM1NjYtNTg5My00MDJhLWEzNWQtMTFjMDY0NjBmYjYypGNvZGXaAnZtZCIiIgpEdWUgdG8gdGhlIHByZXNlbmNlIG9mIHplcm9zIGluIG1vc3QgY29sdW1ucywgd2UgaGF2ZSB0byBncm91cCB0aGUgbG93LWZyZXF1ZW5jeSBjZWxscyBpbnRvIHNpbmdsZSBjZWxscyBvbiBhIHBlci1jb2x1bW4gYmFzaXMuIFRoZSBpbmZvcm1hdGlvbiBpbiBsb3ctZnJlcXVlbmN5IGNlbGxzIGlzIGFscmVhZHkgYWNjb3VudGVkIGZvciBieSB0aGUgb3RoZXIgY2VsbHMuCgpXZSBjYW4gYWxzbyBpbmRpdmlkdWFsbHkgdGVzdCBlYWNoIGNvdW50IGBvYnNlcnZlZF9uYCBfZXF1YWwgdG8gb3IgZ3JlYXRlciB0aGFuIDVfIGluIGEgY29udGluZ2VuY3kgdGFibGUgd2l0aDoKYGBgCistLS0tLS0tLS0tLS0rLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKwp8IG9ic2VydmVkX24gfCBjb2xfdG90YWwgLSBvYnNlcnZlZF9uIHwKKy0tLS0tLS0tLS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0rCnwgZXhwZWN0ZWRfbiB8IGNvbF90b3RhbCAtIGV4cGVjdGVkX24gfAorLS0tLS0tLS0tLS0tKy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsKYGBgClRoaXMgc2Vjb25kIGFwcHJvYWNoIGlzIGxlc3MgcG93ZXJmdWwsIHRob3VnaC4KCkxldCB1cyBiZWdpbiB3aXRoIHRoaXMgc2Vjb25kIGFwcHJvYWNoOgoiIiKobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMPZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM4SnY2VsbF9pZNkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzpGNvZGXZp2JlZ2luCglyb3dfb2sgPSB2ZWMoYW55KCE9KDApLCBjb3VudHM7IGRpbXM9MikpCgljb2xfb2sgPSB2ZWMoYW55KCE9KDApLCBjb3VudHM7IGRpbXM9MSkpCgljbGVhbl9jb3VudHMgPSBjb3VudHNbcm93X29rLCBjb2xfb2tdCglucm93cywgbmNvbHMgPSBzaXplKGNsZWFuX2NvdW50cykKZW5kqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTC2SRhMjVlZWNkNi1mNThkLTQ5M2QtYTVjZi05NDIxODMxOTg0OWSEp2NlbGxfaWTZJGEyNWVlY2Q2LWY1OGQtNDkzZC1hNWNmLTk0MjE4MzE5ODQ5ZKRjb2Rl2W5tZCIiIgpGb3IgZnVydGhlciByZWZlcmVuY2UsIHdlIGFsc28gbG9hZCB0aGUgbGFiZWxzIG9mIHRoZSByb3dzIChgY2F0ZWdvcmllc2ApIGFuZCBjb2x1bW5zIChgZ2Vub3R5cGVzYCkuCiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkw9kkYTVlNjFhNDgtZTA3ZS00OWRjLThjNjEtMTIyNGQxYzQ3ZDEzhKdjZWxsX2lk2SRhNWU2MWE0OC1lMDdlLTQ5ZGMtOGM2MS0xMjI0ZDFjNDdkMTOkY29kZdkvY291bnRzID0gSW50LihkYXRhWyJuYiBnw6huZXMgc3DDqSJdWyJCMzpVMjUiXSmobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMLZJGMwOWI3NzFjLWFhYjEtNDBjZi1hMjczLTE0YWE2Yzg1NzUxMISnY2VsbF9pZNkkYzA5Yjc3MWMtYWFiMS00MGNmLWEyNzMtMTRhYTZjODU3NTEwpGNvZGXZRW1kIiIiCkNvcnJlY3RpbmcgZm9yIGFsbCB0aGUgY29tcGFyaXNvbnMsIG5vIGRpZmZlcmVuY2VzIHN1cnZpdmU6CiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkw9kkMTFhYzVmNmEtMGY2YS0xMWVlLTI1OTgtMTFjN2EwMDY0YjQzhKdjZWxsX2lk2SQxMWFjNWY2YS0wZjZhLTExZWUtMjU5OC0xMWM3YTAwNjRiNDOkY29kZdlFdXNpbmcgU3RhdHNCYXNlLCBIeXBvdGhlc2lzVGVzdHMsIFhMU1gsIFNwYXJzZUFycmF5cywgTXVsdGlwbGVUZXN0aW5nqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTC2SRmMjgyNWQzYy01NzdiLTRiNjEtOGM4Yy1jODY5YTllYzlmMDeEp2NlbGxfaWTZJGYyODI1ZDNjLTU3N2ItNGI2MS04YzhjLWM4NjlhOWVjOWYwN6Rjb2Rl2fVtZCIiIgpUbyB0ZXN0IHdoZXRoZXIgYSBnZW5vdHlwZSBleGhpYml0cyBhIGRpZmZlcmVudCBwYXJ0aXRpb24gaW50byBjYXRlZ29yaWVzIG9mIGdlbmVzLCBvciBlcXVpdmFsZW50bHkgd2hldGhlciBpdCBpcyBlbnJpY2hlZCBpbiBzb21lIGNhdGVnb3J5LCB3ZSBmaXJzdCBkZXJpdmUgYW4gZXhwZWN0ZWQgcGFydGl0aW9uIGF2ZXJhZ2luZyB0aGUgY2F0ZWdvcnkgZnJlcXVlbmNpZXMgYWNyb3NzIGFsbCBnZW5vdHlwZXMuCiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkw9kkMzFkYzU4ZGItNWE0ZS00N2RjLWJkYjgtZmU2ZTliYjQ3MjA0hKdjZWxsX2lk2SQzMWRjNThkYi01YTRlLTQ3ZGMtYmRiOC1mZTZlOWJiNDcyMDSkY29kZdn3YmVnaW4KCWNvcnJlY3RlZF9wZXJfZ2Vub3R5cGVfcHZhbHVlcyA9IGFkanVzdCgKCQljb2xsZWN0KHZhbHVlcyhwZXJfZ2Vub3R5cGVfcHZhbHVlcykpLAoJCUJlbmphbWluaUhvY2hiZXJnQWRhcHRpdmUoVHdvU3RlcCgpKSwKCSkKCWNvcnJlY3RlZF9wZXJfZ2Vub3R5cGVfcHZhbHVlcyA9IERpY3QoemlwKAoJCWtleXMocGVyX2dlbm90eXBlX3B2YWx1ZXMpLAoJCWNvcnJlY3RlZF9wZXJfZ2Vub3R5cGVfcHZhbHVlcywKCSkpCmVuZKhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkwtkkNzJjZjhkNTUtYTQyMy00YzI4LWEzNzAtMzc3ZjllZjZhNzBlhKdjZWxsX2lk2SQ3MmNmOGQ1NS1hNDIzLTRjMjgtYTM3MC0zNzdmOWVmNmE3MGWkY29kZdoBDWJlZ2luCgljb2xfdG90YWwgPSBzdW0oY2xlYW5fY291bnRzOyBkaW1zPTEpCglleHBlY3RlZF9mcmVxdWVuY2llcyA9IG1lYW4oY2xlYW5fY291bnRzIC4vIGNvbF90b3RhbDsgZGltcz0yKQoJQGFzc2VydCBzdW0oZXhwZWN0ZWRfZnJlcXVlbmNpZXMpIOKJiCAxCgkjIHByaW50IHRoZSBmcmVxdWVuY2llcyB3aXRoIHRoZSBjb3JyZXNwb25kaW5nIGNhdGVnb3J5IG5hbWVzCglEaWN0KHppcChjYXRlZ29yaWVzW3Jvd19va10sIGV4cGVjdGVkX2ZyZXF1ZW5jaWVzKSkKZW5kqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTC2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2WEp2NlbGxfaWTZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZaRjb2Rl2gNtYmVnaW4KCW9ic2VydmVkX2NvdW50cyA9IGNsZWFuX2NvdW50cwoJIyBpbiB0aGVvcnksIHdlIGNvdWxkIGFsc28gdXNlIHJlYWwtdmFsdWVkIGNvdW50cyBpbnN0ZWFkCglleHBlY3RlZF9jb3VudHMgPSBALiByb3VuZChJbnQsIGV4cGVjdGVkX2ZyZXF1ZW5jaWVzICogY29sX3RvdGFsKQoJb2JzZXJ2ZWRfcmVtYWluZGVyID0gY29sX3RvdGFsIC4tIG9ic2VydmVkX2NvdW50cwoJZXhwZWN0ZWRfcmVtYWluZGVyID0gY29sX3RvdGFsIC4tIGV4cGVjdGVkX2NvdW50cwoKCXB2YWx1ZXMgPSBzcHplcm9zKG5yb3dzLCBuY29scykKCWZvciByb3cgaW4gMTpucm93cwoJCWZvciBjb2wgaW4gMTpuY29scwoJCQkKCQkJIyBidWlsZCB0aGUgY29udGluZ2VuY3kgdGFibGUKCQkJYSA9IG9ic2VydmVkX2NvdW50c1tyb3csIGNvbF0KCQkJYiA9IG9ic2VydmVkX3JlbWFpbmRlcltyb3csIGNvbF0KCQkJYyA9IGV4cGVjdGVkX2NvdW50c1tyb3csIGNvbF0KCQkJZCA9IGV4cGVjdGVkX3JlbWFpbmRlcltyb3csIGNvbF0KCQkJY29udGluZ2VuY3lfdGFibGUgPSBbIGEgYiA7IGMgZCBdCgkJCQoJCQkjIHBlcmZvcm0gYSDPh8KyIHRlc3Qgb2YgaG9tb2dlbmVpdHkKCQkJaWYgYWxsKD49KDUpLCBjb250aW5nZW5jeV90YWJsZSkKCQkJCXB2YWwgPSBwdmFsdWUoQ2hpc3FUZXN0KGNvbnRpbmdlbmN5X3RhYmxlKSkKCQkJCSMgbm90ZTogRmlzaGVyRXhhY3RUZXN0KGEsIGIsIGMsIGQpIGdpdmVzIHZlcnkgc2ltaWxhciByZXN1bHRzCgkJCQkjcHZhbCA9IHB2YWx1ZShGaXNoZXJFeGFjdFRlc3QoYSwgYiwgYywgZCk7IG1ldGhvZD06bWlubGlrZSkKCQkJCQoJCQkJcHZhbHVlc1tyb3csIGNvbF0gPSBwdmFsCgkJCWVuZAoJCWVuZAoJZW5kCglwdmFsdWVzCmVuZKhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkwtkkNDZjOWJlMDctM2JiNC00OTljLWE4MTktN2E4N2M3M2I2ZTQyhKdjZWxsX2lk2SQ0NmM5YmUwNy0zYmI0LTQ5OWMtYTgxOS03YTg3YzczYjZlNDKkY29kZdoBjWJlZ2luCgkjIHNlZSBodHRwczovL2dpdGh1Yi5jb20vanVsaWFuZ2VocmluZy9NdWx0aXBsZVRlc3RpbmcuamwjdHdvLXN0ZXAKCWNvcnJlY3RlZF9wdmFsdWVzID0gYWRqdXN0KHB2YWx1ZXMubnp2YWwsIEJlbmphbWluaUhvY2hiZXJnQWRhcHRpdmUoVHdvU3RlcCgpKSkKCQoJc2lnbmlmaWNhbnQgPSBjb3JyZWN0ZWRfcHZhbHVlcyAuPD0gLjA1CglzaWduaWZpY2FudF9wdmFsdWVzID0gY29weShwdmFsdWVzKQoJc2lnbmlmaWNhbnRfcHZhbHVlcy5uenZhbCAuPSAwCglzaWduaWZpY2FudF9wdmFsdWVzLm56dmFsW3NpZ25pZmljYW50XSA9IGNvcnJlY3RlZF9wdmFsdWVzW3NpZ25pZmljYW50XQoJc2lnbmlmaWNhbnRfcHZhbHVlcyA9IGRyb3B6ZXJvcyhzaWduaWZpY2FudF9wdmFsdWVzKQplbmSobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMLZJDEyODY2OGMzLTI4MmQtNDQ1My04NGE2LWNmMmMyOWQ3MTQwZoSnY2VsbF9pZNkkMTI4NjY4YzMtMjgyZC00NDUzLTg0YTYtY2YyYzI5ZDcxNDBmpGNvZGXZZm1kIiIiCkhhZCB3ZSBmb3VuZCBkaWZmZXJlbmNlcywgd2UgY291bGQgZ2V0IHRoZSBjb3JyZXNwb25kaW5nIGNhdGVnb3J5LWdlbm90eXBlIHBhaXJzIGFzIGZvbGxvd3M6CiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkw9kkMDFmYmYxYzktMWNlYS00NTkzLWEyYzUtMDM4NTRkZWUyNDczhKdjZWxsX2lk2SQwMWZiZjFjOS0xY2VhLTQ1OTMtYTJjNS0wMzg1NGRlZTI0NzOkY29kZdmjbWQiIiIKVGhpcyBkb2N1bWVudCBpcyBhIFBsdXRvIG5vdGVib29rIChvciBhbiBodG1sIHJlbmRlcmVkIHZlcnNpb24gb2YgaXQpIGFuZCByZXF1aXJlcyBbSnVsaWFdKGh0dHBzOi8vY29tcHV0YXRpb25hbHRoaW5raW5nLm1pdC5lZHUvU3ByaW5nMjEvaW5zdGFsbGF0aW9uLykuCiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkw9kkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZmhKdjZWxsX2lk2SQ1ZTk0YTUxNy1kYjQ2LTQ4NjQtYjcxNy01YjQ1NDM4ODRkZmakY29kZdk6ZGF0YSA9IFhMU1gub3Blbnhsc3goIi4uL2RhdGEvcmF3L2dlbmVzX3NwZWNpZmlxdWVzLnhsc3giKahtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkwtkkOGRkNWQ0YjktNWEzMi00YTk1LThmMzgtN2YzZTViOThlMmQ5hKdjZWxsX2lk2SQ4ZGQ1ZDRiOS01YTMyLTRhOTUtOGYzOC03ZjNlNWI5OGUyZDmkY29kZdnlbWQiIiIKV2UgZmlyc3QgbG9hZCB0aGUgY291bnQgZGF0YS4KCk5vdGUgdGhlIG5vdGVib29rIGlzIGFzc3VtZWQgdG8gcnVuIGZyb20gYSBjaGlsZCBkaXJlY3RvcnkgKCplLmcuKiBgbm90ZWJvb2tzYCkgb2YgdGhlIHByb2plY3Qgcm9vdCwgYW5kIHRoZSBkYXRhIGZpbGVzIGFyZSBleHBlY3RlZCB0byBiZSBmb3VuZCBpbiBgZGF0YS9yYXdgLCBhZ2FpbiBmcm9tIHRoZSBwcm9qZWN0IHJvb3QuCiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkw9kkYjMxNGFkZDctYTZmNS00MmYwLWJjOWEtYmJhNzQ4NTQzZmEyhKdjZWxsX2lk2SRiMzE0YWRkNy1hNmY1LTQyZjAtYmM5YS1iYmE3NDg1NDNmYTKkY29kZdlrbWQiIiIKT3V0IG9mIGN1cmlvc2l0eSwgd2l0aCBubyBjb3JyZWN0aW9uIGZvciBtdWx0aXBsZSBjb21wYXJpc29ucywgd2UgZmluZCBhIGZldyBwLXZhbHVlcyBiZWxvdyAwLjA1OgoiIiKobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMOrbm90ZWJvb2tfaWTZJGMxYTcwYjQwLTFiNGEtMTFlZS0zZWU5LWIxMjNkYThkZWYzN6tpbl90ZW1wX2RpcsKobWV0YWRhdGGA"; window.pluto_preamble_html = undefined; </script> diff --git a/doc/snp_chisq_tests.html b/doc/snp_chisq_tests.html index 5fec883a6e1d15b3c7aa587d073f00ed4061c822..1d66277d16cdb1aa1149c623d4de0c9ed9558a7e 100644 --- a/doc/snp_chisq_tests.html +++ b/doc/snp_chisq_tests.html @@ -3,11 +3,11 @@ <meta name="theme-color" media="(prefers-color-scheme: light)" content="white"><meta name="theme-color" media="(prefers-color-scheme: dark)" content="#2a2928"><meta name="color-scheme" content="light dark"><link rel="icon" type="image/png" sizes="16x16" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/favicon-16x16.347d2855.png" integrity="sha384-3qsGeVLdddzV9oIkj3PhXXQX2CZCjOD/CiyrPQOX6InOWw3HAHClrsQhPfX9uRAj" crossorigin="anonymous"><link rel="icon" type="image/png" sizes="32x32" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/favicon-32x32.8789add4.png" integrity="sha384-cOe5vSoBIgKNgkUL27p9RpsGVY0uBg9PejLccDy+fR8ZD1Iv5dF1MGHjIZAIZwm6" crossorigin="anonymous"><link rel="icon" type="image/png" sizes="96x96" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/favicon-96x96.48689391.png" integrity="sha384-TN49cYb8GyNmrZT14bsYXXo4l1x1NJeJ/EHuVAauAKsNPopPHLojijs9jFT4Vs8c" crossorigin="anonymous"><link rel="pluto-logo-big" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/logo.004c1d7c.svg" integrity="sha384-GkQkODcGxsrSRJCkeakBXihum0GUM44cwBgKyutDimectXCbCgj6Vu3jlrueqEcN" crossorigin="anonymous"><link rel="pluto-logo-small" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/favicon_unsaturated.d1387b25.svg" integrity="sha384-omwjH+Qy3hpAVf5FYd/pkaDBuVAfsEDRN7eBxEA8Ek00OAWP+aiV+GpEYk3I7lyo" crossorigin="anonymous"><script type="module" src="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.4d2be9f0.js" integrity="sha384-CuFAr2AFtrPmN0FVO2PrGqg83e0KHFguP+4bn4V96uoNA6iydUywNAMKS3FYP5bU" crossorigin="anonymous"></script><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/juliamono.c6034ab4.css" integrity="sha384-n0za6lUXlyf4XC+nGkZWj3TLDnRbNpAcoi4PZGSlQMPoyqGa9kGY+ZXkUgZGIhQt" crossorigin="anonymous"><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.9402a72e.css" integrity="sha384-NJUInpSDijrLS5DfgY1ITvzJ/8HJmHa62lN/13hYf8FknsJEMJdwqQWtyreOFUZ3" crossorigin="anonymous"><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/vollkorn.089565a8.css" integrity="sha384-jnV/84VtSgBLF70H+s2rxJcOUZIMDR+X/ElFZA83i9ZtZSWiIMFAgPyrWkOJV08q" crossorigin="anonymous"><script defer="">console.log("Pluto.jl, by Fons van der Plas (https://github.com/fonsp), MikoÅ‚aj Bochenski (https://github.com/malyvsen), Michiel Dral (https://github.com/dralletje) and friends 🌈");</script><script src="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.4b96dd74.js" defer="" integrity="sha384-Y+UtWANyXLeovyghpAI8j9/VZXWboD6G5ZCckOsJO99PawAh/utJxFikf62WBaSu" crossorigin="anonymous"></script><script src="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.9f9dc874.js" defer="" integrity="sha384-tkFo1EK72I9JvoTmHFa199dfRzW8mkXPUkHb/N7UhYI+bxKzX3Kh8LNCZz1ltsFF" crossorigin="anonymous"></script><script src="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.90ede145.js" defer="" integrity="sha384-CuNU9gQg6fa/yynNqNWjHWzPm4nj+d7O6+HXsNGSqClhs/bYQIbBC3Lw/kh8Ukui" crossorigin="anonymous"></script><script src="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.dbeed08a.js" defer="" integrity="sha384-1BEdQwXfZi4ZpsNV8w1X8pQcVK1/DS/+/M8OTo3gol7mdEspSN7nT6llX57NQCSt" crossorigin="anonymous"></script><script id="iframe-resizer-content-window-script" src="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.6386bd9d.js" crossorigin="anonymous" defer="" integrity="sha384-tgN2a0VDi/lCYwZuDqT7L+A/Y/9kpxf3HV7zv2BJ5Fu7zW0EClq0nM4crfK3TRPs"></script><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.20c99564.css" type="text/css" integrity="sha384-ZeUE8EilG635rOn5WI6cu08sHKMkb04kTkNSWBN8oKlADao2MBRWNIn9Yhaddbi6" crossorigin="anonymous"><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.14f23ca4.css" type="text/css" media="all" data-pluto-file="hide-ui" integrity="sha384-++EDAMZbJynENol9onosKuuWP4ex4rhT9Rl/oELs6oVltwZdU9DC0W1nYT4Ttb9V" crossorigin="anonymous"><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.99402935.css" type="text/css" integrity="sha384-Wl7QT6vOzvYxGbF4LKAXVRihsch7DCr4GeiXwOS273IU4E5g7HMSBkrbI9GFP+qI" crossorigin="anonymous"><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.1f4cf2ca.css" type="text/css" integrity="sha384-lBSBsn8FT1UzGOsNVudfV8RSHQEuNWqrCb6xQnF10uvF9AiCzYsCRXvKlhtQvV3c" crossorigin="anonymous"><link rel="preload" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/juliamono.c6034ab4.css" as="style" integrity="sha384-n0za6lUXlyf4XC+nGkZWj3TLDnRbNpAcoi4PZGSlQMPoyqGa9kGY+ZXkUgZGIhQt" crossorigin="anonymous"><link rel="preload" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/vollkorn.089565a8.css" as="style" integrity="sha384-jnV/84VtSgBLF70H+s2rxJcOUZIMDR+X/ElFZA83i9ZtZSWiIMFAgPyrWkOJV08q" crossorigin="anonymous"><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/fonsp/Pluto.jl@0.19.26/frontend-dist/editor.e82e08bd.css" type="text/css" integrity="sha384-7YN+h8b6N4N65qk8TG/J2KPF95D8z3sGNd06rokz4CX9oWu0KnRAF5cVWu3BkkaN" crossorigin="anonymous"><script data-pluto-file="launch-parameters"> window.pluto_notebook_id = undefined; window.pluto_isolated_cell_ids = undefined; -window.pluto_notebookfile = "data:text/julia;charset=utf-8;base64,### A Pluto.jl notebook ###
# v0.19.26

using Markdown
using InteractiveUtils

# ╔═╡ 11ac5f6a-0f6a-11ee-2598-11c7a0064b43
using StatsBase, HypothesisTests, XLSX, SparseArrays, MultipleTesting

# ╔═╡ 8dd5d4b9-5a32-4a95-8f38-7f3e5b98e2d9
md"""
We first load the count data.

!!!
	The notebook is assumed to run from a child directory (*e.g.* `notebooks`) of the project root, and the data files are expected to be found in `data/raw`, from the project root.
"""

# ╔═╡ 5e94a517-db46-4864-b717-5b4543884dff
data = XLSX.openxlsx("../data/raw/SNPspecifiques.xlsx")

# ╔═╡ a5e61a48-e07e-49dc-8c61-1224d1c47d13
counts = Int.(data["Nb SNP"]["B3:U25"])

# ╔═╡ a25eecd6-f58d-493d-a5cf-94218319849d
md"""
For further reference, we also load the labels of the rows (`categories`) and columns (`genotypes`).
"""

# ╔═╡ 9c3b8eb2-a160-4246-a5c7-596a86c73d62
begin
	genotypes = vec(data["Nb SNP"]["B2:U2"]) # columns
	categories = vec(data["Nb SNP"]["A3:A25"]) # rows
end

# ╔═╡ 3eb9d39c-2ca1-430e-b13b-05c809a80d5b
md"""
First, we exclude the rows and columns of zeros only.
"""

# ╔═╡ e3febec7-b84c-45f9-8f65-5a158b0ae933
begin
	row_ok = vec(any(!=(0), counts; dims=2))
	col_ok = vec(any(!=(0), counts; dims=1))
	clean_counts = counts[row_ok, col_ok]
	nrows, ncols = size(clean_counts)
end

# ╔═╡ f2825d3c-577b-4b61-8c8c-c869a9ec9f07
md"""
To test whether a genotype exhibits a different partition into categories of genes, or equivalently whether it is enriched in some category, we first derive an expected partition averaging the category frequencies across all genotypes.
"""

# ╔═╡ 72cf8d55-a423-4c28-a370-377f9ef6a70e
begin
	col_total = sum(clean_counts; dims=1)
	expected_frequencies = mean(clean_counts ./ col_total; dims=2)
	@assert sum(expected_frequencies) ≈ 1
end

# ╔═╡ b8adc566-5893-402a-a35d-11c06460fb62
md"""
Due to the presence of zeros in most columns, we have to group the low-frequency cells into single cells on a per-column basis. The information in low-frequency cells is already accounted for by the other cells.

We can also individually test each count `observed_n` _equal to or greater than 5_ in a contingency table with:
```
+------------+------------------------+
| observed_n | col_total - observed_n |
+------------+------------------------+
| expected_n | col_total - expected_n |
+------------+------------------------+
```
This second approach is less powerful, though.

Let us begin with this second approach:
"""

# ╔═╡ 3df39484-e07a-48d8-90ae-09da0050b3ce
begin
	observed_counts = clean_counts
	# in theory, we could also use real-valued counts instead
	expected_counts = @. round(Int, expected_frequencies * col_total)
	observed_remainder = col_total .- observed_counts
	expected_remainder = col_total .- expected_counts

	pvalues = spzeros(nrows, ncols)
	for row in 1:nrows
		for col in 1:ncols
			
			# build the contingency table
			a = observed_counts[row, col]
			b = observed_remainder[row, col]
			c = expected_counts[row, col]
			d = expected_remainder[row, col]
			contingency_table = [ a b ; c d ]
			
			# perform a χ² test of homogeneity
			if all(>=(5), contingency_table)
				pval = pvalue(ChisqTest(contingency_table))
				# note: FisherExactTest(a, b, c, d) gives very similar results
				#pval = pvalue(FisherExactTest(a, b, c, d); method=:minlike)
				
				pvalues[row, col] = pval
			end
		end
	end
	pvalues
end

# ╔═╡ b314add7-a6f5-42f0-bc9a-bba748543fa2
md"""
Out of curiosity, with no correction for multiple comparisons, we find a single p-value below 0.05:
"""

# ╔═╡ 7e383967-26de-49bd-a106-d215241ffdb1
begin
	uncorrected_pvalues_below_threshold = copy(pvalues)
	uncorrected_pvalues_below_threshold.nzval[.05 .< pvalues.nzval] .= 0
	dropzeros(uncorrected_pvalues_below_threshold)
end

# ╔═╡ c09b771c-aab1-40cf-a273-14aa6c857510
md"""
Correcting for all the comparisons, no differences survive:
"""

# ╔═╡ 46c9be07-3bb4-499c-a819-7a87c73b6e42
# with correction, no differences survive
begin
	# see https://github.com/juliangehring/MultipleTesting.jl#holm
	corrected_pvalues = adjust(pvalues.nzval, Holm())
	significant = corrected_pvalues .<= .05
	significant_pvalues = copy(pvalues)
	significant_pvalues.nzval .= 0
	significant_pvalues.nzval[significant] = corrected_pvalues[significant]
	significant_pvalues = dropzeros(significant_pvalues)
end

# ╔═╡ 128668c3-282d-4453-84a6-cf2c29d7140f
md"""
Had we found differences, we could get the corresponding category-genotype pairs as follows:
"""

# ╔═╡ 548ca244-de4c-47c2-a69e-0ca7a449028f
begin
	row, col = findnz(significant_pvalues)
	category = categories[row_ok][row]
	genotype = genotypes[col_ok][col]
	collect(zip(category, genotype))
end

# ╔═╡ 884a7299-8418-45e4-82f3-65204d48e55b
md"""
Correcting for all comparisons is probably unfair. Frequencies are bound within each column and row (one less degree of freedom).

Anyway, the sample size is far too low for the number of cells, and we need a more powerful test.

Let us now compare each genotype with the "average" genotype grouping the low-frequency cells together. We already know the post-hoc tests fail, and we won't have category-level resolution, but a significant difference may be an argument for increasing the sample size, or rethinking the categories. 

An elaborate approach can be found in [Kass, 1980](https://www4.stat.ncsu.edu/~dickey/analytics/datamine/Reference%20Papers/kass80.pdf).

The simpler approach followed here consists in grouping all observed counts below 5 into a single synthetic category, for each column separately. Expected counts are similarly grouped, based on the observed counts. If some expected count is below 5 (included the synthetic category), we carry on unless this count is 0.
"""

# ╔═╡ 9342e489-a297-4c67-8324-cb41801af713
begin
	per_genotype_pvalues = Float64[]
	for col in 1:ncols
		ok = observed_counts[:, col] .>= 5
		any(ok) || continue
		observed_counts′ = observed_counts[ok, col]
		if !all(ok)
			synthetic_count = sum(observed_counts[(!).(ok), col])
			push!(observed_counts′, synthetic_count)
		end
		expected_counts′ = expected_counts[ok, col]
		if !all(ok)
			synthetic_count = sum(expected_counts[(!).(ok), col])
			push!(expected_counts′, synthetic_count)
		end
		contingency_table = hcat(observed_counts′, expected_counts′)
		if any(expected_counts′ .< 5)
			if any(expected_counts′ .== 0)
				@warn "Expected counts are too low; skipping" contingency_table
				continue
			else
				#@warn "Expected counts are low" contingency_table
			end
		end
		pval = pvalue(ChisqTest(contingency_table))
		push!(per_genotype_pvalues, pval)
	end
	per_genotype_pvalues
end

# ╔═╡ 31dc58db-5a4e-47dc-bdb8-fe6e9bb47204
md"""
We do not bother pretty printing or correcting the p-values: there are no significant differences at all.

We could try pairwise comparisons between genotypes now, instead of focusing on an "average" genotype as a reference.
"""

# ╔═╡ 00000000-0000-0000-0000-000000000001
PLUTO_PROJECT_TOML_CONTENTS = """
[deps]
HypothesisTests = "09f84164-cd44-5f33-b23f-e6b0d136a0d5"
MultipleTesting = "f8716d33-7c4a-5097-896f-ce0ecbd3ef6b"
SparseArrays = "2f01184e-e22b-5df5-ae63-d93ebab69eaf"
StatsBase = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91"
XLSX = "fdbf4ff8-1666-58a4-91e7-1b58723a45e0"

[compat]
HypothesisTests = "~0.11.0"
MultipleTesting = "~0.5.1"
StatsBase = "~0.33.21"
XLSX = "~0.9.0"
"""

# ╔═╡ 00000000-0000-0000-0000-000000000002
PLUTO_MANIFEST_TOML_CONTENTS = """
# This file is machine-generated - editing it directly is not advised

julia_version = "1.9.0"
manifest_format = "2.0"
project_hash = "d9da7e97863fee97b88704272749d1c852674499"

[[deps.ArgTools]]
uuid = "0dad84c5-d112-42e6-8d28-ef12dabb789f"
version = "1.1.1"

[[deps.Artifacts]]
uuid = "56f22d72-fd6d-98f1-02f0-08ddc0907c33"

[[deps.Base64]]
uuid = "2a0f44e3-6c83-55bd-87e4-b1978d98bd5f"

[[deps.Calculus]]
deps = ["LinearAlgebra"]
git-tree-sha1 = "f641eb0a4f00c343bbc32346e1217b86f3ce9dad"
uuid = "49dc2e85-a5d0-5ad3-a950-438e2897f1b9"
version = "0.5.1"

[[deps.ChainRulesCore]]
deps = ["Compat", "LinearAlgebra", "SparseArrays"]
git-tree-sha1 = "e30f2f4e20f7f186dc36529910beaedc60cfa644"
uuid = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4"
version = "1.16.0"

[[deps.Combinatorics]]
git-tree-sha1 = "08c8b6831dc00bfea825826be0bc8336fc369860"
uuid = "861a8166-3701-5b0c-9a16-15d98fcdc6aa"
version = "1.0.2"

[[deps.CommonSolve]]
git-tree-sha1 = "0eee5eb66b1cf62cd6ad1b460238e60e4b09400c"
uuid = "38540f10-b2f7-11e9-35d8-d573e4eb0ff2"
version = "0.2.4"

[[deps.Compat]]
deps = ["UUIDs"]
git-tree-sha1 = "7a60c856b9fa189eb34f5f8a6f6b5529b7942957"
uuid = "34da2185-b29b-5c13-b0c7-acf172513d20"
version = "4.6.1"
weakdeps = ["Dates", "LinearAlgebra"]

    [deps.Compat.extensions]
    CompatLinearAlgebraExt = "LinearAlgebra"

[[deps.CompilerSupportLibraries_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "e66e0078-7015-5450-92f7-15fbd957f2ae"
version = "1.0.2+0"

[[deps.ConstructionBase]]
deps = ["LinearAlgebra"]
git-tree-sha1 = "738fec4d684a9a6ee9598a8bfee305b26831f28c"
uuid = "187b0558-2788-49d3-abe0-74a17ed4e7c9"
version = "1.5.2"

    [deps.ConstructionBase.extensions]
    ConstructionBaseIntervalSetsExt = "IntervalSets"
    ConstructionBaseStaticArraysExt = "StaticArrays"

    [deps.ConstructionBase.weakdeps]
    IntervalSets = "8197267c-284f-5f27-9208-e0e47529a953"
    StaticArrays = "90137ffa-7385-5640-81b9-e52037218182"

[[deps.DataAPI]]
git-tree-sha1 = "8da84edb865b0b5b0100c0666a9bc9a0b71c553c"
uuid = "9a962f9c-6df0-11e9-0e5d-c546b8b5ee8a"
version = "1.15.0"

[[deps.DataStructures]]
deps = ["Compat", "InteractiveUtils", "OrderedCollections"]
git-tree-sha1 = "d1fff3a548102f48987a52a2e0d114fa97d730f0"
uuid = "864edb3b-99cc-5e75-8d2d-829cb0a9cfe8"
version = "0.18.13"

[[deps.DataValueInterfaces]]
git-tree-sha1 = "bfc1187b79289637fa0ef6d4436ebdfe6905cbd6"
uuid = "e2d170a0-9d28-54be-80f0-106bbe20a464"
version = "1.0.0"

[[deps.Dates]]
deps = ["Printf"]
uuid = "ade2ca70-3891-5945-98fb-dc099432e06a"

[[deps.Distributions]]
deps = ["FillArrays", "LinearAlgebra", "PDMats", "Printf", "QuadGK", "Random", "SparseArrays", "SpecialFunctions", "Statistics", "StatsAPI", "StatsBase", "StatsFuns", "Test"]
git-tree-sha1 = "4ed4a6df2548a72f66e03f3a285cd1f3b573035d"
uuid = "31c24e10-a181-5473-b8eb-7969acd0382f"
version = "0.25.96"

    [deps.Distributions.extensions]
    DistributionsChainRulesCoreExt = "ChainRulesCore"
    DistributionsDensityInterfaceExt = "DensityInterface"

    [deps.Distributions.weakdeps]
    ChainRulesCore = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4"
    DensityInterface = "b429d917-457f-4dbc-8f4c-0cc954292b1d"

[[deps.DocStringExtensions]]
deps = ["LibGit2"]
git-tree-sha1 = "2fb1e02f2b635d0845df5d7c167fec4dd739b00d"
uuid = "ffbed154-4ef7-542d-bbb7-c09d3a79fcae"
version = "0.9.3"

[[deps.Downloads]]
deps = ["ArgTools", "FileWatching", "LibCURL", "NetworkOptions"]
uuid = "f43a241f-c20a-4ad4-852c-f6b1247861c6"
version = "1.6.0"

[[deps.DualNumbers]]
deps = ["Calculus", "NaNMath", "SpecialFunctions"]
git-tree-sha1 = "5837a837389fccf076445fce071c8ddaea35a566"
uuid = "fa6b7ba4-c1ee-5f82-b5fc-ecf0adba8f74"
version = "0.6.8"

[[deps.EzXML]]
deps = ["Printf", "XML2_jll"]
git-tree-sha1 = "0fa3b52a04a4e210aeb1626def9c90df3ae65268"
uuid = "8f5d6c58-4d21-5cfd-889c-e3ad7ee6a615"
version = "1.1.0"

[[deps.FileWatching]]
uuid = "7b1f6079-737a-58dc-b8bc-7a2ca5c1b5ee"

[[deps.FillArrays]]
deps = ["LinearAlgebra", "Random", "SparseArrays", "Statistics"]
git-tree-sha1 = "e17cc4dc2d0b0b568e80d937de8ed8341822de67"
uuid = "1a297f60-69ca-5386-bcde-b61e274b549b"
version = "1.2.0"

[[deps.Future]]
deps = ["Random"]
uuid = "9fa8497b-333b-5362-9e8d-4d0656e87820"

[[deps.HypergeometricFunctions]]
deps = ["DualNumbers", "LinearAlgebra", "OpenLibm_jll", "SpecialFunctions"]
git-tree-sha1 = "0ec02c648befc2f94156eaef13b0f38106212f3f"
uuid = "34004b35-14d8-5ef3-9330-4cdb6864b03a"
version = "0.3.17"

[[deps.HypothesisTests]]
deps = ["Combinatorics", "Distributions", "LinearAlgebra", "Printf", "Random", "Rmath", "Roots", "Statistics", "StatsAPI", "StatsBase"]
git-tree-sha1 = "4b5d5ba51f5f473737ed9de6d8a7aa190ad8c72f"
uuid = "09f84164-cd44-5f33-b23f-e6b0d136a0d5"
version = "0.11.0"

[[deps.InteractiveUtils]]
deps = ["Markdown"]
uuid = "b77e0a4c-d291-57a0-90e8-8db25a27a240"

[[deps.IrrationalConstants]]
git-tree-sha1 = "630b497eafcc20001bba38a4651b327dcfc491d2"
uuid = "92d709cd-6900-40b7-9082-c6be49f344b6"
version = "0.2.2"

[[deps.IteratorInterfaceExtensions]]
git-tree-sha1 = "a3f24677c21f5bbe9d2a714f95dcd58337fb2856"
uuid = "82899510-4779-5014-852e-03e436cf321d"
version = "1.0.0"

[[deps.JLLWrappers]]
deps = ["Preferences"]
git-tree-sha1 = "abc9885a7ca2052a736a600f7fa66209f96506e1"
uuid = "692b3bcd-3c85-4b1f-b108-f13ce0eb3210"
version = "1.4.1"

[[deps.LibCURL]]
deps = ["LibCURL_jll", "MozillaCACerts_jll"]
uuid = "b27032c2-a3e7-50c8-80cd-2d36dbcbfd21"
version = "0.6.3"

[[deps.LibCURL_jll]]
deps = ["Artifacts", "LibSSH2_jll", "Libdl", "MbedTLS_jll", "Zlib_jll", "nghttp2_jll"]
uuid = "deac9b47-8bc7-5906-a0fe-35ac56dc84c0"
version = "7.84.0+0"

[[deps.LibGit2]]
deps = ["Base64", "NetworkOptions", "Printf", "SHA"]
uuid = "76f85450-5226-5b5a-8eaa-529ad045b433"

[[deps.LibSSH2_jll]]
deps = ["Artifacts", "Libdl", "MbedTLS_jll"]
uuid = "29816b5a-b9ab-546f-933c-edad1886dfa8"
version = "1.10.2+0"

[[deps.Libdl]]
uuid = "8f399da3-3557-5675-b5ff-fb832c97cbdb"

[[deps.Libiconv_jll]]
deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"]
git-tree-sha1 = "c7cb1f5d892775ba13767a87c7ada0b980ea0a71"
uuid = "94ce4f54-9a6c-5748-9c1c-f9c7231a4531"
version = "1.16.1+2"

[[deps.LinearAlgebra]]
deps = ["Libdl", "OpenBLAS_jll", "libblastrampoline_jll"]
uuid = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e"

[[deps.LogExpFunctions]]
deps = ["DocStringExtensions", "IrrationalConstants", "LinearAlgebra"]
git-tree-sha1 = "c3ce8e7420b3a6e071e0fe4745f5d4300e37b13f"
uuid = "2ab3a3ac-af41-5b50-aa03-7779005ae688"
version = "0.3.24"

    [deps.LogExpFunctions.extensions]
    LogExpFunctionsChainRulesCoreExt = "ChainRulesCore"
    LogExpFunctionsChangesOfVariablesExt = "ChangesOfVariables"
    LogExpFunctionsInverseFunctionsExt = "InverseFunctions"

    [deps.LogExpFunctions.weakdeps]
    ChainRulesCore = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4"
    ChangesOfVariables = "9e997f8a-9a97-42d5-a9f1-ce6bfc15e2c0"
    InverseFunctions = "3587e190-3f89-42d0-90ee-14403ec27112"

[[deps.Logging]]
uuid = "56ddb016-857b-54e1-b83d-db4d58db5568"

[[deps.MacroTools]]
deps = ["Markdown", "Random"]
git-tree-sha1 = "42324d08725e200c23d4dfb549e0d5d89dede2d2"
uuid = "1914dd2f-81c6-5fcd-8719-6d5c9610ff09"
version = "0.5.10"

[[deps.Markdown]]
deps = ["Base64"]
uuid = "d6f4376e-aef5-505a-96c1-9c027394607a"

[[deps.MbedTLS_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "c8ffd9c3-330d-5841-b78e-0817d7145fa1"
version = "2.28.2+0"

[[deps.Missings]]
deps = ["DataAPI"]
git-tree-sha1 = "f66bdc5de519e8f8ae43bdc598782d35a25b1272"
uuid = "e1d29d7a-bbdc-5cf2-9ac0-f12de2c33e28"
version = "1.1.0"

[[deps.MozillaCACerts_jll]]
uuid = "14a3606d-f60d-562e-9121-12d972cd8159"
version = "2022.10.11"

[[deps.MultipleTesting]]
deps = ["Distributions", "SpecialFunctions", "StatsBase"]
git-tree-sha1 = "94df14d821baa34662a1492b10615125cbebd47b"
uuid = "f8716d33-7c4a-5097-896f-ce0ecbd3ef6b"
version = "0.5.1"

[[deps.NaNMath]]
deps = ["OpenLibm_jll"]
git-tree-sha1 = "0877504529a3e5c3343c6f8b4c0381e57e4387e4"
uuid = "77ba4419-2d1f-58cd-9bb1-8ffee604a2e3"
version = "1.0.2"

[[deps.NetworkOptions]]
uuid = "ca575930-c2e3-43a9-ace4-1e988b2c1908"
version = "1.2.0"

[[deps.OpenBLAS_jll]]
deps = ["Artifacts", "CompilerSupportLibraries_jll", "Libdl"]
uuid = "4536629a-c528-5b80-bd46-f80d51c5b363"
version = "0.3.21+4"

[[deps.OpenLibm_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "05823500-19ac-5b8b-9628-191a04bc5112"
version = "0.8.1+0"

[[deps.OpenSpecFun_jll]]
deps = ["Artifacts", "CompilerSupportLibraries_jll", "JLLWrappers", "Libdl", "Pkg"]
git-tree-sha1 = "13652491f6856acfd2db29360e1bbcd4565d04f1"
uuid = "efe28fd5-8261-553b-a9e1-b2916fc3738e"
version = "0.5.5+0"

[[deps.OrderedCollections]]
git-tree-sha1 = "d321bf2de576bf25ec4d3e4360faca399afca282"
uuid = "bac558e1-5e72-5ebc-8fee-abe8a469f55d"
version = "1.6.0"

[[deps.PDMats]]
deps = ["LinearAlgebra", "SparseArrays", "SuiteSparse"]
git-tree-sha1 = "67eae2738d63117a196f497d7db789821bce61d1"
uuid = "90014a1f-27ba-587c-ab20-58faa44d9150"
version = "0.11.17"

[[deps.Pkg]]
deps = ["Artifacts", "Dates", "Downloads", "FileWatching", "LibGit2", "Libdl", "Logging", "Markdown", "Printf", "REPL", "Random", "SHA", "Serialization", "TOML", "Tar", "UUIDs", "p7zip_jll"]
uuid = "44cfe95a-1eb2-52ea-b672-e2afdf69b78f"
version = "1.9.0"

[[deps.Preferences]]
deps = ["TOML"]
git-tree-sha1 = "7eb1686b4f04b82f96ed7a4ea5890a4f0c7a09f1"
uuid = "21216c6a-2e73-6563-6e65-726566657250"
version = "1.4.0"

[[deps.Printf]]
deps = ["Unicode"]
uuid = "de0858da-6303-5e67-8744-51eddeeeb8d7"

[[deps.QuadGK]]
deps = ["DataStructures", "LinearAlgebra"]
git-tree-sha1 = "6ec7ac8412e83d57e313393220879ede1740f9ee"
uuid = "1fd47b50-473d-5c70-9696-f719f8f3bcdc"
version = "2.8.2"

[[deps.REPL]]
deps = ["InteractiveUtils", "Markdown", "Sockets", "Unicode"]
uuid = "3fa0cd96-eef1-5676-8a61-b3b8758bbffb"

[[deps.Random]]
deps = ["SHA", "Serialization"]
uuid = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c"

[[deps.Reexport]]
git-tree-sha1 = "45e428421666073eab6f2da5c9d310d99bb12f9b"
uuid = "189a3867-3050-52da-a836-e630ba90ab69"
version = "1.2.2"

[[deps.Rmath]]
deps = ["Random", "Rmath_jll"]
git-tree-sha1 = "f65dcb5fa46aee0cf9ed6274ccbd597adc49aa7b"
uuid = "79098fc4-a85e-5d69-aa6a-4863f24498fa"
version = "0.7.1"

[[deps.Rmath_jll]]
deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"]
git-tree-sha1 = "6ed52fdd3382cf21947b15e8870ac0ddbff736da"
uuid = "f50d1b31-88e8-58de-be2c-1cc44531875f"
version = "0.4.0+0"

[[deps.Roots]]
deps = ["ChainRulesCore", "CommonSolve", "Printf", "Setfield"]
git-tree-sha1 = "de432823e8aab4dd1a985be4be768f95acf152d4"
uuid = "f2b01f46-fcfa-551c-844a-d8ac1e96c665"
version = "2.0.17"

    [deps.Roots.extensions]
    RootsForwardDiffExt = "ForwardDiff"
    RootsIntervalRootFindingExt = "IntervalRootFinding"
    RootsSymPyExt = "SymPy"

    [deps.Roots.weakdeps]
    ForwardDiff = "f6369f11-7733-5829-9624-2563aa707210"
    IntervalRootFinding = "d2bf35a9-74e0-55ec-b149-d360ff49b807"
    SymPy = "24249f21-da20-56a4-8eb1-6a02cf4ae2e6"

[[deps.SHA]]
uuid = "ea8e919c-243c-51af-8825-aaa63cd721ce"
version = "0.7.0"

[[deps.Serialization]]
uuid = "9e88b42a-f829-5b0c-bbe9-9e923198166b"

[[deps.Setfield]]
deps = ["ConstructionBase", "Future", "MacroTools", "StaticArraysCore"]
git-tree-sha1 = "e2cc6d8c88613c05e1defb55170bf5ff211fbeac"
uuid = "efcf1570-3423-57d1-acb7-fd33fddbac46"
version = "1.1.1"

[[deps.Sockets]]
uuid = "6462fe0b-24de-5631-8697-dd941f90decc"

[[deps.SortingAlgorithms]]
deps = ["DataStructures"]
git-tree-sha1 = "c60ec5c62180f27efea3ba2908480f8055e17cee"
uuid = "a2af1166-a08f-5f64-846c-94a0d3cef48c"
version = "1.1.1"

[[deps.SparseArrays]]
deps = ["Libdl", "LinearAlgebra", "Random", "Serialization", "SuiteSparse_jll"]
uuid = "2f01184e-e22b-5df5-ae63-d93ebab69eaf"

[[deps.SpecialFunctions]]
deps = ["IrrationalConstants", "LogExpFunctions", "OpenLibm_jll", "OpenSpecFun_jll"]
git-tree-sha1 = "ef28127915f4229c971eb43f3fc075dd3fe91880"
uuid = "276daf66-3868-5448-9aa4-cd146d93841b"
version = "2.2.0"
weakdeps = ["ChainRulesCore"]

    [deps.SpecialFunctions.extensions]
    SpecialFunctionsChainRulesCoreExt = "ChainRulesCore"

[[deps.StaticArraysCore]]
git-tree-sha1 = "6b7ba252635a5eff6a0b0664a41ee140a1c9e72a"
uuid = "1e83bf80-4336-4d27-bf5d-d5a4f845583c"
version = "1.4.0"

[[deps.Statistics]]
deps = ["LinearAlgebra", "SparseArrays"]
uuid = "10745b16-79ce-11e8-11f9-7d13ad32a3b2"
version = "1.9.0"

[[deps.StatsAPI]]
deps = ["LinearAlgebra"]
git-tree-sha1 = "45a7769a04a3cf80da1c1c7c60caf932e6f4c9f7"
uuid = "82ae8749-77ed-4fe6-ae5f-f523153014b0"
version = "1.6.0"

[[deps.StatsBase]]
deps = ["DataAPI", "DataStructures", "LinearAlgebra", "LogExpFunctions", "Missings", "Printf", "Random", "SortingAlgorithms", "SparseArrays", "Statistics", "StatsAPI"]
git-tree-sha1 = "d1bf48bfcc554a3761a133fe3a9bb01488e06916"
uuid = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91"
version = "0.33.21"

[[deps.StatsFuns]]
deps = ["HypergeometricFunctions", "IrrationalConstants", "LogExpFunctions", "Reexport", "Rmath", "SpecialFunctions"]
git-tree-sha1 = "f625d686d5a88bcd2b15cd81f18f98186fdc0c9a"
uuid = "4c63d2b9-4356-54db-8cca-17b64c39e42c"
version = "1.3.0"

    [deps.StatsFuns.extensions]
    StatsFunsChainRulesCoreExt = "ChainRulesCore"
    StatsFunsInverseFunctionsExt = "InverseFunctions"

    [deps.StatsFuns.weakdeps]
    ChainRulesCore = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4"
    InverseFunctions = "3587e190-3f89-42d0-90ee-14403ec27112"

[[deps.SuiteSparse]]
deps = ["Libdl", "LinearAlgebra", "Serialization", "SparseArrays"]
uuid = "4607b0f0-06f3-5cda-b6b1-a6196a1729e9"

[[deps.SuiteSparse_jll]]
deps = ["Artifacts", "Libdl", "Pkg", "libblastrampoline_jll"]
uuid = "bea87d4a-7f5b-5778-9afe-8cc45184846c"
version = "5.10.1+6"

[[deps.TOML]]
deps = ["Dates"]
uuid = "fa267f1f-6049-4f14-aa54-33bafae1ed76"
version = "1.0.3"

[[deps.TableTraits]]
deps = ["IteratorInterfaceExtensions"]
git-tree-sha1 = "c06b2f539df1c6efa794486abfb6ed2022561a39"
uuid = "3783bdb8-4a98-5b6b-af9a-565f29a5fe9c"
version = "1.0.1"

[[deps.Tables]]
deps = ["DataAPI", "DataValueInterfaces", "IteratorInterfaceExtensions", "LinearAlgebra", "OrderedCollections", "TableTraits", "Test"]
git-tree-sha1 = "1544b926975372da01227b382066ab70e574a3ec"
uuid = "bd369af6-aec1-5ad0-b16a-f7cc5008161c"
version = "1.10.1"

[[deps.Tar]]
deps = ["ArgTools", "SHA"]
uuid = "a4e569a6-e804-4fa4-b0f3-eef7a1d5b13e"
version = "1.10.0"

[[deps.Test]]
deps = ["InteractiveUtils", "Logging", "Random", "Serialization"]
uuid = "8dfed614-e22c-5e08-85e1-65c5234f0b40"

[[deps.UUIDs]]
deps = ["Random", "SHA"]
uuid = "cf7118a7-6976-5b1a-9a39-7adc72f591a4"

[[deps.Unicode]]
uuid = "4ec0a83e-493e-50e2-b9ac-8f72acf5a8f5"

[[deps.XLSX]]
deps = ["Artifacts", "Dates", "EzXML", "Printf", "Tables", "ZipFile"]
git-tree-sha1 = "d6af50e2e15d32aff416b7e219885976dc3d870f"
uuid = "fdbf4ff8-1666-58a4-91e7-1b58723a45e0"
version = "0.9.0"

[[deps.XML2_jll]]
deps = ["Artifacts", "JLLWrappers", "Libdl", "Libiconv_jll", "Pkg", "Zlib_jll"]
git-tree-sha1 = "93c41695bc1c08c46c5899f4fe06d6ead504bb73"
uuid = "02c8fc9c-b97f-50b9-bbe4-9be30ff0a78a"
version = "2.10.3+0"

[[deps.ZipFile]]
deps = ["Libdl", "Printf", "Zlib_jll"]
git-tree-sha1 = "f492b7fe1698e623024e873244f10d89c95c340a"
uuid = "a5390f91-8eb1-5f08-bee0-b1d1ffed6cea"
version = "0.10.1"

[[deps.Zlib_jll]]
deps = ["Libdl"]
uuid = "83775a58-1f1d-513f-b197-d71354ab007a"
version = "1.2.13+0"

[[deps.libblastrampoline_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "8e850b90-86db-534c-a0d3-1478176c7d93"
version = "5.7.0+0"

[[deps.nghttp2_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "8e850ede-7688-5339-a07c-302acd2aaf8d"
version = "1.48.0+0"

[[deps.p7zip_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "3f19e933-33d8-53b3-aaab-bd5110c3b7a0"
version = "17.4.0+0"
"""

# ╔═╡ Cell order:
# ╠═11ac5f6a-0f6a-11ee-2598-11c7a0064b43
# ╟─8dd5d4b9-5a32-4a95-8f38-7f3e5b98e2d9
# ╠═5e94a517-db46-4864-b717-5b4543884dff
# ╠═a5e61a48-e07e-49dc-8c61-1224d1c47d13
# ╟─a25eecd6-f58d-493d-a5cf-94218319849d
# ╠═9c3b8eb2-a160-4246-a5c7-596a86c73d62
# ╟─3eb9d39c-2ca1-430e-b13b-05c809a80d5b
# ╠═e3febec7-b84c-45f9-8f65-5a158b0ae933
# ╟─f2825d3c-577b-4b61-8c8c-c869a9ec9f07
# ╠═72cf8d55-a423-4c28-a370-377f9ef6a70e
# ╟─b8adc566-5893-402a-a35d-11c06460fb62
# ╠═3df39484-e07a-48d8-90ae-09da0050b3ce
# ╟─b314add7-a6f5-42f0-bc9a-bba748543fa2
# ╠═7e383967-26de-49bd-a106-d215241ffdb1
# ╟─c09b771c-aab1-40cf-a273-14aa6c857510
# ╠═46c9be07-3bb4-499c-a819-7a87c73b6e42
# ╟─128668c3-282d-4453-84a6-cf2c29d7140f
# ╠═548ca244-de4c-47c2-a69e-0ca7a449028f
# ╟─884a7299-8418-45e4-82f3-65204d48e55b
# ╠═9342e489-a297-4c67-8324-cb41801af713
# ╟─31dc58db-5a4e-47dc-bdb8-fe6e9bb47204
# ╟─00000000-0000-0000-0000-000000000001
# ╟─00000000-0000-0000-0000-000000000002
"; +window.pluto_notebookfile = "data:text/julia;charset=utf-8;base64,### A Pluto.jl notebook ###
# v0.19.26

using Markdown
using InteractiveUtils

# ╔═╡ 11ac5f6a-0f6a-11ee-2598-11c7a0064b43
using StatsBase, HypothesisTests, XLSX, SparseArrays, MultipleTesting

# ╔═╡ 01fbf1c9-1cea-4593-a2c5-03854dee2473
md"""
This document is a Pluto notebook (or an html rendered version of it) and requires [Julia](https://computationalthinking.mit.edu/Spring21/installation/).
"""

# ╔═╡ 8dd5d4b9-5a32-4a95-8f38-7f3e5b98e2d9
md"""
We first load the count data.

Note the notebook is assumed to run from a child directory (*e.g.* `notebooks`) of the project root, and the data files are expected to be found in `data/raw`, again from the project root.
"""

# ╔═╡ 5e94a517-db46-4864-b717-5b4543884dff
data = XLSX.openxlsx("../data/raw/SNPspecifiques.xlsx")

# ╔═╡ a5e61a48-e07e-49dc-8c61-1224d1c47d13
counts = Int.(data["Nb SNP"]["B3:U25"])

# ╔═╡ a25eecd6-f58d-493d-a5cf-94218319849d
md"""
For further reference, we also load the labels of the rows (`categories`) and columns (`genotypes`).
"""

# ╔═╡ 9c3b8eb2-a160-4246-a5c7-596a86c73d62
begin
	genotypes = vec(data["Nb SNP"]["B2:U2"]) # columns
	categories = vec(data["Nb SNP"]["A3:A25"]) # rows
end

# ╔═╡ 3eb9d39c-2ca1-430e-b13b-05c809a80d5b
md"""
First, we exclude the rows and columns of zeros only.
"""

# ╔═╡ e3febec7-b84c-45f9-8f65-5a158b0ae933
begin
	row_ok = vec(any(!=(0), counts; dims=2))
	col_ok = vec(any(!=(0), counts; dims=1))
	clean_counts = counts[row_ok, col_ok]
	nrows, ncols = size(clean_counts)
end

# ╔═╡ f2825d3c-577b-4b61-8c8c-c869a9ec9f07
md"""
To test whether a genotype exhibits a different partition into categories of genes, or equivalently whether it is enriched in some category, we first derive an expected partition averaging the category frequencies across all genotypes.
"""

# ╔═╡ 72cf8d55-a423-4c28-a370-377f9ef6a70e
begin
	col_total = sum(clean_counts; dims=1)
	expected_frequencies = mean(clean_counts ./ col_total; dims=2)
	@assert sum(expected_frequencies) ≈ 1
	# print the frequencies with the corresponding category names
	Dict(zip(categories[row_ok], expected_frequencies))
end

# ╔═╡ b8adc566-5893-402a-a35d-11c06460fb62
md"""
Due to the presence of zeros in most columns, we have to group the low-frequency cells into single cells on a per-column basis. The information in low-frequency cells is already accounted for by the other cells.

We can also individually test each count `observed_n` _equal to or greater than 5_ in a contingency table with:
```
+------------+------------------------+
| observed_n | col_total - observed_n |
+------------+------------------------+
| expected_n | col_total - expected_n |
+------------+------------------------+
```
This second approach is less powerful, though.

Let us begin with this second approach:
"""

# ╔═╡ 3df39484-e07a-48d8-90ae-09da0050b3ce
begin
	observed_counts = clean_counts
	# in theory, we could also use real-valued counts instead
	expected_counts = @. round(Int, expected_frequencies * col_total)
	observed_remainder = col_total .- observed_counts
	expected_remainder = col_total .- expected_counts

	pvalues = spzeros(nrows, ncols)
	for row in 1:nrows
		for col in 1:ncols
			
			# build the contingency table
			a = observed_counts[row, col]
			b = observed_remainder[row, col]
			c = expected_counts[row, col]
			d = expected_remainder[row, col]
			contingency_table = [ a b ; c d ]
			
			# perform a χ² test of homogeneity
			if all(>=(5), contingency_table)
				pval = pvalue(ChisqTest(contingency_table))
				# note: FisherExactTest(a, b, c, d) gives very similar results
				#pval = pvalue(FisherExactTest(a, b, c, d); method=:minlike)
				
				pvalues[row, col] = pval
			end
		end
	end
	pvalues
end

# ╔═╡ b314add7-a6f5-42f0-bc9a-bba748543fa2
md"""
Out of curiosity, with no correction for multiple comparisons, we find a single p-value below 0.05:
"""

# ╔═╡ 7e383967-26de-49bd-a106-d215241ffdb1
begin
	uncorrected_pvalues_below_threshold = copy(pvalues)
	uncorrected_pvalues_below_threshold.nzval[.05 .< pvalues.nzval] .= 0
	dropzeros(uncorrected_pvalues_below_threshold)
end

# ╔═╡ c09b771c-aab1-40cf-a273-14aa6c857510
md"""
Correcting for all the comparisons, no differences survive:
"""

# ╔═╡ 46c9be07-3bb4-499c-a819-7a87c73b6e42
begin
	# see https://github.com/juliangehring/MultipleTesting.jl#two-step
	corrected_pvalues = adjust(pvalues.nzval, BenjaminiHochbergAdaptive(TwoStep()))
	
	significant = corrected_pvalues .<= .05
	significant_pvalues = copy(pvalues)
	significant_pvalues.nzval .= 0
	significant_pvalues.nzval[significant] = corrected_pvalues[significant]
	significant_pvalues = dropzeros(significant_pvalues)
end

# ╔═╡ 128668c3-282d-4453-84a6-cf2c29d7140f
md"""
Had we found differences, we could get the corresponding category-genotype pairs as follows:
"""

# ╔═╡ 548ca244-de4c-47c2-a69e-0ca7a449028f
begin
	row, col = findnz(significant_pvalues)
	category = categories[row_ok][row]
	genotype = genotypes[col_ok][col]
	collect(zip(category, genotype))
end

# ╔═╡ 884a7299-8418-45e4-82f3-65204d48e55b
md"""
The sample size is too low if we consider the large number of cells, and we need a more powerful test.
Let us now compare each genotype with the "average" genotype, grouping the low-frequency cells together.

We already know the post-hoc tests fail, therefore we won't have category-level resolution. However, a significant difference is still possible here as the test will cumulate the differences for the different categories. The individual differences should be detectable increasing the sample size.

# Disclaimer

The following analysis is a second iteration motivated by an error in the first iteration. The history of the present notebook can be found [here](https://gitlab.pasteur.fr/flaurent/project19449/-/blob/main/notebooks/snp_chisq_tests.jl).

The categories were grouped based on the observed counts, whereas the minimum-5 criterion actually applies to the expected counts. This is fixed in this version of the analysis.

# Grouping procedure

An elaborate grouping approach can be found in [Kass, 1980](https://www4.stat.ncsu.edu/~dickey/analytics/datamine/Reference%20Papers/kass80.pdf).

The simpler approach followed here consists in grouping all the categories with an expected count below 5 into a single synthetic category, for each column separately. Observed counts are similarly grouped, based on the expected counts.
"""

# ╔═╡ 9342e489-a297-4c67-8324-cb41801af713
begin
	per_genotype_pvalues = Dict{String, Float64}()
	for col in 1:ncols
		# identify cells to be grouped
		ok = expected_counts[:, col] .>= 5
		any(ok) || continue
		# group cells
		expected_counts′ = expected_counts[ok, col]
		if !all(ok)
			synthetic_count = sum(expected_counts[(!).(ok), col])
			push!(expected_counts′, synthetic_count)
		end
		observed_counts′ = observed_counts[ok, col]
		if !all(ok)
			synthetic_count = sum(observed_counts[(!).(ok), col])
			push!(observed_counts′, synthetic_count)
		end
		# perform the test
		contingency_table = hcat(observed_counts′, expected_counts′)
		pval = pvalue(ChisqTest(contingency_table))
		# record the resulting pvalue
		genotype = genotypes[col_ok][col]
		per_genotype_pvalues[genotype] = pval
	end
	per_genotype_pvalues
end

# ╔═╡ 6d768ec2-f9ad-4cc7-a2df-4eeb1a72cd44
md"""
Not any uncorrected p-value drops below 0.05.
"""

# ╔═╡ 00000000-0000-0000-0000-000000000001
PLUTO_PROJECT_TOML_CONTENTS = """
[deps]
HypothesisTests = "09f84164-cd44-5f33-b23f-e6b0d136a0d5"
MultipleTesting = "f8716d33-7c4a-5097-896f-ce0ecbd3ef6b"
SparseArrays = "2f01184e-e22b-5df5-ae63-d93ebab69eaf"
StatsBase = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91"
XLSX = "fdbf4ff8-1666-58a4-91e7-1b58723a45e0"

[compat]
HypothesisTests = "~0.11.0"
MultipleTesting = "~0.5.1"
StatsBase = "~0.33.21"
XLSX = "~0.9.0"
"""

# ╔═╡ 00000000-0000-0000-0000-000000000002
PLUTO_MANIFEST_TOML_CONTENTS = """
# This file is machine-generated - editing it directly is not advised

julia_version = "1.9.0"
manifest_format = "2.0"
project_hash = "d9da7e97863fee97b88704272749d1c852674499"

[[deps.ArgTools]]
uuid = "0dad84c5-d112-42e6-8d28-ef12dabb789f"
version = "1.1.1"

[[deps.Artifacts]]
uuid = "56f22d72-fd6d-98f1-02f0-08ddc0907c33"

[[deps.Base64]]
uuid = "2a0f44e3-6c83-55bd-87e4-b1978d98bd5f"

[[deps.Calculus]]
deps = ["LinearAlgebra"]
git-tree-sha1 = "f641eb0a4f00c343bbc32346e1217b86f3ce9dad"
uuid = "49dc2e85-a5d0-5ad3-a950-438e2897f1b9"
version = "0.5.1"

[[deps.ChainRulesCore]]
deps = ["Compat", "LinearAlgebra", "SparseArrays"]
git-tree-sha1 = "e30f2f4e20f7f186dc36529910beaedc60cfa644"
uuid = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4"
version = "1.16.0"

[[deps.Combinatorics]]
git-tree-sha1 = "08c8b6831dc00bfea825826be0bc8336fc369860"
uuid = "861a8166-3701-5b0c-9a16-15d98fcdc6aa"
version = "1.0.2"

[[deps.CommonSolve]]
git-tree-sha1 = "0eee5eb66b1cf62cd6ad1b460238e60e4b09400c"
uuid = "38540f10-b2f7-11e9-35d8-d573e4eb0ff2"
version = "0.2.4"

[[deps.Compat]]
deps = ["UUIDs"]
git-tree-sha1 = "7a60c856b9fa189eb34f5f8a6f6b5529b7942957"
uuid = "34da2185-b29b-5c13-b0c7-acf172513d20"
version = "4.6.1"
weakdeps = ["Dates", "LinearAlgebra"]

    [deps.Compat.extensions]
    CompatLinearAlgebraExt = "LinearAlgebra"

[[deps.CompilerSupportLibraries_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "e66e0078-7015-5450-92f7-15fbd957f2ae"
version = "1.0.2+0"

[[deps.ConstructionBase]]
deps = ["LinearAlgebra"]
git-tree-sha1 = "738fec4d684a9a6ee9598a8bfee305b26831f28c"
uuid = "187b0558-2788-49d3-abe0-74a17ed4e7c9"
version = "1.5.2"

    [deps.ConstructionBase.extensions]
    ConstructionBaseIntervalSetsExt = "IntervalSets"
    ConstructionBaseStaticArraysExt = "StaticArrays"

    [deps.ConstructionBase.weakdeps]
    IntervalSets = "8197267c-284f-5f27-9208-e0e47529a953"
    StaticArrays = "90137ffa-7385-5640-81b9-e52037218182"

[[deps.DataAPI]]
git-tree-sha1 = "8da84edb865b0b5b0100c0666a9bc9a0b71c553c"
uuid = "9a962f9c-6df0-11e9-0e5d-c546b8b5ee8a"
version = "1.15.0"

[[deps.DataStructures]]
deps = ["Compat", "InteractiveUtils", "OrderedCollections"]
git-tree-sha1 = "d1fff3a548102f48987a52a2e0d114fa97d730f0"
uuid = "864edb3b-99cc-5e75-8d2d-829cb0a9cfe8"
version = "0.18.13"

[[deps.DataValueInterfaces]]
git-tree-sha1 = "bfc1187b79289637fa0ef6d4436ebdfe6905cbd6"
uuid = "e2d170a0-9d28-54be-80f0-106bbe20a464"
version = "1.0.0"

[[deps.Dates]]
deps = ["Printf"]
uuid = "ade2ca70-3891-5945-98fb-dc099432e06a"

[[deps.Distributions]]
deps = ["FillArrays", "LinearAlgebra", "PDMats", "Printf", "QuadGK", "Random", "SparseArrays", "SpecialFunctions", "Statistics", "StatsAPI", "StatsBase", "StatsFuns", "Test"]
git-tree-sha1 = "4ed4a6df2548a72f66e03f3a285cd1f3b573035d"
uuid = "31c24e10-a181-5473-b8eb-7969acd0382f"
version = "0.25.96"

    [deps.Distributions.extensions]
    DistributionsChainRulesCoreExt = "ChainRulesCore"
    DistributionsDensityInterfaceExt = "DensityInterface"

    [deps.Distributions.weakdeps]
    ChainRulesCore = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4"
    DensityInterface = "b429d917-457f-4dbc-8f4c-0cc954292b1d"

[[deps.DocStringExtensions]]
deps = ["LibGit2"]
git-tree-sha1 = "2fb1e02f2b635d0845df5d7c167fec4dd739b00d"
uuid = "ffbed154-4ef7-542d-bbb7-c09d3a79fcae"
version = "0.9.3"

[[deps.Downloads]]
deps = ["ArgTools", "FileWatching", "LibCURL", "NetworkOptions"]
uuid = "f43a241f-c20a-4ad4-852c-f6b1247861c6"
version = "1.6.0"

[[deps.DualNumbers]]
deps = ["Calculus", "NaNMath", "SpecialFunctions"]
git-tree-sha1 = "5837a837389fccf076445fce071c8ddaea35a566"
uuid = "fa6b7ba4-c1ee-5f82-b5fc-ecf0adba8f74"
version = "0.6.8"

[[deps.EzXML]]
deps = ["Printf", "XML2_jll"]
git-tree-sha1 = "0fa3b52a04a4e210aeb1626def9c90df3ae65268"
uuid = "8f5d6c58-4d21-5cfd-889c-e3ad7ee6a615"
version = "1.1.0"

[[deps.FileWatching]]
uuid = "7b1f6079-737a-58dc-b8bc-7a2ca5c1b5ee"

[[deps.FillArrays]]
deps = ["LinearAlgebra", "Random", "SparseArrays", "Statistics"]
git-tree-sha1 = "e17cc4dc2d0b0b568e80d937de8ed8341822de67"
uuid = "1a297f60-69ca-5386-bcde-b61e274b549b"
version = "1.2.0"

[[deps.Future]]
deps = ["Random"]
uuid = "9fa8497b-333b-5362-9e8d-4d0656e87820"

[[deps.HypergeometricFunctions]]
deps = ["DualNumbers", "LinearAlgebra", "OpenLibm_jll", "SpecialFunctions"]
git-tree-sha1 = "0ec02c648befc2f94156eaef13b0f38106212f3f"
uuid = "34004b35-14d8-5ef3-9330-4cdb6864b03a"
version = "0.3.17"

[[deps.HypothesisTests]]
deps = ["Combinatorics", "Distributions", "LinearAlgebra", "Printf", "Random", "Rmath", "Roots", "Statistics", "StatsAPI", "StatsBase"]
git-tree-sha1 = "4b5d5ba51f5f473737ed9de6d8a7aa190ad8c72f"
uuid = "09f84164-cd44-5f33-b23f-e6b0d136a0d5"
version = "0.11.0"

[[deps.InteractiveUtils]]
deps = ["Markdown"]
uuid = "b77e0a4c-d291-57a0-90e8-8db25a27a240"

[[deps.IrrationalConstants]]
git-tree-sha1 = "630b497eafcc20001bba38a4651b327dcfc491d2"
uuid = "92d709cd-6900-40b7-9082-c6be49f344b6"
version = "0.2.2"

[[deps.IteratorInterfaceExtensions]]
git-tree-sha1 = "a3f24677c21f5bbe9d2a714f95dcd58337fb2856"
uuid = "82899510-4779-5014-852e-03e436cf321d"
version = "1.0.0"

[[deps.JLLWrappers]]
deps = ["Preferences"]
git-tree-sha1 = "abc9885a7ca2052a736a600f7fa66209f96506e1"
uuid = "692b3bcd-3c85-4b1f-b108-f13ce0eb3210"
version = "1.4.1"

[[deps.LibCURL]]
deps = ["LibCURL_jll", "MozillaCACerts_jll"]
uuid = "b27032c2-a3e7-50c8-80cd-2d36dbcbfd21"
version = "0.6.3"

[[deps.LibCURL_jll]]
deps = ["Artifacts", "LibSSH2_jll", "Libdl", "MbedTLS_jll", "Zlib_jll", "nghttp2_jll"]
uuid = "deac9b47-8bc7-5906-a0fe-35ac56dc84c0"
version = "7.84.0+0"

[[deps.LibGit2]]
deps = ["Base64", "NetworkOptions", "Printf", "SHA"]
uuid = "76f85450-5226-5b5a-8eaa-529ad045b433"

[[deps.LibSSH2_jll]]
deps = ["Artifacts", "Libdl", "MbedTLS_jll"]
uuid = "29816b5a-b9ab-546f-933c-edad1886dfa8"
version = "1.10.2+0"

[[deps.Libdl]]
uuid = "8f399da3-3557-5675-b5ff-fb832c97cbdb"

[[deps.Libiconv_jll]]
deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"]
git-tree-sha1 = "c7cb1f5d892775ba13767a87c7ada0b980ea0a71"
uuid = "94ce4f54-9a6c-5748-9c1c-f9c7231a4531"
version = "1.16.1+2"

[[deps.LinearAlgebra]]
deps = ["Libdl", "OpenBLAS_jll", "libblastrampoline_jll"]
uuid = "37e2e46d-f89d-539d-b4ee-838fcccc9c8e"

[[deps.LogExpFunctions]]
deps = ["DocStringExtensions", "IrrationalConstants", "LinearAlgebra"]
git-tree-sha1 = "c3ce8e7420b3a6e071e0fe4745f5d4300e37b13f"
uuid = "2ab3a3ac-af41-5b50-aa03-7779005ae688"
version = "0.3.24"

    [deps.LogExpFunctions.extensions]
    LogExpFunctionsChainRulesCoreExt = "ChainRulesCore"
    LogExpFunctionsChangesOfVariablesExt = "ChangesOfVariables"
    LogExpFunctionsInverseFunctionsExt = "InverseFunctions"

    [deps.LogExpFunctions.weakdeps]
    ChainRulesCore = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4"
    ChangesOfVariables = "9e997f8a-9a97-42d5-a9f1-ce6bfc15e2c0"
    InverseFunctions = "3587e190-3f89-42d0-90ee-14403ec27112"

[[deps.Logging]]
uuid = "56ddb016-857b-54e1-b83d-db4d58db5568"

[[deps.MacroTools]]
deps = ["Markdown", "Random"]
git-tree-sha1 = "42324d08725e200c23d4dfb549e0d5d89dede2d2"
uuid = "1914dd2f-81c6-5fcd-8719-6d5c9610ff09"
version = "0.5.10"

[[deps.Markdown]]
deps = ["Base64"]
uuid = "d6f4376e-aef5-505a-96c1-9c027394607a"

[[deps.MbedTLS_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "c8ffd9c3-330d-5841-b78e-0817d7145fa1"
version = "2.28.2+0"

[[deps.Missings]]
deps = ["DataAPI"]
git-tree-sha1 = "f66bdc5de519e8f8ae43bdc598782d35a25b1272"
uuid = "e1d29d7a-bbdc-5cf2-9ac0-f12de2c33e28"
version = "1.1.0"

[[deps.MozillaCACerts_jll]]
uuid = "14a3606d-f60d-562e-9121-12d972cd8159"
version = "2022.10.11"

[[deps.MultipleTesting]]
deps = ["Distributions", "SpecialFunctions", "StatsBase"]
git-tree-sha1 = "94df14d821baa34662a1492b10615125cbebd47b"
uuid = "f8716d33-7c4a-5097-896f-ce0ecbd3ef6b"
version = "0.5.1"

[[deps.NaNMath]]
deps = ["OpenLibm_jll"]
git-tree-sha1 = "0877504529a3e5c3343c6f8b4c0381e57e4387e4"
uuid = "77ba4419-2d1f-58cd-9bb1-8ffee604a2e3"
version = "1.0.2"

[[deps.NetworkOptions]]
uuid = "ca575930-c2e3-43a9-ace4-1e988b2c1908"
version = "1.2.0"

[[deps.OpenBLAS_jll]]
deps = ["Artifacts", "CompilerSupportLibraries_jll", "Libdl"]
uuid = "4536629a-c528-5b80-bd46-f80d51c5b363"
version = "0.3.21+4"

[[deps.OpenLibm_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "05823500-19ac-5b8b-9628-191a04bc5112"
version = "0.8.1+0"

[[deps.OpenSpecFun_jll]]
deps = ["Artifacts", "CompilerSupportLibraries_jll", "JLLWrappers", "Libdl", "Pkg"]
git-tree-sha1 = "13652491f6856acfd2db29360e1bbcd4565d04f1"
uuid = "efe28fd5-8261-553b-a9e1-b2916fc3738e"
version = "0.5.5+0"

[[deps.OrderedCollections]]
git-tree-sha1 = "d321bf2de576bf25ec4d3e4360faca399afca282"
uuid = "bac558e1-5e72-5ebc-8fee-abe8a469f55d"
version = "1.6.0"

[[deps.PDMats]]
deps = ["LinearAlgebra", "SparseArrays", "SuiteSparse"]
git-tree-sha1 = "67eae2738d63117a196f497d7db789821bce61d1"
uuid = "90014a1f-27ba-587c-ab20-58faa44d9150"
version = "0.11.17"

[[deps.Pkg]]
deps = ["Artifacts", "Dates", "Downloads", "FileWatching", "LibGit2", "Libdl", "Logging", "Markdown", "Printf", "REPL", "Random", "SHA", "Serialization", "TOML", "Tar", "UUIDs", "p7zip_jll"]
uuid = "44cfe95a-1eb2-52ea-b672-e2afdf69b78f"
version = "1.9.0"

[[deps.Preferences]]
deps = ["TOML"]
git-tree-sha1 = "7eb1686b4f04b82f96ed7a4ea5890a4f0c7a09f1"
uuid = "21216c6a-2e73-6563-6e65-726566657250"
version = "1.4.0"

[[deps.Printf]]
deps = ["Unicode"]
uuid = "de0858da-6303-5e67-8744-51eddeeeb8d7"

[[deps.QuadGK]]
deps = ["DataStructures", "LinearAlgebra"]
git-tree-sha1 = "6ec7ac8412e83d57e313393220879ede1740f9ee"
uuid = "1fd47b50-473d-5c70-9696-f719f8f3bcdc"
version = "2.8.2"

[[deps.REPL]]
deps = ["InteractiveUtils", "Markdown", "Sockets", "Unicode"]
uuid = "3fa0cd96-eef1-5676-8a61-b3b8758bbffb"

[[deps.Random]]
deps = ["SHA", "Serialization"]
uuid = "9a3f8284-a2c9-5f02-9a11-845980a1fd5c"

[[deps.Reexport]]
git-tree-sha1 = "45e428421666073eab6f2da5c9d310d99bb12f9b"
uuid = "189a3867-3050-52da-a836-e630ba90ab69"
version = "1.2.2"

[[deps.Rmath]]
deps = ["Random", "Rmath_jll"]
git-tree-sha1 = "f65dcb5fa46aee0cf9ed6274ccbd597adc49aa7b"
uuid = "79098fc4-a85e-5d69-aa6a-4863f24498fa"
version = "0.7.1"

[[deps.Rmath_jll]]
deps = ["Artifacts", "JLLWrappers", "Libdl", "Pkg"]
git-tree-sha1 = "6ed52fdd3382cf21947b15e8870ac0ddbff736da"
uuid = "f50d1b31-88e8-58de-be2c-1cc44531875f"
version = "0.4.0+0"

[[deps.Roots]]
deps = ["ChainRulesCore", "CommonSolve", "Printf", "Setfield"]
git-tree-sha1 = "de432823e8aab4dd1a985be4be768f95acf152d4"
uuid = "f2b01f46-fcfa-551c-844a-d8ac1e96c665"
version = "2.0.17"

    [deps.Roots.extensions]
    RootsForwardDiffExt = "ForwardDiff"
    RootsIntervalRootFindingExt = "IntervalRootFinding"
    RootsSymPyExt = "SymPy"

    [deps.Roots.weakdeps]
    ForwardDiff = "f6369f11-7733-5829-9624-2563aa707210"
    IntervalRootFinding = "d2bf35a9-74e0-55ec-b149-d360ff49b807"
    SymPy = "24249f21-da20-56a4-8eb1-6a02cf4ae2e6"

[[deps.SHA]]
uuid = "ea8e919c-243c-51af-8825-aaa63cd721ce"
version = "0.7.0"

[[deps.Serialization]]
uuid = "9e88b42a-f829-5b0c-bbe9-9e923198166b"

[[deps.Setfield]]
deps = ["ConstructionBase", "Future", "MacroTools", "StaticArraysCore"]
git-tree-sha1 = "e2cc6d8c88613c05e1defb55170bf5ff211fbeac"
uuid = "efcf1570-3423-57d1-acb7-fd33fddbac46"
version = "1.1.1"

[[deps.Sockets]]
uuid = "6462fe0b-24de-5631-8697-dd941f90decc"

[[deps.SortingAlgorithms]]
deps = ["DataStructures"]
git-tree-sha1 = "c60ec5c62180f27efea3ba2908480f8055e17cee"
uuid = "a2af1166-a08f-5f64-846c-94a0d3cef48c"
version = "1.1.1"

[[deps.SparseArrays]]
deps = ["Libdl", "LinearAlgebra", "Random", "Serialization", "SuiteSparse_jll"]
uuid = "2f01184e-e22b-5df5-ae63-d93ebab69eaf"

[[deps.SpecialFunctions]]
deps = ["IrrationalConstants", "LogExpFunctions", "OpenLibm_jll", "OpenSpecFun_jll"]
git-tree-sha1 = "ef28127915f4229c971eb43f3fc075dd3fe91880"
uuid = "276daf66-3868-5448-9aa4-cd146d93841b"
version = "2.2.0"
weakdeps = ["ChainRulesCore"]

    [deps.SpecialFunctions.extensions]
    SpecialFunctionsChainRulesCoreExt = "ChainRulesCore"

[[deps.StaticArraysCore]]
git-tree-sha1 = "6b7ba252635a5eff6a0b0664a41ee140a1c9e72a"
uuid = "1e83bf80-4336-4d27-bf5d-d5a4f845583c"
version = "1.4.0"

[[deps.Statistics]]
deps = ["LinearAlgebra", "SparseArrays"]
uuid = "10745b16-79ce-11e8-11f9-7d13ad32a3b2"
version = "1.9.0"

[[deps.StatsAPI]]
deps = ["LinearAlgebra"]
git-tree-sha1 = "45a7769a04a3cf80da1c1c7c60caf932e6f4c9f7"
uuid = "82ae8749-77ed-4fe6-ae5f-f523153014b0"
version = "1.6.0"

[[deps.StatsBase]]
deps = ["DataAPI", "DataStructures", "LinearAlgebra", "LogExpFunctions", "Missings", "Printf", "Random", "SortingAlgorithms", "SparseArrays", "Statistics", "StatsAPI"]
git-tree-sha1 = "d1bf48bfcc554a3761a133fe3a9bb01488e06916"
uuid = "2913bbd2-ae8a-5f71-8c99-4fb6c76f3a91"
version = "0.33.21"

[[deps.StatsFuns]]
deps = ["HypergeometricFunctions", "IrrationalConstants", "LogExpFunctions", "Reexport", "Rmath", "SpecialFunctions"]
git-tree-sha1 = "f625d686d5a88bcd2b15cd81f18f98186fdc0c9a"
uuid = "4c63d2b9-4356-54db-8cca-17b64c39e42c"
version = "1.3.0"

    [deps.StatsFuns.extensions]
    StatsFunsChainRulesCoreExt = "ChainRulesCore"
    StatsFunsInverseFunctionsExt = "InverseFunctions"

    [deps.StatsFuns.weakdeps]
    ChainRulesCore = "d360d2e6-b24c-11e9-a2a3-2a2ae2dbcce4"
    InverseFunctions = "3587e190-3f89-42d0-90ee-14403ec27112"

[[deps.SuiteSparse]]
deps = ["Libdl", "LinearAlgebra", "Serialization", "SparseArrays"]
uuid = "4607b0f0-06f3-5cda-b6b1-a6196a1729e9"

[[deps.SuiteSparse_jll]]
deps = ["Artifacts", "Libdl", "Pkg", "libblastrampoline_jll"]
uuid = "bea87d4a-7f5b-5778-9afe-8cc45184846c"
version = "5.10.1+6"

[[deps.TOML]]
deps = ["Dates"]
uuid = "fa267f1f-6049-4f14-aa54-33bafae1ed76"
version = "1.0.3"

[[deps.TableTraits]]
deps = ["IteratorInterfaceExtensions"]
git-tree-sha1 = "c06b2f539df1c6efa794486abfb6ed2022561a39"
uuid = "3783bdb8-4a98-5b6b-af9a-565f29a5fe9c"
version = "1.0.1"

[[deps.Tables]]
deps = ["DataAPI", "DataValueInterfaces", "IteratorInterfaceExtensions", "LinearAlgebra", "OrderedCollections", "TableTraits", "Test"]
git-tree-sha1 = "1544b926975372da01227b382066ab70e574a3ec"
uuid = "bd369af6-aec1-5ad0-b16a-f7cc5008161c"
version = "1.10.1"

[[deps.Tar]]
deps = ["ArgTools", "SHA"]
uuid = "a4e569a6-e804-4fa4-b0f3-eef7a1d5b13e"
version = "1.10.0"

[[deps.Test]]
deps = ["InteractiveUtils", "Logging", "Random", "Serialization"]
uuid = "8dfed614-e22c-5e08-85e1-65c5234f0b40"

[[deps.UUIDs]]
deps = ["Random", "SHA"]
uuid = "cf7118a7-6976-5b1a-9a39-7adc72f591a4"

[[deps.Unicode]]
uuid = "4ec0a83e-493e-50e2-b9ac-8f72acf5a8f5"

[[deps.XLSX]]
deps = ["Artifacts", "Dates", "EzXML", "Printf", "Tables", "ZipFile"]
git-tree-sha1 = "d6af50e2e15d32aff416b7e219885976dc3d870f"
uuid = "fdbf4ff8-1666-58a4-91e7-1b58723a45e0"
version = "0.9.0"

[[deps.XML2_jll]]
deps = ["Artifacts", "JLLWrappers", "Libdl", "Libiconv_jll", "Pkg", "Zlib_jll"]
git-tree-sha1 = "93c41695bc1c08c46c5899f4fe06d6ead504bb73"
uuid = "02c8fc9c-b97f-50b9-bbe4-9be30ff0a78a"
version = "2.10.3+0"

[[deps.ZipFile]]
deps = ["Libdl", "Printf", "Zlib_jll"]
git-tree-sha1 = "f492b7fe1698e623024e873244f10d89c95c340a"
uuid = "a5390f91-8eb1-5f08-bee0-b1d1ffed6cea"
version = "0.10.1"

[[deps.Zlib_jll]]
deps = ["Libdl"]
uuid = "83775a58-1f1d-513f-b197-d71354ab007a"
version = "1.2.13+0"

[[deps.libblastrampoline_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "8e850b90-86db-534c-a0d3-1478176c7d93"
version = "5.7.0+0"

[[deps.nghttp2_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "8e850ede-7688-5339-a07c-302acd2aaf8d"
version = "1.48.0+0"

[[deps.p7zip_jll]]
deps = ["Artifacts", "Libdl"]
uuid = "3f19e933-33d8-53b3-aaab-bd5110c3b7a0"
version = "17.4.0+0"
"""

# ╔═╡ Cell order:
# ╟─01fbf1c9-1cea-4593-a2c5-03854dee2473
# ╠═11ac5f6a-0f6a-11ee-2598-11c7a0064b43
# ╟─8dd5d4b9-5a32-4a95-8f38-7f3e5b98e2d9
# ╠═5e94a517-db46-4864-b717-5b4543884dff
# ╠═a5e61a48-e07e-49dc-8c61-1224d1c47d13
# ╟─a25eecd6-f58d-493d-a5cf-94218319849d
# ╠═9c3b8eb2-a160-4246-a5c7-596a86c73d62
# ╟─3eb9d39c-2ca1-430e-b13b-05c809a80d5b
# ╠═e3febec7-b84c-45f9-8f65-5a158b0ae933
# ╟─f2825d3c-577b-4b61-8c8c-c869a9ec9f07
# ╠═72cf8d55-a423-4c28-a370-377f9ef6a70e
# ╟─b8adc566-5893-402a-a35d-11c06460fb62
# ╠═3df39484-e07a-48d8-90ae-09da0050b3ce
# ╠═b314add7-a6f5-42f0-bc9a-bba748543fa2
# ╠═7e383967-26de-49bd-a106-d215241ffdb1
# ╟─c09b771c-aab1-40cf-a273-14aa6c857510
# ╠═46c9be07-3bb4-499c-a819-7a87c73b6e42
# ╟─128668c3-282d-4453-84a6-cf2c29d7140f
# ╠═548ca244-de4c-47c2-a69e-0ca7a449028f
# ╟─884a7299-8418-45e4-82f3-65204d48e55b
# ╠═9342e489-a297-4c67-8324-cb41801af713
# ╟─6d768ec2-f9ad-4cc7-a2df-4eeb1a72cd44
# ╟─00000000-0000-0000-0000-000000000001
# ╟─00000000-0000-0000-0000-000000000002
"; window.pluto_disable_ui = true; window.pluto_slider_server_url = undefined; window.pluto_binder_url = "https://mybinder.org/v2/gh/fonsp/pluto-on-binder/v0.19.26"; -window.pluto_statefile = "data:;base64,3gARpWJvbmRzgKxjZWxsX3Jlc3VsdHPeABXZJGE1ZTYxYTQ4LWUwN2UtNDlkYy04YzYxLTEyMjRkMWM0N2QxM4qmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHnaA+EyM8OXMjAgTWF0cml4e0ludDY0fToKIDAgICAxICAwICAgMiAgIDEgICAxICAwICAwICAgMyAgMCAgIDQgICA2ICAwICAwICAwICAgMSAgMCAgMCAgMiAgIDEKIDIgICA3ICA0ICAgOCAgIDUgICA1ICAxICA2ICAxMCAgMiAgIDIgIDE3ICAxICAwICAyICAgNiAgNSAgMiAgMyAgIDgKIDAgICAzICAwICAgMSAgIDEgICAyICAxICAyICAgMyAgMCAgIDMgICAyICAwICAwICAyICAgMSAgMiAgMCAgMSAgIDQKIDEgICAwICAwICAgMiAgIDAgICAxICAwICAxICAgNSAgMiAgIDAgICA1ICAwICAwICAxICAgMyAgMyAgMSAgMiAgIDIKIDAgICA0ICAwICAgMyAgIDAgICA2ICAyICAyICAgNiAgMSAgIDEgICA3ICAwICAwICAxICAgMyAgMSAgMSAgMyAgIDQKIDEgICAwICAyICAgNiAgIDQgICAyICAyICAwICAgOSAgMSAgIDYgICA5ICAwICAwICAxICAgMyAgNSAgMSAgNSAgIDQKIDEgICAwICAwICAgMCAgIDAgICAwICAwICAwICAgMiAgMCAgIDAgICAyICAwICAwICAxICAgMSAgMiAgMCAgMiAgIDEKIOKLriAgICAgICAgICAgICAgICAgIOKLriAgICAgICAgICAgICAgICDii64gICAgICAgICAgICAgICAg4ouuICAgICAgICAgICAKIDAgICA2ICAxICAgNiAgIDYgICA1ICAyICA5ICAgOSAgNCAgIDggIDE3ICAxICAwICAxICAgMyAgNSAgMSAgNiAgIDgKIDAgICAzICAxICAgMiAgIDIgICAzICAxICAwICAgMyAgMiAgIDQgICA5ICAwICAwICAxICAgMiAgMiAgMiAgMiAgIDEKIDAgIDE4ICAyICAgOCAgIDkgIDEyICA1ICAzICAxNSAgNSAgIDggIDE1ICAwICAwICA0ICAgNCAgMiAgNCAgNiAgMTEKIDAgICAwICAyICAgMiAgIDAgICAwICAxICAwICAgMiAgMCAgIDEgICA1ICAwICAwICAxICAgMSAgMiAgMSAgMCAgIDAKIDEgIDI3ICAyICAxMyAgMTggIDI3ICA4ICA3ICAyMyAgNyAgMTAgIDQwICAwICAwICAyICAxMyAgNyAgMiAgOCAgMjEKIDAgICAxICAwICAgMyAgIDEgICAwICAwICAwICAgMCAgMCAgIDEgICA2ICAwICAwICAwICAgMyAgMCAgMCAgMSAgIDKkbWltZap0ZXh0L3BsYWlurHJvb3Rhc3NpZ25lZaZjb3VudHOybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3OuzUFsHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SRhNWU2MWE0OC1lMDdlLTQ5ZGMtOGM2MS0xMjI0ZDFjNDdkMTO5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4SMFthtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkOWMzYjhlYjItYTE2MC00MjQ2LWE1YzctNTk2YTg2YzczZDYyiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9keYWmcHJlZml4o0FueahlbGVtZW50c9wAF5IBkqMiRCKqdGV4dC9wbGFpbpICkqMiTSKqdGV4dC9wbGFpbpIDkqMiTiKqdGV4dC9wbGFpbpIEkqMiTyKqdGV4dC9wbGFpbpIFkqMiVCKqdGV4dC9wbGFpbpIGkqMiVSKqdGV4dC9wbGFpbpIHkqMiViKqdGV4dC9wbGFpbpIIkqMiVyKqdGV4dC9wbGFpbpIJkqMiQSKqdGV4dC9wbGFpbpIKkqMiQiKqdGV4dC9wbGFpbpILkqMiSiKqdGV4dC9wbGFpbpIMkqMiSyKqdGV4dC9wbGFpbpINkqMiTCKqdGV4dC9wbGFpbpIOkqMiQyKqdGV4dC9wbGFpbpIPkqMiRSKqdGV4dC9wbGFpbpIQkqMiRiKqdGV4dC9wbGFpbpIRkqMiRyKqdGV4dC9wbGFpbpISkqMiSCKqdGV4dC9wbGFpbpITkqMiSSKqdGV4dC9wbGFpbpIUkqMiUCKqdGV4dC9wbGFpbpIVkqMiUSKqdGV4dC9wbGFpbpIWkqMiUyKqdGV4dC9wbGFpbpIXkqgiQXVjdW5lIqp0ZXh0L3BsYWlupHR5cGWlQXJyYXmscHJlZml4X3Nob3J0oKhvYmplY3RpZLBjYjQxMzY2NzAxMzc4YjcwpG1pbWXZIWFwcGxpY2F0aW9uL3ZuZC5wbHV0by50cmVlK29iamVjdKxyb290YXNzaWduZWXAsmxhc3RfcnVuX3RpbWVzdGFtcMtB2SR9zuo9irBwZXJzaXN0X2pzX3N0YXRlwrdoYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkOWMzYjhlYjItYTE2MC00MjQ2LWE1YzctNTk2YTg2YzczZDYyuWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXOAXl0YrVwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJDkzNDJlNDg5LWEyOTctNGM2Ny04MzI0LWNiNDE4MDFhZjcxM4qmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHmFpnByZWZpeKdGbG9hdDY0qGVsZW1lbnRznpIBkqgwLjM2Nzc1Map0ZXh0L3BsYWlukgKSqDAuOTk2ODAyqnRleHQvcGxhaW6SA5KoMC41ODg4MjGqdGV4dC9wbGFpbpIEkqgwLjI0NzE5Nap0ZXh0L3BsYWlukgWSqDAuNDY5NjY2qnRleHQvcGxhaW6SBpKnMC41OTM2Oap0ZXh0L3BsYWlukgeSqDAuOTI2MTQ5qnRleHQvcGxhaW6SCJKoMC40NDU5ODaqdGV4dC9wbGFpbpIJkqgwLjkyNTI4Nqp0ZXh0L3BsYWlukgqSqDAuOTE1NDQ0qnRleHQvcGxhaW6SC5KoMC45NjQ1NzmqdGV4dC9wbGFpbpIMkqgwLjg0MjEwNKp0ZXh0L3BsYWlukg2SqDAuOTE1MDg3qnRleHQvcGxhaW6SDpKoMC45NzA2ODiqdGV4dC9wbGFpbqR0eXBlpUFycmF5rHByZWZpeF9zaG9ydKCob2JqZWN0aWSwYjVlYTUzZjYxYjkxOTczNKRtaW1l2SFhcHBsaWNhdGlvbi92bmQucGx1dG8udHJlZStvYmplY3Sscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkkfdB9tl+wcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDkzNDJlNDg5LWEyOTctNGM2Ny04MzI0LWNiNDE4MDFhZjcxM7lkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgQMk/W1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQxMWFjNWY2YS0wZjZhLTExZWUtMjU5OC0xMWM3YTAwNjRiNDOKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R5oKRtaW1lqnRleHQvcGxhaW6scm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkkfc1qh2awcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDExYWM1ZjZhLTBmNmEtMTFlZS0yNTk4LTExYzdhMDA2NGI0M7lkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzia7H0S1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQ3ZTM4Mzk2Ny0yNmRlLTQ5YmQtYTEwNi1kMjE1MjQxZmZkYjGKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R52gEZMjHDlzE5IFNwYXJzZU1hdHJpeENTQ3tGbG9hdDY0LCBJbnQ2NH0gd2l0aCAxIHN0b3JlZCBlbnRyeToK4o6h4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4o6kCuKOouKggOKggOKggOKggOKggOKggOKggOKggOKggOKggOKOpQrijqLioIDioIDioIDioIDioIDioIDioIDioIDioIDioIDijqUK4o6i4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4o6lCuKOouKggOKggOKigOKggOKggOKggOKggOKggOKggOKggOKOpQrijqPioIDioIDioIDioIDioIDioIDioIDioIDioIDioIDijqakbWltZap0ZXh0L3BsYWlurHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3P+0CasHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQ3ZTM4Mzk2Ny0yNmRlLTQ5YmQtYTEwNi1kMjE1MjQxZmZkYjG5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4HBtJMtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkZjI4MjVkM2MtNTc3Yi00YjYxLThjOGMtYzg2OWE5ZWM5ZjA3iqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedoBDzxkaXYgY2xhc3M9Im1hcmtkb3duIj48cD5UbyB0ZXN0IHdoZXRoZXIgYSBnZW5vdHlwZSBleGhpYml0cyBhIGRpZmZlcmVudCBwYXJ0aXRpb24gaW50byBjYXRlZ29yaWVzIG9mIGdlbmVzLCBvciBlcXVpdmFsZW50bHkgd2hldGhlciBpdCBpcyBlbnJpY2hlZCBpbiBzb21lIGNhdGVnb3J5LCB3ZSBmaXJzdCBkZXJpdmUgYW4gZXhwZWN0ZWQgcGFydGl0aW9uIGF2ZXJhZ2luZyB0aGUgY2F0ZWdvcnkgZnJlcXVlbmNpZXMgYWNyb3NzIGFsbCBnZW5vdHlwZXMuPC9wPgo8L2Rpdj6kbWltZal0ZXh0L2h0bWyscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkkfcnATcKwcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJGYyODI1ZDNjLTU3N2ItNGI2MS04YzhjLWM4NjlhOWVjOWYwN7lkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgACM4i1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQzZWI5ZDM5Yy0yY2ExLTQzMGUtYjEzYi0wNWM4MDlhODBkNWKKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R52Vk8ZGl2IGNsYXNzPSJtYXJrZG93biI+PHA+Rmlyc3QsIHdlIGV4Y2x1ZGUgdGhlIHJvd3MgYW5kIGNvbHVtbnMgb2YgemVyb3Mgb25seS48L3A+CjwvZGl2PqRtaW1lqXRleHQvaHRtbKxyb290YXNzaWduZWXAsmxhc3RfcnVuX3RpbWVzdGFtcMtB2SR9ycA96rBwZXJzaXN0X2pzX3N0YXRlwrdoYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkM2ViOWQzOWMtMmNhMS00MzBlLWIxM2ItMDVjODA5YTgwZDViuWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXOAANuCrVwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJDMxZGM1OGRiLTVhNGUtNDdkYy1iZGI4LWZlNmU5YmI0NzIwNIqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHnaARQ8ZGl2IGNsYXNzPSJtYXJrZG93biI+PHA+V2UgZG8gbm90IGJvdGhlciBwcmV0dHkgcHJpbnRpbmcgb3IgY29ycmVjdGluZyB0aGUgcC12YWx1ZXM6IHRoZXJlIGFyZSBubyBzaWduaWZpY2FudCBkaWZmZXJlbmNlcyBhdCBhbGwuPC9wPgo8cD5XZSBjb3VsZCB0cnkgcGFpcndpc2UgY29tcGFyaXNvbnMgYmV0d2VlbiBnZW5vdHlwZXMgbm93LCBpbnN0ZWFkIG9mIGZvY3VzaW5nIG9uIGFuICZxdW90O2F2ZXJhZ2UmcXVvdDsgZ2Vub3R5cGUgYXMgYSByZWZlcmVuY2UuPC9wPgo8L2Rpdj6kbWltZal0ZXh0L2h0bWyscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkkfcnBpPSwcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDMxZGM1OGRiLTVhNGUtNDdkYy1iZGI4LWZlNmU5YmI0NzIwNLlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgAC/iW1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQ1NDhjYTI0NC1kZTRjLTQ3YzItYTY5ZS0wY2E3YTQ0OTAyOGaKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R5haZwcmVmaXivVHVwbGV7QW55LCBBbnl9qGVsZW1lbnRzkKR0eXBlpUFycmF5rHByZWZpeF9zaG9ydKCob2JqZWN0aWSwOWY0NGNjOWZhOGEzMWQ4ZqRtaW1l2SFhcHBsaWNhdGlvbi92bmQucGx1dG8udHJlZStvYmplY3Sscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkkfdBLJ6awcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZrlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzZbOtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkODg0YTcyOTktODQxOC00NWU0LTgyZjMtNjUyMDRkNDhlNTViiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedoERjxkaXYgY2xhc3M9Im1hcmtkb3duIj48cD5Db3JyZWN0aW5nIGZvciBhbGwgY29tcGFyaXNvbnMgaXMgcHJvYmFibHkgdW5mYWlyLiBGcmVxdWVuY2llcyBhcmUgYm91bmQgd2l0aGluIGVhY2ggY29sdW1uIGFuZCByb3cgJiM0MDtvbmUgbGVzcyBkZWdyZWUgb2YgZnJlZWRvbSYjNDE7LjwvcD4KPHA+QW55d2F5LCB0aGUgc2FtcGxlIHNpemUgaXMgZmFyIHRvbyBsb3cgZm9yIHRoZSBudW1iZXIgb2YgY2VsbHMsIGFuZCB3ZSBuZWVkIGEgbW9yZSBwb3dlcmZ1bCB0ZXN0LjwvcD4KPHA+TGV0IHVzIG5vdyBjb21wYXJlIGVhY2ggZ2Vub3R5cGUgd2l0aCB0aGUgJnF1b3Q7YXZlcmFnZSZxdW90OyBnZW5vdHlwZSBncm91cGluZyB0aGUgbG93LWZyZXF1ZW5jeSBjZWxscyB0b2dldGhlci4gV2UgYWxyZWFkeSBrbm93IHRoZSBwb3N0LWhvYyB0ZXN0cyBmYWlsLCBhbmQgd2Ugd29uJiMzOTt0IGhhdmUgY2F0ZWdvcnktbGV2ZWwgcmVzb2x1dGlvbiwgYnV0IGEgc2lnbmlmaWNhbnQgZGlmZmVyZW5jZSBtYXkgYmUgYW4gYXJndW1lbnQgZm9yIGluY3JlYXNpbmcgdGhlIHNhbXBsZSBzaXplLCBvciByZXRoaW5raW5nIHRoZSBjYXRlZ29yaWVzLiA8L3A+CjxwPkFuIGVsYWJvcmF0ZSBhcHByb2FjaCBjYW4gYmUgZm91bmQgaW4gPGEgaHJlZj0iaHR0cHM6Ly93d3c0LnN0YXQubmNzdS5lZHUvfmRpY2tleS9hbmFseXRpY3MvZGF0YW1pbmUvUmVmZXJlbmNlJiMzNzsyMFBhcGVycy9rYXNzODAucGRmIj5LYXNzLCAxOTgwPC9hPi48L3A+CjxwPlRoZSBzaW1wbGVyIGFwcHJvYWNoIGZvbGxvd2VkIGhlcmUgY29uc2lzdHMgaW4gZ3JvdXBpbmcgYWxsIG9ic2VydmVkIGNvdW50cyBiZWxvdyA1IGludG8gYSBzaW5nbGUgc3ludGhldGljIGNhdGVnb3J5LCBmb3IgZWFjaCBjb2x1bW4gc2VwYXJhdGVseS4gRXhwZWN0ZWQgY291bnRzIGFyZSBzaW1pbGFybHkgZ3JvdXBlZCwgYmFzZWQgb24gdGhlIG9ic2VydmVkIGNvdW50cy4gSWYgc29tZSBleHBlY3RlZCBjb3VudCBpcyBiZWxvdyA1ICYjNDA7aW5jbHVkZWQgdGhlIHN5bnRoZXRpYyBjYXRlZ29yeSYjNDE7LCB3ZSBjYXJyeSBvbiB1bmxlc3MgdGhpcyBjb3VudCBpcyAwLjwvcD4KPC9kaXY+pG1pbWWpdGV4dC9odG1srHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3JwZCCsHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQ4ODRhNzI5OS04NDE4LTQ1ZTQtODJmMy02NTIwNGQ0OGU1NWK5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4ABNrdtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkYjhhZGM1NjYtNTg5My00MDJhLWEzNWQtMTFjMDY0NjBmYjYyiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedoC6TxkaXYgY2xhc3M9Im1hcmtkb3duIj48cD5EdWUgdG8gdGhlIHByZXNlbmNlIG9mIHplcm9zIGluIG1vc3QgY29sdW1ucywgd2UgaGF2ZSB0byBncm91cCB0aGUgbG93LWZyZXF1ZW5jeSBjZWxscyBpbnRvIHNpbmdsZSBjZWxscyBvbiBhIHBlci1jb2x1bW4gYmFzaXMuIFRoZSBpbmZvcm1hdGlvbiBpbiBsb3ctZnJlcXVlbmN5IGNlbGxzIGlzIGFscmVhZHkgYWNjb3VudGVkIGZvciBieSB0aGUgb3RoZXIgY2VsbHMuPC9wPgo8cD5XZSBjYW4gYWxzbyBpbmRpdmlkdWFsbHkgdGVzdCBlYWNoIGNvdW50IDxjb2RlPm9ic2VydmVkX248L2NvZGU+IDxlbT5lcXVhbCB0byBvciBncmVhdGVyIHRoYW4gNTwvZW0+IGluIGEgY29udGluZ2VuY3kgdGFibGUgd2l0aDo8L3A+CjxwcmU+PGNvZGU+JiM0MzstLS0tLS0tLS0tLS0mIzQzOy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSYjNDM7Cnwgb2JzZXJ2ZWRfbiB8IGNvbF90b3RhbCAtIG9ic2VydmVkX24gfAomIzQzOy0tLS0tLS0tLS0tLSYjNDM7LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tJiM0MzsKfCBleHBlY3RlZF9uIHwgY29sX3RvdGFsIC0gZXhwZWN0ZWRfbiB8CiYjNDM7LS0tLS0tLS0tLS0tJiM0MzstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0mIzQzOzwvY29kZT48L3ByZT4KPHA+VGhpcyBzZWNvbmQgYXBwcm9hY2ggaXMgbGVzcyBwb3dlcmZ1bCwgdGhvdWdoLjwvcD4KPHA+TGV0IHVzIGJlZ2luIHdpdGggdGhpcyBzZWNvbmQgYXBwcm9hY2g6PC9wPgo8L2Rpdj6kbWltZal0ZXh0L2h0bWyscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkkfcnAYtiwcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJGI4YWRjNTY2LTU4OTMtNDAyYS1hMzVkLTExYzA2NDYwZmI2MrlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgAEJ+K1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQ3MmNmOGQ1NS1hNDIzLTRjMjgtYTM3MC0zNzdmOWVmNmE3MGWKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R5oKRtaW1lqnRleHQvcGxhaW6scm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkkfc8o9R+wcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDcyY2Y4ZDU1LWE0MjMtNGMyOC1hMzcwLTM3N2Y5ZWY2YTcwZblkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzhjl/4+1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2WKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R52gEcMjHDlzE5IFNwYXJzZU1hdHJpeENTQ3tGbG9hdDY0LCBJbnQ2NH0gd2l0aCA4MCBzdG9yZWQgZW50cmllczoK4o6h4qCQ4qCQ4qCS4qCQ4qCC4qKQ4qCA4qCS4qCA4qCC4o6kCuKOouKggOKggOKggOKggOKgguKgmOKggOKggOKggOKggOKOpQrijqLioJjioJDioJDioIDioYTiorjioIDioYDioIDioYHijqUK4o6i4qKo4qKo4qOt4qKg4qGG4qO84qCA4qKE4qKA4qGF4o6lCuKOouKikOKikOKjkuKjgOKjguKjmuKggOKjgOKikOKhguKOpQrijqPioIDioIDioIDioIDioIDioIDioIDioIDioIDioIDijqakbWltZap0ZXh0L3BsYWlurHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3P6BZIsHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2W5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc5MyFS0tXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkNDZjOWJlMDctM2JiNC00OTljLWE4MTktN2E4N2M3M2I2ZTQyiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedoBGzIxw5cxOSBTcGFyc2VNYXRyaXhDU0N7RmxvYXQ2NCwgSW50NjR9IHdpdGggMCBzdG9yZWQgZW50cmllczoK4o6h4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4o6kCuKOouKggOKggOKggOKggOKggOKggOKggOKggOKggOKggOKOpQrijqLioIDioIDioIDioIDioIDioIDioIDioIDioIDioIDijqUK4o6i4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4o6lCuKOouKggOKggOKggOKggOKggOKggOKggOKggOKggOKggOKOpQrijqPioIDioIDioIDioIDioIDioIDioIDioIDioIDioIDijqakbWltZap0ZXh0L3BsYWlurHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3QKWm+sHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQ0NmM5YmUwNy0zYmI0LTQ5OWMtYTgxOS03YTg3YzczYjZlNDK5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4HXRYTtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkMTI4NjY4YzMtMjgyZC00NDUzLTg0YTYtY2YyYzI5ZDcxNDBmiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedmAPGRpdiBjbGFzcz0ibWFya2Rvd24iPjxwPkhhZCB3ZSBmb3VuZCBkaWZmZXJlbmNlcywgd2UgY291bGQgZ2V0IHRoZSBjb3JyZXNwb25kaW5nIGNhdGVnb3J5LWdlbm90eXBlIHBhaXJzIGFzIGZvbGxvd3M6PC9wPgo8L2Rpdj6kbWltZal0ZXh0L2h0bWyscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkkfcnAlTqwcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDEyODY2OGMzLTI4MmQtNDQ1My04NGE2LWNmMmMyOWQ3MTQwZrlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgACDz61cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzOKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R5g6hlbGVtZW50c5KSAZKiMjGqdGV4dC9wbGFpbpICkqIxOap0ZXh0L3BsYWlupHR5cGWlVHVwbGWob2JqZWN0aWSwNTE5MTdiOWRlMzg1NDRiMqRtaW1l2SFhcHBsaWNhdGlvbi92bmQucGx1dG8udHJlZStvYmplY3Sscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkkfc8NPJewcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM7lkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzcZWtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZmiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedoBDFhMU1hGaWxlKCIuLi9kYXRhL3Jhdy9TTlBzcGVjaWZpcXVlcy54bHN4IikgY29udGFpbmluZyAyIFdvcmtzaGVldHMKICAgICAgICAgICAgc2hlZXRuYW1lIHNpemUgICAgICAgICAgcmFuZ2UgICAgICAgIAotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICAgICAgICAgICAgIE5iIFNOUCAyOXgyMiAgICAgICAgIEExOlYyOSAgICAgICAKICAgICAgcG91cmNlbnRhZ2UgU05QIDMweDIxICAgICAgICAgQTE6VTMwICAgICAgIAqkbWltZap0ZXh0L3BsYWlurHJvb3Rhc3NpZ25lZaRkYXRhsmxhc3RfcnVuX3RpbWVzdGFtcMtB2SR9zk+x3bBwZXJzaXN0X2pzX3N0YXRlwrdoYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZmuWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXOfAtpj7VwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJDhkZDVkNGI5LTVhMzItNGE5NS04ZjM4LTdmM2U1Yjk4ZTJkOYqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHnaATA8ZGl2IGNsYXNzPSJtYXJrZG93biI+PHA+V2UgZmlyc3QgbG9hZCB0aGUgY291bnQgZGF0YS48L3A+CjxwPiYjMzM7JiMzMzsmIzMzOyAJVGhlIG5vdGVib29rIGlzIGFzc3VtZWQgdG8gcnVuIGZyb20gYSBjaGlsZCBkaXJlY3RvcnkgJiM0MDs8ZW0+ZS5nLjwvZW0+IDxjb2RlPm5vdGVib29rczwvY29kZT4mIzQxOyBvZiB0aGUgcHJvamVjdCByb290LCBhbmQgdGhlIGRhdGEgZmlsZXMgYXJlIGV4cGVjdGVkIHRvIGJlIGZvdW5kIGluIDxjb2RlPmRhdGEvcmF3PC9jb2RlPiwgZnJvbSB0aGUgcHJvamVjdCByb290LjwvcD4KPC9kaXY+pG1pbWWpdGV4dC9odG1srHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3JwBfOsHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQ4ZGQ1ZDRiOS01YTMyLTRhOTUtOGYzOC03ZjNlNWI5OGUyZDm5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4AAyYitXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkYTI1ZWVjZDYtZjU4ZC00OTNkLWE1Y2YtOTQyMTgzMTk4NDlkiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedmuPGRpdiBjbGFzcz0ibWFya2Rvd24iPjxwPkZvciBmdXJ0aGVyIHJlZmVyZW5jZSwgd2UgYWxzbyBsb2FkIHRoZSBsYWJlbHMgb2YgdGhlIHJvd3MgJiM0MDs8Y29kZT5jYXRlZ29yaWVzPC9jb2RlPiYjNDE7IGFuZCBjb2x1bW5zICYjNDA7PGNvZGU+Z2Vub3R5cGVzPC9jb2RlPiYjNDE7LjwvcD4KPC9kaXY+pG1pbWWpdGV4dC9odG1srHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3JwCeRsHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SRhMjVlZWNkNi1mNThkLTQ5M2QtYTVjZi05NDIxODMxOTg0OWS5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4AAi+qtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkYjMxNGFkZDctYTZmNS00MmYwLWJjOWEtYmJhNzQ4NTQzZmEyiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedmHPGRpdiBjbGFzcz0ibWFya2Rvd24iPjxwPk91dCBvZiBjdXJpb3NpdHksIHdpdGggbm8gY29ycmVjdGlvbiBmb3IgbXVsdGlwbGUgY29tcGFyaXNvbnMsIHdlIGZpbmQgYSBzaW5nbGUgcC12YWx1ZSBiZWxvdyAwLjA1OjwvcD4KPC9kaXY+pG1pbWWpdGV4dC9odG1srHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZJH3JwHOjsHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SRiMzE0YWRkNy1hNmY1LTQyZjAtYmM5YS1iYmE3NDg1NDNmYTK5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4AAhy6tXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkYzA5Yjc3MWMtYWFiMS00MGNmLWEyNzMtMTRhYTZjODU3NTEwiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedlfPGRpdiBjbGFzcz0ibWFya2Rvd24iPjxwPkNvcnJlY3RpbmcgZm9yIGFsbCB0aGUgY29tcGFyaXNvbnMsIG5vIGRpZmZlcmVuY2VzIHN1cnZpdmU6PC9wPgo8L2Rpdj6kbWltZal0ZXh0L2h0bWyscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkkfcnAhduwcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJGMwOWI3NzFjLWFhYjEtNDBjZi1hMjczLTE0YWE2Yzg1NzUxMLlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgAC89q1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTCq3N0YXR1c190cmVlhKRuYW1lqG5vdGVib29rqHN1YnRhc2tzhKZzYXZpbmeEpG5hbWWmc2F2aW5nqHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2SR9zXOsJqpzdGFydGVkX2F0y0HZJH3Nc6nKqXdvcmtzcGFjZYSkbmFtZal3b3Jrc3BhY2Woc3VidGFza3OCrGluaXRfcHJvY2Vzc4SkbmFtZaxpbml0X3Byb2Nlc3Ooc3VidGFza3OEoTSEpG5hbWWhNKhzdWJ0YXNrc4CrZmluaXNoZWRfYXTLQdkkfcwtS1Wqc3RhcnRlZF9hdMtB2SR9y5ClM6ExhKRuYW1loTGoc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZJH3Li0IpqnN0YXJ0ZWRfYXTLQdkkfcs0MEmhMoSkbmFtZaEyqHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2SR9y4+iJ6pzdGFydGVkX2F0y0HZJH3Li1AJoTOEpG5hbWWhM6hzdWJ0YXNrc4CrZmluaXNoZWRfYXTLQdkkfcuQpSKqc3RhcnRlZF9hdMtB2SR9y4+wfatmaW5pc2hlZF9hdMtB2SR9zC1ZT6pzdGFydGVkX2F0y0HZJH3LNDArrmNyZWF0ZV9wcm9jZXNzhKRuYW1lrmNyZWF0ZV9wcm9jZXNzqHN1YnRhc2tzgqExhKRuYW1loTGoc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZJH3KbQCfqnN0YXJ0ZWRfYXTLQdkkfcnN0N2hMoSkbmFtZaEyqHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2SR9yzQv+apzdGFydGVkX2F0y0HZJH3KbQ8fq2ZpbmlzaGVkX2F0y0HZJH3LNB4qqnN0YXJ0ZWRfYXTLQdkkfcnN0MyrZmluaXNoZWRfYXTLQdkkfcwtWVOqc3RhcnRlZF9hdMtB2SR9yc3Qt6Nwa2eEpG5hbWWjcGtnqHN1YnRhc2tzhKxpbnN0YW50aWF0ZTGEpG5hbWWsaW5zdGFudGlhdGUxqHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2SR9ycI7hqpzdGFydGVkX2F0y0HZJH3JwhU4qGFuYWx5c2lzhKRuYW1lqGFuYWx5c2lzqHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2SR9ycG3D6pzdGFydGVkX2F0y0HZJH3JwaZEqnByZWNvbXBpbGWEpG5hbWWqcHJlY29tcGlsZahzdWJ0YXNrc4CrZmluaXNoZWRfYXTLQdkkfcqVDjmqc3RhcnRlZF9hdMtB2SR9yc2Q66dyZXNvbHZlhKRuYW1lp3Jlc29sdmWoc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZJH3JzZDeqnN0YXJ0ZWRfYXTLQdkkfcnCO4qrZmluaXNoZWRfYXTLQdkkfcqVZoiqc3RhcnRlZF9hdMtB2SR9ycGmN6NydW6EpG5hbWWjcnVuqHN1YnRhc2tzgrByZXNvbHZlX3RvcG9sb2d5hKRuYW1lsHJlc29sdmVfdG9wb2xvZ3moc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZJH3Nc6wuqnN0YXJ0ZWRfYXTLQdkkfc1zn7aoZXZhbHVhdGWEpG5hbWWoZXZhbHVhdGWoc3VidGFza3OKoTOEpG5hbWWhM6hzdWJ0YXNrc4CrZmluaXNoZWRfYXTLQdkkfc7qPbSqc3RhcnRlZF9hdMtB2SR9zrtETqE0hKRuYW1loTSoc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZJH3PDTzFqnN0YXJ0ZWRfYXTLQdkkfc7qTA6hMYSkbmFtZaExqHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2SR9zk+yFKpzdGFydGVkX2F0y0HZJH3NdAq3ojEwhKRuYW1lojEwqHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2SR90H22japzdGFydGVkX2F0y0HZJH3QSzcqoTKEpG5hbWWhMqhzdWJ0YXNrc4CrZmluaXNoZWRfYXTLQdkkfc67NTuqc3RhcnRlZF9hdMtB2SR9zk/A6KE2hKRuYW1loTaoc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZJH3P6BaDqnN0YXJ0ZWRfYXTLQdkkfc8pA9GhN4SkbmFtZaE3qHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2SR9z/tAxKpzdGFydGVkX2F0y0HZJH3P6CXZoTWEpG5hbWWhNahzdWJ0YXNrc4CrZmluaXNoZWRfYXTLQdkkfc8o9U2qc3RhcnRlZF9hdMtB2SR9zw1K5KE5hKRuYW1loTmoc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZJH3QSyfQqnN0YXJ0ZWRfYXTLQdkkfdApeoGhOISkbmFtZaE4qHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2SR90ClqFqpzdGFydGVkX2F0y0HZJH3P+1Arq2ZpbmlzaGVkX2F0y0HZJH3QfdEPqnN0YXJ0ZWRfYXTLQdkkfc1zrC6rZmluaXNoZWRfYXTLQdkkfdB90Q+qc3RhcnRlZF9hdMtB2SR9zXOflatmaW5pc2hlZF9hdMCqc3RhcnRlZF9hdMtB2SR9ybpoRbFjZWxsX2RlcGVuZGVuY2llc94AFdkkYTVlNjFhNDgtZTA3ZS00OWRjLThjNjEtMTIyNGQxYzQ3ZDEzhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkYTVlNjFhNDgtZTA3ZS00OWRjLThjNjEtMTIyNGQxYzQ3ZDEztGRvd25zdHJlYW1fY2VsbHNfbWFwgaZjb3VudHOR2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzOydXBzdHJlYW1fY2VsbHNfbWFwgqNJbnSQpGRhdGGR2SQ1ZTk0YTUxNy1kYjQ2LTQ4NjQtYjcxNy01YjQ1NDM4ODRkZmbZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MoS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MrRkb3duc3RyZWFtX2NlbGxzX21hcIKpZ2Vub3R5cGVzkdkkNTQ4Y2EyNDQtZGU0Yy00N2MyLWE2OWUtMGNhN2E0NDkwMjhmqmNhdGVnb3JpZXOR2SQ1NDhjYTI0NC1kZTRjLTQ3YzItYTY5ZS0wY2E3YTQ0OTAyOGaydXBzdHJlYW1fY2VsbHNfbWFwgqN2ZWOQpGRhdGGR2SQ1ZTk0YTUxNy1kYjQ2LTQ4NjQtYjcxNy01YjQ1NDM4ODRkZmbZJDkzNDJlNDg5LWEyOTctNGM2Ny04MzI0LWNiNDE4MDFhZjcxM4S0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDkzNDJlNDg5LWEyOTctNGM2Ny04MzI0LWNiNDE4MDFhZjcxM7Rkb3duc3RyZWFtX2NlbGxzX21hcIG0cGVyX2dlbm90eXBlX3B2YWx1ZXOQsnVwc3RyZWFtX2NlbGxzX21hcN4AH6RDb3JlkKNzdW2Qr29ic2VydmVkX2NvdW50c5HZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZaEhkKNhbnmQpmlzbGVzc5CnRmxvYXQ2NJDZJ0Jhc2UuQ29yZUxvZ2dpbmcuQmFzZS5maXh1cF9zdGRsaWJfcGF0aJCyQmFzZS5Db3JlTG9nZ2luZy4hkKVAd2FybpChPJCvZXhwZWN0ZWRfY291bnRzkdkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2NlpnB2YWx1ZZCxQmFzZS5pbnZva2VsYXRlc3SQ2SdCYXNlLkNvcmVMb2dnaW5nLmN1cnJlbnRfbG9nZ2VyX2Zvcl9lbnaQoj09kLhCYXNlLkNvcmVMb2dnaW5nLmNvbnZlcnSQvUJhc2UuQ29yZUxvZ2dpbmcuaW52b2tlbGF0ZXN0kLJDb3JlLlVuZGVmVmFyRXJyb3KQtEJhc2UuQ29yZUxvZ2dpbmcuPT09kKE6kKRoY2F0kLojX19fdGhpc19wbHV0b19tb2R1bGVfbmFtZZClbmNvbHOR2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzOjYWxskKRCYXNlkKVwdXNoIZC0QmFzZS5Db3JlTG9nZ2luZy5pc2GQoj49kLNCYXNlLkNvcmVMb2dnaW5nLj49kKlDaGlzcVRlc3SQ2SQxMWFjNWY2YS0wZjZhLTExZWUtMjU5OC0xMWM3YTAwNjRiNDOEtHByZWNlZGVuY2VfaGV1cmlzdGljB6djZWxsX2lk2SQxMWFjNWY2YS0wZjZhLTExZWUtMjU5OC0xMWM3YTAwNjRiNDO0ZG93bnN0cmVhbV9jZWxsc19tYXCFqVN0YXRzQmFzZZCkWExTWJHZJDVlOTRhNTE3LWRiNDYtNDg2NC1iNzE3LTViNDU0Mzg4NGRmZq9NdWx0aXBsZVRlc3RpbmeQrFNwYXJzZUFycmF5c5CvSHlwb3RoZXNpc1Rlc3RzkLJ1cHN0cmVhbV9jZWxsc19tYXCA2SQ3ZTM4Mzk2Ny0yNmRlLTQ5YmQtYTEwNi1kMjE1MjQxZmZkYjGEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SQ3ZTM4Mzk2Ny0yNmRlLTQ5YmQtYTEwNi1kMjE1MjQxZmZkYjG0ZG93bnN0cmVhbV9jZWxsc19tYXCB2SN1bmNvcnJlY3RlZF9wdmFsdWVzX2JlbG93X3RocmVzaG9sZJCydXBzdHJlYW1fY2VsbHNfbWFwhaE8kKlkcm9wemVyb3OQp3B2YWx1ZXOR2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2WmaXNsZXNzkKRjb3B5kNkkZjI4MjVkM2MtNTc3Yi00YjYxLThjOGMtYzg2OWE5ZWM5ZjA3hLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkZjI4MjVkM2MtNTc3Yi00YjYxLThjOGMtYzg2OWE5ZWM5ZjA3tGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkM2ViOWQzOWMtMmNhMS00MzBlLWIxM2ItMDVjODA5YTgwZDVihLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkM2ViOWQzOWMtMmNhMS00MzBlLWIxM2ItMDVjODA5YTgwZDVitGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkMzFkYzU4ZGItNWE0ZS00N2RjLWJkYjgtZmU2ZTliYjQ3MjA0hLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkMzFkYzU4ZGItNWE0ZS00N2RjLWJkYjgtZmU2ZTliYjQ3MjA0tGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkNTQ4Y2EyNDQtZGU0Yy00N2MyLWE2OWUtMGNhN2E0NDkwMjhmhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkNTQ4Y2EyNDQtZGU0Yy00N2MyLWE2OWUtMGNhN2E0NDkwMjhmtGRvd25zdHJlYW1fY2VsbHNfbWFwhKNyb3eQqGdlbm90eXBlkKNjb2yQqGNhdGVnb3J5kLJ1cHN0cmVhbV9jZWxsc19tYXCIqWdlbm90eXBlc5HZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MqZyb3dfb2uR2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzOmZmluZG56kKdjb2xsZWN0kKZjb2xfb2uR2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzOjemlwkKpjYXRlZ29yaWVzkdkkOWMzYjhlYjItYTE2MC00MjQ2LWE1YzctNTk2YTg2YzczZDYys3NpZ25pZmljYW50X3B2YWx1ZXOR2SQ0NmM5YmUwNy0zYmI0LTQ5OWMtYTgxOS03YTg3YzczYjZlNDLZJDg4NGE3Mjk5LTg0MTgtNDVlNC04MmYzLTY1MjA0ZDQ4ZTU1YoS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDg4NGE3Mjk5LTg0MTgtNDVlNC04MmYzLTY1MjA0ZDQ4ZTU1YrRkb3duc3RyZWFtX2NlbGxzX21hcICydXBzdHJlYW1fY2VsbHNfbWFwgqdAbWRfc3RykKhnZXRpbmRleJDZJGI4YWRjNTY2LTU4OTMtNDAyYS1hMzVkLTExYzA2NDYwZmI2MoS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJGI4YWRjNTY2LTU4OTMtNDAyYS1hMzVkLTExYzA2NDYwZmI2MrRkb3duc3RyZWFtX2NlbGxzX21hcICydXBzdHJlYW1fY2VsbHNfbWFwgqdAbWRfc3RykKhnZXRpbmRleJDZJDcyY2Y4ZDU1LWE0MjMtNGMyOC1hMzcwLTM3N2Y5ZWY2YTcwZYS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDcyY2Y4ZDU1LWE0MjMtNGMyOC1hMzcwLTM3N2Y5ZWY2YTcwZbRkb3duc3RyZWFtX2NlbGxzX21hcIK0ZXhwZWN0ZWRfZnJlcXVlbmNpZXOR2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2WpY29sX3RvdGFskdkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2NlsnVwc3RyZWFtX2NlbGxzX21hcIij4omIkKNzdW2QrGNsZWFuX2NvdW50c5HZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM6dAYXNzZXJ0kKV0aHJvd5ChL5CuQXNzZXJ0aW9uRXJyb3KQpG1lYW6Q2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2WEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2W0ZG93bnN0cmVhbV9jZWxsc19tYXCFr29ic2VydmVkX2NvdW50c5HZJDkzNDJlNDg5LWEyOTctNGM2Ny04MzI0LWNiNDE4MDFhZjcxM69leHBlY3RlZF9jb3VudHOR2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTOncHZhbHVlc5LZJDdlMzgzOTY3LTI2ZGUtNDliZC1hMTA2LWQyMTUyNDFmZmRiMdkkNDZjOWJlMDctM2JiNC00OTljLWE4MTktN2E4N2M3M2I2ZTQysm9ic2VydmVkX3JlbWFpbmRlcpCyZXhwZWN0ZWRfcmVtYWluZGVykLJ1cHN0cmVhbV9jZWxsc19tYXDeABC0ZXhwZWN0ZWRfZnJlcXVlbmNpZXOR2SQ3MmNmOGQ1NS1hNDIzLTRjMjgtYTM3MC0zNzdmOWVmNmE3MGWnc3B6ZXJvc5CsY2xlYW5fY291bnRzkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzpW5yb3dzkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzoTqQqWNvbF90b3RhbJHZJDcyY2Y4ZDU1LWE0MjMtNGMyOC1hMzcwLTM3N2Y5ZWY2YTcwZahAX19kb3RfX5ClbmNvbHOR2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzOjYWxskKEtkKZwdmFsdWWQo0ludJCiPj2QoSqQpXJvdW5kkKlDaGlzcVRlc3SQ2SQ0NmM5YmUwNy0zYmI0LTQ5OWMtYTgxOS03YTg3YzczYjZlNDKEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SQ0NmM5YmUwNy0zYmI0LTQ5OWMtYTgxOS03YTg3YzczYjZlNDK0ZG93bnN0cmVhbV9jZWxsc19tYXCDq3NpZ25pZmljYW50kLFjb3JyZWN0ZWRfcHZhbHVlc5Czc2lnbmlmaWNhbnRfcHZhbHVlc5HZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZrJ1cHN0cmVhbV9jZWxsc19tYXCGpmFkanVzdJCiPD2QqWRyb3B6ZXJvc5CncHZhbHVlc5HZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZaRIb2xtkKRjb3B5kNkkMTI4NjY4YzMtMjgyZC00NDUzLTg0YTYtY2YyYzI5ZDcxNDBmhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkMTI4NjY4YzMtMjgyZC00NDUzLTg0YTYtY2YyYzI5ZDcxNDBmtGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMztGRvd25zdHJlYW1fY2VsbHNfbWFwhaZyb3dfb2uR2SQ1NDhjYTI0NC1kZTRjLTQ3YzItYTY5ZS0wY2E3YTQ0OTAyOGasY2xlYW5fY291bnRzktkkNzJjZjhkNTUtYTQyMy00YzI4LWEzNzAtMzc3ZjllZjZhNzBl2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2WlbnJvd3OR2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2WmY29sX29rkdkkNTQ4Y2EyNDQtZGU0Yy00N2MyLWE2OWUtMGNhN2E0NDkwMjhmpW5jb2xzktkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2Nl2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTOydXBzdHJlYW1fY2VsbHNfbWFwhqN2ZWOQo2FueZCiIT2QpHNpemWQoj09kKZjb3VudHOR2SRhNWU2MWE0OC1lMDdlLTQ5ZGMtOGM2MS0xMjI0ZDFjNDdkMTPZJDVlOTRhNTE3LWRiNDYtNDg2NC1iNzE3LTViNDU0Mzg4NGRmZoS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDVlOTRhNTE3LWRiNDYtNDg2NC1iNzE3LTViNDU0Mzg4NGRmZrRkb3duc3RyZWFtX2NlbGxzX21hcIGkZGF0YZLZJGE1ZTYxYTQ4LWUwN2UtNDlkYy04YzYxLTEyMjRkMWM0N2QxM9kkOWMzYjhlYjItYTE2MC00MjQ2LWE1YzctNTk2YTg2YzczZDYysnVwc3RyZWFtX2NlbGxzX21hcIKkWExTWJHZJDExYWM1ZjZhLTBmNmEtMTFlZS0yNTk4LTExYzdhMDA2NGI0M61YTFNYLm9wZW54bHN4kNkkOGRkNWQ0YjktNWEzMi00YTk1LThmMzgtN2YzZTViOThlMmQ5hLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkOGRkNWQ0YjktNWEzMi00YTk1LThmMzgtN2YzZTViOThlMmQ5tGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkYTI1ZWVjZDYtZjU4ZC00OTNkLWE1Y2YtOTQyMTgzMTk4NDlkhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkYTI1ZWVjZDYtZjU4ZC00OTNkLWE1Y2YtOTQyMTgzMTk4NDlktGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkYjMxNGFkZDctYTZmNS00MmYwLWJjOWEtYmJhNzQ4NTQzZmEyhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkYjMxNGFkZDctYTZmNS00MmYwLWJjOWEtYmJhNzQ4NTQzZmEytGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkYzA5Yjc3MWMtYWFiMS00MGNmLWEyNzMtMTRhYTZjODU3NTEwhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkYzA5Yjc3MWMtYWFiMS00MGNmLWEyNzMtMTRhYTZjODU3NTEwtGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kLRjZWxsX2V4ZWN1dGlvbl9vcmRlctwAFdkkMTFhYzVmNmEtMGY2YS0xMWVlLTI1OTgtMTFjN2EwMDY0YjQz2SQ4ZGQ1ZDRiOS01YTMyLTRhOTUtOGYzOC03ZjNlNWI5OGUyZDnZJDVlOTRhNTE3LWRiNDYtNDg2NC1iNzE3LTViNDU0Mzg4NGRmZtkkYTVlNjFhNDgtZTA3ZS00OWRjLThjNjEtMTIyNGQxYzQ3ZDEz2SRhMjVlZWNkNi1mNThkLTQ5M2QtYTVjZi05NDIxODMxOTg0OWTZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MtkkM2ViOWQzOWMtMmNhMS00MzBlLWIxM2ItMDVjODA5YTgwZDVi2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzPZJGYyODI1ZDNjLTU3N2ItNGI2MS04YzhjLWM4NjlhOWVjOWYwN9kkNzJjZjhkNTUtYTQyMy00YzI4LWEzNzAtMzc3ZjllZjZhNzBl2SRiOGFkYzU2Ni01ODkzLTQwMmEtYTM1ZC0xMWMwNjQ2MGZiNjLZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZdkkYjMxNGFkZDctYTZmNS00MmYwLWJjOWEtYmJhNzQ4NTQzZmEy2SQ3ZTM4Mzk2Ny0yNmRlLTQ5YmQtYTEwNi1kMjE1MjQxZmZkYjHZJGMwOWI3NzFjLWFhYjEtNDBjZi1hMjczLTE0YWE2Yzg1NzUxMNkkNDZjOWJlMDctM2JiNC00OTljLWE4MTktN2E4N2M3M2I2ZTQy2SQxMjg2NjhjMy0yODJkLTQ0NTMtODRhNi1jZjJjMjlkNzE0MGbZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZtkkODg0YTcyOTktODQxOC00NWU0LTgyZjMtNjUyMDRkNDhlNTVi2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTPZJDMxZGM1OGRiLTVhNGUtNDdkYy1iZGI4LWZlNmU5YmI0NzIwNLRsYXN0X2hvdF9yZWxvYWRfdGltZcsAAAAAAAAAAKlzaG9ydHBhdGiyc25wX2NoaXNxX3Rlc3RzLmpsrnByb2Nlc3Nfc3RhdHVzpXJlYWR5pHBhdGjZWC9ob21lL2ZsYXVyZW50L0JveGVzL3R1bWJsZXdlZWQtMS9Qcm9qZWN0cy9zdGF0cy9DeXJpbFNhdmluL25vdGVib29rcy9zbnBfY2hpc3FfdGVzdHMuamyubGFzdF9zYXZlX3RpbWXLQdkkfc1zqcqqY2VsbF9vcmRlctwAFdkkMTFhYzVmNmEtMGY2YS0xMWVlLTI1OTgtMTFjN2EwMDY0YjQz2SQ4ZGQ1ZDRiOS01YTMyLTRhOTUtOGYzOC03ZjNlNWI5OGUyZDnZJDVlOTRhNTE3LWRiNDYtNDg2NC1iNzE3LTViNDU0Mzg4NGRmZtkkYTVlNjFhNDgtZTA3ZS00OWRjLThjNjEtMTIyNGQxYzQ3ZDEz2SRhMjVlZWNkNi1mNThkLTQ5M2QtYTVjZi05NDIxODMxOTg0OWTZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MtkkM2ViOWQzOWMtMmNhMS00MzBlLWIxM2ItMDVjODA5YTgwZDVi2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzPZJGYyODI1ZDNjLTU3N2ItNGI2MS04YzhjLWM4NjlhOWVjOWYwN9kkNzJjZjhkNTUtYTQyMy00YzI4LWEzNzAtMzc3ZjllZjZhNzBl2SRiOGFkYzU2Ni01ODkzLTQwMmEtYTM1ZC0xMWMwNjQ2MGZiNjLZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZdkkYjMxNGFkZDctYTZmNS00MmYwLWJjOWEtYmJhNzQ4NTQzZmEy2SQ3ZTM4Mzk2Ny0yNmRlLTQ5YmQtYTEwNi1kMjE1MjQxZmZkYjHZJGMwOWI3NzFjLWFhYjEtNDBjZi1hMjczLTE0YWE2Yzg1NzUxMNkkNDZjOWJlMDctM2JiNC00OTljLWE4MTktN2E4N2M3M2I2ZTQy2SQxMjg2NjhjMy0yODJkLTQ0NTMtODRhNi1jZjJjMjlkNzE0MGbZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZtkkODg0YTcyOTktODQxOC00NWU0LTgyZjMtNjUyMDRkNDhlNTVi2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTPZJDMxZGM1OGRiLTVhNGUtNDdkYy1iZGI4LWZlNmU5YmI0NzIwNLFwdWJsaXNoZWRfb2JqZWN0c4ClbmJwa2eIsmluc3RhbGxlZF92ZXJzaW9uc4WpU3RhdHNCYXNlpzAuMzMuMjGkWExTWKUwLjkuMK9NdWx0aXBsZVRlc3RpbmelMC41LjGsU3BhcnNlQXJyYXlzpnN0ZGxpYq9IeXBvdGhlc2lzVGVzdHOmMC4xMS4wsHRlcm1pbmFsX291dHB1dHOGqVN0YXRzQmFzZdnvCkluc3RhbnRpYXRpbmcuLi4KClJlc29sdmluZy4uLgobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psX2VYakVRSy9Qcm9qZWN0LnRvbWxgChtbMzJtG1sxbSAgTm8gQ2hhbmdlcxtbMjJtG1szOW0gdG8gYC90bXAvamxfZVhqRVFLL01hbmlmZXN0LnRvbWxgCgpQcmVjb21waWxpbmcuLi4KG1szMm0bWzFtICBBY3RpdmF0aW5nG1syMm0bWzM5bSBwcm9qZWN0IGF0IGAvdG1wL2psX2VYakVRS2CkWExTWNnvCkluc3RhbnRpYXRpbmcuLi4KClJlc29sdmluZy4uLgobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psX2VYakVRSy9Qcm9qZWN0LnRvbWxgChtbMzJtG1sxbSAgTm8gQ2hhbmdlcxtbMjJtG1szOW0gdG8gYC90bXAvamxfZVhqRVFLL01hbmlmZXN0LnRvbWxgCgpQcmVjb21waWxpbmcuLi4KG1szMm0bWzFtICBBY3RpdmF0aW5nG1syMm0bWzM5bSBwcm9qZWN0IGF0IGAvdG1wL2psX2VYakVRS2CqbmJwa2dfc3luY9nvCkluc3RhbnRpYXRpbmcuLi4KClJlc29sdmluZy4uLgobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psX2VYakVRSy9Qcm9qZWN0LnRvbWxgChtbMzJtG1sxbSAgTm8gQ2hhbmdlcxtbMjJtG1szOW0gdG8gYC90bXAvamxfZVhqRVFLL01hbmlmZXN0LnRvbWxgCgpQcmVjb21waWxpbmcuLi4KG1szMm0bWzFtICBBY3RpdmF0aW5nG1syMm0bWzM5bSBwcm9qZWN0IGF0IGAvdG1wL2psX2VYakVRS2CvTXVsdGlwbGVUZXN0aW5n2e8KSW5zdGFudGlhdGluZy4uLgoKUmVzb2x2aW5nLi4uChtbMzJtG1sxbSAgTm8gQ2hhbmdlcxtbMjJtG1szOW0gdG8gYC90bXAvamxfZVhqRVFLL1Byb2plY3QudG9tbGAKG1szMm0bWzFtICBObyBDaGFuZ2VzG1syMm0bWzM5bSB0byBgL3RtcC9qbF9lWGpFUUsvTWFuaWZlc3QudG9tbGAKClByZWNvbXBpbGluZy4uLgobWzMybRtbMW0gIEFjdGl2YXRpbmcbWzIybRtbMzltIHByb2plY3QgYXQgYC90bXAvamxfZVhqRVFLYKxTcGFyc2VBcnJheXPZ7wpJbnN0YW50aWF0aW5nLi4uCgpSZXNvbHZpbmcuLi4KG1szMm0bWzFtICBObyBDaGFuZ2VzG1syMm0bWzM5bSB0byBgL3RtcC9qbF9lWGpFUUsvUHJvamVjdC50b21sYAobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psX2VYakVRSy9NYW5pZmVzdC50b21sYAoKUHJlY29tcGlsaW5nLi4uChtbMzJtG1sxbSAgQWN0aXZhdGluZxtbMjJtG1szOW0gcHJvamVjdCBhdCBgL3RtcC9qbF9lWGpFUUtgr0h5cG90aGVzaXNUZXN0c9nvCkluc3RhbnRpYXRpbmcuLi4KClJlc29sdmluZy4uLgobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psX2VYakVRSy9Qcm9qZWN0LnRvbWxgChtbMzJtG1sxbSAgTm8gQ2hhbmdlcxtbMjJtG1szOW0gdG8gYC90bXAvamxfZVhqRVFLL01hbmlmZXN0LnRvbWxgCgpQcmVjb21waWxpbmcuLi4KG1szMm0bWzFtICBBY3RpdmF0aW5nG1syMm0bWzM5bSBwcm9qZWN0IGF0IGAvdG1wL2psX2VYakVRS2CnZW5hYmxlZMO3cmVzdGFydF9yZWNvbW1lbmRlZF9tc2fAtHJlc3RhcnRfcmVxdWlyZWRfbXNnwK1idXN5X3BhY2thZ2VzkK9pbnN0YWxsX3RpbWVfbnPOue2SJqxpbnN0YW50aWF0ZWTDq2NlbGxfaW5wdXRz3gAV2SRhNWU2MWE0OC1lMDdlLTQ5ZGMtOGM2MS0xMjI0ZDFjNDdkMTOEp2NlbGxfaWTZJGE1ZTYxYTQ4LWUwN2UtNDlkYy04YzYxLTEyMjRkMWM0N2QxM6Rjb2Rl2Sdjb3VudHMgPSBJbnQuKGRhdGFbIk5iIFNOUCJdWyJCMzpVMjUiXSmobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMLZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MoSnY2VsbF9pZNkkOWMzYjhlYjItYTE2MC00MjQ2LWE1YzctNTk2YTg2YzczZDYypGNvZGXZcGJlZ2luCglnZW5vdHlwZXMgPSB2ZWMoZGF0YVsiTmIgU05QIl1bIkIyOlUyIl0pICMgY29sdW1ucwoJY2F0ZWdvcmllcyA9IHZlYyhkYXRhWyJOYiBTTlAiXVsiQTM6QTI1Il0pICMgcm93cwplbmSobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMLZJDkzNDJlNDg5LWEyOTctNGM2Ny04MzI0LWNiNDE4MDFhZjcxM4SnY2VsbF9pZNkkOTM0MmU0ODktYTI5Ny00YzY3LTgzMjQtY2I0MTgwMWFmNzEzpGNvZGXaA2NiZWdpbgoJcGVyX2dlbm90eXBlX3B2YWx1ZXMgPSBGbG9hdDY0W10KCWZvciBjb2wgaW4gMTpuY29scwoJCW9rID0gb2JzZXJ2ZWRfY291bnRzWzosIGNvbF0gLj49IDUKCQlhbnkob2spIHx8IGNvbnRpbnVlCgkJb2JzZXJ2ZWRfY291bnRz4oCyID0gb2JzZXJ2ZWRfY291bnRzW29rLCBjb2xdCgkJaWYgIWFsbChvaykKCQkJc3ludGhldGljX2NvdW50ID0gc3VtKG9ic2VydmVkX2NvdW50c1soISkuKG9rKSwgY29sXSkKCQkJcHVzaCEob2JzZXJ2ZWRfY291bnRz4oCyLCBzeW50aGV0aWNfY291bnQpCgkJZW5kCgkJZXhwZWN0ZWRfY291bnRz4oCyID0gZXhwZWN0ZWRfY291bnRzW29rLCBjb2xdCgkJaWYgIWFsbChvaykKCQkJc3ludGhldGljX2NvdW50ID0gc3VtKGV4cGVjdGVkX2NvdW50c1soISkuKG9rKSwgY29sXSkKCQkJcHVzaCEoZXhwZWN0ZWRfY291bnRz4oCyLCBzeW50aGV0aWNfY291bnQpCgkJZW5kCgkJY29udGluZ2VuY3lfdGFibGUgPSBoY2F0KG9ic2VydmVkX2NvdW50c+KAsiwgZXhwZWN0ZWRfY291bnRz4oCyKQoJCWlmIGFueShleHBlY3RlZF9jb3VudHPigLIgLjwgNSkKCQkJaWYgYW55KGV4cGVjdGVkX2NvdW50c+KAsiAuPT0gMCkKCQkJCUB3YXJuICJFeHBlY3RlZCBjb3VudHMgYXJlIHRvbyBsb3c7IHNraXBwaW5nIiBjb250aW5nZW5jeV90YWJsZQoJCQkJY29udGludWUKCQkJZWxzZQoJCQkJI0B3YXJuICJFeHBlY3RlZCBjb3VudHMgYXJlIGxvdyIgY29udGluZ2VuY3lfdGFibGUKCQkJZW5kCgkJZW5kCgkJcHZhbCA9IHB2YWx1ZShDaGlzcVRlc3QoY29udGluZ2VuY3lfdGFibGUpKQoJCXB1c2ghKHBlcl9nZW5vdHlwZV9wdmFsdWVzLCBwdmFsKQoJZW5kCglwZXJfZ2Vub3R5cGVfcHZhbHVlcwplbmSobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMLZJDExYWM1ZjZhLTBmNmEtMTFlZS0yNTk4LTExYzdhMDA2NGI0M4SnY2VsbF9pZNkkMTFhYzVmNmEtMGY2YS0xMWVlLTI1OTgtMTFjN2EwMDY0YjQzpGNvZGXZRXVzaW5nIFN0YXRzQmFzZSwgSHlwb3RoZXNpc1Rlc3RzLCBYTFNYLCBTcGFyc2VBcnJheXMsIE11bHRpcGxlVGVzdGluZ6htZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkwtkkN2UzODM5NjctMjZkZS00OWJkLWExMDYtZDIxNTI0MWZmZGIxhKdjZWxsX2lk2SQ3ZTM4Mzk2Ny0yNmRlLTQ5YmQtYTEwNi1kMjE1MjQxZmZkYjGkY29kZdm0YmVnaW4KCXVuY29ycmVjdGVkX3B2YWx1ZXNfYmVsb3dfdGhyZXNob2xkID0gY29weShwdmFsdWVzKQoJdW5jb3JyZWN0ZWRfcHZhbHVlc19iZWxvd190aHJlc2hvbGQubnp2YWxbLjA1IC48IHB2YWx1ZXMubnp2YWxdIC49IDAKCWRyb3B6ZXJvcyh1bmNvcnJlY3RlZF9wdmFsdWVzX2JlbG93X3RocmVzaG9sZCkKZW5kqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTC2SRmMjgyNWQzYy01NzdiLTRiNjEtOGM4Yy1jODY5YTllYzlmMDeEp2NlbGxfaWTZJGYyODI1ZDNjLTU3N2ItNGI2MS04YzhjLWM4NjlhOWVjOWYwN6Rjb2Rl2fVtZCIiIgpUbyB0ZXN0IHdoZXRoZXIgYSBnZW5vdHlwZSBleGhpYml0cyBhIGRpZmZlcmVudCBwYXJ0aXRpb24gaW50byBjYXRlZ29yaWVzIG9mIGdlbmVzLCBvciBlcXVpdmFsZW50bHkgd2hldGhlciBpdCBpcyBlbnJpY2hlZCBpbiBzb21lIGNhdGVnb3J5LCB3ZSBmaXJzdCBkZXJpdmUgYW4gZXhwZWN0ZWQgcGFydGl0aW9uIGF2ZXJhZ2luZyB0aGUgY2F0ZWdvcnkgZnJlcXVlbmNpZXMgYWNyb3NzIGFsbCBnZW5vdHlwZXMuCiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkw9kkM2ViOWQzOWMtMmNhMS00MzBlLWIxM2ItMDVjODA5YTgwZDVihKdjZWxsX2lk2SQzZWI5ZDM5Yy0yY2ExLTQzMGUtYjEzYi0wNWM4MDlhODBkNWKkY29kZdk/bWQiIiIKRmlyc3QsIHdlIGV4Y2x1ZGUgdGhlIHJvd3MgYW5kIGNvbHVtbnMgb2YgemVyb3Mgb25seS4KIiIiqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTD2SQzMWRjNThkYi01YTRlLTQ3ZGMtYmRiOC1mZTZlOWJiNDcyMDSEp2NlbGxfaWTZJDMxZGM1OGRiLTVhNGUtNDdkYy1iZGI4LWZlNmU5YmI0NzIwNKRjb2Rl2eptZCIiIgpXZSBkbyBub3QgYm90aGVyIHByZXR0eSBwcmludGluZyBvciBjb3JyZWN0aW5nIHRoZSBwLXZhbHVlczogdGhlcmUgYXJlIG5vIHNpZ25pZmljYW50IGRpZmZlcmVuY2VzIGF0IGFsbC4KCldlIGNvdWxkIHRyeSBwYWlyd2lzZSBjb21wYXJpc29ucyBiZXR3ZWVuIGdlbm90eXBlcyBub3csIGluc3RlYWQgb2YgZm9jdXNpbmcgb24gYW4gImF2ZXJhZ2UiIGdlbm90eXBlIGFzIGEgcmVmZXJlbmNlLgoiIiKobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMPZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZoSnY2VsbF9pZNkkNTQ4Y2EyNDQtZGU0Yy00N2MyLWE2OWUtMGNhN2E0NDkwMjhmpGNvZGXZmmJlZ2luCglyb3csIGNvbCA9IGZpbmRueihzaWduaWZpY2FudF9wdmFsdWVzKQoJY2F0ZWdvcnkgPSBjYXRlZ29yaWVzW3Jvd19va11bcm93XQoJZ2Vub3R5cGUgPSBnZW5vdHlwZXNbY29sX29rXVtjb2xdCgljb2xsZWN0KHppcChjYXRlZ29yeSwgZ2Vub3R5cGUpKQplbmSobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMLZJDg4NGE3Mjk5LTg0MTgtNDVlNC04MmYzLTY1MjA0ZDQ4ZTU1YoSnY2VsbF9pZNkkODg0YTcyOTktODQxOC00NWU0LTgyZjMtNjUyMDRkNDhlNTVipGNvZGXaA+dtZCIiIgpDb3JyZWN0aW5nIGZvciBhbGwgY29tcGFyaXNvbnMgaXMgcHJvYmFibHkgdW5mYWlyLiBGcmVxdWVuY2llcyBhcmUgYm91bmQgd2l0aGluIGVhY2ggY29sdW1uIGFuZCByb3cgKG9uZSBsZXNzIGRlZ3JlZSBvZiBmcmVlZG9tKS4KCkFueXdheSwgdGhlIHNhbXBsZSBzaXplIGlzIGZhciB0b28gbG93IGZvciB0aGUgbnVtYmVyIG9mIGNlbGxzLCBhbmQgd2UgbmVlZCBhIG1vcmUgcG93ZXJmdWwgdGVzdC4KCkxldCB1cyBub3cgY29tcGFyZSBlYWNoIGdlbm90eXBlIHdpdGggdGhlICJhdmVyYWdlIiBnZW5vdHlwZSBncm91cGluZyB0aGUgbG93LWZyZXF1ZW5jeSBjZWxscyB0b2dldGhlci4gV2UgYWxyZWFkeSBrbm93IHRoZSBwb3N0LWhvYyB0ZXN0cyBmYWlsLCBhbmQgd2Ugd29uJ3QgaGF2ZSBjYXRlZ29yeS1sZXZlbCByZXNvbHV0aW9uLCBidXQgYSBzaWduaWZpY2FudCBkaWZmZXJlbmNlIG1heSBiZSBhbiBhcmd1bWVudCBmb3IgaW5jcmVhc2luZyB0aGUgc2FtcGxlIHNpemUsIG9yIHJldGhpbmtpbmcgdGhlIGNhdGVnb3JpZXMuIAoKQW4gZWxhYm9yYXRlIGFwcHJvYWNoIGNhbiBiZSBmb3VuZCBpbiBbS2FzcywgMTk4MF0oaHR0cHM6Ly93d3c0LnN0YXQubmNzdS5lZHUvfmRpY2tleS9hbmFseXRpY3MvZGF0YW1pbmUvUmVmZXJlbmNlJTIwUGFwZXJzL2thc3M4MC5wZGYpLgoKVGhlIHNpbXBsZXIgYXBwcm9hY2ggZm9sbG93ZWQgaGVyZSBjb25zaXN0cyBpbiBncm91cGluZyBhbGwgb2JzZXJ2ZWQgY291bnRzIGJlbG93IDUgaW50byBhIHNpbmdsZSBzeW50aGV0aWMgY2F0ZWdvcnksIGZvciBlYWNoIGNvbHVtbiBzZXBhcmF0ZWx5LiBFeHBlY3RlZCBjb3VudHMgYXJlIHNpbWlsYXJseSBncm91cGVkLCBiYXNlZCBvbiB0aGUgb2JzZXJ2ZWQgY291bnRzLiBJZiBzb21lIGV4cGVjdGVkIGNvdW50IGlzIGJlbG93IDUgKGluY2x1ZGVkIHRoZSBzeW50aGV0aWMgY2F0ZWdvcnkpLCB3ZSBjYXJyeSBvbiB1bmxlc3MgdGhpcyBjb3VudCBpcyAwLgoiIiKobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMPZJGI4YWRjNTY2LTU4OTMtNDAyYS1hMzVkLTExYzA2NDYwZmI2MoSnY2VsbF9pZNkkYjhhZGM1NjYtNTg5My00MDJhLWEzNWQtMTFjMDY0NjBmYjYypGNvZGXaAnZtZCIiIgpEdWUgdG8gdGhlIHByZXNlbmNlIG9mIHplcm9zIGluIG1vc3QgY29sdW1ucywgd2UgaGF2ZSB0byBncm91cCB0aGUgbG93LWZyZXF1ZW5jeSBjZWxscyBpbnRvIHNpbmdsZSBjZWxscyBvbiBhIHBlci1jb2x1bW4gYmFzaXMuIFRoZSBpbmZvcm1hdGlvbiBpbiBsb3ctZnJlcXVlbmN5IGNlbGxzIGlzIGFscmVhZHkgYWNjb3VudGVkIGZvciBieSB0aGUgb3RoZXIgY2VsbHMuCgpXZSBjYW4gYWxzbyBpbmRpdmlkdWFsbHkgdGVzdCBlYWNoIGNvdW50IGBvYnNlcnZlZF9uYCBfZXF1YWwgdG8gb3IgZ3JlYXRlciB0aGFuIDVfIGluIGEgY29udGluZ2VuY3kgdGFibGUgd2l0aDoKYGBgCistLS0tLS0tLS0tLS0rLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKwp8IG9ic2VydmVkX24gfCBjb2xfdG90YWwgLSBvYnNlcnZlZF9uIHwKKy0tLS0tLS0tLS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0rCnwgZXhwZWN0ZWRfbiB8IGNvbF90b3RhbCAtIGV4cGVjdGVkX24gfAorLS0tLS0tLS0tLS0tKy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsKYGBgClRoaXMgc2Vjb25kIGFwcHJvYWNoIGlzIGxlc3MgcG93ZXJmdWwsIHRob3VnaC4KCkxldCB1cyBiZWdpbiB3aXRoIHRoaXMgc2Vjb25kIGFwcHJvYWNoOgoiIiKobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMPZJDcyY2Y4ZDU1LWE0MjMtNGMyOC1hMzcwLTM3N2Y5ZWY2YTcwZYSnY2VsbF9pZNkkNzJjZjhkNTUtYTQyMy00YzI4LWEzNzAtMzc3ZjllZjZhNzBlpGNvZGXZmWJlZ2luCgljb2xfdG90YWwgPSBzdW0oY2xlYW5fY291bnRzOyBkaW1zPTEpCglleHBlY3RlZF9mcmVxdWVuY2llcyA9IG1lYW4oY2xlYW5fY291bnRzIC4vIGNvbF90b3RhbDsgZGltcz0yKQoJQGFzc2VydCBzdW0oZXhwZWN0ZWRfZnJlcXVlbmNpZXMpIOKJiCAxCmVuZKhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkwtkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2NlhKdjZWxsX2lk2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2WkY29kZdoDbWJlZ2luCglvYnNlcnZlZF9jb3VudHMgPSBjbGVhbl9jb3VudHMKCSMgaW4gdGhlb3J5LCB3ZSBjb3VsZCBhbHNvIHVzZSByZWFsLXZhbHVlZCBjb3VudHMgaW5zdGVhZAoJZXhwZWN0ZWRfY291bnRzID0gQC4gcm91bmQoSW50LCBleHBlY3RlZF9mcmVxdWVuY2llcyAqIGNvbF90b3RhbCkKCW9ic2VydmVkX3JlbWFpbmRlciA9IGNvbF90b3RhbCAuLSBvYnNlcnZlZF9jb3VudHMKCWV4cGVjdGVkX3JlbWFpbmRlciA9IGNvbF90b3RhbCAuLSBleHBlY3RlZF9jb3VudHMKCglwdmFsdWVzID0gc3B6ZXJvcyhucm93cywgbmNvbHMpCglmb3Igcm93IGluIDE6bnJvd3MKCQlmb3IgY29sIGluIDE6bmNvbHMKCQkJCgkJCSMgYnVpbGQgdGhlIGNvbnRpbmdlbmN5IHRhYmxlCgkJCWEgPSBvYnNlcnZlZF9jb3VudHNbcm93LCBjb2xdCgkJCWIgPSBvYnNlcnZlZF9yZW1haW5kZXJbcm93LCBjb2xdCgkJCWMgPSBleHBlY3RlZF9jb3VudHNbcm93LCBjb2xdCgkJCWQgPSBleHBlY3RlZF9yZW1haW5kZXJbcm93LCBjb2xdCgkJCWNvbnRpbmdlbmN5X3RhYmxlID0gWyBhIGIgOyBjIGQgXQoJCQkKCQkJIyBwZXJmb3JtIGEgz4fCsiB0ZXN0IG9mIGhvbW9nZW5laXR5CgkJCWlmIGFsbCg+PSg1KSwgY29udGluZ2VuY3lfdGFibGUpCgkJCQlwdmFsID0gcHZhbHVlKENoaXNxVGVzdChjb250aW5nZW5jeV90YWJsZSkpCgkJCQkjIG5vdGU6IEZpc2hlckV4YWN0VGVzdChhLCBiLCBjLCBkKSBnaXZlcyB2ZXJ5IHNpbWlsYXIgcmVzdWx0cwoJCQkJI3B2YWwgPSBwdmFsdWUoRmlzaGVyRXhhY3RUZXN0KGEsIGIsIGMsIGQpOyBtZXRob2Q9Om1pbmxpa2UpCgkJCQkKCQkJCXB2YWx1ZXNbcm93LCBjb2xdID0gcHZhbAoJCQllbmQKCQllbmQKCWVuZAoJcHZhbHVlcwplbmSobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMLZJDQ2YzliZTA3LTNiYjQtNDk5Yy1hODE5LTdhODdjNzNiNmU0MoSnY2VsbF9pZNkkNDZjOWJlMDctM2JiNC00OTljLWE4MTktN2E4N2M3M2I2ZTQypGNvZGXaAZMjIHdpdGggY29ycmVjdGlvbiwgbm8gZGlmZmVyZW5jZXMgc3Vydml2ZQpiZWdpbgoJIyBzZWUgaHR0cHM6Ly9naXRodWIuY29tL2p1bGlhbmdlaHJpbmcvTXVsdGlwbGVUZXN0aW5nLmpsI2hvbG0KCWNvcnJlY3RlZF9wdmFsdWVzID0gYWRqdXN0KHB2YWx1ZXMubnp2YWwsIEhvbG0oKSkKCXNpZ25pZmljYW50ID0gY29ycmVjdGVkX3B2YWx1ZXMgLjw9IC4wNQoJc2lnbmlmaWNhbnRfcHZhbHVlcyA9IGNvcHkocHZhbHVlcykKCXNpZ25pZmljYW50X3B2YWx1ZXMubnp2YWwgLj0gMAoJc2lnbmlmaWNhbnRfcHZhbHVlcy5uenZhbFtzaWduaWZpY2FudF0gPSBjb3JyZWN0ZWRfcHZhbHVlc1tzaWduaWZpY2FudF0KCXNpZ25pZmljYW50X3B2YWx1ZXMgPSBkcm9wemVyb3Moc2lnbmlmaWNhbnRfcHZhbHVlcykKZW5kqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTC2SQxMjg2NjhjMy0yODJkLTQ0NTMtODRhNi1jZjJjMjlkNzE0MGaEp2NlbGxfaWTZJDEyODY2OGMzLTI4MmQtNDQ1My04NGE2LWNmMmMyOWQ3MTQwZqRjb2Rl2WZtZCIiIgpIYWQgd2UgZm91bmQgZGlmZmVyZW5jZXMsIHdlIGNvdWxkIGdldCB0aGUgY29ycmVzcG9uZGluZyBjYXRlZ29yeS1nZW5vdHlwZSBwYWlycyBhcyBmb2xsb3dzOgoiIiKobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMPZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM4SnY2VsbF9pZNkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzpGNvZGXZp2JlZ2luCglyb3dfb2sgPSB2ZWMoYW55KCE9KDApLCBjb3VudHM7IGRpbXM9MikpCgljb2xfb2sgPSB2ZWMoYW55KCE9KDApLCBjb3VudHM7IGRpbXM9MSkpCgljbGVhbl9jb3VudHMgPSBjb3VudHNbcm93X29rLCBjb2xfb2tdCglucm93cywgbmNvbHMgPSBzaXplKGNsZWFuX2NvdW50cykKZW5kqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTC2SQ1ZTk0YTUxNy1kYjQ2LTQ4NjQtYjcxNy01YjQ1NDM4ODRkZmaEp2NlbGxfaWTZJDVlOTRhNTE3LWRiNDYtNDg2NC1iNzE3LTViNDU0Mzg4NGRmZqRjb2Rl2TdkYXRhID0gWExTWC5vcGVueGxzeCgiLi4vZGF0YS9yYXcvU05Qc3BlY2lmaXF1ZXMueGxzeCIpqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTC2SQ4ZGQ1ZDRiOS01YTMyLTRhOTUtOGYzOC03ZjNlNWI5OGUyZDmEp2NlbGxfaWTZJDhkZDVkNGI5LTVhMzItNGE5NS04ZjM4LTdmM2U1Yjk4ZTJkOaRjb2Rl2d9tZCIiIgpXZSBmaXJzdCBsb2FkIHRoZSBjb3VudCBkYXRhLgoKISEhCglUaGUgbm90ZWJvb2sgaXMgYXNzdW1lZCB0byBydW4gZnJvbSBhIGNoaWxkIGRpcmVjdG9yeSAoKmUuZy4qIGBub3RlYm9va3NgKSBvZiB0aGUgcHJvamVjdCByb290LCBhbmQgdGhlIGRhdGEgZmlsZXMgYXJlIGV4cGVjdGVkIHRvIGJlIGZvdW5kIGluIGBkYXRhL3Jhd2AsIGZyb20gdGhlIHByb2plY3Qgcm9vdC4KIiIiqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTD2SRhMjVlZWNkNi1mNThkLTQ5M2QtYTVjZi05NDIxODMxOTg0OWSEp2NlbGxfaWTZJGEyNWVlY2Q2LWY1OGQtNDkzZC1hNWNmLTk0MjE4MzE5ODQ5ZKRjb2Rl2W5tZCIiIgpGb3IgZnVydGhlciByZWZlcmVuY2UsIHdlIGFsc28gbG9hZCB0aGUgbGFiZWxzIG9mIHRoZSByb3dzIChgY2F0ZWdvcmllc2ApIGFuZCBjb2x1bW5zIChgZ2Vub3R5cGVzYCkuCiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkw9kkYjMxNGFkZDctYTZmNS00MmYwLWJjOWEtYmJhNzQ4NTQzZmEyhKdjZWxsX2lk2SRiMzE0YWRkNy1hNmY1LTQyZjAtYmM5YS1iYmE3NDg1NDNmYTKkY29kZdltbWQiIiIKT3V0IG9mIGN1cmlvc2l0eSwgd2l0aCBubyBjb3JyZWN0aW9uIGZvciBtdWx0aXBsZSBjb21wYXJpc29ucywgd2UgZmluZCBhIHNpbmdsZSBwLXZhbHVlIGJlbG93IDAuMDU6CiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkw9kkYzA5Yjc3MWMtYWFiMS00MGNmLWEyNzMtMTRhYTZjODU3NTEwhKdjZWxsX2lk2SRjMDliNzcxYy1hYWIxLTQwY2YtYTI3My0xNGFhNmM4NTc1MTCkY29kZdlFbWQiIiIKQ29ycmVjdGluZyBmb3IgYWxsIHRoZSBjb21wYXJpc29ucywgbm8gZGlmZmVyZW5jZXMgc3Vydml2ZToKIiIiqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTDq25vdGVib29rX2lk2SRhMjY3NDIwNC0wZjljLTExZWUtMjIwNy0yZjhkZjE0NGRhOGGraW5fdGVtcF9kaXLCqG1ldGFkYXRhgA=="; +window.pluto_statefile = "data:;base64,3gARpWJvbmRzgKxjZWxsX3Jlc3VsdHPeABbZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MoqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHmFpnByZWZpeKNBbnmoZWxlbWVudHPcABeSAZKjIkQiqnRleHQvcGxhaW6SApKjIk0iqnRleHQvcGxhaW6SA5KjIk4iqnRleHQvcGxhaW6SBJKjIk8iqnRleHQvcGxhaW6SBZKjIlQiqnRleHQvcGxhaW6SBpKjIlUiqnRleHQvcGxhaW6SB5KjIlYiqnRleHQvcGxhaW6SCJKjIlciqnRleHQvcGxhaW6SCZKjIkEiqnRleHQvcGxhaW6SCpKjIkIiqnRleHQvcGxhaW6SC5KjIkoiqnRleHQvcGxhaW6SDJKjIksiqnRleHQvcGxhaW6SDZKjIkwiqnRleHQvcGxhaW6SDpKjIkMiqnRleHQvcGxhaW6SD5KjIkUiqnRleHQvcGxhaW6SEJKjIkYiqnRleHQvcGxhaW6SEZKjIkciqnRleHQvcGxhaW6SEpKjIkgiqnRleHQvcGxhaW6SE5KjIkkiqnRleHQvcGxhaW6SFJKjIlAiqnRleHQvcGxhaW6SFZKjIlEiqnRleHQvcGxhaW6SFpKjIlMiqnRleHQvcGxhaW6SF5KoIkF1Y3VuZSKqdGV4dC9wbGFpbqR0eXBlpUFycmF5rHByZWZpeF9zaG9ydKCob2JqZWN0aWSwOGU5NGU3NGM1ODBhMmU3OKRtaW1l2SFhcHBsaWNhdGlvbi92bmQucGx1dG8udHJlZStvYmplY3Sscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpaLnYEBuwcGVyc2lzdF9qc19zdGF0ZcO3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MrlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgAVzfS1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTOKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R5haZwcmVmaXi1RGljdHtTdHJpbmcsIEZsb2F0NjR9qGVsZW1lbnRznpKSpSJHMjMiqnRleHQvcGxhaW6SqDAuNzA1Mzg3qnRleHQvcGxhaW6SkqQiRzUiqnRleHQvcGxhaW6SqDAuOTkwODk5qnRleHQvcGxhaW6SkqQiRzIiqnRleHQvcGxhaW6SpzAuMjUwMTGqdGV4dC9wbGFpbpKSpSJHMjIiqnRleHQvcGxhaW6SqDAuODc1MjI1qnRleHQvcGxhaW6SkqUiRzEwIqp0ZXh0L3BsYWlukqgwLjcyMzYwNKp0ZXh0L3BsYWlukpKkIkc4Iqp0ZXh0L3BsYWlukqgwLjM4NjY2Nqp0ZXh0L3BsYWlukpKlIkcxMyKqdGV4dC9wbGFpbpKoMC42NDIxNzWqdGV4dC9wbGFpbpKSpSJHMzAiqnRleHQvcGxhaW6SqDAuNjIwMzgzqnRleHQvcGxhaW6SkqUiRzc3Iqp0ZXh0L3BsYWlukqcwLjk4OTYxqnRleHQvcGxhaW6SkqUiRzEyIqp0ZXh0L3BsYWlukqgwLjc5OTM4N6p0ZXh0L3BsYWlukpKlIkcxMSKqdGV4dC9wbGFpbpKoMC44MTc5MzmqdGV4dC9wbGFpbpKSpSJHMTQiqnRleHQvcGxhaW6SqDAuOTM0NDgxqnRleHQvcGxhaW6SkqQiRzciqnRleHQvcGxhaW6SqDAuNDg4NTgxqnRleHQvcGxhaW6SkqQiRzYiqnRleHQvcGxhaW6SqDAuOTE4MTIxqnRleHQvcGxhaW6kdHlwZaREaWN0rHByZWZpeF9zaG9ydKREaWN0qG9iamVjdGlksGVmMWU0NjZhMWE1ZDMwYWKkbWltZdkhYXBwbGljYXRpb24vdm5kLnBsdXRvLnRyZWUrb2JqZWN0rHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZKWi6m5wbsHBlcnNpc3RfanNfc3RhdGXDt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTO5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4AAYcStXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkNmQ3NjhlYzItZjlhZC00Y2M3LWEyZGYtNGVlYjFhNzJjZDQ0iqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedlRPGRpdiBjbGFzcz0ibWFya2Rvd24iPjxwPk5vdCBhbnkgdW5jb3JyZWN0ZWQgcC12YWx1ZSBkcm9wcyBiZWxvdyAwLjA1LjwvcD4KPC9kaXY+pG1pbWWpdGV4dC9odG1srHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZKWjb35IEsHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQ2ZDc2OGVjMi1mOWFkLTRjYzctYTJkZi00ZWViMWE3MmNkNDS5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4AAsQItXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkN2UzODM5NjctMjZkZS00OWJkLWExMDYtZDIxNTI0MWZmZGIxiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedoBGTIxw5cxOSBTcGFyc2VNYXRyaXhDU0N7RmxvYXQ2NCwgSW50NjR9IHdpdGggMSBzdG9yZWQgZW50cnk6CuKOoeKggOKggOKggOKggOKggOKggOKggOKggOKggOKggOKOpArijqLioIDioIDioIDioIDioIDioIDioIDioIDioIDioIDijqUK4o6i4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4o6lCuKOouKggOKggOKggOKggOKggOKggOKggOKggOKggOKggOKOpQrijqLioIDioIDiooDioIDioIDioIDioIDioIDioIDioIDijqUK4o6j4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4o6mpG1pbWWqdGV4dC9wbGFpbqxyb290YXNzaWduZWXAsmxhc3RfcnVuX3RpbWVzdGFtcMtB2Sloups3BLBwZXJzaXN0X2pzX3N0YXRlw7doYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkN2UzODM5NjctMjZkZS00OWJkLWExMDYtZDIxNTI0MWZmZGIxuWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXNJMS1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQzZWI5ZDM5Yy0yY2ExLTQzMGUtYjEzYi0wNWM4MDlhODBkNWKKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R52Vk8ZGl2IGNsYXNzPSJtYXJrZG93biI+PHA+Rmlyc3QsIHdlIGV4Y2x1ZGUgdGhlIHJvd3MgYW5kIGNvbHVtbnMgb2YgemVyb3Mgb25seS48L3A+CjwvZGl2PqRtaW1lqXRleHQvaHRtbKxyb290YXNzaWduZWXAsmxhc3RfcnVuX3RpbWVzdGFtcMtB2SlorMGVNrBwZXJzaXN0X2pzX3N0YXRlwrdoYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkM2ViOWQzOWMtMmNhMS00MzBlLWIxM2ItMDVjODA5YTgwZDViuWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXOAAIE+rVwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZoqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHmFpnByZWZpeK9UdXBsZXtBbnksIEFueX2oZWxlbWVudHOQpHR5cGWlQXJyYXmscHJlZml4X3Nob3J0oKhvYmplY3RpZLBhZGFhNmJjMTBmMjcwMmQypG1pbWXZIWFwcGxpY2F0aW9uL3ZuZC5wbHV0by50cmVlK29iamVjdKxyb290YXNzaWduZWXAsmxhc3RfcnVuX3RpbWVzdGFtcMtB2SloupttpLBwZXJzaXN0X2pzX3N0YXRlw7doYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkNTQ4Y2EyNDQtZGU0Yy00N2MyLWE2OWUtMGNhN2E0NDkwMjhmuWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXNBni1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQ4ODRhNzI5OS04NDE4LTQ1ZTQtODJmMy02NTIwNGQ0OGU1NWKKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R52gW2PGRpdiBjbGFzcz0ibWFya2Rvd24iPjxwPlRoZSBzYW1wbGUgc2l6ZSBpcyB0b28gbG93IGlmIHdlIGNvbnNpZGVyIHRoZSBsYXJnZSBudW1iZXIgb2YgY2VsbHMsIGFuZCB3ZSBuZWVkIGEgbW9yZSBwb3dlcmZ1bCB0ZXN0LiBMZXQgdXMgbm93IGNvbXBhcmUgZWFjaCBnZW5vdHlwZSB3aXRoIHRoZSAmcXVvdDthdmVyYWdlJnF1b3Q7IGdlbm90eXBlLCBncm91cGluZyB0aGUgbG93LWZyZXF1ZW5jeSBjZWxscyB0b2dldGhlci48L3A+CjxwPldlIGFscmVhZHkga25vdyB0aGUgcG9zdC1ob2MgdGVzdHMgZmFpbCwgdGhlcmVmb3JlIHdlIHdvbiYjMzk7dCBoYXZlIGNhdGVnb3J5LWxldmVsIHJlc29sdXRpb24uIEhvd2V2ZXIsIGEgc2lnbmlmaWNhbnQgZGlmZmVyZW5jZSBpcyBzdGlsbCBwb3NzaWJsZSBoZXJlIGFzIHRoZSB0ZXN0IHdpbGwgY3VtdWxhdGUgdGhlIGRpZmZlcmVuY2VzIGZvciB0aGUgZGlmZmVyZW50IGNhdGVnb3JpZXMuIFRoZSBpbmRpdmlkdWFsIGRpZmZlcmVuY2VzIHNob3VsZCBiZSBkZXRlY3RhYmxlIGluY3JlYXNpbmcgdGhlIHNhbXBsZSBzaXplLjwvcD4KPGgxPkRpc2NsYWltZXI8L2gxPgo8cD5UaGUgZm9sbG93aW5nIGFuYWx5c2lzIGlzIGEgc2Vjb25kIGl0ZXJhdGlvbiBtb3RpdmF0ZWQgYnkgYW4gZXJyb3IgaW4gdGhlIGZpcnN0IGl0ZXJhdGlvbi4gVGhlIGhpc3Rvcnkgb2YgdGhlIHByZXNlbnQgbm90ZWJvb2sgY2FuIGJlIGZvdW5kIDxhIGhyZWY9Imh0dHBzOi8vZ2l0bGFiLnBhc3RldXIuZnIvZmxhdXJlbnQvcHJvamVjdDE5NDQ5Ly0vYmxvYi9tYWluL25vdGVib29rcy9zbnBfY2hpc3FfdGVzdHMuamwiPmhlcmU8L2E+LjwvcD4KPHA+VGhlIGNhdGVnb3JpZXMgd2VyZSBncm91cGVkIGJhc2VkIG9uIHRoZSBvYnNlcnZlZCBjb3VudHMsIHdoZXJlYXMgdGhlIG1pbmltdW0tNSBjcml0ZXJpb24gYWN0dWFsbHkgYXBwbGllcyB0byB0aGUgZXhwZWN0ZWQgY291bnRzLiBUaGlzIGlzIGZpeGVkIGluIHRoaXMgdmVyc2lvbiBvZiB0aGUgYW5hbHlzaXMuPC9wPgo8aDE+R3JvdXBpbmcgcHJvY2VkdXJlPC9oMT4KPHA+QW4gZWxhYm9yYXRlIGdyb3VwaW5nIGFwcHJvYWNoIGNhbiBiZSBmb3VuZCBpbiA8YSBocmVmPSJodHRwczovL3d3dzQuc3RhdC5uY3N1LmVkdS9+ZGlja2V5L2FuYWx5dGljcy9kYXRhbWluZS9SZWZlcmVuY2UmIzM3OzIwUGFwZXJzL2thc3M4MC5wZGYiPkthc3MsIDE5ODA8L2E+LjwvcD4KPHA+VGhlIHNpbXBsZXIgYXBwcm9hY2ggZm9sbG93ZWQgaGVyZSBjb25zaXN0cyBpbiBncm91cGluZyBhbGwgdGhlIGNhdGVnb3JpZXMgd2l0aCBhbiBleHBlY3RlZCBjb3VudCBiZWxvdyA1IGludG8gYSBzaW5nbGUgc3ludGhldGljIGNhdGVnb3J5LCBmb3IgZWFjaCBjb2x1bW4gc2VwYXJhdGVseS4gT2JzZXJ2ZWQgY291bnRzIGFyZSBzaW1pbGFybHkgZ3JvdXBlZCwgYmFzZWQgb24gdGhlIGV4cGVjdGVkIGNvdW50cy48L3A+CjwvZGl2PqRtaW1lqXRleHQvaHRtbKxyb290YXNzaWduZWXAsmxhc3RfcnVuX3RpbWVzdGFtcMtB2Slo8ULuJLBwZXJzaXN0X2pzX3N0YXRlwrdoYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkODg0YTcyOTktODQxOC00NWU0LTgyZjMtNjUyMDRkNDhlNTViuWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXOAAlwkLVwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJGI4YWRjNTY2LTU4OTMtNDAyYS1hMzVkLTExYzA2NDYwZmI2MoqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHnaAuk8ZGl2IGNsYXNzPSJtYXJrZG93biI+PHA+RHVlIHRvIHRoZSBwcmVzZW5jZSBvZiB6ZXJvcyBpbiBtb3N0IGNvbHVtbnMsIHdlIGhhdmUgdG8gZ3JvdXAgdGhlIGxvdy1mcmVxdWVuY3kgY2VsbHMgaW50byBzaW5nbGUgY2VsbHMgb24gYSBwZXItY29sdW1uIGJhc2lzLiBUaGUgaW5mb3JtYXRpb24gaW4gbG93LWZyZXF1ZW5jeSBjZWxscyBpcyBhbHJlYWR5IGFjY291bnRlZCBmb3IgYnkgdGhlIG90aGVyIGNlbGxzLjwvcD4KPHA+V2UgY2FuIGFsc28gaW5kaXZpZHVhbGx5IHRlc3QgZWFjaCBjb3VudCA8Y29kZT5vYnNlcnZlZF9uPC9jb2RlPiA8ZW0+ZXF1YWwgdG8gb3IgZ3JlYXRlciB0aGFuIDU8L2VtPiBpbiBhIGNvbnRpbmdlbmN5IHRhYmxlIHdpdGg6PC9wPgo8cHJlPjxjb2RlPiYjNDM7LS0tLS0tLS0tLS0tJiM0MzstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0mIzQzOwp8IG9ic2VydmVkX24gfCBjb2xfdG90YWwgLSBvYnNlcnZlZF9uIHwKJiM0MzstLS0tLS0tLS0tLS0mIzQzOy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSYjNDM7CnwgZXhwZWN0ZWRfbiB8IGNvbF90b3RhbCAtIGV4cGVjdGVkX24gfAomIzQzOy0tLS0tLS0tLS0tLSYjNDM7LS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tJiM0Mzs8L2NvZGU+PC9wcmU+CjxwPlRoaXMgc2Vjb25kIGFwcHJvYWNoIGlzIGxlc3MgcG93ZXJmdWwsIHRob3VnaC48L3A+CjxwPkxldCB1cyBiZWdpbiB3aXRoIHRoaXMgc2Vjb25kIGFwcHJvYWNoOjwvcD4KPC9kaXY+pG1pbWWpdGV4dC9odG1srHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZKWiswbvosHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SRiOGFkYzU2Ni01ODkzLTQwMmEtYTM1ZC0xMWMwNjQ2MGZiNjK5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4ABFDBtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMziqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9keYOoZWxlbWVudHOSkgGSojIxqnRleHQvcGxhaW6SApKiMTmqdGV4dC9wbGFpbqR0eXBlpVR1cGxlqG9iamVjdGlksDUxOTE3YjlkZTM4NTQ0YjKkbWltZdkhYXBwbGljYXRpb24vdm5kLnBsdXRvLnRyZWUrb2JqZWN0rHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZKWi6mquGsHBlcnNpc3RfanNfc3RhdGXDt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzO5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc0crbVwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJGEyNWVlY2Q2LWY1OGQtNDkzZC1hNWNmLTk0MjE4MzE5ODQ5ZIqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHnZrjxkaXYgY2xhc3M9Im1hcmtkb3duIj48cD5Gb3IgZnVydGhlciByZWZlcmVuY2UsIHdlIGFsc28gbG9hZCB0aGUgbGFiZWxzIG9mIHRoZSByb3dzICYjNDA7PGNvZGU+Y2F0ZWdvcmllczwvY29kZT4mIzQxOyBhbmQgY29sdW1ucyAmIzQwOzxjb2RlPmdlbm90eXBlczwvY29kZT4mIzQxOy48L3A+CjwvZGl2PqRtaW1lqXRleHQvaHRtbKxyb290YXNzaWduZWXAsmxhc3RfcnVuX3RpbWVzdGFtcMtB2SlorMGFurBwZXJzaXN0X2pzX3N0YXRlwrdoYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkYTI1ZWVjZDYtZjU4ZC00OTNkLWE1Y2YtOTQyMTgzMTk4NDlkuWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXOAAJWo7VwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJGE1ZTYxYTQ4LWUwN2UtNDlkYy04YzYxLTEyMjRkMWM0N2QxM4qmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHnaA+EyM8OXMjAgTWF0cml4e0ludDY0fToKIDAgICAxICAwICAgMiAgIDEgICAxICAwICAwICAgMyAgMCAgIDQgICA2ICAwICAwICAwICAgMSAgMCAgMCAgMiAgIDEKIDIgICA3ICA0ICAgOCAgIDUgICA1ICAxICA2ICAxMCAgMiAgIDIgIDE3ICAxICAwICAyICAgNiAgNSAgMiAgMyAgIDgKIDAgICAzICAwICAgMSAgIDEgICAyICAxICAyICAgMyAgMCAgIDMgICAyICAwICAwICAyICAgMSAgMiAgMCAgMSAgIDQKIDEgICAwICAwICAgMiAgIDAgICAxICAwICAxICAgNSAgMiAgIDAgICA1ICAwICAwICAxICAgMyAgMyAgMSAgMiAgIDIKIDAgICA0ICAwICAgMyAgIDAgICA2ICAyICAyICAgNiAgMSAgIDEgICA3ICAwICAwICAxICAgMyAgMSAgMSAgMyAgIDQKIDEgICAwICAyICAgNiAgIDQgICAyICAyICAwICAgOSAgMSAgIDYgICA5ICAwICAwICAxICAgMyAgNSAgMSAgNSAgIDQKIDEgICAwICAwICAgMCAgIDAgICAwICAwICAwICAgMiAgMCAgIDAgICAyICAwICAwICAxICAgMSAgMiAgMCAgMiAgIDEKIOKLriAgICAgICAgICAgICAgICAgIOKLriAgICAgICAgICAgICAgICDii64gICAgICAgICAgICAgICAg4ouuICAgICAgICAgICAKIDAgICA2ICAxICAgNiAgIDYgICA1ICAyICA5ICAgOSAgNCAgIDggIDE3ICAxICAwICAxICAgMyAgNSAgMSAgNiAgIDgKIDAgICAzICAxICAgMiAgIDIgICAzICAxICAwICAgMyAgMiAgIDQgICA5ICAwICAwICAxICAgMiAgMiAgMiAgMiAgIDEKIDAgIDE4ICAyICAgOCAgIDkgIDEyICA1ICAzICAxNSAgNSAgIDggIDE1ICAwICAwICA0ICAgNCAgMiAgNCAgNiAgMTEKIDAgICAwICAyICAgMiAgIDAgICAwICAxICAwICAgMiAgMCAgIDEgICA1ICAwICAwICAxICAgMSAgMiAgMSAgMCAgIDAKIDEgIDI3ICAyICAxMyAgMTggIDI3ICA4ICA3ICAyMyAgNyAgMTAgIDQwICAwICAwICAyICAxMyAgNyAgMiAgOCAgMjEKIDAgICAxICAwICAgMyAgIDEgICAwICAwICAwICAgMCAgMCAgIDEgICA2ICAwICAwICAwICAgMyAgMCAgMCAgMSAgIDKkbWltZap0ZXh0L3BsYWlurHJvb3Rhc3NpZ25lZaZjb3VudHOybGFzdF9ydW5fdGltZXN0YW1wy0HZKWi6mn/hsHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SRhNWU2MWE0OC1lMDdlLTQ5ZGMtOGM2MS0xMjI0ZDFjNDdkMTO5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4ADiLqtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkYzA5Yjc3MWMtYWFiMS00MGNmLWEyNzMtMTRhYTZjODU3NTEwiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedlfPGRpdiBjbGFzcz0ibWFya2Rvd24iPjxwPkNvcnJlY3RpbmcgZm9yIGFsbCB0aGUgY29tcGFyaXNvbnMsIG5vIGRpZmZlcmVuY2VzIHN1cnZpdmU6PC9wPgo8L2Rpdj6kbWltZal0ZXh0L2h0bWyscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpaKzB2/2wcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJGMwOWI3NzFjLWFhYjEtNDBjZi1hMjczLTE0YWE2Yzg1NzUxMLlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgACBvS1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQxMWFjNWY2YS0wZjZhLTExZWUtMjU5OC0xMWM3YTAwNjRiNDOKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R5oKRtaW1lqnRleHQvcGxhaW6scm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpaLA+YQ+wcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDExYWM1ZjZhLTBmNmEtMTFlZS0yNTk4LTExYzdhMDA2NGI0M7lkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lziasU4+1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SRmMjgyNWQzYy01NzdiLTRiNjEtOGM4Yy1jODY5YTllYzlmMDeKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R52gEPPGRpdiBjbGFzcz0ibWFya2Rvd24iPjxwPlRvIHRlc3Qgd2hldGhlciBhIGdlbm90eXBlIGV4aGliaXRzIGEgZGlmZmVyZW50IHBhcnRpdGlvbiBpbnRvIGNhdGVnb3JpZXMgb2YgZ2VuZXMsIG9yIGVxdWl2YWxlbnRseSB3aGV0aGVyIGl0IGlzIGVucmljaGVkIGluIHNvbWUgY2F0ZWdvcnksIHdlIGZpcnN0IGRlcml2ZSBhbiBleHBlY3RlZCBwYXJ0aXRpb24gYXZlcmFnaW5nIHRoZSBjYXRlZ29yeSBmcmVxdWVuY2llcyBhY3Jvc3MgYWxsIGdlbm90eXBlcy48L3A+CjwvZGl2PqRtaW1lqXRleHQvaHRtbKxyb290YXNzaWduZWXAsmxhc3RfcnVuX3RpbWVzdGFtcMtB2SlorMGl6LBwZXJzaXN0X2pzX3N0YXRlwrdoYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkZjI4MjVkM2MtNTc3Yi00YjYxLThjOGMtYzg2OWE5ZWM5ZjA3uWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXOAAIuSLVwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJDcyY2Y4ZDU1LWE0MjMtNGMyOC1hMzcwLTM3N2Y5ZWY2YTcwZYqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHmFpnByZWZpeLJEaWN0e0FueSwgRmxvYXQ2NH2oZWxlbWVudHPcABWSkqMiUSKqdGV4dC9wbGFpbpKpMC4wMTc1ODg4qnRleHQvcGxhaW6SkqMiVyKqdGV4dC9wbGFpbpKqMC4wMDIyMjc2N6p0ZXh0L3BsYWlukpKjIlQiqnRleHQvcGxhaW6SqTAuMDI5Mzc0Nqp0ZXh0L3BsYWlukpKjIkMiqnRleHQvcGxhaW6SqTAuMDU4ODE0Nqp0ZXh0L3BsYWlukpKjIlAiqnRleHQvcGxhaW6SqTAuMDk1MjAwNap0ZXh0L3BsYWlukpKjIlYiqnRleHQvcGxhaW6SqTAuMDEzMjg3Nap0ZXh0L3BsYWlukpKjIkwiqnRleHQvcGxhaW6SqTAuMDM1MTM1Map0ZXh0L3BsYWlukpKjIk8iqnRleHQvcGxhaW6SqTAuMDI1NDM0Nap0ZXh0L3BsYWlukpKjIk0iqnRleHQvcGxhaW6SqTAuMDk0NzIwOap0ZXh0L3BsYWlukpKjIk4iqnRleHQvcGxhaW6SpjAuMDIwNqp0ZXh0L3BsYWlukpKoIkF1Y3VuZSKqdGV4dC9wbGFpbpKqMC4wMDg3MTQxMap0ZXh0L3BsYWlukpKjIkgiqnRleHQvcGxhaW6SpzAuMDgxNTSqdGV4dC9wbGFpbpKSoyJEIqp0ZXh0L3BsYWlukqkwLjAxMDgwODGqdGV4dC9wbGFpbpKSoyJHIqp0ZXh0L3BsYWlukqkwLjA4NTYxMjeqdGV4dC9wbGFpbpKSoyJFIqp0ZXh0L3BsYWlukqkwLjA1NzQ4NziqdGV4dC9wbGFpbpKSoyJVIqp0ZXh0L3BsYWlukqkwLjA0ODM3MTSqdGV4dC9wbGFpbpKSoyJKIqp0ZXh0L3BsYWlukqkwLjA0NTcwMzGqdGV4dC9wbGFpbpKSoyJJIqp0ZXh0L3BsYWlukqkwLjAzMDM5ODiqdGV4dC9wbGFpbpKSoyJTIqp0ZXh0L3BsYWlukqgwLjE0OTc1Map0ZXh0L3BsYWlukpKjIksiqnRleHQvcGxhaW6SqTAuMDUwMzQ4NKp0ZXh0L3BsYWlukpKjIkYiqnRleHQvcGxhaW6SqTAuMDM4ODgwNap0ZXh0L3BsYWlupHR5cGWkRGljdKxwcmVmaXhfc2hvcnSkRGljdKhvYmplY3RpZLAyOWQzZmMxNjEwNDk3ZDI2pG1pbWXZIWFwcGxpY2F0aW9uL3ZuZC5wbHV0by50cmVlK29iamVjdKxyb290YXNzaWduZWXAsmxhc3RfcnVuX3RpbWVzdGFtcMtB2Sloupry/rBwZXJzaXN0X2pzX3N0YXRlw7doYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkNzJjZjhkNTUtYTQyMy00YzI4LWEzNzAtMzc3ZjllZjZhNzBluWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXOAAoilrVwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZYqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHnaARwyMcOXMTkgU3BhcnNlTWF0cml4Q1NDe0Zsb2F0NjQsIEludDY0fSB3aXRoIDgwIHN0b3JlZCBlbnRyaWVzOgrijqHioJDioJDioJLioJDioILiopDioIDioJLioIDioILijqQK4o6i4qCA4qCA4qCA4qCA4qCC4qCY4qCA4qCA4qCA4qCA4o6lCuKOouKgmOKgkOKgkOKggOKhhOKiuOKggOKhgOKggOKhgeKOpQrijqLioqjioqjio63ioqDioYbio7zioIDiooTiooDioYXijqUK4o6i4qKQ4qKQ4qOS4qOA4qOC4qOa4qCA4qOA4qKQ4qGC4o6lCuKOo+KggOKggOKggOKggOKggOKggOKggOKggOKggOKggOKOpqRtaW1lqnRleHQvcGxhaW6scm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpaLqbIASwcGVyc2lzdF9qc19zdGF0ZcO3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZblkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgAHQWC1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQ0NmM5YmUwNy0zYmI0LTQ5OWMtYTgxOS03YTg3YzczYjZlNDKKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R52gEbMjHDlzE5IFNwYXJzZU1hdHJpeENTQ3tGbG9hdDY0LCBJbnQ2NH0gd2l0aCAwIHN0b3JlZCBlbnRyaWVzOgrijqHioIDioIDioIDioIDioIDioIDioIDioIDioIDioIDijqQK4o6i4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4o6lCuKOouKggOKggOKggOKggOKggOKggOKggOKggOKggOKggOKOpQrijqLioIDioIDioIDioIDioIDioIDioIDioIDioIDioIDijqUK4o6i4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4qCA4o6lCuKOo+KggOKggOKggOKggOKggOKggOKggOKggOKggOKggOKOpqRtaW1lqnRleHQvcGxhaW6scm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpaLqbUqCwcGVyc2lzdF9qc19zdGF0ZcO3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDQ2YzliZTA3LTNiYjQtNDk5Yy1hODE5LTdhODdjNzNiNmU0MrlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzXbutXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkMTI4NjY4YzMtMjgyZC00NDUzLTg0YTYtY2YyYzI5ZDcxNDBmiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedmAPGRpdiBjbGFzcz0ibWFya2Rvd24iPjxwPkhhZCB3ZSBmb3VuZCBkaWZmZXJlbmNlcywgd2UgY291bGQgZ2V0IHRoZSBjb3JyZXNwb25kaW5nIGNhdGVnb3J5LWdlbm90eXBlIHBhaXJzIGFzIGZvbGxvd3M6PC9wPgo8L2Rpdj6kbWltZal0ZXh0L2h0bWyscm9vdGFzc2lnbmVlwLJsYXN0X3J1bl90aW1lc3RhbXDLQdkpaKzB+wmwcGVyc2lzdF9qc19zdGF0ZcK3aGFzX3BsdXRvX2hvb2tfZmVhdHVyZXPCp2NlbGxfaWTZJDEyODY2OGMzLTI4MmQtNDQ1My04NGE2LWNmMmMyOWQ3MTQwZrlkZXBlbmRzX29uX2Rpc2FibGVkX2NlbGxzwqdydW50aW1lzgACStC1cHVibGlzaGVkX29iamVjdF9rZXlzkLhkZXBlbmRzX29uX3NraXBwZWRfY2VsbHPCp2Vycm9yZWTC2SQwMWZiZjFjOS0xY2VhLTQ1OTMtYTJjNS0wMzg1NGRlZTI0NzOKpnF1ZXVlZMKkbG9nc5CncnVubmluZ8Kmb3V0cHV0hqRib2R52dA8ZGl2IGNsYXNzPSJtYXJrZG93biI+PHA+VGhpcyBkb2N1bWVudCBpcyBhIFBsdXRvIG5vdGVib29rICYjNDA7b3IgYW4gaHRtbCByZW5kZXJlZCB2ZXJzaW9uIG9mIGl0JiM0MTsgYW5kIHJlcXVpcmVzIDxhIGhyZWY9Imh0dHBzOi8vY29tcHV0YXRpb25hbHRoaW5raW5nLm1pdC5lZHUvU3ByaW5nMjEvaW5zdGFsbGF0aW9uLyI+SnVsaWE8L2E+LjwvcD4KPC9kaXY+pG1pbWWpdGV4dC9odG1srHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZKWiswWD2sHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQwMWZiZjFjOS0xY2VhLTQ1OTMtYTJjNS0wMzg1NGRlZTI0NzO5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4AA01ItXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZmiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedoBDFhMU1hGaWxlKCIuLi9kYXRhL3Jhdy9TTlBzcGVjaWZpcXVlcy54bHN4IikgY29udGFpbmluZyAyIFdvcmtzaGVldHMKICAgICAgICAgICAgc2hlZXRuYW1lIHNpemUgICAgICAgICAgcmFuZ2UgICAgICAgIAotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAgICAgICAgICAgICAgIE5iIFNOUCAyOXgyMiAgICAgICAgIEExOlYyOSAgICAgICAKICAgICAgcG91cmNlbnRhZ2UgU05QIDMweDIxICAgICAgICAgQTE6VTMwICAgICAgIAqkbWltZap0ZXh0L3BsYWlurHJvb3Rhc3NpZ25lZaRkYXRhsmxhc3RfcnVuX3RpbWVzdGFtcMtB2SloucrSqrBwZXJzaXN0X2pzX3N0YXRlwrdoYXNfcGx1dG9faG9va19mZWF0dXJlc8KnY2VsbF9pZNkkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZmuWRlcGVuZHNfb25fZGlzYWJsZWRfY2VsbHPCp3J1bnRpbWXOABd+4LVwdWJsaXNoZWRfb2JqZWN0X2tleXOQuGRlcGVuZHNfb25fc2tpcHBlZF9jZWxsc8KnZXJyb3JlZMLZJDhkZDVkNGI5LTVhMzItNGE5NS04ZjM4LTdmM2U1Yjk4ZTJkOYqmcXVldWVkwqRsb2dzkKdydW5uaW5nwqZvdXRwdXSGpGJvZHnaASo8ZGl2IGNsYXNzPSJtYXJrZG93biI+PHA+V2UgZmlyc3QgbG9hZCB0aGUgY291bnQgZGF0YS48L3A+CjxwPk5vdGUgdGhlIG5vdGVib29rIGlzIGFzc3VtZWQgdG8gcnVuIGZyb20gYSBjaGlsZCBkaXJlY3RvcnkgJiM0MDs8ZW0+ZS5nLjwvZW0+IDxjb2RlPm5vdGVib29rczwvY29kZT4mIzQxOyBvZiB0aGUgcHJvamVjdCByb290LCBhbmQgdGhlIGRhdGEgZmlsZXMgYXJlIGV4cGVjdGVkIHRvIGJlIGZvdW5kIGluIDxjb2RlPmRhdGEvcmF3PC9jb2RlPiwgYWdhaW4gZnJvbSB0aGUgcHJvamVjdCByb290LjwvcD4KPC9kaXY+pG1pbWWpdGV4dC9odG1srHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZKWnGt0edsHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SQ4ZGQ1ZDRiOS01YTMyLTRhOTUtOGYzOC03ZjNlNWI5OGUyZDm5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4ABJ2UtXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwtkkYjMxNGFkZDctYTZmNS00MmYwLWJjOWEtYmJhNzQ4NTQzZmEyiqZxdWV1ZWTCpGxvZ3OQp3J1bm5pbmfCpm91dHB1dIakYm9kedmHPGRpdiBjbGFzcz0ibWFya2Rvd24iPjxwPk91dCBvZiBjdXJpb3NpdHksIHdpdGggbm8gY29ycmVjdGlvbiBmb3IgbXVsdGlwbGUgY29tcGFyaXNvbnMsIHdlIGZpbmQgYSBzaW5nbGUgcC12YWx1ZSBiZWxvdyAwLjA1OjwvcD4KPC9kaXY+pG1pbWWpdGV4dC9odG1srHJvb3Rhc3NpZ25lZcCybGFzdF9ydW5fdGltZXN0YW1wy0HZKWi/TUcksHBlcnNpc3RfanNfc3RhdGXCt2hhc19wbHV0b19ob29rX2ZlYXR1cmVzwqdjZWxsX2lk2SRiMzE0YWRkNy1hNmY1LTQyZjAtYmM5YS1iYmE3NDg1NDNmYTK5ZGVwZW5kc19vbl9kaXNhYmxlZF9jZWxsc8KncnVudGltZc4AS8RftXB1Ymxpc2hlZF9vYmplY3Rfa2V5c5C4ZGVwZW5kc19vbl9za2lwcGVkX2NlbGxzwqdlcnJvcmVkwqtzdGF0dXNfdHJlZYSkbmFtZahub3RlYm9va6hzdWJ0YXNrc4Smc2F2aW5nhKRuYW1lpnNhdmluZ6hzdWJ0YXNrc4CrZmluaXNoZWRfYXTLQdkpaccpTgWqc3RhcnRlZF9hdMtB2SlpxykzGql3b3Jrc3BhY2WEpG5hbWWpd29ya3NwYWNlqHN1YnRhc2tzgqxpbml0X3Byb2Nlc3OEpG5hbWWsaW5pdF9wcm9jZXNzqHN1YnRhc2tzhKE0hKRuYW1loTSoc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZKWivJtaVqnN0YXJ0ZWRfYXTLQdkpaK6S9lGhMYSkbmFtZaExqHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2Sloro4P/qpzdGFydGVkX2F0y0HZKWiuPIh/oTKEpG5hbWWhMqhzdWJ0YXNrc4CrZmluaXNoZWRfYXTLQdkpaK6SB3Cqc3RhcnRlZF9hdMtB2Sloro4g2qEzhKRuYW1loTOoc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZKWiukvZAqnN0YXJ0ZWRfYXTLQdkpaK6SGG6rZmluaXNoZWRfYXTLQdkpaK8m5FSqc3RhcnRlZF9hdMtB2SlorjyIVa5jcmVhdGVfcHJvY2Vzc4SkbmFtZa5jcmVhdGVfcHJvY2Vzc6hzdWJ0YXNrc4KhMYSkbmFtZaExqHN1YnRhc2tzgKtmaW5pc2hlZF9hdMtB2SlorYI2P6pzdGFydGVkX2F0y0HZKWiszxZdoTKEpG5hbWWhMqhzdWJ0YXNrc4CrZmluaXNoZWRfYXTLQdkpaK48iBqqc3RhcnRlZF9hdMtB2SlorYJSfqtmaW5pc2hlZF9hdMtB2Slorjx2tKpzdGFydGVkX2F0y0HZKWiszxZEq2ZpbmlzaGVkX2F0y0HZKWivJuRcqnN0YXJ0ZWRfYXTLQdkpaKzPFiejcGtnhKRuYW1lo3BrZ6hzdWJ0YXNrc4GoYW5hbHlzaXOEpG5hbWWoYW5hbHlzaXOoc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZKWnGtszZqnN0YXJ0ZWRfYXTLQdkpaca2ue2rZmluaXNoZWRfYXTLQdkpaca2zNmqc3RhcnRlZF9hdMtB2Slpxra50KNydW6EpG5hbWWjcnVuqHN1YnRhc2tzgrByZXNvbHZlX3RvcG9sb2d5hKRuYW1lsHJlc29sdmVfdG9wb2xvZ3moc3VidGFza3OAq2ZpbmlzaGVkX2F0y0HZKWnGtxLXqnN0YXJ0ZWRfYXTLQdkpaca271KoZXZhbHVhdGWEpG5hbWWoZXZhbHVhdGWoc3VidGFza3OBoTGEpG5hbWWhMahzdWJ0YXNrc4CrZmluaXNoZWRfYXTLQdkpaca3R7uqc3RhcnRlZF9hdMtB2SlpxrcgS6tmaW5pc2hlZF9hdMtB2SlpxrdWgqpzdGFydGVkX2F0y0HZKWnGtxLXq2ZpbmlzaGVkX2F0y0HZKWnGt1aCqnN0YXJ0ZWRfYXTLQdkpaca27yCrZmluaXNoZWRfYXTAqnN0YXJ0ZWRfYXTLQdkpaKy5jg2xY2VsbF9kZXBlbmRlbmNpZXPeABbZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MoS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MrRkb3duc3RyZWFtX2NlbGxzX21hcIKpZ2Vub3R5cGVzktkkNTQ4Y2EyNDQtZGU0Yy00N2MyLWE2OWUtMGNhN2E0NDkwMjhm2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTOqY2F0ZWdvcmllc5LZJDcyY2Y4ZDU1LWE0MjMtNGMyOC1hMzcwLTM3N2Y5ZWY2YTcwZdkkNTQ4Y2EyNDQtZGU0Yy00N2MyLWE2OWUtMGNhN2E0NDkwMjhmsnVwc3RyZWFtX2NlbGxzX21hcIKjdmVjkKRkYXRhkdkkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZm2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTOEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTO0ZG93bnN0cmVhbV9jZWxsc19tYXCBtHBlcl9nZW5vdHlwZV9wdmFsdWVzkLJ1cHN0cmVhbV9jZWxsc19tYXDeABKpZ2Vub3R5cGVzkdkkOWMzYjhlYjItYTE2MC00MjQ2LWE1YzctNTk2YTg2YzczZDYypERpY3SQoTqQr29ic2VydmVkX2NvdW50c5HZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZaNzdW2QoSGQpGhjYXSQo2FueZCnRmxvYXQ2NJCmU3RyaW5nkKVuY29sc5HZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM6NhbGyQpXB1c2ghkK9leHBlY3RlZF9jb3VudHOR2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2WmcHZhbHVlkKI+PZCmY29sX29rkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzqUNoaXNxVGVzdJDZJDZkNzY4ZWMyLWY5YWQtNGNjNy1hMmRmLTRlZWIxYTcyY2Q0NIS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDZkNzY4ZWMyLWY5YWQtNGNjNy1hMmRmLTRlZWIxYTcyY2Q0NLRkb3duc3RyZWFtX2NlbGxzX21hcICydXBzdHJlYW1fY2VsbHNfbWFwgqdAbWRfc3RykKhnZXRpbmRleJDZJDdlMzgzOTY3LTI2ZGUtNDliZC1hMTA2LWQyMTUyNDFmZmRiMYS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDdlMzgzOTY3LTI2ZGUtNDliZC1hMTA2LWQyMTUyNDFmZmRiMbRkb3duc3RyZWFtX2NlbGxzX21hcIHZI3VuY29ycmVjdGVkX3B2YWx1ZXNfYmVsb3dfdGhyZXNob2xkkLJ1cHN0cmVhbV9jZWxsc19tYXCFoTyQqWRyb3B6ZXJvc5CncHZhbHVlc5HZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZaZpc2xlc3OQpGNvcHmQ2SQzZWI5ZDM5Yy0yY2ExLTQzMGUtYjEzYi0wNWM4MDlhODBkNWKEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SQzZWI5ZDM5Yy0yY2ExLTQzMGUtYjEzYi0wNWM4MDlhODBkNWK0ZG93bnN0cmVhbV9jZWxsc19tYXCAsnVwc3RyZWFtX2NlbGxzX21hcIKnQG1kX3N0cpCoZ2V0aW5kZXiQ2SQ1NDhjYTI0NC1kZTRjLTQ3YzItYTY5ZS0wY2E3YTQ0OTAyOGaEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SQ1NDhjYTI0NC1kZTRjLTQ3YzItYTY5ZS0wY2E3YTQ0OTAyOGa0ZG93bnN0cmVhbV9jZWxsc19tYXCEo3Jvd5CoZ2Vub3R5cGWQo2NvbJCoY2F0ZWdvcnmQsnVwc3RyZWFtX2NlbGxzX21hcIipZ2Vub3R5cGVzkdkkOWMzYjhlYjItYTE2MC00MjQ2LWE1YzctNTk2YTg2YzczZDYypnJvd19va5HZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM6ZmaW5kbnqQp2NvbGxlY3SQpmNvbF9va5HZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM6N6aXCQqmNhdGVnb3JpZXOR2SQ5YzNiOGViMi1hMTYwLTQyNDYtYTVjNy01OTZhODZjNzNkNjKzc2lnbmlmaWNhbnRfcHZhbHVlc5HZJDQ2YzliZTA3LTNiYjQtNDk5Yy1hODE5LTdhODdjNzNiNmU0MtkkODg0YTcyOTktODQxOC00NWU0LTgyZjMtNjUyMDRkNDhlNTVihLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkODg0YTcyOTktODQxOC00NWU0LTgyZjMtNjUyMDRkNDhlNTVitGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkYjhhZGM1NjYtNTg5My00MDJhLWEzNWQtMTFjMDY0NjBmYjYyhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkYjhhZGM1NjYtNTg5My00MDJhLWEzNWQtMTFjMDY0NjBmYjYytGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMztGRvd25zdHJlYW1fY2VsbHNfbWFwhaZyb3dfb2uS2SQ3MmNmOGQ1NS1hNDIzLTRjMjgtYTM3MC0zNzdmOWVmNmE3MGXZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZqxjbGVhbl9jb3VudHOS2SQ3MmNmOGQ1NS1hNDIzLTRjMjgtYTM3MC0zNzdmOWVmNmE3MGXZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZaVucm93c5HZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZaZjb2xfb2uS2SQ1NDhjYTI0NC1kZTRjLTQ3YzItYTY5ZS0wY2E3YTQ0OTAyOGbZJDkzNDJlNDg5LWEyOTctNGM2Ny04MzI0LWNiNDE4MDFhZjcxM6VuY29sc5LZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZdkkOTM0MmU0ODktYTI5Ny00YzY3LTgzMjQtY2I0MTgwMWFmNzEzsnVwc3RyZWFtX2NlbGxzX21hcIajdmVjkKNhbnmQoiE9kKRzaXplkKI9PZCmY291bnRzkdkkYTVlNjFhNDgtZTA3ZS00OWRjLThjNjEtMTIyNGQxYzQ3ZDEz2SRhMjVlZWNkNi1mNThkLTQ5M2QtYTVjZi05NDIxODMxOTg0OWSEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SRhMjVlZWNkNi1mNThkLTQ5M2QtYTVjZi05NDIxODMxOTg0OWS0ZG93bnN0cmVhbV9jZWxsc19tYXCAsnVwc3RyZWFtX2NlbGxzX21hcIKnQG1kX3N0cpCoZ2V0aW5kZXiQ2SRhNWU2MWE0OC1lMDdlLTQ5ZGMtOGM2MS0xMjI0ZDFjNDdkMTOEtHByZWNlZGVuY2VfaGV1cmlzdGljCadjZWxsX2lk2SRhNWU2MWE0OC1lMDdlLTQ5ZGMtOGM2MS0xMjI0ZDFjNDdkMTO0ZG93bnN0cmVhbV9jZWxsc19tYXCBpmNvdW50c5HZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM7J1cHN0cmVhbV9jZWxsc19tYXCCo0ludJCkZGF0YZHZJDVlOTRhNTE3LWRiNDYtNDg2NC1iNzE3LTViNDU0Mzg4NGRmZtkkYzA5Yjc3MWMtYWFiMS00MGNmLWEyNzMtMTRhYTZjODU3NTEwhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkYzA5Yjc3MWMtYWFiMS00MGNmLWEyNzMtMTRhYTZjODU3NTEwtGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkMTFhYzVmNmEtMGY2YS0xMWVlLTI1OTgtMTFjN2EwMDY0YjQzhLRwcmVjZWRlbmNlX2hldXJpc3RpYwenY2VsbF9pZNkkMTFhYzVmNmEtMGY2YS0xMWVlLTI1OTgtMTFjN2EwMDY0YjQztGRvd25zdHJlYW1fY2VsbHNfbWFwhalTdGF0c0Jhc2WQpFhMU1iR2SQ1ZTk0YTUxNy1kYjQ2LTQ4NjQtYjcxNy01YjQ1NDM4ODRkZmavTXVsdGlwbGVUZXN0aW5nkKxTcGFyc2VBcnJheXOQr0h5cG90aGVzaXNUZXN0c5CydXBzdHJlYW1fY2VsbHNfbWFwgNkkZjI4MjVkM2MtNTc3Yi00YjYxLThjOGMtYzg2OWE5ZWM5ZjA3hLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkZjI4MjVkM2MtNTc3Yi00YjYxLThjOGMtYzg2OWE5ZWM5ZjA3tGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkNzJjZjhkNTUtYTQyMy00YzI4LWEzNzAtMzc3ZjllZjZhNzBlhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkNzJjZjhkNTUtYTQyMy00YzI4LWEzNzAtMzc3ZjllZjZhNzBltGRvd25zdHJlYW1fY2VsbHNfbWFwgrRleHBlY3RlZF9mcmVxdWVuY2llc5HZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZaljb2xfdG90YWyR2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2WydXBzdHJlYW1fY2VsbHNfbWFwjKPiiYiQpERpY3SQo3N1bZCsY2xlYW5fY291bnRzkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzp0Bhc3NlcnSQo3ppcJCmcm93X29rkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzpXRocm93kKEvkK5Bc3NlcnRpb25FcnJvcpCqY2F0ZWdvcmllc5HZJDljM2I4ZWIyLWExNjAtNDI0Ni1hNWM3LTU5NmE4NmM3M2Q2MqRtZWFukNkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2NlhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2NltGRvd25zdHJlYW1fY2VsbHNfbWFwha9vYnNlcnZlZF9jb3VudHOR2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTOvZXhwZWN0ZWRfY291bnRzkdkkOTM0MmU0ODktYTI5Ny00YzY3LTgzMjQtY2I0MTgwMWFmNzEzp3B2YWx1ZXOS2SQ3ZTM4Mzk2Ny0yNmRlLTQ5YmQtYTEwNi1kMjE1MjQxZmZkYjHZJDQ2YzliZTA3LTNiYjQtNDk5Yy1hODE5LTdhODdjNzNiNmU0MrJvYnNlcnZlZF9yZW1haW5kZXKQsmV4cGVjdGVkX3JlbWFpbmRlcpCydXBzdHJlYW1fY2VsbHNfbWFw3gAQtGV4cGVjdGVkX2ZyZXF1ZW5jaWVzkdkkNzJjZjhkNTUtYTQyMy00YzI4LWEzNzAtMzc3ZjllZjZhNzBlp3NwemVyb3OQrGNsZWFuX2NvdW50c5HZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM6Vucm93c5HZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM6E6kKljb2xfdG90YWyR2SQ3MmNmOGQ1NS1hNDIzLTRjMjgtYTM3MC0zNzdmOWVmNmE3MGWoQF9fZG90X1+QpW5jb2xzkdkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzo2FsbJChLZCmcHZhbHVlkKNJbnSQoj49kKEqkKVyb3VuZJCpQ2hpc3FUZXN0kNkkNDZjOWJlMDctM2JiNC00OTljLWE4MTktN2E4N2M3M2I2ZTQyhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkNDZjOWJlMDctM2JiNC00OTljLWE4MTktN2E4N2M3M2I2ZTQytGRvd25zdHJlYW1fY2VsbHNfbWFwg6tzaWduaWZpY2FudJCxY29ycmVjdGVkX3B2YWx1ZXOQs3NpZ25pZmljYW50X3B2YWx1ZXOR2SQ1NDhjYTI0NC1kZTRjLTQ3YzItYTY5ZS0wY2E3YTQ0OTAyOGaydXBzdHJlYW1fY2VsbHNfbWFwh6ZhZGp1c3SQuUJlbmphbWluaUhvY2hiZXJnQWRhcHRpdmWQojw9kKlkcm9wemVyb3OQp3B2YWx1ZXOR2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2WnVHdvU3RlcJCkY29weZDZJDEyODY2OGMzLTI4MmQtNDQ1My04NGE2LWNmMmMyOWQ3MTQwZoS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDEyODY2OGMzLTI4MmQtNDQ1My04NGE2LWNmMmMyOWQ3MTQwZrRkb3duc3RyZWFtX2NlbGxzX21hcICydXBzdHJlYW1fY2VsbHNfbWFwgqdAbWRfc3RykKhnZXRpbmRleJDZJDAxZmJmMWM5LTFjZWEtNDU5My1hMmM1LTAzODU0ZGVlMjQ3M4S0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDAxZmJmMWM5LTFjZWEtNDU5My1hMmM1LTAzODU0ZGVlMjQ3M7Rkb3duc3RyZWFtX2NlbGxzX21hcICydXBzdHJlYW1fY2VsbHNfbWFwgqdAbWRfc3RykKhnZXRpbmRleJDZJDVlOTRhNTE3LWRiNDYtNDg2NC1iNzE3LTViNDU0Mzg4NGRmZoS0cHJlY2VkZW5jZV9oZXVyaXN0aWMJp2NlbGxfaWTZJDVlOTRhNTE3LWRiNDYtNDg2NC1iNzE3LTViNDU0Mzg4NGRmZrRkb3duc3RyZWFtX2NlbGxzX21hcIGkZGF0YZLZJGE1ZTYxYTQ4LWUwN2UtNDlkYy04YzYxLTEyMjRkMWM0N2QxM9kkOWMzYjhlYjItYTE2MC00MjQ2LWE1YzctNTk2YTg2YzczZDYysnVwc3RyZWFtX2NlbGxzX21hcIKkWExTWJHZJDExYWM1ZjZhLTBmNmEtMTFlZS0yNTk4LTExYzdhMDA2NGI0M61YTFNYLm9wZW54bHN4kNkkOGRkNWQ0YjktNWEzMi00YTk1LThmMzgtN2YzZTViOThlMmQ5hLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkOGRkNWQ0YjktNWEzMi00YTk1LThmMzgtN2YzZTViOThlMmQ5tGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kNkkYjMxNGFkZDctYTZmNS00MmYwLWJjOWEtYmJhNzQ4NTQzZmEyhLRwcmVjZWRlbmNlX2hldXJpc3RpYwmnY2VsbF9pZNkkYjMxNGFkZDctYTZmNS00MmYwLWJjOWEtYmJhNzQ4NTQzZmEytGRvd25zdHJlYW1fY2VsbHNfbWFwgLJ1cHN0cmVhbV9jZWxsc19tYXCCp0BtZF9zdHKQqGdldGluZGV4kLRjZWxsX2V4ZWN1dGlvbl9vcmRlctwAFtkkMTFhYzVmNmEtMGY2YS0xMWVlLTI1OTgtMTFjN2EwMDY0YjQz2SQwMWZiZjFjOS0xY2VhLTQ1OTMtYTJjNS0wMzg1NGRlZTI0NzPZJDhkZDVkNGI5LTVhMzItNGE5NS04ZjM4LTdmM2U1Yjk4ZTJkOdkkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZm2SRhNWU2MWE0OC1lMDdlLTQ5ZGMtOGM2MS0xMjI0ZDFjNDdkMTPZJGEyNWVlY2Q2LWY1OGQtNDkzZC1hNWNmLTk0MjE4MzE5ODQ5ZNkkOWMzYjhlYjItYTE2MC00MjQ2LWE1YzctNTk2YTg2YzczZDYy2SQzZWI5ZDM5Yy0yY2ExLTQzMGUtYjEzYi0wNWM4MDlhODBkNWLZJGUzZmViZWM3LWI4NGMtNDVmOS04ZjY1LTVhMTU4YjBhZTkzM9kkZjI4MjVkM2MtNTc3Yi00YjYxLThjOGMtYzg2OWE5ZWM5ZjA32SQ3MmNmOGQ1NS1hNDIzLTRjMjgtYTM3MC0zNzdmOWVmNmE3MGXZJGI4YWRjNTY2LTU4OTMtNDAyYS1hMzVkLTExYzA2NDYwZmI2MtkkM2RmMzk0ODQtZTA3YS00OGQ4LTkwYWUtMDlkYTAwNTBiM2Nl2SRiMzE0YWRkNy1hNmY1LTQyZjAtYmM5YS1iYmE3NDg1NDNmYTLZJDdlMzgzOTY3LTI2ZGUtNDliZC1hMTA2LWQyMTUyNDFmZmRiMdkkYzA5Yjc3MWMtYWFiMS00MGNmLWEyNzMtMTRhYTZjODU3NTEw2SQ0NmM5YmUwNy0zYmI0LTQ5OWMtYTgxOS03YTg3YzczYjZlNDLZJDEyODY2OGMzLTI4MmQtNDQ1My04NGE2LWNmMmMyOWQ3MTQwZtkkNTQ4Y2EyNDQtZGU0Yy00N2MyLWE2OWUtMGNhN2E0NDkwMjhm2SQ4ODRhNzI5OS04NDE4LTQ1ZTQtODJmMy02NTIwNGQ0OGU1NWLZJDkzNDJlNDg5LWEyOTctNGM2Ny04MzI0LWNiNDE4MDFhZjcxM9kkNmQ3NjhlYzItZjlhZC00Y2M3LWEyZGYtNGVlYjFhNzJjZDQ0tGxhc3RfaG90X3JlbG9hZF90aW1lywAAAAAAAAAAqXNob3J0cGF0aLJzbnBfY2hpc3FfdGVzdHMuamyucHJvY2Vzc19zdGF0dXOlcmVhZHmkcGF0aNlYL2hvbWUvZmxhdXJlbnQvQm94ZXMvdHVtYmxld2VlZC0xL1Byb2plY3RzL3N0YXRzL0N5cmlsU2F2aW4vbm90ZWJvb2tzL3NucF9jaGlzcV90ZXN0cy5qbK5sYXN0X3NhdmVfdGltZctB2SlpxykzFqpjZWxsX29yZGVy3AAW2SQwMWZiZjFjOS0xY2VhLTQ1OTMtYTJjNS0wMzg1NGRlZTI0NzPZJDExYWM1ZjZhLTBmNmEtMTFlZS0yNTk4LTExYzdhMDA2NGI0M9kkOGRkNWQ0YjktNWEzMi00YTk1LThmMzgtN2YzZTViOThlMmQ52SQ1ZTk0YTUxNy1kYjQ2LTQ4NjQtYjcxNy01YjQ1NDM4ODRkZmbZJGE1ZTYxYTQ4LWUwN2UtNDlkYy04YzYxLTEyMjRkMWM0N2QxM9kkYTI1ZWVjZDYtZjU4ZC00OTNkLWE1Y2YtOTQyMTgzMTk4NDlk2SQ5YzNiOGViMi1hMTYwLTQyNDYtYTVjNy01OTZhODZjNzNkNjLZJDNlYjlkMzljLTJjYTEtNDMwZS1iMTNiLTA1YzgwOWE4MGQ1YtkkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMz2SRmMjgyNWQzYy01NzdiLTRiNjEtOGM4Yy1jODY5YTllYzlmMDfZJDcyY2Y4ZDU1LWE0MjMtNGMyOC1hMzcwLTM3N2Y5ZWY2YTcwZdkkYjhhZGM1NjYtNTg5My00MDJhLWEzNWQtMTFjMDY0NjBmYjYy2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2XZJGIzMTRhZGQ3LWE2ZjUtNDJmMC1iYzlhLWJiYTc0ODU0M2ZhMtkkN2UzODM5NjctMjZkZS00OWJkLWExMDYtZDIxNTI0MWZmZGIx2SRjMDliNzcxYy1hYWIxLTQwY2YtYTI3My0xNGFhNmM4NTc1MTDZJDQ2YzliZTA3LTNiYjQtNDk5Yy1hODE5LTdhODdjNzNiNmU0MtkkMTI4NjY4YzMtMjgyZC00NDUzLTg0YTYtY2YyYzI5ZDcxNDBm2SQ1NDhjYTI0NC1kZTRjLTQ3YzItYTY5ZS0wY2E3YTQ0OTAyOGbZJDg4NGE3Mjk5LTg0MTgtNDVlNC04MmYzLTY1MjA0ZDQ4ZTU1YtkkOTM0MmU0ODktYTI5Ny00YzY3LTgzMjQtY2I0MTgwMWFmNzEz2SQ2ZDc2OGVjMi1mOWFkLTRjYzctYTJkZi00ZWViMWE3MmNkNDSxcHVibGlzaGVkX29iamVjdHOApW5icGtniLJpbnN0YWxsZWRfdmVyc2lvbnOFqVN0YXRzQmFzZacwLjMzLjIxpFhMU1ilMC45LjCvTXVsdGlwbGVUZXN0aW5npTAuNS4xrFNwYXJzZUFycmF5c6ZzdGRsaWKvSHlwb3RoZXNpc1Rlc3RzpjAuMTEuMLB0ZXJtaW5hbF9vdXRwdXRzhqlTdGF0c0Jhc2XZ7wpJbnN0YW50aWF0aW5nLi4uCgpSZXNvbHZpbmcuLi4KG1szMm0bWzFtICBObyBDaGFuZ2VzG1syMm0bWzM5bSB0byBgL3RtcC9qbF9TOEJKelUvUHJvamVjdC50b21sYAobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psX1M4Qkp6VS9NYW5pZmVzdC50b21sYAoKUHJlY29tcGlsaW5nLi4uChtbMzJtG1sxbSAgQWN0aXZhdGluZxtbMjJtG1szOW0gcHJvamVjdCBhdCBgL3RtcC9qbF9TOEJKelVgpFhMU1jZ7wpJbnN0YW50aWF0aW5nLi4uCgpSZXNvbHZpbmcuLi4KG1szMm0bWzFtICBObyBDaGFuZ2VzG1syMm0bWzM5bSB0byBgL3RtcC9qbF9TOEJKelUvUHJvamVjdC50b21sYAobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psX1M4Qkp6VS9NYW5pZmVzdC50b21sYAoKUHJlY29tcGlsaW5nLi4uChtbMzJtG1sxbSAgQWN0aXZhdGluZxtbMjJtG1szOW0gcHJvamVjdCBhdCBgL3RtcC9qbF9TOEJKelVgqm5icGtnX3N5bmPZ7wpJbnN0YW50aWF0aW5nLi4uCgpSZXNvbHZpbmcuLi4KG1szMm0bWzFtICBObyBDaGFuZ2VzG1syMm0bWzM5bSB0byBgL3RtcC9qbF9TOEJKelUvUHJvamVjdC50b21sYAobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psX1M4Qkp6VS9NYW5pZmVzdC50b21sYAoKUHJlY29tcGlsaW5nLi4uChtbMzJtG1sxbSAgQWN0aXZhdGluZxtbMjJtG1szOW0gcHJvamVjdCBhdCBgL3RtcC9qbF9TOEJKelVgr011bHRpcGxlVGVzdGluZ9nvCkluc3RhbnRpYXRpbmcuLi4KClJlc29sdmluZy4uLgobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psX1M4Qkp6VS9Qcm9qZWN0LnRvbWxgChtbMzJtG1sxbSAgTm8gQ2hhbmdlcxtbMjJtG1szOW0gdG8gYC90bXAvamxfUzhCSnpVL01hbmlmZXN0LnRvbWxgCgpQcmVjb21waWxpbmcuLi4KG1szMm0bWzFtICBBY3RpdmF0aW5nG1syMm0bWzM5bSBwcm9qZWN0IGF0IGAvdG1wL2psX1M4Qkp6VWCsU3BhcnNlQXJyYXlz2e8KSW5zdGFudGlhdGluZy4uLgoKUmVzb2x2aW5nLi4uChtbMzJtG1sxbSAgTm8gQ2hhbmdlcxtbMjJtG1szOW0gdG8gYC90bXAvamxfUzhCSnpVL1Byb2plY3QudG9tbGAKG1szMm0bWzFtICBObyBDaGFuZ2VzG1syMm0bWzM5bSB0byBgL3RtcC9qbF9TOEJKelUvTWFuaWZlc3QudG9tbGAKClByZWNvbXBpbGluZy4uLgobWzMybRtbMW0gIEFjdGl2YXRpbmcbWzIybRtbMzltIHByb2plY3QgYXQgYC90bXAvamxfUzhCSnpVYK9IeXBvdGhlc2lzVGVzdHPZ7wpJbnN0YW50aWF0aW5nLi4uCgpSZXNvbHZpbmcuLi4KG1szMm0bWzFtICBObyBDaGFuZ2VzG1syMm0bWzM5bSB0byBgL3RtcC9qbF9TOEJKelUvUHJvamVjdC50b21sYAobWzMybRtbMW0gIE5vIENoYW5nZXMbWzIybRtbMzltIHRvIGAvdG1wL2psX1M4Qkp6VS9NYW5pZmVzdC50b21sYAoKUHJlY29tcGlsaW5nLi4uChtbMzJtG1sxbSAgQWN0aXZhdGluZxtbMjJtG1szOW0gcHJvamVjdCBhdCBgL3RtcC9qbF9TOEJKelVgp2VuYWJsZWTDt3Jlc3RhcnRfcmVjb21tZW5kZWRfbXNnwLRyZXN0YXJ0X3JlcXVpcmVkX21zZ8CtYnVzeV9wYWNrYWdlc5CvaW5zdGFsbF90aW1lX25zzskLYE2saW5zdGFudGlhdGVkw6tjZWxsX2lucHV0c94AFtkkOWMzYjhlYjItYTE2MC00MjQ2LWE1YzctNTk2YTg2YzczZDYyhKdjZWxsX2lk2SQ5YzNiOGViMi1hMTYwLTQyNDYtYTVjNy01OTZhODZjNzNkNjKkY29kZdlwYmVnaW4KCWdlbm90eXBlcyA9IHZlYyhkYXRhWyJOYiBTTlAiXVsiQjI6VTIiXSkgIyBjb2x1bW5zCgljYXRlZ29yaWVzID0gdmVjKGRhdGFbIk5iIFNOUCJdWyJBMzpBMjUiXSkgIyByb3dzCmVuZKhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkwtkkOTM0MmU0ODktYTI5Ny00YzY3LTgzMjQtY2I0MTgwMWFmNzEzhKdjZWxsX2lk2SQ5MzQyZTQ4OS1hMjk3LTRjNjctODMyNC1jYjQxODAxYWY3MTOkY29kZdoDHGJlZ2luCglwZXJfZ2Vub3R5cGVfcHZhbHVlcyA9IERpY3R7U3RyaW5nLCBGbG9hdDY0fSgpCglmb3IgY29sIGluIDE6bmNvbHMKCQkjIGlkZW50aWZ5IGNlbGxzIHRvIGJlIGdyb3VwZWQKCQlvayA9IGV4cGVjdGVkX2NvdW50c1s6LCBjb2xdIC4+PSA1CgkJYW55KG9rKSB8fCBjb250aW51ZQoJCSMgZ3JvdXAgY2VsbHMKCQlleHBlY3RlZF9jb3VudHPigLIgPSBleHBlY3RlZF9jb3VudHNbb2ssIGNvbF0KCQlpZiAhYWxsKG9rKQoJCQlzeW50aGV0aWNfY291bnQgPSBzdW0oZXhwZWN0ZWRfY291bnRzWyghKS4ob2spLCBjb2xdKQoJCQlwdXNoIShleHBlY3RlZF9jb3VudHPigLIsIHN5bnRoZXRpY19jb3VudCkKCQllbmQKCQlvYnNlcnZlZF9jb3VudHPigLIgPSBvYnNlcnZlZF9jb3VudHNbb2ssIGNvbF0KCQlpZiAhYWxsKG9rKQoJCQlzeW50aGV0aWNfY291bnQgPSBzdW0ob2JzZXJ2ZWRfY291bnRzWyghKS4ob2spLCBjb2xdKQoJCQlwdXNoIShvYnNlcnZlZF9jb3VudHPigLIsIHN5bnRoZXRpY19jb3VudCkKCQllbmQKCQkjIHBlcmZvcm0gdGhlIHRlc3QKCQljb250aW5nZW5jeV90YWJsZSA9IGhjYXQob2JzZXJ2ZWRfY291bnRz4oCyLCBleHBlY3RlZF9jb3VudHPigLIpCgkJcHZhbCA9IHB2YWx1ZShDaGlzcVRlc3QoY29udGluZ2VuY3lfdGFibGUpKQoJCSMgcmVjb3JkIHRoZSByZXN1bHRpbmcgcHZhbHVlCgkJZ2Vub3R5cGUgPSBnZW5vdHlwZXNbY29sX29rXVtjb2xdCgkJcGVyX2dlbm90eXBlX3B2YWx1ZXNbZ2Vub3R5cGVdID0gcHZhbAoJZW5kCglwZXJfZ2Vub3R5cGVfcHZhbHVlcwplbmSobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMLZJDZkNzY4ZWMyLWY5YWQtNGNjNy1hMmRmLTRlZWIxYTcyY2Q0NISnY2VsbF9pZNkkNmQ3NjhlYzItZjlhZC00Y2M3LWEyZGYtNGVlYjFhNzJjZDQ0pGNvZGXZN21kIiIiCk5vdCBhbnkgdW5jb3JyZWN0ZWQgcC12YWx1ZSBkcm9wcyBiZWxvdyAwLjA1LgoiIiKobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMPZJDdlMzgzOTY3LTI2ZGUtNDliZC1hMTA2LWQyMTUyNDFmZmRiMYSnY2VsbF9pZNkkN2UzODM5NjctMjZkZS00OWJkLWExMDYtZDIxNTI0MWZmZGIxpGNvZGXZtGJlZ2luCgl1bmNvcnJlY3RlZF9wdmFsdWVzX2JlbG93X3RocmVzaG9sZCA9IGNvcHkocHZhbHVlcykKCXVuY29ycmVjdGVkX3B2YWx1ZXNfYmVsb3dfdGhyZXNob2xkLm56dmFsWy4wNSAuPCBwdmFsdWVzLm56dmFsXSAuPSAwCglkcm9wemVyb3ModW5jb3JyZWN0ZWRfcHZhbHVlc19iZWxvd190aHJlc2hvbGQpCmVuZKhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkwtkkM2ViOWQzOWMtMmNhMS00MzBlLWIxM2ItMDVjODA5YTgwZDVihKdjZWxsX2lk2SQzZWI5ZDM5Yy0yY2ExLTQzMGUtYjEzYi0wNWM4MDlhODBkNWKkY29kZdk/bWQiIiIKRmlyc3QsIHdlIGV4Y2x1ZGUgdGhlIHJvd3MgYW5kIGNvbHVtbnMgb2YgemVyb3Mgb25seS4KIiIiqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTD2SQ1NDhjYTI0NC1kZTRjLTQ3YzItYTY5ZS0wY2E3YTQ0OTAyOGaEp2NlbGxfaWTZJDU0OGNhMjQ0LWRlNGMtNDdjMi1hNjllLTBjYTdhNDQ5MDI4ZqRjb2Rl2ZpiZWdpbgoJcm93LCBjb2wgPSBmaW5kbnooc2lnbmlmaWNhbnRfcHZhbHVlcykKCWNhdGVnb3J5ID0gY2F0ZWdvcmllc1tyb3dfb2tdW3Jvd10KCWdlbm90eXBlID0gZ2Vub3R5cGVzW2NvbF9va11bY29sXQoJY29sbGVjdCh6aXAoY2F0ZWdvcnksIGdlbm90eXBlKSkKZW5kqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTC2SQ4ODRhNzI5OS04NDE4LTQ1ZTQtODJmMy02NTIwNGQ0OGU1NWKEp2NlbGxfaWTZJDg4NGE3Mjk5LTg0MTgtNDVlNC04MmYzLTY1MjA0ZDQ4ZTU1YqRjb2Rl2gVKbWQiIiIKVGhlIHNhbXBsZSBzaXplIGlzIHRvbyBsb3cgaWYgd2UgY29uc2lkZXIgdGhlIGxhcmdlIG51bWJlciBvZiBjZWxscywgYW5kIHdlIG5lZWQgYSBtb3JlIHBvd2VyZnVsIHRlc3QuCkxldCB1cyBub3cgY29tcGFyZSBlYWNoIGdlbm90eXBlIHdpdGggdGhlICJhdmVyYWdlIiBnZW5vdHlwZSwgZ3JvdXBpbmcgdGhlIGxvdy1mcmVxdWVuY3kgY2VsbHMgdG9nZXRoZXIuCgpXZSBhbHJlYWR5IGtub3cgdGhlIHBvc3QtaG9jIHRlc3RzIGZhaWwsIHRoZXJlZm9yZSB3ZSB3b24ndCBoYXZlIGNhdGVnb3J5LWxldmVsIHJlc29sdXRpb24uIEhvd2V2ZXIsIGEgc2lnbmlmaWNhbnQgZGlmZmVyZW5jZSBpcyBzdGlsbCBwb3NzaWJsZSBoZXJlIGFzIHRoZSB0ZXN0IHdpbGwgY3VtdWxhdGUgdGhlIGRpZmZlcmVuY2VzIGZvciB0aGUgZGlmZmVyZW50IGNhdGVnb3JpZXMuIFRoZSBpbmRpdmlkdWFsIGRpZmZlcmVuY2VzIHNob3VsZCBiZSBkZXRlY3RhYmxlIGluY3JlYXNpbmcgdGhlIHNhbXBsZSBzaXplLgoKIyBEaXNjbGFpbWVyCgpUaGUgZm9sbG93aW5nIGFuYWx5c2lzIGlzIGEgc2Vjb25kIGl0ZXJhdGlvbiBtb3RpdmF0ZWQgYnkgYW4gZXJyb3IgaW4gdGhlIGZpcnN0IGl0ZXJhdGlvbi4gVGhlIGhpc3Rvcnkgb2YgdGhlIHByZXNlbnQgbm90ZWJvb2sgY2FuIGJlIGZvdW5kIFtoZXJlXShodHRwczovL2dpdGxhYi5wYXN0ZXVyLmZyL2ZsYXVyZW50L3Byb2plY3QxOTQ0OS8tL2Jsb2IvbWFpbi9ub3RlYm9va3Mvc25wX2NoaXNxX3Rlc3RzLmpsKS4KClRoZSBjYXRlZ29yaWVzIHdlcmUgZ3JvdXBlZCBiYXNlZCBvbiB0aGUgb2JzZXJ2ZWQgY291bnRzLCB3aGVyZWFzIHRoZSBtaW5pbXVtLTUgY3JpdGVyaW9uIGFjdHVhbGx5IGFwcGxpZXMgdG8gdGhlIGV4cGVjdGVkIGNvdW50cy4gVGhpcyBpcyBmaXhlZCBpbiB0aGlzIHZlcnNpb24gb2YgdGhlIGFuYWx5c2lzLgoKIyBHcm91cGluZyBwcm9jZWR1cmUKCkFuIGVsYWJvcmF0ZSBncm91cGluZyBhcHByb2FjaCBjYW4gYmUgZm91bmQgaW4gW0thc3MsIDE5ODBdKGh0dHBzOi8vd3d3NC5zdGF0Lm5jc3UuZWR1L35kaWNrZXkvYW5hbHl0aWNzL2RhdGFtaW5lL1JlZmVyZW5jZSUyMFBhcGVycy9rYXNzODAucGRmKS4KClRoZSBzaW1wbGVyIGFwcHJvYWNoIGZvbGxvd2VkIGhlcmUgY29uc2lzdHMgaW4gZ3JvdXBpbmcgYWxsIHRoZSBjYXRlZ29yaWVzIHdpdGggYW4gZXhwZWN0ZWQgY291bnQgYmVsb3cgNSBpbnRvIGEgc2luZ2xlIHN5bnRoZXRpYyBjYXRlZ29yeSwgZm9yIGVhY2ggY29sdW1uIHNlcGFyYXRlbHkuIE9ic2VydmVkIGNvdW50cyBhcmUgc2ltaWxhcmx5IGdyb3VwZWQsIGJhc2VkIG9uIHRoZSBleHBlY3RlZCBjb3VudHMuCiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkw9kkYjhhZGM1NjYtNTg5My00MDJhLWEzNWQtMTFjMDY0NjBmYjYyhKdjZWxsX2lk2SRiOGFkYzU2Ni01ODkzLTQwMmEtYTM1ZC0xMWMwNjQ2MGZiNjKkY29kZdoCdm1kIiIiCkR1ZSB0byB0aGUgcHJlc2VuY2Ugb2YgemVyb3MgaW4gbW9zdCBjb2x1bW5zLCB3ZSBoYXZlIHRvIGdyb3VwIHRoZSBsb3ctZnJlcXVlbmN5IGNlbGxzIGludG8gc2luZ2xlIGNlbGxzIG9uIGEgcGVyLWNvbHVtbiBiYXNpcy4gVGhlIGluZm9ybWF0aW9uIGluIGxvdy1mcmVxdWVuY3kgY2VsbHMgaXMgYWxyZWFkeSBhY2NvdW50ZWQgZm9yIGJ5IHRoZSBvdGhlciBjZWxscy4KCldlIGNhbiBhbHNvIGluZGl2aWR1YWxseSB0ZXN0IGVhY2ggY291bnQgYG9ic2VydmVkX25gIF9lcXVhbCB0byBvciBncmVhdGVyIHRoYW4gNV8gaW4gYSBjb250aW5nZW5jeSB0YWJsZSB3aXRoOgpgYGAKKy0tLS0tLS0tLS0tLSstLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0rCnwgb2JzZXJ2ZWRfbiB8IGNvbF90b3RhbCAtIG9ic2VydmVkX24gfAorLS0tLS0tLS0tLS0tKy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSsKfCBleHBlY3RlZF9uIHwgY29sX3RvdGFsIC0gZXhwZWN0ZWRfbiB8CistLS0tLS0tLS0tLS0rLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKwpgYGAKVGhpcyBzZWNvbmQgYXBwcm9hY2ggaXMgbGVzcyBwb3dlcmZ1bCwgdGhvdWdoLgoKTGV0IHVzIGJlZ2luIHdpdGggdGhpcyBzZWNvbmQgYXBwcm9hY2g6CiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkw9kkZTNmZWJlYzctYjg0Yy00NWY5LThmNjUtNWExNThiMGFlOTMzhKdjZWxsX2lk2SRlM2ZlYmVjNy1iODRjLTQ1ZjktOGY2NS01YTE1OGIwYWU5MzOkY29kZdmnYmVnaW4KCXJvd19vayA9IHZlYyhhbnkoIT0oMCksIGNvdW50czsgZGltcz0yKSkKCWNvbF9vayA9IHZlYyhhbnkoIT0oMCksIGNvdW50czsgZGltcz0xKSkKCWNsZWFuX2NvdW50cyA9IGNvdW50c1tyb3dfb2ssIGNvbF9va10KCW5yb3dzLCBuY29scyA9IHNpemUoY2xlYW5fY291bnRzKQplbmSobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMLZJGEyNWVlY2Q2LWY1OGQtNDkzZC1hNWNmLTk0MjE4MzE5ODQ5ZISnY2VsbF9pZNkkYTI1ZWVjZDYtZjU4ZC00OTNkLWE1Y2YtOTQyMTgzMTk4NDlkpGNvZGXZbm1kIiIiCkZvciBmdXJ0aGVyIHJlZmVyZW5jZSwgd2UgYWxzbyBsb2FkIHRoZSBsYWJlbHMgb2YgdGhlIHJvd3MgKGBjYXRlZ29yaWVzYCkgYW5kIGNvbHVtbnMgKGBnZW5vdHlwZXNgKS4KIiIiqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTD2SRhNWU2MWE0OC1lMDdlLTQ5ZGMtOGM2MS0xMjI0ZDFjNDdkMTOEp2NlbGxfaWTZJGE1ZTYxYTQ4LWUwN2UtNDlkYy04YzYxLTEyMjRkMWM0N2QxM6Rjb2Rl2Sdjb3VudHMgPSBJbnQuKGRhdGFbIk5iIFNOUCJdWyJCMzpVMjUiXSmobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMLZJGMwOWI3NzFjLWFhYjEtNDBjZi1hMjczLTE0YWE2Yzg1NzUxMISnY2VsbF9pZNkkYzA5Yjc3MWMtYWFiMS00MGNmLWEyNzMtMTRhYTZjODU3NTEwpGNvZGXZRW1kIiIiCkNvcnJlY3RpbmcgZm9yIGFsbCB0aGUgY29tcGFyaXNvbnMsIG5vIGRpZmZlcmVuY2VzIHN1cnZpdmU6CiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkw9kkMTFhYzVmNmEtMGY2YS0xMWVlLTI1OTgtMTFjN2EwMDY0YjQzhKdjZWxsX2lk2SQxMWFjNWY2YS0wZjZhLTExZWUtMjU5OC0xMWM3YTAwNjRiNDOkY29kZdlFdXNpbmcgU3RhdHNCYXNlLCBIeXBvdGhlc2lzVGVzdHMsIFhMU1gsIFNwYXJzZUFycmF5cywgTXVsdGlwbGVUZXN0aW5nqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTC2SRmMjgyNWQzYy01NzdiLTRiNjEtOGM4Yy1jODY5YTllYzlmMDeEp2NlbGxfaWTZJGYyODI1ZDNjLTU3N2ItNGI2MS04YzhjLWM4NjlhOWVjOWYwN6Rjb2Rl2fVtZCIiIgpUbyB0ZXN0IHdoZXRoZXIgYSBnZW5vdHlwZSBleGhpYml0cyBhIGRpZmZlcmVudCBwYXJ0aXRpb24gaW50byBjYXRlZ29yaWVzIG9mIGdlbmVzLCBvciBlcXVpdmFsZW50bHkgd2hldGhlciBpdCBpcyBlbnJpY2hlZCBpbiBzb21lIGNhdGVnb3J5LCB3ZSBmaXJzdCBkZXJpdmUgYW4gZXhwZWN0ZWQgcGFydGl0aW9uIGF2ZXJhZ2luZyB0aGUgY2F0ZWdvcnkgZnJlcXVlbmNpZXMgYWNyb3NzIGFsbCBnZW5vdHlwZXMuCiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkw9kkNzJjZjhkNTUtYTQyMy00YzI4LWEzNzAtMzc3ZjllZjZhNzBlhKdjZWxsX2lk2SQ3MmNmOGQ1NS1hNDIzLTRjMjgtYTM3MC0zNzdmOWVmNmE3MGWkY29kZdoBDWJlZ2luCgljb2xfdG90YWwgPSBzdW0oY2xlYW5fY291bnRzOyBkaW1zPTEpCglleHBlY3RlZF9mcmVxdWVuY2llcyA9IG1lYW4oY2xlYW5fY291bnRzIC4vIGNvbF90b3RhbDsgZGltcz0yKQoJQGFzc2VydCBzdW0oZXhwZWN0ZWRfZnJlcXVlbmNpZXMpIOKJiCAxCgkjIHByaW50IHRoZSBmcmVxdWVuY2llcyB3aXRoIHRoZSBjb3JyZXNwb25kaW5nIGNhdGVnb3J5IG5hbWVzCglEaWN0KHppcChjYXRlZ29yaWVzW3Jvd19va10sIGV4cGVjdGVkX2ZyZXF1ZW5jaWVzKSkKZW5kqG1ldGFkYXRhg6lzaG93X2xvZ3PDqGRpc2FibGVkwq5za2lwX2FzX3NjcmlwdMKrY29kZV9mb2xkZWTC2SQzZGYzOTQ4NC1lMDdhLTQ4ZDgtOTBhZS0wOWRhMDA1MGIzY2WEp2NlbGxfaWTZJDNkZjM5NDg0LWUwN2EtNDhkOC05MGFlLTA5ZGEwMDUwYjNjZaRjb2Rl2gNtYmVnaW4KCW9ic2VydmVkX2NvdW50cyA9IGNsZWFuX2NvdW50cwoJIyBpbiB0aGVvcnksIHdlIGNvdWxkIGFsc28gdXNlIHJlYWwtdmFsdWVkIGNvdW50cyBpbnN0ZWFkCglleHBlY3RlZF9jb3VudHMgPSBALiByb3VuZChJbnQsIGV4cGVjdGVkX2ZyZXF1ZW5jaWVzICogY29sX3RvdGFsKQoJb2JzZXJ2ZWRfcmVtYWluZGVyID0gY29sX3RvdGFsIC4tIG9ic2VydmVkX2NvdW50cwoJZXhwZWN0ZWRfcmVtYWluZGVyID0gY29sX3RvdGFsIC4tIGV4cGVjdGVkX2NvdW50cwoKCXB2YWx1ZXMgPSBzcHplcm9zKG5yb3dzLCBuY29scykKCWZvciByb3cgaW4gMTpucm93cwoJCWZvciBjb2wgaW4gMTpuY29scwoJCQkKCQkJIyBidWlsZCB0aGUgY29udGluZ2VuY3kgdGFibGUKCQkJYSA9IG9ic2VydmVkX2NvdW50c1tyb3csIGNvbF0KCQkJYiA9IG9ic2VydmVkX3JlbWFpbmRlcltyb3csIGNvbF0KCQkJYyA9IGV4cGVjdGVkX2NvdW50c1tyb3csIGNvbF0KCQkJZCA9IGV4cGVjdGVkX3JlbWFpbmRlcltyb3csIGNvbF0KCQkJY29udGluZ2VuY3lfdGFibGUgPSBbIGEgYiA7IGMgZCBdCgkJCQoJCQkjIHBlcmZvcm0gYSDPh8KyIHRlc3Qgb2YgaG9tb2dlbmVpdHkKCQkJaWYgYWxsKD49KDUpLCBjb250aW5nZW5jeV90YWJsZSkKCQkJCXB2YWwgPSBwdmFsdWUoQ2hpc3FUZXN0KGNvbnRpbmdlbmN5X3RhYmxlKSkKCQkJCSMgbm90ZTogRmlzaGVyRXhhY3RUZXN0KGEsIGIsIGMsIGQpIGdpdmVzIHZlcnkgc2ltaWxhciByZXN1bHRzCgkJCQkjcHZhbCA9IHB2YWx1ZShGaXNoZXJFeGFjdFRlc3QoYSwgYiwgYywgZCk7IG1ldGhvZD06bWlubGlrZSkKCQkJCQoJCQkJcHZhbHVlc1tyb3csIGNvbF0gPSBwdmFsCgkJCWVuZAoJCWVuZAoJZW5kCglwdmFsdWVzCmVuZKhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkwtkkNDZjOWJlMDctM2JiNC00OTljLWE4MTktN2E4N2M3M2I2ZTQyhKdjZWxsX2lk2SQ0NmM5YmUwNy0zYmI0LTQ5OWMtYTgxOS03YTg3YzczYjZlNDKkY29kZdoBjWJlZ2luCgkjIHNlZSBodHRwczovL2dpdGh1Yi5jb20vanVsaWFuZ2VocmluZy9NdWx0aXBsZVRlc3RpbmcuamwjdHdvLXN0ZXAKCWNvcnJlY3RlZF9wdmFsdWVzID0gYWRqdXN0KHB2YWx1ZXMubnp2YWwsIEJlbmphbWluaUhvY2hiZXJnQWRhcHRpdmUoVHdvU3RlcCgpKSkKCQoJc2lnbmlmaWNhbnQgPSBjb3JyZWN0ZWRfcHZhbHVlcyAuPD0gLjA1CglzaWduaWZpY2FudF9wdmFsdWVzID0gY29weShwdmFsdWVzKQoJc2lnbmlmaWNhbnRfcHZhbHVlcy5uenZhbCAuPSAwCglzaWduaWZpY2FudF9wdmFsdWVzLm56dmFsW3NpZ25pZmljYW50XSA9IGNvcnJlY3RlZF9wdmFsdWVzW3NpZ25pZmljYW50XQoJc2lnbmlmaWNhbnRfcHZhbHVlcyA9IGRyb3B6ZXJvcyhzaWduaWZpY2FudF9wdmFsdWVzKQplbmSobWV0YWRhdGGDqXNob3dfbG9nc8OoZGlzYWJsZWTCrnNraXBfYXNfc2NyaXB0wqtjb2RlX2ZvbGRlZMLZJDEyODY2OGMzLTI4MmQtNDQ1My04NGE2LWNmMmMyOWQ3MTQwZoSnY2VsbF9pZNkkMTI4NjY4YzMtMjgyZC00NDUzLTg0YTYtY2YyYzI5ZDcxNDBmpGNvZGXZZm1kIiIiCkhhZCB3ZSBmb3VuZCBkaWZmZXJlbmNlcywgd2UgY291bGQgZ2V0IHRoZSBjb3JyZXNwb25kaW5nIGNhdGVnb3J5LWdlbm90eXBlIHBhaXJzIGFzIGZvbGxvd3M6CiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkw9kkMDFmYmYxYzktMWNlYS00NTkzLWEyYzUtMDM4NTRkZWUyNDczhKdjZWxsX2lk2SQwMWZiZjFjOS0xY2VhLTQ1OTMtYTJjNS0wMzg1NGRlZTI0NzOkY29kZdmjbWQiIiIKVGhpcyBkb2N1bWVudCBpcyBhIFBsdXRvIG5vdGVib29rIChvciBhbiBodG1sIHJlbmRlcmVkIHZlcnNpb24gb2YgaXQpIGFuZCByZXF1aXJlcyBbSnVsaWFdKGh0dHBzOi8vY29tcHV0YXRpb25hbHRoaW5raW5nLm1pdC5lZHUvU3ByaW5nMjEvaW5zdGFsbGF0aW9uLykuCiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkw9kkNWU5NGE1MTctZGI0Ni00ODY0LWI3MTctNWI0NTQzODg0ZGZmhKdjZWxsX2lk2SQ1ZTk0YTUxNy1kYjQ2LTQ4NjQtYjcxNy01YjQ1NDM4ODRkZmakY29kZdk3ZGF0YSA9IFhMU1gub3Blbnhsc3goIi4uL2RhdGEvcmF3L1NOUHNwZWNpZmlxdWVzLnhsc3giKahtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkwtkkOGRkNWQ0YjktNWEzMi00YTk1LThmMzgtN2YzZTViOThlMmQ5hKdjZWxsX2lk2SQ4ZGQ1ZDRiOS01YTMyLTRhOTUtOGYzOC03ZjNlNWI5OGUyZDmkY29kZdnlbWQiIiIKV2UgZmlyc3QgbG9hZCB0aGUgY291bnQgZGF0YS4KCk5vdGUgdGhlIG5vdGVib29rIGlzIGFzc3VtZWQgdG8gcnVuIGZyb20gYSBjaGlsZCBkaXJlY3RvcnkgKCplLmcuKiBgbm90ZWJvb2tzYCkgb2YgdGhlIHByb2plY3Qgcm9vdCwgYW5kIHRoZSBkYXRhIGZpbGVzIGFyZSBleHBlY3RlZCB0byBiZSBmb3VuZCBpbiBgZGF0YS9yYXdgLCBhZ2FpbiBmcm9tIHRoZSBwcm9qZWN0IHJvb3QuCiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkw9kkYjMxNGFkZDctYTZmNS00MmYwLWJjOWEtYmJhNzQ4NTQzZmEyhKdjZWxsX2lk2SRiMzE0YWRkNy1hNmY1LTQyZjAtYmM5YS1iYmE3NDg1NDNmYTKkY29kZdltbWQiIiIKT3V0IG9mIGN1cmlvc2l0eSwgd2l0aCBubyBjb3JyZWN0aW9uIGZvciBtdWx0aXBsZSBjb21wYXJpc29ucywgd2UgZmluZCBhIHNpbmdsZSBwLXZhbHVlIGJlbG93IDAuMDU6CiIiIqhtZXRhZGF0YYOpc2hvd19sb2dzw6hkaXNhYmxlZMKuc2tpcF9hc19zY3JpcHTCq2NvZGVfZm9sZGVkwqtub3RlYm9va19pZNkkMGRkZWI4NjgtMWI1Ni0xMWVlLTBiMTktNzFiM2EwODc4NTIxq2luX3RlbXBfZGlywqhtZXRhZGF0YYA="; window.pluto_preamble_html = undefined; </script> diff --git a/notebooks/genes_chisq_tests.jl b/notebooks/genes_chisq_tests.jl index ae8359aec1d163266e11fc591436702bc854dd8c..60ac933e0e325f57169a0d81b6bada1830689d89 100644 --- a/notebooks/genes_chisq_tests.jl +++ b/notebooks/genes_chisq_tests.jl @@ -7,12 +7,16 @@ using InteractiveUtils # â•”â•â•¡ 11ac5f6a-0f6a-11ee-2598-11c7a0064b43 using StatsBase, HypothesisTests, XLSX, SparseArrays, MultipleTesting +# â•”â•â•¡ 01fbf1c9-1cea-4593-a2c5-03854dee2473 +md""" +This document is a Pluto notebook (or an html rendered version of it) and requires [Julia](https://computationalthinking.mit.edu/Spring21/installation/). +""" + # â•”â•â•¡ 8dd5d4b9-5a32-4a95-8f38-7f3e5b98e2d9 md""" We first load the count data. -!!! - The notebook is assumed to run from a child directory (*e.g.* `notebooks`) of the project root, and the data files are expected to be found in `data/raw`, from the project root. +Note the notebook is assumed to run from a child directory (*e.g.* `notebooks`) of the project root, and the data files are expected to be found in `data/raw`, again from the project root. """ # â•”â•â•¡ 5e94a517-db46-4864-b717-5b4543884dff @@ -55,6 +59,8 @@ begin col_total = sum(clean_counts; dims=1) expected_frequencies = mean(clean_counts ./ col_total; dims=2) @assert sum(expected_frequencies) ≈ 1 + # print the frequencies with the corresponding category names + Dict(zip(categories[row_ok], expected_frequencies)) end # â•”â•â•¡ b8adc566-5893-402a-a35d-11c06460fb62 @@ -124,10 +130,10 @@ Correcting for all the comparisons, no differences survive: """ # â•”â•â•¡ 46c9be07-3bb4-499c-a819-7a87c73b6e42 -# with correction, no differences survive begin - # see https://github.com/juliangehring/MultipleTesting.jl#holm - corrected_pvalues = adjust(pvalues.nzval, Holm()) + # see https://github.com/juliangehring/MultipleTesting.jl#two-step + corrected_pvalues = adjust(pvalues.nzval, BenjaminiHochbergAdaptive(TwoStep())) + significant = corrected_pvalues .<= .05 significant_pvalues = copy(pvalues) significant_pvalues.nzval .= 0 @@ -150,62 +156,69 @@ end # â•”â•â•¡ 884a7299-8418-45e4-82f3-65204d48e55b md""" -Correcting for all comparisons is probably unfair. Frequencies are bound within each column and row (one less degree of freedom). +The sample size is too low if we consider the large number of cells, and we need a more powerful test. +Let us now compare each genotype with the "average" genotype, grouping the low-frequency cells together. + +We already know the post-hoc tests fail, therefore we won't have category-level resolution. However, a significant difference is still possible here as the test will cumulate the differences for the different categories. The individual differences should be detectable increasing the sample size. + +# Disclaimer + +The following analysis is a second iteration motivated by an error in the first iteration. The history of the present notebook can be found [here](https://gitlab.pasteur.fr/flaurent/project19449/-/blob/main/notebooks/genes_chisq_tests.jl). -Anyway, the sample size is far too low for the number of cells, and we need a more powerful test. +The categories were grouped based on the observed counts, whereas the minimum-5 criterion actually applies to the expected counts. This is fixed in this version of the analysis. -Let us now compare each genotype with the "average" genotype grouping the low-frequency cells together. We already know the post-hoc tests fail, and we won't have category-level resolution, but a significant difference may be an argument for increasing the sample size, or rethinking the categories. +In addition, from the first iteration of the analysis, we know that controlling the family-wise error rate would not allow to reject any null hypothesis. We therefore consider controlling the false discovery rate instead, as described in [Benjamini *et al.*, 2006](https://doi.org/10.1093/biomet/93.3.491). -An elaborate approach can be found in [Kass, 1980](https://www4.stat.ncsu.edu/~dickey/analytics/datamine/Reference%20Papers/kass80.pdf). +# Grouping procedure -The simpler approach followed here consists in grouping all observed counts below 5 into a single synthetic category, for each column separately. Expected counts are similarly grouped, based on the observed counts. If some expected count is below 5 (included the synthetic category), we carry on unless this count is 0. +An elaborate grouping approach can be found in [Kass, 1980](https://www4.stat.ncsu.edu/~dickey/analytics/datamine/Reference%20Papers/kass80.pdf). + +The simpler approach followed here consists in grouping all the categories with an expected count below 5 into a single synthetic category, for each column separately. Observed counts are similarly grouped, based on the expected counts. """ # â•”â•â•¡ 9342e489-a297-4c67-8324-cb41801af713 begin - per_genotype_pvalues = spzeros(ncols) + per_genotype_pvalues = Dict{String, Float64}() for col in 1:ncols - ok = observed_counts[:, col] .>= 5 + # identify cells to be grouped + ok = expected_counts[:, col] .>= 5 any(ok) || continue - observed_counts′ = observed_counts[ok, col] - if !all(ok) - synthetic_count = sum(observed_counts[(!).(ok), col]) - push!(observed_counts′, synthetic_count) - end + # group cells expected_counts′ = expected_counts[ok, col] if !all(ok) synthetic_count = sum(expected_counts[(!).(ok), col]) push!(expected_counts′, synthetic_count) end - contingency_table = hcat(observed_counts′, expected_counts′) - if any(expected_counts′ .< 5) - #continue # to get significant results... - if any(expected_counts′ .== 0) - @warn "Expected counts are too low; skipping" contingency_table - continue - else - #@warn "Expected counts are low" contingency_table - end + observed_counts′ = observed_counts[ok, col] + if !all(ok) + synthetic_count = sum(observed_counts[(!).(ok), col]) + push!(observed_counts′, synthetic_count) end + # perform the test + contingency_table = hcat(observed_counts′, expected_counts′) pval = pvalue(ChisqTest(contingency_table)) - per_genotype_pvalues[col] = pval + # record the resulting pvalue + genotype = genotypes[col_ok][col] + per_genotype_pvalues[genotype] = pval end per_genotype_pvalues end # â•”â•â•¡ 31dc58db-5a4e-47dc-bdb8-fe6e9bb47204 begin - corrected_per_genotype_pvalues = adjust(per_genotype_pvalues.nzval, Holm()) - minimum(corrected_per_genotype_pvalues) + corrected_per_genotype_pvalues = adjust( + collect(values(per_genotype_pvalues)), + BenjaminiHochbergAdaptive(TwoStep()), + ) + corrected_per_genotype_pvalues = Dict(zip( + keys(per_genotype_pvalues), + corrected_per_genotype_pvalues, + )) end # â•”â•â•¡ 6d768ec2-f9ad-4cc7-a2df-4eeb1a72cd44 md""" -We fail by a little margin. Too many columns here. - -Actually, if we had chosen to reject the columns with `any(expected_counts′ .< 5)`, we would have at least one significantly different genotype. This notebook shows the original approach, with no iterations. - -More can be done. +Genotypes G10 and G14 significantly differ from the average genotype. """ # â•”â•â•¡ 00000000-0000-0000-0000-000000000001 @@ -730,6 +743,7 @@ version = "17.4.0+0" """ # â•”â•â•¡ Cell order: +# ╟─01fbf1c9-1cea-4593-a2c5-03854dee2473 # â• â•11ac5f6a-0f6a-11ee-2598-11c7a0064b43 # ╟─8dd5d4b9-5a32-4a95-8f38-7f3e5b98e2d9 # â• â•5e94a517-db46-4864-b717-5b4543884dff diff --git a/notebooks/snp_chisq_tests.jl b/notebooks/snp_chisq_tests.jl index 593f440c2f15b3cc25a03ebbf7698c6981531b8f..dce479d3862a390abc5aea83df71b6c051c2d956 100644 --- a/notebooks/snp_chisq_tests.jl +++ b/notebooks/snp_chisq_tests.jl @@ -7,12 +7,16 @@ using InteractiveUtils # â•”â•â•¡ 11ac5f6a-0f6a-11ee-2598-11c7a0064b43 using StatsBase, HypothesisTests, XLSX, SparseArrays, MultipleTesting +# â•”â•â•¡ 01fbf1c9-1cea-4593-a2c5-03854dee2473 +md""" +This document is a Pluto notebook (or an html rendered version of it) and requires [Julia](https://computationalthinking.mit.edu/Spring21/installation/). +""" + # â•”â•â•¡ 8dd5d4b9-5a32-4a95-8f38-7f3e5b98e2d9 md""" We first load the count data. -!!! - The notebook is assumed to run from a child directory (*e.g.* `notebooks`) of the project root, and the data files are expected to be found in `data/raw`, from the project root. +Note the notebook is assumed to run from a child directory (*e.g.* `notebooks`) of the project root, and the data files are expected to be found in `data/raw`, again from the project root. """ # â•”â•â•¡ 5e94a517-db46-4864-b717-5b4543884dff @@ -55,6 +59,8 @@ begin col_total = sum(clean_counts; dims=1) expected_frequencies = mean(clean_counts ./ col_total; dims=2) @assert sum(expected_frequencies) ≈ 1 + # print the frequencies with the corresponding category names + Dict(zip(categories[row_ok], expected_frequencies)) end # â•”â•â•¡ b8adc566-5893-402a-a35d-11c06460fb62 @@ -124,10 +130,10 @@ Correcting for all the comparisons, no differences survive: """ # â•”â•â•¡ 46c9be07-3bb4-499c-a819-7a87c73b6e42 -# with correction, no differences survive begin - # see https://github.com/juliangehring/MultipleTesting.jl#holm - corrected_pvalues = adjust(pvalues.nzval, Holm()) + # see https://github.com/juliangehring/MultipleTesting.jl#two-step + corrected_pvalues = adjust(pvalues.nzval, BenjaminiHochbergAdaptive(TwoStep())) + significant = corrected_pvalues .<= .05 significant_pvalues = copy(pvalues) significant_pvalues.nzval .= 0 @@ -150,53 +156,55 @@ end # â•”â•â•¡ 884a7299-8418-45e4-82f3-65204d48e55b md""" -Correcting for all comparisons is probably unfair. Frequencies are bound within each column and row (one less degree of freedom). +The sample size is too low if we consider the large number of cells, and we need a more powerful test. +Let us now compare each genotype with the "average" genotype, grouping the low-frequency cells together. + +We already know the post-hoc tests fail, therefore we won't have category-level resolution. However, a significant difference is still possible here as the test will cumulate the differences for the different categories. The individual differences should be detectable increasing the sample size. + +# Disclaimer -Anyway, the sample size is far too low for the number of cells, and we need a more powerful test. +The following analysis is a second iteration motivated by an error in the first iteration. The history of the present notebook can be found [here](https://gitlab.pasteur.fr/flaurent/project19449/-/blob/main/notebooks/snp_chisq_tests.jl). -Let us now compare each genotype with the "average" genotype grouping the low-frequency cells together. We already know the post-hoc tests fail, and we won't have category-level resolution, but a significant difference may be an argument for increasing the sample size, or rethinking the categories. +The categories were grouped based on the observed counts, whereas the minimum-5 criterion actually applies to the expected counts. This is fixed in this version of the analysis. -An elaborate approach can be found in [Kass, 1980](https://www4.stat.ncsu.edu/~dickey/analytics/datamine/Reference%20Papers/kass80.pdf). +# Grouping procedure -The simpler approach followed here consists in grouping all observed counts below 5 into a single synthetic category, for each column separately. Expected counts are similarly grouped, based on the observed counts. If some expected count is below 5 (included the synthetic category), we carry on unless this count is 0. +An elaborate grouping approach can be found in [Kass, 1980](https://www4.stat.ncsu.edu/~dickey/analytics/datamine/Reference%20Papers/kass80.pdf). + +The simpler approach followed here consists in grouping all the categories with an expected count below 5 into a single synthetic category, for each column separately. Observed counts are similarly grouped, based on the expected counts. """ # â•”â•â•¡ 9342e489-a297-4c67-8324-cb41801af713 begin - per_genotype_pvalues = Float64[] + per_genotype_pvalues = Dict{String, Float64}() for col in 1:ncols - ok = observed_counts[:, col] .>= 5 + # identify cells to be grouped + ok = expected_counts[:, col] .>= 5 any(ok) || continue - observed_counts′ = observed_counts[ok, col] - if !all(ok) - synthetic_count = sum(observed_counts[(!).(ok), col]) - push!(observed_counts′, synthetic_count) - end + # group cells expected_counts′ = expected_counts[ok, col] if !all(ok) synthetic_count = sum(expected_counts[(!).(ok), col]) push!(expected_counts′, synthetic_count) end - contingency_table = hcat(observed_counts′, expected_counts′) - if any(expected_counts′ .< 5) - if any(expected_counts′ .== 0) - @warn "Expected counts are too low; skipping" contingency_table - continue - else - #@warn "Expected counts are low" contingency_table - end + observed_counts′ = observed_counts[ok, col] + if !all(ok) + synthetic_count = sum(observed_counts[(!).(ok), col]) + push!(observed_counts′, synthetic_count) end + # perform the test + contingency_table = hcat(observed_counts′, expected_counts′) pval = pvalue(ChisqTest(contingency_table)) - push!(per_genotype_pvalues, pval) + # record the resulting pvalue + genotype = genotypes[col_ok][col] + per_genotype_pvalues[genotype] = pval end per_genotype_pvalues end -# â•”â•â•¡ 31dc58db-5a4e-47dc-bdb8-fe6e9bb47204 +# â•”â•â•¡ 6d768ec2-f9ad-4cc7-a2df-4eeb1a72cd44 md""" -We do not bother pretty printing or correcting the p-values: there are no significant differences at all. - -We could try pairwise comparisons between genotypes now, instead of focusing on an "average" genotype as a reference. +Not any uncorrected p-value drops below 0.05. """ # â•”â•â•¡ 00000000-0000-0000-0000-000000000001 @@ -721,6 +729,7 @@ version = "17.4.0+0" """ # â•”â•â•¡ Cell order: +# ╟─01fbf1c9-1cea-4593-a2c5-03854dee2473 # â• â•11ac5f6a-0f6a-11ee-2598-11c7a0064b43 # ╟─8dd5d4b9-5a32-4a95-8f38-7f3e5b98e2d9 # â• â•5e94a517-db46-4864-b717-5b4543884dff @@ -733,7 +742,7 @@ version = "17.4.0+0" # â• â•72cf8d55-a423-4c28-a370-377f9ef6a70e # ╟─b8adc566-5893-402a-a35d-11c06460fb62 # â• â•3df39484-e07a-48d8-90ae-09da0050b3ce -# ╟─b314add7-a6f5-42f0-bc9a-bba748543fa2 +# â• â•b314add7-a6f5-42f0-bc9a-bba748543fa2 # â• â•7e383967-26de-49bd-a106-d215241ffdb1 # ╟─c09b771c-aab1-40cf-a273-14aa6c857510 # â• â•46c9be07-3bb4-499c-a819-7a87c73b6e42 @@ -741,6 +750,6 @@ version = "17.4.0+0" # â• â•548ca244-de4c-47c2-a69e-0ca7a449028f # ╟─884a7299-8418-45e4-82f3-65204d48e55b # â• â•9342e489-a297-4c67-8324-cb41801af713 -# ╟─31dc58db-5a4e-47dc-bdb8-fe6e9bb47204 +# ╟─6d768ec2-f9ad-4cc7-a2df-4eeb1a72cd44 # ╟─00000000-0000-0000-0000-000000000001 # ╟─00000000-0000-0000-0000-000000000002