From 4482c4f6c2517610f845ac0eafcb8b04e6c59cb1 Mon Sep 17 00:00:00 2001 From: Andrew Jackson Date: Thu, 22 Apr 2021 11:50:19 +0100 Subject: [PATCH] added credible intervals for bayesian overlap --- .../siber-comparing-populations.Rmd | 16 + .../siber-comparing-populations.nb.html | 1809 ++--------------- aj-content/practicals/source-aggregation.Rmd | 8 +- .../practicals/source-aggregation.nb.html | 1743 +--------------- aj-content/siar-dos-and-donts.Rmd | 1 + 5 files changed, 289 insertions(+), 3288 deletions(-) diff --git a/aj-content/practicals/siber-comparing-populations.Rmd b/aj-content/practicals/siber-comparing-populations.Rmd index 92bfbbe..154b97b 100644 --- a/aj-content/practicals/siber-comparing-populations.Rmd +++ b/aj-content/practicals/siber-comparing-populations.Rmd @@ -267,7 +267,23 @@ bayes.overlap.G2.G3 <- bayesianOverlap("1.3", "1.4", ellipses.posterior, n = 360) print(bayes.overlap.G2.G3) + +``` + +And summarise the credible intervals of the Bayesian overlap output. Note that this code does not work well on the small number of posterior draws we are using for this basic example - for one it returns negative values which is not possible, but is arising as the smoother has not got enough information to stay close to or within the positive number range. + +```{r} +# and we can calculate the corresponding credible intervals using +# our code from above again +# call to hdrcde:hdr using lapply() +overlap.credibles <- lapply( + as.data.frame(bayes.overlap.G2.G3), + function(x,...){tmp<-hdrcde::hdr(x)$hdr}, + prob = cr.p) + +print(overlap.credibles) ``` + diff --git a/aj-content/practicals/siber-comparing-populations.nb.html b/aj-content/practicals/siber-comparing-populations.nb.html index e5ad09c..769c25f 100644 --- a/aj-content/practicals/siber-comparing-populations.nb.html +++ b/aj-content/practicals/siber-comparing-populations.nb.html @@ -14,1549 +14,40 @@ Comparing populations in isotope-space - + + - - - - - - - - - - + + + + + + + + + + + - + code{white-space: pre-wrap;} + span.smallcaps{font-variant: small-caps;} + span.underline{text-decoration: underline;} + div.column{display: inline-block; vertical-align: top; width: 50%;} + div.hanging-indent{margin-left: 1.5em; text-indent: -1.5em;} + ul.task-list{list-style: none;} + + + + + + +
NA
+ + + +

And summarise the credible intervals of the Bayesian overlap output. Note that this code does not work well on the small number of posterior draws we are using for this basic example - for one it returns negative values which is not possible, but is arising as the smoother has not got enough information to stay close to or within the positive number range.

+ + + +
# and we can calculate the corresponding credible intervals using
+# our code from above again
+# call to hdrcde:hdr using lapply()
+overlap.credibles <- lapply(
+  as.data.frame(bayes.overlap.G2.G3), 
+  function(x,...){tmp<-hdrcde::hdr(x)$hdr},
+  prob = cr.p)
+
+print(overlap.credibles)
+ +
$area1
+         [,1]     [,2]
+99%  79.16268 311.1822
+95% 106.50917 268.3878
+50% 164.79977 205.5054
+
+$area2
+        [,1]     [,2]
+99% 56.25541 124.6480
+95% 57.20355 123.1461
+50% 76.40570  96.1009
+
+$overlap
+         [,1]     [,2]
+99% -5.322731 50.81477
+95% -1.382026 46.61919
+50% 11.919114 32.73379
+ -
LS0tCnRpdGxlOiAiQ29tcGFyaW5nIHBvcHVsYXRpb25zIGluIGlzb3RvcGUtc3BhY2UiCmF1dGhvcjogIkFuZHJldyBMIEphY2tzb24iCmRhdGU6ICJgciBmb3JtYXQoU3lzLnRpbWUoKSwgJyVkICVCLCAlWScpYCIKb3V0cHV0OiBodG1sX25vdGVib29rCi0tLQoKYGBge3IsIGVjaG89RkFMU0UsIG1lc3NhZ2UgPSBGQUxTRSwgZmlnLndpZHRoID0gNywgZmlnLmhlaWdodCA9IDd9CgpsaWJyYXJ5KFNJQkVSLCBxdWlldGx5ID0gVFJVRSwKICAgICAgICB2ZXJib3NlID0gRkFMU0UsCiAgICAgICAgbG9naWNhbC5yZXR1cm4gPSBGQUxTRSkKCmxpYnJhcnkodmlyaWRpcykKcGFsZXR0ZSh2aXJpZGlzKDQpKQoKIyByZWFkIGluIHRoZSBkYXRhCm15ZGF0YSA8LSByZWFkLmNzdigiLi4vZGF0YS9leGFtcGxlX2xheW1hbl9kYXRhX2FsbC5jc3YiLAogICAgICAgICAgICAgICAgICAgaGVhZGVyPVRSVUUpCgojIGNyZWF0ZSB0aGUgc2liZXIgb2JqZWN0CnNpYmVyLmV4YW1wbGUgPC0gY3JlYXRlU2liZXJPYmplY3QobXlkYXRhKQoKIyBDcmVhdGUgbGlzdHMgb2YgcGxvdHRpbmcgYXJndW1lbnRzIHRvIGJlIHBhc3NlZCBvbndhcmRzIHRvIGVhY2ggCiMgb2YgdGhlIHRocmVlIHBsb3R0aW5nIGZ1bmN0aW9ucy4KY29tbXVuaXR5Lmh1bGxzLmFyZ3MgPC0gbGlzdChjb2wgPSAxLCBsdHkgPSAxLCBsd2QgPSAxKQpncm91cC5lbGxpcHNlcy5hcmdzICA8LSBsaXN0KG4gPSAxMDAsIHAuaW50ZXJ2YWwgPSAwLjk1LCBsdHkgPSAxLCBsd2QgPSAyKQpncm91cC5odWxsLmFyZ3MgICAgICA8LSBsaXN0KGx0eSA9IDIsIGNvbCA9ICJncmV5MjAiKQoKIyBwbG90IHRoZSByYXcgZGF0YQpwYXIobWZyb3c9YygxLDEpKQpwbG90U2liZXJPYmplY3Qoc2liZXIuZXhhbXBsZSwKICAgICAgICAgICAgICAgICAgYXgucGFkID0gMiwgCiAgICAgICAgICAgICAgICAgIGh1bGxzID0gRkFMU0UsIGNvbW11bml0eS5odWxscy5hcmdzLCAKICAgICAgICAgICAgICAgICAgZWxsaXBzZXMgPSBGQUxTRSwgZ3JvdXAuZWxsaXBzZXMuYXJncywKICAgICAgICAgICAgICAgICAgZ3JvdXAuaHVsbHMgPSBGQUxTRSwgZ3JvdXAuaHVsbC5hcmdzLAogICAgICAgICAgICAgICAgICBidHkgPSAiTCIsCiAgICAgICAgICAgICAgICAgIGlzby5vcmRlciA9IGMoMSwyKSwKICAgICAgICAgICAgICAgICAgeGxhYiA9IGV4cHJlc3Npb24oe2RlbHRhfV4xMypDfidcdTIwMzAnKSwKICAgICAgICAgICAgICAgICAgeWxhYiA9IGV4cHJlc3Npb24oe2RlbHRhfV4xNSpOfidcdTIwMzAnKQogICAgICAgICAgICAgICAgICApCgpgYGAKCkluIHRoaXMgZmlndXJlLCB3ZSBoYXZlIDQgcG9wdWxhdGlvbnMgKG9yIG1vcmUgZ2VuZXJpY2FsbHk6IGdyb3Vwcykgb2YgaW5kaXZ1YWxzLiBXZSBtaWdodCB3YW50IHRvIG1ha2Ugc29tZSBjb21wYXJpc29ucyBvZiB0aGUgaXNvdG9waWMgKGFuZCBoZW5jZSBlY29sb2dpY2FsKSBuaWNoZXMgb2NjdXBpZWQgYnkgdGhlc2UgaW5kaXZpZHVhbHMuIFRoZSB0d28gbW9zdCBvYnZpb3VzIHdheXMgdG8gY29tcGFyZSB0d28gb2YgdGhlc2UgcG9wdWxhdGlvbnMsIGlzIHRvIGFzayB3aGV0aGVyIHRoZWlyIG5pY2hlcyBhcmUgbG9jYXRlZCBpbiB0aGUgc2FtZSBwbGFjZSwgYW5kIGlmIHRoZXkgYXJlIHRoZSBzYW1lIHNpemUuIFRoZXJlYWZ0ZXIsIHdlIG1heSBiZSBpbnRlcmVzdGVkIGluIGFza2luZyB0byB3aGF0IGV4dGVudCBkbyB0aGVpciBuaWNoZXMgb3ZlcmxhcC4KCldlIGNhbiB2aXN1YWxpc2UgdGhpcyBieSBhZGRpbmcgYm90aCBlbGxpcHNlcywgYW5kIGNvbnZleCBodWxscyB0byB0aGUgZGF0YS4gSW4gdGhpcyBjYXNlLCB3ZSBhZGQgc3RhbmRhcmQgZWxsaXBzZXMsIHdoaWNoIGFyZSB0byBiaXZhcmlhdGUgZGF0YSBhcyBzdGFuZGFyZCBkZXZpYXRpb25zIGFyZSB0byB1bml2YXJpYXRlIGRhdGEuIEEgc3RhbmRhcmQgZWxsaXBzZSBjb250YWlucyBhcHByb3hpbWF0ZWx5IDQwJSBvZiB0aGUgZGF0YSwgYWx0aG91Z2ggdGhleSBjYW4gYmUgcmVzY2FsZWQgdG8gY29udGFpbiBhbnkgcHJvcG9yaXRpb24gb2YgdGhlIGRhdGEgd2Ugd2lzaCBpZiB3ZSBhY2NlcHQgdGhlIGFzc3VtcHRpb24gdGhhdCB0aGV5IG11bHRpdmFyaWF0ZSBub3JtYWwgZGlzdHJpYnV0ZWQuIE93aW5nIHRvIHRoaXMgcHJvcG9ydGlvbmFsIHJlcHJlc2VudGF0aW9uIG9mIHRoZSBkYXRhLCB0aGUgZWxsaXBzZSBfc2hvdWxkXyBiZSBpbnNlbnNpdGl2ZSB0byBzYW1wbGUgc2l6ZSwgYW5kIF9zaG91bGRfIGFsd2F5cyBjb250YWluIDQwJSBvZiB0aGUgZGF0YS4gSG93ZXZlciwgYXMgd2FzIGRlbW9uc3RyYXRlZCBpbiB0aGUgU0lCRVIgcGFwZXIgW0phY2tzb24gZXQgYWwgMjAxMF0oaHR0cHM6Ly9zY2hvbGFyLmdvb2dsZS5jb20vY2l0YXRpb25zP3ZpZXdfb3A9dmlld19jaXRhdGlvbiZobD1lbiZ1c2VyPUUwc0I3ZlVBQUFBSiZjaXRhdGlvbl9mb3Jfdmlldz1FMHNCN2ZVQUFBQUo6X0Z4R29GeXpwNVFDKSwgdGhlIGJhc2ljIFN0YW5kYXJkIEVsbGlwc2UgQXJlYSAoU0VBKSBzaG93cyBiaWFzIGF0IHNtYWxsIHNhbXBsZSBzaXplcywgd2hpY2ggY2FuIGJlIGNvcnJlY3RlZCB0byBjYWxjdWxhdGUgU0VBYy4KCkluIGNvbnRyYXN0LCB0aGUgY29udmV4IGh1bGwgaXMgYSBwb2x5Z29uIHRoYXQgaXMgZHJhd24gYXJvdW5kIHRoZSBvdXRlcm1vc3QgcG9pbnRzIGluIHRoZSBjbG91ZCBvZiBkYXRhIHN1Y2ggdGhhdCBhbGwgb3RoZXIgcG9pbnRzIGxpZSB3aXRoaW4gdGhlIG91dGxpbmUuIElmIHdlIHdlcmUgdG8gZ28gb3V0IGFuZCBjb2xsZWN0IG1vcmUgc2FtcGxlcywgdGhlbiB0aGlzIGh1bGwgY2FuIG9ubHkgZ3JvdyBpbiBzaXplIGFuZCBub3QgZ2V0IHNtYWxsZXIuIFRoZSByZXN1bHQgb2YgdGhpcyBpcyB0aGF0IHNtYWxsZXIgc2FtcGxlIHNpemVzIHdpbGwgcmVzdWx0IGluIHNtYWxsZXIgY29udmV4IGh1bGxzLiBEZXNwaXRlIHRoaXMgc3RhdGlzdGljYWwgcHJvYmxlbSwgdGhlIGNvbnZleCBodWxsIHJlbWFpbnMgYSB1c2VmdWwgd2F5IHRvIGhlbHAgdXMgdmlzdWFsaXNlIGJpdmFyaWF0ZSBkYXRhIHN1Y2ggYXMgY2FyYm9uLW5pdHJvZ2VuIHN0YWJsZSBpc290b3BlIHZhbHVlcy4KCldlIGNhbiB0aGVuIGdvIGJhY2sgdG8gb3VyIGNvbW11bml0eSBjb21wcmlzaW5nIDQgcG9wdWxhdGlvbnMsIGFuZCBhZGQgc3RhbmRhcmQgZWxsaXBzZXMgYW5kIGNvbnZleCBodWxscyB0byBlYWNoIGdyb3VwLiBUaGUgbmV3IGNvZGUgaW4gU0lCRVIgY3JlYXRlcyBhIHNwZWNpYWwgb2JqZWN0IHRoYXQgY29udGFpbnMgdGhlIG9yaWdpbmFsIGRhdGEsIHRoZSByZXNjYWxlZCBhbmQgei1zY29yZWQgZGF0YSwgYWxvbmcgd2l0aCB2YXJpb3VzIHN1bW1hcnkgc3RhdGlzdGljcyB0byBhaWQgd2l0aCBwbG90dGluZyBhbmQgbW9kZWwgZml0dGluZy4gTW9zdCBvZiB0aGlzIGhhcHBlbnMgaW4gdGhlIGJhY2tncm91bmQsIHNvIHlvdSBkb250IG5lZWQgdG8gd29ycnkgYWJvdXQgdGhlIGRldGFpbHMgb2YgdGhpcyBvYmplY3QgdW5sZXNzIHlvdSB3YW50IHRvIGRlbHZlIGRlZXBlci4KCgpBbmQgbm93IHRoZSBmdWxsIGNvZGUuLi4KCmBgYHtyIGltcG9ydC1kYXRhLCBmaWcud2lkdGggPSA2LCBmaWcuaGVpZ2h0ID0gNn0KCnJtKGxpc3QgPSBscygpKSAjIGNsZWFyIHRoZSBtZW1vcnkgb2Ygb2JqZWN0cwoKIyBsb2FkIHRoZSBzaWFyIHBhY2thZ2Ugb2YgZnVuY3Rpb25zCiMgbGlicmFyeShTSUJFUikKCiMgcmVhZCBpbiB0aGUgZGF0YQpteWRhdGEgPC0gcmVhZC5jc3YoIi4uL2RhdGEvZXhhbXBsZV9sYXltYW5fZGF0YV9hbGwuY3N2IiwKICAgICAgICAgICAgICAgICAgIGhlYWRlcj1UUlVFKQoKIyBjcmVhdGUgdGhlIHNpYmVyIG9iamVjdApzaWJlci5leGFtcGxlIDwtIGNyZWF0ZVNpYmVyT2JqZWN0KG15ZGF0YSkKCiMgQ3JlYXRlIGxpc3RzIG9mIHBsb3R0aW5nIGFyZ3VtZW50cyB0byBiZSBwYXNzZWQgb253YXJkcyB0byBlYWNoIAojIG9mIHRoZSB0aHJlZSBwbG90dGluZyBmdW5jdGlvbnMuCmNvbW11bml0eS5odWxscy5hcmdzIDwtIGxpc3QoY29sID0gMSwgbHR5ID0gMSwgbHdkID0gMSkKZ3JvdXAuZWxsaXBzZXMuYXJncyAgPC0gbGlzdChuID0gMTAwLCBwLmludGVydmFsID0gMC45NSwgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbHR5ID0gMSwgbHdkID0gMikKZ3JvdXAuaHVsbC5hcmdzICAgICAgPC0gbGlzdChsdHkgPSAyLCBjb2wgPSAiZ3JleTIwIikKCgojIGVsbGlwc2VzIGFuZCBncm91cC5odWxscyBhcmUgc2V0IHRvIFRSVUUgb3IgVCBmb3Igc2hvcnQgdG8gZm9yY2UKIyB0aGVpciBwbG90dGluZy4gCnBhcihtZnJvdz1jKDEsMSkpCnBsb3RTaWJlck9iamVjdChzaWJlci5leGFtcGxlLAogICAgICAgICAgICAgICAgICBheC5wYWQgPSAyLCAKICAgICAgICAgICAgICAgICAgaHVsbHMgPSBGQUxTRSwgY29tbXVuaXR5Lmh1bGxzLmFyZ3MsIAogICAgICAgICAgICAgICAgICBlbGxpcHNlcyA9IFRSVUUsIGdyb3VwLmVsbGlwc2VzLmFyZ3MsCiAgICAgICAgICAgICAgICAgIGdyb3VwLmh1bGxzID0gVFJVRSwgZ3JvdXAuaHVsbC5hcmdzLAogICAgICAgICAgICAgICAgICBidHkgPSAiTCIsCiAgICAgICAgICAgICAgICAgIGlzby5vcmRlciA9IGMoMSwyKSwKICAgICAgICAgICAgICAgICAgeGxhYiA9IGV4cHJlc3Npb24oe2RlbHRhfV4xMypDfidcdTIwMzAnKSwKICAgICAgICAgICAgICAgICAgeWxhYiA9IGV4cHJlc3Npb24oe2RlbHRhfV4xNSpOfidcdTIwMzAnKQogICAgICAgICAgICAgICAgICApCgojIFlvdSBjYW4gYWRkIG1vcmUgZWxsaXBzZXMgYnkgZGlyZWN0bHkgY2FsbGluZyBwbG90Lmdyb3VwLmVsbGlwc2VzKCkKIyBBZGQgYW4gYWRkaXRpb25hbCBwLmludGVydmFsICUgcHJlZGljdGlvbiBlbGxpbHBzZQpwbG90R3JvdXBFbGxpcHNlcyhzaWJlci5leGFtcGxlLCBuID0gMTAwLCBwLmludGVydmFsID0gMC41MCwKICAgICAgICAgICAgICAgICAgICBsdHkgPSAxLCBsd2QgPSAyKQoKIyBvciB5b3UgY2FuIGFkZCB0aGUgWFglIGNvbmZpZGVuY2UgaW50ZXJ2YWwgYXJvdW5kIHRoZSBiaXZhcmlhdGUgbWVhbnMKIyBieSBzcGVjaWZ5aW5nIGNpLm1lYW4gPSBUIGFsb25nIHdpdGggd2hhdGV2ZXIgcC5pbnRlcnZhbCB5b3Ugd2FudC4KcGxvdEdyb3VwRWxsaXBzZXMoc2liZXIuZXhhbXBsZSwgbiA9IDEwMCwgcC5pbnRlcnZhbCA9IDAuOTUsCiAgICAgICAgICAgICAgICAgIGNpLm1lYW4gPSBUUlVFLCBsdHkgPSAxLCBsd2QgPSAyKQoKCiMgQ2FsY3VsYXRlIHN1bWFtcnkgc3RhdGlzdGljcyBmb3IgZWFjaCBncm91cDogVEEsIFNFQSBhbmQgU0VBYwpncm91cC5NTCA8LSBncm91cE1ldHJpY3NNTChzaWJlci5leGFtcGxlKQpwcmludChncm91cC5NTCkKCiMgYWRkIGEgbGVnZW5kCmxlZ2VuZCgidG9wcmlnaHQiLCBjb2xuYW1lcyhncm91cC5NTCksIAogICAgICAgcGNoID0gYygxLDEsMSwxLDIsMiwyLDIpLCBjb2wgPSBjKDE6NCwgMTo0KSwgbHR5ID0gMSkKCmBgYAoKKioqCgojIyBVc2luZyBCYXllc2lhbiBJbmZlcmVuY2UgdG8gY2FsY3VsYXRlIHVuY2VydGFpbnR5IGFyb3VuZCBlbGxpcHNlcwpTbyBmYXIgdGhlc2Ugc3RpbGwganVzdCBwb2ludC1tZXRyaWNzIHRoYXQgZGVzY3JpYmUgdGhlIHdpZHRoIG9mIHRoZSBpc290b3BpYyBuaWNoZS4gVGhhdCBpcywgdGhleSBhcmUgc2luZ2xlIG51bWJlcnMgZm9yIGVhY2ggZ3JvdXAsIHdoaWNoIG1lYW5zIHRoYXQgd2UgY2FuJ3QgY29tcGFyZSBvbmUgZ3JvdXAgdG8gYW5vdGhlciBpbiBhIHN0YXRpc2ljYWwgc2Vuc2UgYXMgd2UgbGFjayBhIG1lYXN1cmUgb2YgdGhlIHVuY2VydGFpbnR5IGFyb3VuZCBlYWNoIGVzdGltYXRlLiBUaGlzIGlzIHdoZXJlIHdlIGNhbiB1c2UgQmF5ZXNpYW4gSW5mZXJlbmNlIHRvIHF1YW50aWZ5IHRoZSBlcnJvciBhc3NvY2lhdGVkIHdpdGggZml0dGluZyB0aGVzZSBlbGxpcHNlcyB0byBlYWNoIGdyb3VwLCB0aGF0IGFyaXNlcyBmcm9tIGJvdGggdGhlIG51bWJlciBvZiBzYW1wbGVzIHdlIGhhdmUsIGFuZCBhbHNvIHRoZWlyIGRpc3RyaWJ1dGlvbi4KCkVzc2VudGlhbGx5LCB3aGF0IHRoZSBNQ01DIGFsZ29yaXRobSBkb2VzIGlzIGdlbmVyYXRlIGEgZGlzdHJpYnV0aW9uIG9mIGNvdmFyaWFuY2UgbWF0cmljZXMgdGhhdCB0byBhIGdyZWF0ZXIgb3IgbGVzc2VyIGV4dGVudCAoaW4gdGVybXMgb2YgbGlrZWxpaG9vZCkgZGVzY3JpYmUgdGhlIG9ic2VydmVkIGRhdGEuIEl0IGRvZXMgc28sIGFzIGlzIHRoZSBnZW5lcmFsIGNhc2UgaW4gQmF5ZXNpYW4gSW5mZXJlbmNlLCBieSBjb21iaW5nIHRoZSBwcmlvciBwcm9iYWJpbGl0eSB3aXRoIHRoZSBsaWtlbGlob29kIG9mIHRoZSBkYXRhIGZvciBhIGdpdmVuIGNvdmFyaWFuY2UgbWF0cml4LgoKU0lCRVIgdXNlcyB0aGUgamFncyBwYWNrYWdlIHRvIGZpdCB0aGUgQmF5ZXNpYW4gbW9kZWwgYW5kIHNvIHdlIG5lZWQgdG8gc3BlY2lmeSB0aGUgcGFyYW1ldGVycyBvZiB0aGUgc2ltdWxhdGlvbiBydW4sIGluY2x1ZGluZzogcnVuIGxlbmd0aCwgYnVybi1pbiBwZXJpb2QsIG51bWJlciBvZiBjaGFpbnMgZXRjLi4uCgpgYGB7ciBmaXQtYmF5ZXN9CgojIG9wdGlvbnMgZm9yIHJ1bm5pbmcgamFncwpwYXJtcyA8LSBsaXN0KCkKcGFybXMkbi5pdGVyIDwtIDIgKiAxMF40ICAgIyBudW1iZXIgb2YgaXRlcmF0aW9ucyB0byBydW4gdGhlIG1vZGVsIGZvcgpwYXJtcyRuLmJ1cm5pbiA8LSAxICogMTBeMyAjIGRpc2NhcmQgdGhlIGZpcnN0IHNldCBvZiB2YWx1ZXMKcGFybXMkbi50aGluIDwtIDEwICAgICAjIHRoaW4gdGhlIHBvc3RlcmlvciBieSB0aGlzIG1hbnkKcGFybXMkbi5jaGFpbnMgPC0gMiAgICAgICAgIyBydW4gdGhpcyBtYW55IGNoYWlucwoKIyBkZWZpbmUgdGhlIHByaW9ycwpwcmlvcnMgPC0gbGlzdCgpCnByaW9ycyRSIDwtIDEgKiBkaWFnKDIpCnByaW9ycyRrIDwtIDIKcHJpb3JzJHRhdS5tdSA8LSAxLjBFLTMKCiMgZml0IHRoZSBlbGxpcHNlcyB3aGljaCB1c2VzIGFuIEludmVyc2UgV2lzaGFydCBwcmlvcgojIG9uIHRoZSBjb3ZhcmlhbmNlIG1hdHJpeCBTaWdtYSwgYW5kIGEgdmFndWUgbm9ybWFsIHByaW9yIG9uIHRoZSAKIyBtZWFucy4gRml0dGluZyBpcyB2aWEgdGhlIEpBR1MgbWV0aG9kLgplbGxpcHNlcy5wb3N0ZXJpb3IgPC0gc2liZXJNVk4oc2liZXIuZXhhbXBsZSwgcGFybXMsIHByaW9ycykKCmBgYAoKV2hhdCB3ZSBlbmQgdXAgd2l0aCBpcyBhIHJhbmdlIG9mIGVsbGlwc2VzIHRoYXQgY291bGQgZXhwbGFpbiB0aGUgZGF0YSwgd2l0aCBtb3JlIG9mIHRoZW0gY2x1c3RlcmVkIGFyb3VuZCB0aGUgbW9zdCBsaWtlbHkgc29sdXRpb24uIEhvd2V2ZXIsIG9uZSBjYW5ub3Qgc2ltcGx5IHRha2UgYW4gYXZlcmFnZSBhY3Jvc3MgdGhlc2UgY292YXJpYW5jZSBtYXRyaWNlcywgYXMgdGhlcmUgYXJlIHN0cmljdCBtYXRoZW1hdGljYWwgcHJvcGVydGllcyB0aGF0IG11c3QgYmUgbWFpbnRhaW5lZC4gVGhlIHJlc3VsdCBvZiB0aGlzIGlzIHRoYXQgaXQgaXMgbm90IHBvc3NpYmxlIHRvIHBsb3QgYSBtZWFuLCBtZWRpYW4gb3IgbW9kYWwgQmF5ZXNpYW4gU3RhbmRhcmQgRWxsaXBzZTsgaW5zdGVhZCB3ZSBtdXN0IGNhbGN1bGF0ZSBlYWNoIG9uZSBvZiB0aGUgZWxsaXBzZSdzIGFyZWEsIGFuZCB0aGVuIHByZXNlbnQgc3VtbWFyeSBzdGF0aXN0aWNzIG9mIHRoaXMgZGVyaXZlZCBtZWFzdXJlbWVudC4gU0lCRVIgY29udGFpbnMgYSBmdW5jdGlvbiB0aGF0IHdpbGwgYXV0b21hdGljYWxseSBsb29wIG92ZXIgYWxsIHRoZSBncm91cHMgYW5kIGRvIHRoaXMuCgpUaGUgcGxvdHMgYmVsb3cgcmVwcmVzZW50IHRoZSBwb3N0ZXJpb3IgZGlzdHJpYnV0aW9uIG9mIHRoZSBTRUFfQiBmaXR0ZWQgdG8gZWFjaCBvZiB0aGUgNCBncm91cHMgaW4gb3VyIGRhdGFzZXQuCgpgYGB7ciBwbG90LWRhdGEsIGZpZy53aWR0aCA9IDEwLCBmaWcuaGVpZ2h0ID0gNn0KIyAKIyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUGxvdCBvdXQgc29tZSBvZiB0aGUgZGF0YSBhbmQgcmVzdWx0cwojIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCiMgVGhlIHBvc3RlcmlvciBlc3RpbWF0ZXMgb2YgdGhlIGVsbGlwc2VzIGZvciBlYWNoIGdyb3VwIGNhbiBiZSB1c2VkIHRvCiMgY2FsY3VsYXRlIHRoZSBTRUEuQiBmb3IgZWFjaCBncm91cC4KU0VBLkIgPC0gc2liZXJFbGxpcHNlcyhlbGxpcHNlcy5wb3N0ZXJpb3IpCgpzaWJlckRlbnNpdHlQbG90KFNFQS5CLCB4dGlja2xhYmVscyA9IGNvbG5hbWVzKGdyb3VwLk1MKSwgCiAgICAgICAgICAgICAgICB4bGFiID0gYygiQ29tbXVuaXR5IHwgR3JvdXAiKSwKICAgICAgICAgICAgICAgIHlsYWIgPSBleHByZXNzaW9uKCJTdGFuZGFyZCBFbGxpcHNlIEFyZWEgIiAoJ1x1MjAzMCcgXjIpICksCiAgICAgICAgICAgICAgICBidHkgPSAiTCIsCiAgICAgICAgICAgICAgICBsYXMgPSAxLAogICAgICAgICAgICAgICAgbWFpbiA9ICJTSUJFUiBlbGxpcHNlcyBvbiBlYWNoIGdyb3VwIgogICAgICAgICAgICAgICAgKQoKIyBBZGQgcmVkIHgncyBmb3IgdGhlIE1MIGVzdGltYXRlZCBTRUEtYwpwb2ludHMoMTpuY29sKFNFQS5CKSwgZ3JvdXAuTUxbMyxdLCBjb2w9InJlZCIsIHBjaCA9ICJ4IiwgbHdkID0gMikKCiMgQ2FsY3VsYXRlIHNvbWUgY3JlZGlibGUgaW50ZXJ2YWxzIApjci5wIDwtIGMoMC45NSwgMC45OSkgIyB2ZWN0b3Igb2YgcXVhbnRpbGVzCgojIGNhbGwgdG8gaGRyY2RlOmhkciB1c2luZyBsYXBwbHkoKQpTRUEuQi5jcmVkaWJsZXMgPC0gbGFwcGx5KAogIGFzLmRhdGEuZnJhbWUoU0VBLkIpLCAKICBmdW5jdGlvbih4LC4uLil7dG1wPC1oZHJjZGU6Omhkcih4KSRoZHJ9LAogIHByb2IgPSBjci5wKQoKcHJpbnQoU0VBLkIuY3JlZGlibGVzKQoKIyBkbyBzaW1pbGFyIHRvIGdldCB0aGUgbW9kZXMsIHRha2luZyBjYXJlIHRvIHBpY2sgdXAgbXVsdGltb2RhbCBwb3N0ZXJpb3IKIyBkaXN0cmlidXRpb25zIGlmIHByZXNlbnQKU0VBLkIubW9kZXMgPC0gbGFwcGx5KAogIGFzLmRhdGEuZnJhbWUoU0VBLkIpLCAKICBmdW5jdGlvbih4LC4uLil7dG1wPC1oZHJjZGU6Omhkcih4KSRtb2RlfSwKICBwcm9iID0gY3IucCwgYWxsLm1vZGVzPVQpCgpwcmludChTRUEuQi5tb2RlcykKYGBgCgoqKioKCiMjIENvbXBhcmluZyB0aGUgcG9zdGVyaW9yIGRpc3RyaWJ1dGlvbnMKCkluIG9yZGVyIHRvIHRlc3Qgd2hldGhlciBvbmUgZ3JvdXAncyBlbGxpcHNlIGlzIHNtYWxsZXIgb3IgbGFyZ2VyIHRoYW4gYW5vdGhlciwgd2UgY2FuIHNpbXBseSBjYWxjdWxhdGUgdGhlIHByb2JhYmlsaXR5IHRoYXQgaXRzIHBvc3RlcmlvciBkaXN0cmlidXRpb24gaXMgc21hbGxlciAob3IgbGFyZ2VyKS4gVGhpcyBpcyBhY2hlaXZlZCBieSBjb21wYXJpbmcgZWFjaCBwYWlyIG9mIHBvc3RlcmlvciBkcmF3cyBmb3IgYm90aCBncm91cHMsIGFuZCBkdGVybWluaW5nIHdoaWNoIGlzIHNtYWxsZXIgaW4gbWFnbml0dWRlLiBXZSB0aGVuIGZpbmQgdGhlIHByb3BvcnRpb24gb2YgZHJhd3MgdGhhdCBhcmUgc21hbGxlciwgYW5kIHRoaXMgaXMgYSBkaXJlY3QgcHJveHkgZm9yIHRoZSBwcm9iYWJpbGl0eSB0aGF0IG9uZSBncm91cCdzIHBvc3RlcmlvciBkaXN0cmlidXRpb24gKG9mIGVsbGlwc2Ugc2l6ZSBpbiB0aGlzIGNhc2UpIGlzIHNtYWxsZXIgdGhhbiB0aGUgb3RoZXIuCgoKSGVyZSwgd2UgZmlyc3QgY2FsY3VsYXRlIHRoZSBwcm9wb3J0aW9uLCBhbmQgaGVuY2UgcHJvYmFiaWxpdHksIG9mIHRoZSBTRUEuQiBmb3IgZ3JvdXAgMSBiZWluZyBzbWFsbGVyIHRoYW4gdGhlIFNFQS5CIGZvciBncm91cCAyLgoKYGBge3IgcHJvYi1kaWZmLWcxMn0KUGcxLmx0LmcyIDwtIHN1bSggU0VBLkJbLDFdIDwgU0VBLkJbLDJdICkgLyBucm93KFNFQS5CKQpwcmludChQZzEubHQuZzIpCmBgYAoKU28sIGluIHRoaXMgY2FzZSwgYWxsIG9mIHRoZSBlc3RpbWF0ZXMgZm9yIGdyb3VwcyAxJ3MgZWxsaXBzZSBhcmUgc21hbGxlciB0aGFuIGZvciBncm91cCAyOyBhbHRob3VnaCB3ZSBjb3VsZCBwcm9iYWJseSBndWVzcyBhdCB0aGlzIGdpdmVuIHRoYXQgdGhlcmUgYXBwZWFycyB0byBiZSBubyBvdmVybGFwIGJldHdlZW4gdGhlbiA5NSUgY3JlZGlibGUgaW50ZXJ2YWxzIG9mIHRoZSB0d28gZ3JvdXBzIChzZWUgdGhlIGZpZ3VyZSBhYm92ZSkuCgpUaGVuIHdlIGNhbiBkbyBleGFjdGx5IHRoZSBzYW1lIGZvciBncm91cHMgMSBhbmQgMy4KCmBgYHtyIHByb2ItZGlmZi1nMTN9ClBnMS5sdC5nMyA8LSBzdW0oIFNFQS5CWywxXSA8IFNFQS5CWywzXSApIC8gbnJvdyhTRUEuQikKcHJpbnQoUGcxLmx0LmczICkKYGBgCgpBbmQgdGhlbiBmb3IgdGhlIG90aGVyIHBhaXJpbmdzOgoKYGBge3IgcHJvYi1kaWZmLWFsbH0KUGcxLmx0Lmc0IDwtIHN1bSggU0VBLkJbLDFdIDwgU0VBLkJbLDRdICkgLyBucm93KFNFQS5CKQpwcmludChQZzEubHQuZzQpCgpQZzIubHQuZzMgPC0gc3VtKCBTRUEuQlssMl0gPCBTRUEuQlssM10gKSAvIG5yb3coU0VBLkIpCnByaW50KFBnMi5sdC5nMykKClBnMy5sdC5nNCA8LSBzdW0oIFNFQS5CWywzXSA8IFNFQS5CWyw0XSApIC8gbnJvdyhTRUEuQikKcHJpbnQoUGczLmx0Lmc0KQpgYGAKCioqKgoKIyMgT3ZlcmxhcCBCZXR3ZWVuIEVsbGlwc2VzCk9uZSBjYW4gY2FsY3VsYXRlIHRoZSBvdmVybGFwIGJldHdlZW4gdHdvIChvciBtb3JlKSBlbGxpcHNlcy4gSW4gdGhlIGZpcnN0IGluc3RhbmNlLCB0aGlzIG92ZXJsYXAgaXMgc2ltcGx5IHRoZSBhcmVhLCBpbiB1bml0cyBvZiBwZXIgbWlsIHNxdWFyZWQsIGNvbnRhaW5lZCBieSB0aGUgc2hhcGUgdGhhdCBsaWVzIHdpdGhpbiB0aGUgb3ZlcmxhcHBpbmcgcmVnaW9uLiBUaGlzIG92ZXJsYXAgaXMgbW9zdCBlYXNpbHkgY2FsY3VsYXRlZCBieSB1c2luZyB0aGUgU0VBYyBvZiBlYWNoIGVsbGlwc2UuCgpUaGUgb3ZlcmxhcCBiZXR3ZWVuIHRoZSBTRUFjIGZvciBncm91cHMgMyBhbmQgNCBpbiBDb21tdW5pdHkgMSBpcyBnaXZlbiBieToKCmBgYHtyIE1MLW92ZXJsYXB9CgpvdmVybGFwLkczLkc0IDwtIG1heExpa092ZXJsYXAoIjEuMyIsICIxLjQiLCBzaWJlci5leGFtcGxlLCBwID0gMC45NSwgbiA9MTAwKQoKYGBgCgoKQW5kIHRoZSBvdmVybGFwIGJldHdlZW4gU0VBYyBvZiBncm91cHMgMS4yIGFuZCAyLjEgaXMgZ2l2ZW4gYnk6CgpgYGB7cn0Kb3ZlcmxhcC5DMUcyLkMyRzEgPC0gbWF4TGlrT3ZlcmxhcCgiMS4yIiwgIjIuMSIsIHNpYmVyLmV4YW1wbGUsIHAgPSAwLjk1LCBuID0gMTAwKQpgYGAKCk9uZSBtaWdodCB0aGVuIHdpc2ggdG8gY2FsY3VsYXRlIHRoZSBwcm9wb3J0aW9uIG92ZXJsYXA7IGF0aG91Z2ggb25lIHRoZW4gcnVucyBpbnRvIGEgY2hvaWNlIGFzIHRvIHdoYXQgdGhlIGRlbW9uaW5hdG9yIHdpbGwgYmUgaW4gdGhlIGVxdWF0aW9uLiBZb3UgY291bGQgZm9yIGluc3RhbmNlIGNhbGN1bGF0ZSB0aGUgcHJvcG9ydGlvbiBvZiBBIHRoYXQgb3ZlcmxhcHMgd2l0aCBCLCB0aGUgcHJvcG9yaXRvbiBvZiBCIHRoYXQgb3ZlcmxhcHMgd2l0aCBBLCBvciB0aGUgcHJvcG9ydGlvbiBvZiBBIGFuZCBCIHRoYXQgb3ZlcmxhcCB3aXRoIGVhY2ggb3RoZXIuCgpgYGB7ciBNTC1vdmVybGFwLXByb3BvcnRpb25zfQpwcm9wLm9mLmZpcnN0IDwtIGFzLm51bWVyaWMob3ZlcmxhcC5HMy5HNFsib3ZlcmxhcCJdIC8gb3ZlcmxhcC5HMy5HNFsiYXJlYS4xIl0pCnByaW50KHByb3Aub2YuZmlyc3QpCgpwcm9wLm9mLnNlY29uZCA8LSBhcy5udW1lcmljKG92ZXJsYXAuRzMuRzRbIm92ZXJsYXAiXSAvIG92ZXJsYXAuRzMuRzRbImFyZWEuMiJdKQpwcmludChwcm9wLm9mLnNlY29uZCkKCnByb3Aub2YuYm90aCA8LSBhcy5udW1lcmljKG92ZXJsYXAuRzMuRzRbIm92ZXJsYXAiXSAvIChvdmVybGFwLkczLkc0WyJhcmVhLjEiXSArIG92ZXJsYXAuRzMuRzRbImFyZWEuMiJdKSkKcHJpbnQocHJvcC5vZi5ib3RoKQoKcHJvcC5vZi5ib3RoLmxlc3Mub3ZlcmxhcCA8LSBhcy5udW1lcmljKG92ZXJsYXAuRzMuRzRbIm92ZXJsYXAiXSAvIChvdmVybGFwLkczLkc0WyJhcmVhLjEiXSArIG92ZXJsYXAuRzMuRzRbImFyZWEuMiJdIC0gb3ZlcmxhcC5HMy5HNFsib3ZlcmxhcCJdKSkKcHJpbnQocHJvcC5vZi5ib3RoLmxlc3Mub3ZlcmxhcCkKYGBgCgpBIHByb2JsZW0gd2l0aCB0aGlzIHNpbXBsZSBvdmVybGFwIGNhbGN1bGF0aW9uIGlzIHRoYXQgaXQgeWllbGRzIGEgcG9pbnQtZXN0aW1hdGUgb2Ygb3ZlcmxhcCBiYXNlZCBvbiB0aGUgbWF4aW11bSBsaWtlbGlob29kIGVzdGltYXRlZCBTRUFfYy4gT25lIGNhbiBpbnN0ZWFkIGNhbGN1bGF0ZSBhIGRpc3RyaWJ1dGlvbiBvZiBvdmVybGFwIGJhc2VkIG9uIHRoZSBwb3N0ZXJpb3IgZGlzdGlyYnV0aW9ucyBvZiB0aGUgZml0dGVkIGVsbGlwc2VzLiBJdCBjYW4gYmUgYSBiaXQgc2xvdyB0byBjYWxjdWxhdGUgdGhpcyBvdmVybGFwLCBzbyB5b3UgbWF5IHdhbnQgdG8gZHJvcCB0aGUgbnVtYmVyIG9mIGBkcmF3c2AgaWYgeW91ciBjb21wdXRlciBpcyBzbG93LgoKYGBge3IgYmF5ZXNpYW4tb3ZlcmxhcH0KYmF5ZXMub3ZlcmxhcC5HMi5HMyA8LSBiYXllc2lhbk92ZXJsYXAoIjEuMyIsICIxLjQiLCBlbGxpcHNlcy5wb3N0ZXJpb3IsIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkcmF3cyA9IDEwLCBwLmludGVydmFsID0gMC45NSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbiA9IDM2MCkKcHJpbnQoYmF5ZXMub3ZlcmxhcC5HMi5HMykKCmBgYAoKCgo=
+
LS0tCnRpdGxlOiAiQ29tcGFyaW5nIHBvcHVsYXRpb25zIGluIGlzb3RvcGUtc3BhY2UiCmF1dGhvcjogIkFuZHJldyBMIEphY2tzb24iCmRhdGU6ICJgciBmb3JtYXQoU3lzLnRpbWUoKSwgJyVkICVCLCAlWScpYCIKb3V0cHV0OiBodG1sX25vdGVib29rCi0tLQoKYGBge3IsIGVjaG89RkFMU0UsIG1lc3NhZ2UgPSBGQUxTRSwgZmlnLndpZHRoID0gNywgZmlnLmhlaWdodCA9IDd9CgpsaWJyYXJ5KFNJQkVSLCBxdWlldGx5ID0gVFJVRSwKICAgICAgICB2ZXJib3NlID0gRkFMU0UsCiAgICAgICAgbG9naWNhbC5yZXR1cm4gPSBGQUxTRSkKCmxpYnJhcnkodmlyaWRpcykKcGFsZXR0ZSh2aXJpZGlzKDQpKQoKIyByZWFkIGluIHRoZSBkYXRhCm15ZGF0YSA8LSByZWFkLmNzdigiLi4vZGF0YS9leGFtcGxlX2xheW1hbl9kYXRhX2FsbC5jc3YiLAogICAgICAgICAgICAgICAgICAgaGVhZGVyPVRSVUUpCgojIGNyZWF0ZSB0aGUgc2liZXIgb2JqZWN0CnNpYmVyLmV4YW1wbGUgPC0gY3JlYXRlU2liZXJPYmplY3QobXlkYXRhKQoKIyBDcmVhdGUgbGlzdHMgb2YgcGxvdHRpbmcgYXJndW1lbnRzIHRvIGJlIHBhc3NlZCBvbndhcmRzIHRvIGVhY2ggCiMgb2YgdGhlIHRocmVlIHBsb3R0aW5nIGZ1bmN0aW9ucy4KY29tbXVuaXR5Lmh1bGxzLmFyZ3MgPC0gbGlzdChjb2wgPSAxLCBsdHkgPSAxLCBsd2QgPSAxKQpncm91cC5lbGxpcHNlcy5hcmdzICA8LSBsaXN0KG4gPSAxMDAsIHAuaW50ZXJ2YWwgPSAwLjk1LCBsdHkgPSAxLCBsd2QgPSAyKQpncm91cC5odWxsLmFyZ3MgICAgICA8LSBsaXN0KGx0eSA9IDIsIGNvbCA9ICJncmV5MjAiKQoKIyBwbG90IHRoZSByYXcgZGF0YQpwYXIobWZyb3c9YygxLDEpKQpwbG90U2liZXJPYmplY3Qoc2liZXIuZXhhbXBsZSwKICAgICAgICAgICAgICAgICAgYXgucGFkID0gMiwgCiAgICAgICAgICAgICAgICAgIGh1bGxzID0gRkFMU0UsIGNvbW11bml0eS5odWxscy5hcmdzLCAKICAgICAgICAgICAgICAgICAgZWxsaXBzZXMgPSBGQUxTRSwgZ3JvdXAuZWxsaXBzZXMuYXJncywKICAgICAgICAgICAgICAgICAgZ3JvdXAuaHVsbHMgPSBGQUxTRSwgZ3JvdXAuaHVsbC5hcmdzLAogICAgICAgICAgICAgICAgICBidHkgPSAiTCIsCiAgICAgICAgICAgICAgICAgIGlzby5vcmRlciA9IGMoMSwyKSwKICAgICAgICAgICAgICAgICAgeGxhYiA9IGV4cHJlc3Npb24oe2RlbHRhfV4xMypDfidcdTIwMzAnKSwKICAgICAgICAgICAgICAgICAgeWxhYiA9IGV4cHJlc3Npb24oe2RlbHRhfV4xNSpOfidcdTIwMzAnKQogICAgICAgICAgICAgICAgICApCgpgYGAKCkluIHRoaXMgZmlndXJlLCB3ZSBoYXZlIDQgcG9wdWxhdGlvbnMgKG9yIG1vcmUgZ2VuZXJpY2FsbHk6IGdyb3Vwcykgb2YgaW5kaXZ1YWxzLiBXZSBtaWdodCB3YW50IHRvIG1ha2Ugc29tZSBjb21wYXJpc29ucyBvZiB0aGUgaXNvdG9waWMgKGFuZCBoZW5jZSBlY29sb2dpY2FsKSBuaWNoZXMgb2NjdXBpZWQgYnkgdGhlc2UgaW5kaXZpZHVhbHMuIFRoZSB0d28gbW9zdCBvYnZpb3VzIHdheXMgdG8gY29tcGFyZSB0d28gb2YgdGhlc2UgcG9wdWxhdGlvbnMsIGlzIHRvIGFzayB3aGV0aGVyIHRoZWlyIG5pY2hlcyBhcmUgbG9jYXRlZCBpbiB0aGUgc2FtZSBwbGFjZSwgYW5kIGlmIHRoZXkgYXJlIHRoZSBzYW1lIHNpemUuIFRoZXJlYWZ0ZXIsIHdlIG1heSBiZSBpbnRlcmVzdGVkIGluIGFza2luZyB0byB3aGF0IGV4dGVudCBkbyB0aGVpciBuaWNoZXMgb3ZlcmxhcC4KCldlIGNhbiB2aXN1YWxpc2UgdGhpcyBieSBhZGRpbmcgYm90aCBlbGxpcHNlcywgYW5kIGNvbnZleCBodWxscyB0byB0aGUgZGF0YS4gSW4gdGhpcyBjYXNlLCB3ZSBhZGQgc3RhbmRhcmQgZWxsaXBzZXMsIHdoaWNoIGFyZSB0byBiaXZhcmlhdGUgZGF0YSBhcyBzdGFuZGFyZCBkZXZpYXRpb25zIGFyZSB0byB1bml2YXJpYXRlIGRhdGEuIEEgc3RhbmRhcmQgZWxsaXBzZSBjb250YWlucyBhcHByb3hpbWF0ZWx5IDQwJSBvZiB0aGUgZGF0YSwgYWx0aG91Z2ggdGhleSBjYW4gYmUgcmVzY2FsZWQgdG8gY29udGFpbiBhbnkgcHJvcG9yaXRpb24gb2YgdGhlIGRhdGEgd2Ugd2lzaCBpZiB3ZSBhY2NlcHQgdGhlIGFzc3VtcHRpb24gdGhhdCB0aGV5IG11bHRpdmFyaWF0ZSBub3JtYWwgZGlzdHJpYnV0ZWQuIE93aW5nIHRvIHRoaXMgcHJvcG9ydGlvbmFsIHJlcHJlc2VudGF0aW9uIG9mIHRoZSBkYXRhLCB0aGUgZWxsaXBzZSBfc2hvdWxkXyBiZSBpbnNlbnNpdGl2ZSB0byBzYW1wbGUgc2l6ZSwgYW5kIF9zaG91bGRfIGFsd2F5cyBjb250YWluIDQwJSBvZiB0aGUgZGF0YS4gSG93ZXZlciwgYXMgd2FzIGRlbW9uc3RyYXRlZCBpbiB0aGUgU0lCRVIgcGFwZXIgW0phY2tzb24gZXQgYWwgMjAxMF0oaHR0cHM6Ly9zY2hvbGFyLmdvb2dsZS5jb20vY2l0YXRpb25zP3ZpZXdfb3A9dmlld19jaXRhdGlvbiZobD1lbiZ1c2VyPUUwc0I3ZlVBQUFBSiZjaXRhdGlvbl9mb3Jfdmlldz1FMHNCN2ZVQUFBQUo6X0Z4R29GeXpwNVFDKSwgdGhlIGJhc2ljIFN0YW5kYXJkIEVsbGlwc2UgQXJlYSAoU0VBKSBzaG93cyBiaWFzIGF0IHNtYWxsIHNhbXBsZSBzaXplcywgd2hpY2ggY2FuIGJlIGNvcnJlY3RlZCB0byBjYWxjdWxhdGUgU0VBYy4KCkluIGNvbnRyYXN0LCB0aGUgY29udmV4IGh1bGwgaXMgYSBwb2x5Z29uIHRoYXQgaXMgZHJhd24gYXJvdW5kIHRoZSBvdXRlcm1vc3QgcG9pbnRzIGluIHRoZSBjbG91ZCBvZiBkYXRhIHN1Y2ggdGhhdCBhbGwgb3RoZXIgcG9pbnRzIGxpZSB3aXRoaW4gdGhlIG91dGxpbmUuIElmIHdlIHdlcmUgdG8gZ28gb3V0IGFuZCBjb2xsZWN0IG1vcmUgc2FtcGxlcywgdGhlbiB0aGlzIGh1bGwgY2FuIG9ubHkgZ3JvdyBpbiBzaXplIGFuZCBub3QgZ2V0IHNtYWxsZXIuIFRoZSByZXN1bHQgb2YgdGhpcyBpcyB0aGF0IHNtYWxsZXIgc2FtcGxlIHNpemVzIHdpbGwgcmVzdWx0IGluIHNtYWxsZXIgY29udmV4IGh1bGxzLiBEZXNwaXRlIHRoaXMgc3RhdGlzdGljYWwgcHJvYmxlbSwgdGhlIGNvbnZleCBodWxsIHJlbWFpbnMgYSB1c2VmdWwgd2F5IHRvIGhlbHAgdXMgdmlzdWFsaXNlIGJpdmFyaWF0ZSBkYXRhIHN1Y2ggYXMgY2FyYm9uLW5pdHJvZ2VuIHN0YWJsZSBpc290b3BlIHZhbHVlcy4KCldlIGNhbiB0aGVuIGdvIGJhY2sgdG8gb3VyIGNvbW11bml0eSBjb21wcmlzaW5nIDQgcG9wdWxhdGlvbnMsIGFuZCBhZGQgc3RhbmRhcmQgZWxsaXBzZXMgYW5kIGNvbnZleCBodWxscyB0byBlYWNoIGdyb3VwLiBUaGUgbmV3IGNvZGUgaW4gU0lCRVIgY3JlYXRlcyBhIHNwZWNpYWwgb2JqZWN0IHRoYXQgY29udGFpbnMgdGhlIG9yaWdpbmFsIGRhdGEsIHRoZSByZXNjYWxlZCBhbmQgei1zY29yZWQgZGF0YSwgYWxvbmcgd2l0aCB2YXJpb3VzIHN1bW1hcnkgc3RhdGlzdGljcyB0byBhaWQgd2l0aCBwbG90dGluZyBhbmQgbW9kZWwgZml0dGluZy4gTW9zdCBvZiB0aGlzIGhhcHBlbnMgaW4gdGhlIGJhY2tncm91bmQsIHNvIHlvdSBkb250IG5lZWQgdG8gd29ycnkgYWJvdXQgdGhlIGRldGFpbHMgb2YgdGhpcyBvYmplY3QgdW5sZXNzIHlvdSB3YW50IHRvIGRlbHZlIGRlZXBlci4KCgpBbmQgbm93IHRoZSBmdWxsIGNvZGUuLi4KCmBgYHtyIGltcG9ydC1kYXRhLCBmaWcud2lkdGggPSA2LCBmaWcuaGVpZ2h0ID0gNn0KCnJtKGxpc3QgPSBscygpKSAjIGNsZWFyIHRoZSBtZW1vcnkgb2Ygb2JqZWN0cwoKIyBsb2FkIHRoZSBzaWFyIHBhY2thZ2Ugb2YgZnVuY3Rpb25zCiMgbGlicmFyeShTSUJFUikKCiMgcmVhZCBpbiB0aGUgZGF0YQpteWRhdGEgPC0gcmVhZC5jc3YoIi4uL2RhdGEvZXhhbXBsZV9sYXltYW5fZGF0YV9hbGwuY3N2IiwKICAgICAgICAgICAgICAgICAgIGhlYWRlcj1UUlVFKQoKIyBjcmVhdGUgdGhlIHNpYmVyIG9iamVjdApzaWJlci5leGFtcGxlIDwtIGNyZWF0ZVNpYmVyT2JqZWN0KG15ZGF0YSkKCiMgQ3JlYXRlIGxpc3RzIG9mIHBsb3R0aW5nIGFyZ3VtZW50cyB0byBiZSBwYXNzZWQgb253YXJkcyB0byBlYWNoIAojIG9mIHRoZSB0aHJlZSBwbG90dGluZyBmdW5jdGlvbnMuCmNvbW11bml0eS5odWxscy5hcmdzIDwtIGxpc3QoY29sID0gMSwgbHR5ID0gMSwgbHdkID0gMSkKZ3JvdXAuZWxsaXBzZXMuYXJncyAgPC0gbGlzdChuID0gMTAwLCBwLmludGVydmFsID0gMC45NSwgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbHR5ID0gMSwgbHdkID0gMikKZ3JvdXAuaHVsbC5hcmdzICAgICAgPC0gbGlzdChsdHkgPSAyLCBjb2wgPSAiZ3JleTIwIikKCgojIGVsbGlwc2VzIGFuZCBncm91cC5odWxscyBhcmUgc2V0IHRvIFRSVUUgb3IgVCBmb3Igc2hvcnQgdG8gZm9yY2UKIyB0aGVpciBwbG90dGluZy4gCnBhcihtZnJvdz1jKDEsMSkpCnBsb3RTaWJlck9iamVjdChzaWJlci5leGFtcGxlLAogICAgICAgICAgICAgICAgICBheC5wYWQgPSAyLCAKICAgICAgICAgICAgICAgICAgaHVsbHMgPSBGQUxTRSwgY29tbXVuaXR5Lmh1bGxzLmFyZ3MsIAogICAgICAgICAgICAgICAgICBlbGxpcHNlcyA9IFRSVUUsIGdyb3VwLmVsbGlwc2VzLmFyZ3MsCiAgICAgICAgICAgICAgICAgIGdyb3VwLmh1bGxzID0gVFJVRSwgZ3JvdXAuaHVsbC5hcmdzLAogICAgICAgICAgICAgICAgICBidHkgPSAiTCIsCiAgICAgICAgICAgICAgICAgIGlzby5vcmRlciA9IGMoMSwyKSwKICAgICAgICAgICAgICAgICAgeGxhYiA9IGV4cHJlc3Npb24oe2RlbHRhfV4xMypDfidcdTIwMzAnKSwKICAgICAgICAgICAgICAgICAgeWxhYiA9IGV4cHJlc3Npb24oe2RlbHRhfV4xNSpOfidcdTIwMzAnKQogICAgICAgICAgICAgICAgICApCgojIFlvdSBjYW4gYWRkIG1vcmUgZWxsaXBzZXMgYnkgZGlyZWN0bHkgY2FsbGluZyBwbG90Lmdyb3VwLmVsbGlwc2VzKCkKIyBBZGQgYW4gYWRkaXRpb25hbCBwLmludGVydmFsICUgcHJlZGljdGlvbiBlbGxpbHBzZQpwbG90R3JvdXBFbGxpcHNlcyhzaWJlci5leGFtcGxlLCBuID0gMTAwLCBwLmludGVydmFsID0gMC41MCwKICAgICAgICAgICAgICAgICAgICBsdHkgPSAxLCBsd2QgPSAyKQoKIyBvciB5b3UgY2FuIGFkZCB0aGUgWFglIGNvbmZpZGVuY2UgaW50ZXJ2YWwgYXJvdW5kIHRoZSBiaXZhcmlhdGUgbWVhbnMKIyBieSBzcGVjaWZ5aW5nIGNpLm1lYW4gPSBUIGFsb25nIHdpdGggd2hhdGV2ZXIgcC5pbnRlcnZhbCB5b3Ugd2FudC4KcGxvdEdyb3VwRWxsaXBzZXMoc2liZXIuZXhhbXBsZSwgbiA9IDEwMCwgcC5pbnRlcnZhbCA9IDAuOTUsCiAgICAgICAgICAgICAgICAgIGNpLm1lYW4gPSBUUlVFLCBsdHkgPSAxLCBsd2QgPSAyKQoKCiMgQ2FsY3VsYXRlIHN1bWFtcnkgc3RhdGlzdGljcyBmb3IgZWFjaCBncm91cDogVEEsIFNFQSBhbmQgU0VBYwpncm91cC5NTCA8LSBncm91cE1ldHJpY3NNTChzaWJlci5leGFtcGxlKQpwcmludChncm91cC5NTCkKCiMgYWRkIGEgbGVnZW5kCmxlZ2VuZCgidG9wcmlnaHQiLCBjb2xuYW1lcyhncm91cC5NTCksIAogICAgICAgcGNoID0gYygxLDEsMSwxLDIsMiwyLDIpLCBjb2wgPSBjKDE6NCwgMTo0KSwgbHR5ID0gMSkKCmBgYAoKKioqCgojIyBVc2luZyBCYXllc2lhbiBJbmZlcmVuY2UgdG8gY2FsY3VsYXRlIHVuY2VydGFpbnR5IGFyb3VuZCBlbGxpcHNlcwpTbyBmYXIgdGhlc2Ugc3RpbGwganVzdCBwb2ludC1tZXRyaWNzIHRoYXQgZGVzY3JpYmUgdGhlIHdpZHRoIG9mIHRoZSBpc290b3BpYyBuaWNoZS4gVGhhdCBpcywgdGhleSBhcmUgc2luZ2xlIG51bWJlcnMgZm9yIGVhY2ggZ3JvdXAsIHdoaWNoIG1lYW5zIHRoYXQgd2UgY2FuJ3QgY29tcGFyZSBvbmUgZ3JvdXAgdG8gYW5vdGhlciBpbiBhIHN0YXRpc2ljYWwgc2Vuc2UgYXMgd2UgbGFjayBhIG1lYXN1cmUgb2YgdGhlIHVuY2VydGFpbnR5IGFyb3VuZCBlYWNoIGVzdGltYXRlLiBUaGlzIGlzIHdoZXJlIHdlIGNhbiB1c2UgQmF5ZXNpYW4gSW5mZXJlbmNlIHRvIHF1YW50aWZ5IHRoZSBlcnJvciBhc3NvY2lhdGVkIHdpdGggZml0dGluZyB0aGVzZSBlbGxpcHNlcyB0byBlYWNoIGdyb3VwLCB0aGF0IGFyaXNlcyBmcm9tIGJvdGggdGhlIG51bWJlciBvZiBzYW1wbGVzIHdlIGhhdmUsIGFuZCBhbHNvIHRoZWlyIGRpc3RyaWJ1dGlvbi4KCkVzc2VudGlhbGx5LCB3aGF0IHRoZSBNQ01DIGFsZ29yaXRobSBkb2VzIGlzIGdlbmVyYXRlIGEgZGlzdHJpYnV0aW9uIG9mIGNvdmFyaWFuY2UgbWF0cmljZXMgdGhhdCB0byBhIGdyZWF0ZXIgb3IgbGVzc2VyIGV4dGVudCAoaW4gdGVybXMgb2YgbGlrZWxpaG9vZCkgZGVzY3JpYmUgdGhlIG9ic2VydmVkIGRhdGEuIEl0IGRvZXMgc28sIGFzIGlzIHRoZSBnZW5lcmFsIGNhc2UgaW4gQmF5ZXNpYW4gSW5mZXJlbmNlLCBieSBjb21iaW5nIHRoZSBwcmlvciBwcm9iYWJpbGl0eSB3aXRoIHRoZSBsaWtlbGlob29kIG9mIHRoZSBkYXRhIGZvciBhIGdpdmVuIGNvdmFyaWFuY2UgbWF0cml4LgoKU0lCRVIgdXNlcyB0aGUgamFncyBwYWNrYWdlIHRvIGZpdCB0aGUgQmF5ZXNpYW4gbW9kZWwgYW5kIHNvIHdlIG5lZWQgdG8gc3BlY2lmeSB0aGUgcGFyYW1ldGVycyBvZiB0aGUgc2ltdWxhdGlvbiBydW4sIGluY2x1ZGluZzogcnVuIGxlbmd0aCwgYnVybi1pbiBwZXJpb2QsIG51bWJlciBvZiBjaGFpbnMgZXRjLi4uCgpgYGB7ciBmaXQtYmF5ZXN9CgojIG9wdGlvbnMgZm9yIHJ1bm5pbmcgamFncwpwYXJtcyA8LSBsaXN0KCkKcGFybXMkbi5pdGVyIDwtIDIgKiAxMF40ICAgIyBudW1iZXIgb2YgaXRlcmF0aW9ucyB0byBydW4gdGhlIG1vZGVsIGZvcgpwYXJtcyRuLmJ1cm5pbiA8LSAxICogMTBeMyAjIGRpc2NhcmQgdGhlIGZpcnN0IHNldCBvZiB2YWx1ZXMKcGFybXMkbi50aGluIDwtIDEwICAgICAjIHRoaW4gdGhlIHBvc3RlcmlvciBieSB0aGlzIG1hbnkKcGFybXMkbi5jaGFpbnMgPC0gMiAgICAgICAgIyBydW4gdGhpcyBtYW55IGNoYWlucwoKIyBkZWZpbmUgdGhlIHByaW9ycwpwcmlvcnMgPC0gbGlzdCgpCnByaW9ycyRSIDwtIDEgKiBkaWFnKDIpCnByaW9ycyRrIDwtIDIKcHJpb3JzJHRhdS5tdSA8LSAxLjBFLTMKCiMgZml0IHRoZSBlbGxpcHNlcyB3aGljaCB1c2VzIGFuIEludmVyc2UgV2lzaGFydCBwcmlvcgojIG9uIHRoZSBjb3ZhcmlhbmNlIG1hdHJpeCBTaWdtYSwgYW5kIGEgdmFndWUgbm9ybWFsIHByaW9yIG9uIHRoZSAKIyBtZWFucy4gRml0dGluZyBpcyB2aWEgdGhlIEpBR1MgbWV0aG9kLgplbGxpcHNlcy5wb3N0ZXJpb3IgPC0gc2liZXJNVk4oc2liZXIuZXhhbXBsZSwgcGFybXMsIHByaW9ycykKCmBgYAoKV2hhdCB3ZSBlbmQgdXAgd2l0aCBpcyBhIHJhbmdlIG9mIGVsbGlwc2VzIHRoYXQgY291bGQgZXhwbGFpbiB0aGUgZGF0YSwgd2l0aCBtb3JlIG9mIHRoZW0gY2x1c3RlcmVkIGFyb3VuZCB0aGUgbW9zdCBsaWtlbHkgc29sdXRpb24uIEhvd2V2ZXIsIG9uZSBjYW5ub3Qgc2ltcGx5IHRha2UgYW4gYXZlcmFnZSBhY3Jvc3MgdGhlc2UgY292YXJpYW5jZSBtYXRyaWNlcywgYXMgdGhlcmUgYXJlIHN0cmljdCBtYXRoZW1hdGljYWwgcHJvcGVydGllcyB0aGF0IG11c3QgYmUgbWFpbnRhaW5lZC4gVGhlIHJlc3VsdCBvZiB0aGlzIGlzIHRoYXQgaXQgaXMgbm90IHBvc3NpYmxlIHRvIHBsb3QgYSBtZWFuLCBtZWRpYW4gb3IgbW9kYWwgQmF5ZXNpYW4gU3RhbmRhcmQgRWxsaXBzZTsgaW5zdGVhZCB3ZSBtdXN0IGNhbGN1bGF0ZSBlYWNoIG9uZSBvZiB0aGUgZWxsaXBzZSdzIGFyZWEsIGFuZCB0aGVuIHByZXNlbnQgc3VtbWFyeSBzdGF0aXN0aWNzIG9mIHRoaXMgZGVyaXZlZCBtZWFzdXJlbWVudC4gU0lCRVIgY29udGFpbnMgYSBmdW5jdGlvbiB0aGF0IHdpbGwgYXV0b21hdGljYWxseSBsb29wIG92ZXIgYWxsIHRoZSBncm91cHMgYW5kIGRvIHRoaXMuCgpUaGUgcGxvdHMgYmVsb3cgcmVwcmVzZW50IHRoZSBwb3N0ZXJpb3IgZGlzdHJpYnV0aW9uIG9mIHRoZSBTRUFfQiBmaXR0ZWQgdG8gZWFjaCBvZiB0aGUgNCBncm91cHMgaW4gb3VyIGRhdGFzZXQuCgpgYGB7ciBwbG90LWRhdGEsIGZpZy53aWR0aCA9IDEwLCBmaWcuaGVpZ2h0ID0gNn0KIyAKIyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiMgUGxvdCBvdXQgc29tZSBvZiB0aGUgZGF0YSBhbmQgcmVzdWx0cwojIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KCiMgVGhlIHBvc3RlcmlvciBlc3RpbWF0ZXMgb2YgdGhlIGVsbGlwc2VzIGZvciBlYWNoIGdyb3VwIGNhbiBiZSB1c2VkIHRvCiMgY2FsY3VsYXRlIHRoZSBTRUEuQiBmb3IgZWFjaCBncm91cC4KU0VBLkIgPC0gc2liZXJFbGxpcHNlcyhlbGxpcHNlcy5wb3N0ZXJpb3IpCgpzaWJlckRlbnNpdHlQbG90KFNFQS5CLCB4dGlja2xhYmVscyA9IGNvbG5hbWVzKGdyb3VwLk1MKSwgCiAgICAgICAgICAgICAgICB4bGFiID0gYygiQ29tbXVuaXR5IHwgR3JvdXAiKSwKICAgICAgICAgICAgICAgIHlsYWIgPSBleHByZXNzaW9uKCJTdGFuZGFyZCBFbGxpcHNlIEFyZWEgIiAoJ1x1MjAzMCcgXjIpICksCiAgICAgICAgICAgICAgICBidHkgPSAiTCIsCiAgICAgICAgICAgICAgICBsYXMgPSAxLAogICAgICAgICAgICAgICAgbWFpbiA9ICJTSUJFUiBlbGxpcHNlcyBvbiBlYWNoIGdyb3VwIgogICAgICAgICAgICAgICAgKQoKIyBBZGQgcmVkIHgncyBmb3IgdGhlIE1MIGVzdGltYXRlZCBTRUEtYwpwb2ludHMoMTpuY29sKFNFQS5CKSwgZ3JvdXAuTUxbMyxdLCBjb2w9InJlZCIsIHBjaCA9ICJ4IiwgbHdkID0gMikKCiMgQ2FsY3VsYXRlIHNvbWUgY3JlZGlibGUgaW50ZXJ2YWxzIApjci5wIDwtIGMoMC45NSwgMC45OSkgIyB2ZWN0b3Igb2YgcXVhbnRpbGVzCgojIGNhbGwgdG8gaGRyY2RlOmhkciB1c2luZyBsYXBwbHkoKQpTRUEuQi5jcmVkaWJsZXMgPC0gbGFwcGx5KAogIGFzLmRhdGEuZnJhbWUoU0VBLkIpLCAKICBmdW5jdGlvbih4LC4uLil7dG1wPC1oZHJjZGU6Omhkcih4KSRoZHJ9LAogIHByb2IgPSBjci5wKQoKcHJpbnQoU0VBLkIuY3JlZGlibGVzKQoKIyBkbyBzaW1pbGFyIHRvIGdldCB0aGUgbW9kZXMsIHRha2luZyBjYXJlIHRvIHBpY2sgdXAgbXVsdGltb2RhbCBwb3N0ZXJpb3IKIyBkaXN0cmlidXRpb25zIGlmIHByZXNlbnQKU0VBLkIubW9kZXMgPC0gbGFwcGx5KAogIGFzLmRhdGEuZnJhbWUoU0VBLkIpLCAKICBmdW5jdGlvbih4LC4uLil7dG1wPC1oZHJjZGU6Omhkcih4KSRtb2RlfSwKICBwcm9iID0gY3IucCwgYWxsLm1vZGVzPVQpCgpwcmludChTRUEuQi5tb2RlcykKYGBgCgoqKioKCiMjIENvbXBhcmluZyB0aGUgcG9zdGVyaW9yIGRpc3RyaWJ1dGlvbnMKCkluIG9yZGVyIHRvIHRlc3Qgd2hldGhlciBvbmUgZ3JvdXAncyBlbGxpcHNlIGlzIHNtYWxsZXIgb3IgbGFyZ2VyIHRoYW4gYW5vdGhlciwgd2UgY2FuIHNpbXBseSBjYWxjdWxhdGUgdGhlIHByb2JhYmlsaXR5IHRoYXQgaXRzIHBvc3RlcmlvciBkaXN0cmlidXRpb24gaXMgc21hbGxlciAob3IgbGFyZ2VyKS4gVGhpcyBpcyBhY2hlaXZlZCBieSBjb21wYXJpbmcgZWFjaCBwYWlyIG9mIHBvc3RlcmlvciBkcmF3cyBmb3IgYm90aCBncm91cHMsIGFuZCBkdGVybWluaW5nIHdoaWNoIGlzIHNtYWxsZXIgaW4gbWFnbml0dWRlLiBXZSB0aGVuIGZpbmQgdGhlIHByb3BvcnRpb24gb2YgZHJhd3MgdGhhdCBhcmUgc21hbGxlciwgYW5kIHRoaXMgaXMgYSBkaXJlY3QgcHJveHkgZm9yIHRoZSBwcm9iYWJpbGl0eSB0aGF0IG9uZSBncm91cCdzIHBvc3RlcmlvciBkaXN0cmlidXRpb24gKG9mIGVsbGlwc2Ugc2l6ZSBpbiB0aGlzIGNhc2UpIGlzIHNtYWxsZXIgdGhhbiB0aGUgb3RoZXIuCgoKSGVyZSwgd2UgZmlyc3QgY2FsY3VsYXRlIHRoZSBwcm9wb3J0aW9uLCBhbmQgaGVuY2UgcHJvYmFiaWxpdHksIG9mIHRoZSBTRUEuQiBmb3IgZ3JvdXAgMSBiZWluZyBzbWFsbGVyIHRoYW4gdGhlIFNFQS5CIGZvciBncm91cCAyLgoKYGBge3IgcHJvYi1kaWZmLWcxMn0KUGcxLmx0LmcyIDwtIHN1bSggU0VBLkJbLDFdIDwgU0VBLkJbLDJdICkgLyBucm93KFNFQS5CKQpwcmludChQZzEubHQuZzIpCmBgYAoKU28sIGluIHRoaXMgY2FzZSwgYWxsIG9mIHRoZSBlc3RpbWF0ZXMgZm9yIGdyb3VwcyAxJ3MgZWxsaXBzZSBhcmUgc21hbGxlciB0aGFuIGZvciBncm91cCAyOyBhbHRob3VnaCB3ZSBjb3VsZCBwcm9iYWJseSBndWVzcyBhdCB0aGlzIGdpdmVuIHRoYXQgdGhlcmUgYXBwZWFycyB0byBiZSBubyBvdmVybGFwIGJldHdlZW4gdGhlbiA5NSUgY3JlZGlibGUgaW50ZXJ2YWxzIG9mIHRoZSB0d28gZ3JvdXBzIChzZWUgdGhlIGZpZ3VyZSBhYm92ZSkuCgpUaGVuIHdlIGNhbiBkbyBleGFjdGx5IHRoZSBzYW1lIGZvciBncm91cHMgMSBhbmQgMy4KCmBgYHtyIHByb2ItZGlmZi1nMTN9ClBnMS5sdC5nMyA8LSBzdW0oIFNFQS5CWywxXSA8IFNFQS5CWywzXSApIC8gbnJvdyhTRUEuQikKcHJpbnQoUGcxLmx0LmczICkKYGBgCgpBbmQgdGhlbiBmb3IgdGhlIG90aGVyIHBhaXJpbmdzOgoKYGBge3IgcHJvYi1kaWZmLWFsbH0KUGcxLmx0Lmc0IDwtIHN1bSggU0VBLkJbLDFdIDwgU0VBLkJbLDRdICkgLyBucm93KFNFQS5CKQpwcmludChQZzEubHQuZzQpCgpQZzIubHQuZzMgPC0gc3VtKCBTRUEuQlssMl0gPCBTRUEuQlssM10gKSAvIG5yb3coU0VBLkIpCnByaW50KFBnMi5sdC5nMykKClBnMy5sdC5nNCA8LSBzdW0oIFNFQS5CWywzXSA8IFNFQS5CWyw0XSApIC8gbnJvdyhTRUEuQikKcHJpbnQoUGczLmx0Lmc0KQpgYGAKCioqKgoKIyMgT3ZlcmxhcCBCZXR3ZWVuIEVsbGlwc2VzCk9uZSBjYW4gY2FsY3VsYXRlIHRoZSBvdmVybGFwIGJldHdlZW4gdHdvIChvciBtb3JlKSBlbGxpcHNlcy4gSW4gdGhlIGZpcnN0IGluc3RhbmNlLCB0aGlzIG92ZXJsYXAgaXMgc2ltcGx5IHRoZSBhcmVhLCBpbiB1bml0cyBvZiBwZXIgbWlsIHNxdWFyZWQsIGNvbnRhaW5lZCBieSB0aGUgc2hhcGUgdGhhdCBsaWVzIHdpdGhpbiB0aGUgb3ZlcmxhcHBpbmcgcmVnaW9uLiBUaGlzIG92ZXJsYXAgaXMgbW9zdCBlYXNpbHkgY2FsY3VsYXRlZCBieSB1c2luZyB0aGUgU0VBYyBvZiBlYWNoIGVsbGlwc2UuCgpUaGUgb3ZlcmxhcCBiZXR3ZWVuIHRoZSBTRUFjIGZvciBncm91cHMgMyBhbmQgNCBpbiBDb21tdW5pdHkgMSBpcyBnaXZlbiBieToKCmBgYHtyIE1MLW92ZXJsYXB9CgpvdmVybGFwLkczLkc0IDwtIG1heExpa092ZXJsYXAoIjEuMyIsICIxLjQiLCBzaWJlci5leGFtcGxlLCBwID0gMC45NSwgbiA9MTAwKQoKYGBgCgoKQW5kIHRoZSBvdmVybGFwIGJldHdlZW4gU0VBYyBvZiBncm91cHMgMS4yIGFuZCAyLjEgaXMgZ2l2ZW4gYnk6CgpgYGB7cn0Kb3ZlcmxhcC5DMUcyLkMyRzEgPC0gbWF4TGlrT3ZlcmxhcCgiMS4yIiwgIjIuMSIsIHNpYmVyLmV4YW1wbGUsIHAgPSAwLjk1LCBuID0gMTAwKQpgYGAKCk9uZSBtaWdodCB0aGVuIHdpc2ggdG8gY2FsY3VsYXRlIHRoZSBwcm9wb3J0aW9uIG92ZXJsYXA7IGF0aG91Z2ggb25lIHRoZW4gcnVucyBpbnRvIGEgY2hvaWNlIGFzIHRvIHdoYXQgdGhlIGRlbW9uaW5hdG9yIHdpbGwgYmUgaW4gdGhlIGVxdWF0aW9uLiBZb3UgY291bGQgZm9yIGluc3RhbmNlIGNhbGN1bGF0ZSB0aGUgcHJvcG9ydGlvbiBvZiBBIHRoYXQgb3ZlcmxhcHMgd2l0aCBCLCB0aGUgcHJvcG9yaXRvbiBvZiBCIHRoYXQgb3ZlcmxhcHMgd2l0aCBBLCBvciB0aGUgcHJvcG9ydGlvbiBvZiBBIGFuZCBCIHRoYXQgb3ZlcmxhcCB3aXRoIGVhY2ggb3RoZXIuCgpgYGB7ciBNTC1vdmVybGFwLXByb3BvcnRpb25zfQpwcm9wLm9mLmZpcnN0IDwtIGFzLm51bWVyaWMob3ZlcmxhcC5HMy5HNFsib3ZlcmxhcCJdIC8gb3ZlcmxhcC5HMy5HNFsiYXJlYS4xIl0pCnByaW50KHByb3Aub2YuZmlyc3QpCgpwcm9wLm9mLnNlY29uZCA8LSBhcy5udW1lcmljKG92ZXJsYXAuRzMuRzRbIm92ZXJsYXAiXSAvIG92ZXJsYXAuRzMuRzRbImFyZWEuMiJdKQpwcmludChwcm9wLm9mLnNlY29uZCkKCnByb3Aub2YuYm90aCA8LSBhcy5udW1lcmljKG92ZXJsYXAuRzMuRzRbIm92ZXJsYXAiXSAvIChvdmVybGFwLkczLkc0WyJhcmVhLjEiXSArIG92ZXJsYXAuRzMuRzRbImFyZWEuMiJdKSkKcHJpbnQocHJvcC5vZi5ib3RoKQoKcHJvcC5vZi5ib3RoLmxlc3Mub3ZlcmxhcCA8LSBhcy5udW1lcmljKG92ZXJsYXAuRzMuRzRbIm92ZXJsYXAiXSAvIChvdmVybGFwLkczLkc0WyJhcmVhLjEiXSArIG92ZXJsYXAuRzMuRzRbImFyZWEuMiJdIC0gb3ZlcmxhcC5HMy5HNFsib3ZlcmxhcCJdKSkKcHJpbnQocHJvcC5vZi5ib3RoLmxlc3Mub3ZlcmxhcCkKYGBgCgpBIHByb2JsZW0gd2l0aCB0aGlzIHNpbXBsZSBvdmVybGFwIGNhbGN1bGF0aW9uIGlzIHRoYXQgaXQgeWllbGRzIGEgcG9pbnQtZXN0aW1hdGUgb2Ygb3ZlcmxhcCBiYXNlZCBvbiB0aGUgbWF4aW11bSBsaWtlbGlob29kIGVzdGltYXRlZCBTRUFfYy4gT25lIGNhbiBpbnN0ZWFkIGNhbGN1bGF0ZSBhIGRpc3RyaWJ1dGlvbiBvZiBvdmVybGFwIGJhc2VkIG9uIHRoZSBwb3N0ZXJpb3IgZGlzdGlyYnV0aW9ucyBvZiB0aGUgZml0dGVkIGVsbGlwc2VzLiBJdCBjYW4gYmUgYSBiaXQgc2xvdyB0byBjYWxjdWxhdGUgdGhpcyBvdmVybGFwLCBzbyB5b3UgbWF5IHdhbnQgdG8gZHJvcCB0aGUgbnVtYmVyIG9mIGBkcmF3c2AgaWYgeW91ciBjb21wdXRlciBpcyBzbG93LgoKYGBge3IgYmF5ZXNpYW4tb3ZlcmxhcH0KYmF5ZXMub3ZlcmxhcC5HMi5HMyA8LSBiYXllc2lhbk92ZXJsYXAoIjEuMyIsICIxLjQiLCBlbGxpcHNlcy5wb3N0ZXJpb3IsIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBkcmF3cyA9IDEwLCBwLmludGVydmFsID0gMC45NSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgbiA9IDM2MCkKcHJpbnQoYmF5ZXMub3ZlcmxhcC5HMi5HMykKCgpgYGAKCkFuZCBzdW1tYXJpc2UgdGhlIGNyZWRpYmxlIGludGVydmFscyBvZiB0aGUgQmF5ZXNpYW4gb3ZlcmxhcCBvdXRwdXQuIE5vdGUgdGhhdCB0aGlzIGNvZGUgZG9lcyBub3Qgd29yayB3ZWxsIG9uIHRoZSBzbWFsbCBudW1iZXIgb2YgcG9zdGVyaW9yIGRyYXdzIHdlIGFyZSB1c2luZyBmb3IgdGhpcyBiYXNpYyBleGFtcGxlIC0gZm9yIG9uZSBpdCByZXR1cm5zIG5lZ2F0aXZlIHZhbHVlcyB3aGljaCBpcyBub3QgcG9zc2libGUsIGJ1dCBpcyBhcmlzaW5nIGFzIHRoZSBzbW9vdGhlciBoYXMgbm90IGdvdCBlbm91Z2ggaW5mb3JtYXRpb24gdG8gc3RheSBjbG9zZSB0byBvciB3aXRoaW4gdGhlIHBvc2l0aXZlIG51bWJlciByYW5nZS4KCmBgYHtyfQojIGFuZCB3ZSBjYW4gY2FsY3VsYXRlIHRoZSBjb3JyZXNwb25kaW5nIGNyZWRpYmxlIGludGVydmFscyB1c2luZwojIG91ciBjb2RlIGZyb20gYWJvdmUgYWdhaW4KIyBjYWxsIHRvIGhkcmNkZTpoZHIgdXNpbmcgbGFwcGx5KCkKb3ZlcmxhcC5jcmVkaWJsZXMgPC0gbGFwcGx5KAogIGFzLmRhdGEuZnJhbWUoYmF5ZXMub3ZlcmxhcC5HMi5HMyksIAogIGZ1bmN0aW9uKHgsLi4uKXt0bXA8LWhkcmNkZTo6aGRyKHgpJGhkcn0sCiAgcHJvYiA9IGNyLnApCgpwcmludChvdmVybGFwLmNyZWRpYmxlcykKYGBgCgoKCgo=
@@ -3015,7 +1550,7 @@

Overlap Between Ellipses

// add bootstrap table styles to pandoc tables function bootstrapStylePandocTables() { - $('tr.header').parent('thead').parent('table').addClass('table table-condensed'); + $('tr.odd').parent('tbody').parent('table').addClass('table table-condensed'); } $(document).ready(function () { bootstrapStylePandocTables(); @@ -3044,7 +1579,7 @@

Overlap Between Ellipses

$(document).ready(function () { $('.tabset-dropdown > .nav-tabs > li').click(function () { - $(this).parent().toggleClass('nav-tabs-open') + $(this).parent().toggleClass('nav-tabs-open'); }); }); diff --git a/aj-content/practicals/source-aggregation.Rmd b/aj-content/practicals/source-aggregation.Rmd index bb166e6..8dcff23 100644 --- a/aj-content/practicals/source-aggregation.Rmd +++ b/aj-content/practicals/source-aggregation.Rmd @@ -10,9 +10,9 @@ knitr::opts_chunk$set(echo = TRUE) ``` ## Create some simulated data for us to work with -This is essentially the example used in Fry, B. 2013. Alternative approaches for solving underdetermined isotope mixing problems. *MEPS*. +This is essentially the example used in Fry, B. 2013. Alternative approaches for solving under-determined isotope mixing problems. *MEPS*. -Here we use the package simmr to explore the two alternatives to aggregating sources in mixing models. +Here we use the package `simmr` to explore the two alternatives to aggregating sources in mixing models. ```{r simulate-data} library(simmr, quietly = TRUE) @@ -38,8 +38,8 @@ S_sds = cbind(c(1,1,1,1), c(1,1,1,1)) # speficy the consumer data at the origin # Ten consumers for this example around 0 with small sd of error. -consumers <- cbind(dC = rnorm(10, 0, 0.1), - dN = rnorm(10, 0, 0.1) ) +consumers <- cbind(dC = rnorm(n = 10, mean = 0, sd = 0.1), + dN = rnorm(n = 10, mean = 0, sd = 0.1) ) # and create the simmr object # here we have no TDFs or concentration values diff --git a/aj-content/practicals/source-aggregation.nb.html b/aj-content/practicals/source-aggregation.nb.html index 870201a..4fbd171 100644 --- a/aj-content/practicals/source-aggregation.nb.html +++ b/aj-content/practicals/source-aggregation.nb.html @@ -14,1549 +14,40 @@ Source Aggregation - + + - - - - - - - - - - + + + + + + + + + + + - + code{white-space: pre-wrap;} + span.smallcaps{font-variant: small-caps;} + span.underline{text-decoration: underline;} + div.column{display: inline-block; vertical-align: top; width: 50%;} + div.hanging-indent{margin-left: 1.5em; text-indent: -1.5em;} + ul.task-list{list-style: none;} + + + diff --git a/aj-content/siar-dos-and-donts.Rmd b/aj-content/siar-dos-and-donts.Rmd index 9ef5ebe..ce17e68 100644 --- a/aj-content/siar-dos-and-donts.Rmd +++ b/aj-content/siar-dos-and-donts.Rmd @@ -88,6 +88,7 @@ p <- c(0.2, 0.4, 0.4) consumer <- p %*% sources + plot(sources[,1], sources[,2], pch = c(15,15,15), col = c(1,6,4), xlab = "", ylab = "", bty="L", cex = 3, xlim = c(-12,6), ylim = c(-5, 10))