# libraries ----
-::shelf(
- librarian
- arrow, dismo, dplyr, DT, glue, here, readr, robis, sdmpredictors, terra, sf, mapview,quiet = T)
diff --git a/sdm_1.html b/sdm_1.html index 692d091..eecb759 100644 --- a/sdm_1.html +++ b/sdm_1.html @@ -84,6 +84,14 @@ + + + + + + + + @@ -136,77 +144,82 @@
# libraries ----
-::shelf(
- librarian
- arrow, dismo, dplyr, DT, glue, here, readr, robis, sdmpredictors, terra, sf, mapview,quiet = T)
Warning: package 'arrow' was built under R version 4.3.1
options(readr.show_col_types = F)
-
-# variables -----
-<- "/Users/bbest/My Drive/projects/mbon-sdm/data"
- dir_data <- glue("{dir_data}/raw/obis.org/obis_20230726.parquet")
- obis_prq
-# functions -----
-<- function(
- get_sp_occ_obis_prq
- aphia_id,obis_prq = "/Users/bbest/My Drive/projects/mbon-sdm/data/raw/obis.org/obis_20230726.parquet",
- cols_keep = c(
- "id",
- "phylum",
- "class",
- "taxonRank",
- "scientificName",
- "AphiaID",
- "date_mid",
- "decimalLongitude",
- "decimalLatitude",
- "depth",
- "individualCount",
- "flags")) {
- # get species occurrences from OBIS parquet file
-
- # TODO: add caching per species request/args
-
- # return only observations with valid coordinates and year
- <- open_dataset(obis_prq) |>
- o filter(
- !is.na(date_mid),
- !is.na(decimalLongitude),
- !is.na(decimalLatitude),
- == !!aphia_id) |>
- AphiaID select(all_of(cols_keep)) |>
- collect() |>
- mutate(
- date_mid =as.POSIXct(
- /1000, origin = "1970-01-01",tz = "GMT") |>
- date_midas.Date()) |>
- st_as_sf(
- coords = c("decimalLongitude", "decimalLatitude"),
- crs = 4326)
- }
Warning: package 'leafem' was built under R version 4.3.1
+options(readr.show_col_types = F)
+
+# variables -----
+<- "/Users/bbest/My Drive/projects/mbon-sdm/data"
+ dir_data <- glue("{dir_data}/raw/obis.org/obis_20230726.parquet")
+ obis_prq
+# functions -----
+<- function(
+ get_sp_occ_obis_prq
+ aphia_id,obis_prq = "/Users/bbest/My Drive/projects/mbon-sdm/data/raw/obis.org/obis_20230726.parquet",
+ cols_keep = c(
+ "id",
+ "phylum",
+ "class",
+ "taxonRank",
+ "scientificName",
+ "AphiaID",
+ "date_mid",
+ "decimalLongitude",
+ "decimalLatitude",
+ "depth",
+ "individualCount",
+ "flags")) {
+ # get species occurrences from OBIS parquet file
+
+ # TODO: add caching per species request/args
+
+ # return only observations with valid coordinates and year
+ <- open_dataset(obis_prq) |>
+ o filter(
+ !is.na(date_mid),
+ !is.na(decimalLongitude),
+ !is.na(decimalLatitude),
+ == !!aphia_id) |>
+ AphiaID select(all_of(cols_keep)) |>
+ collect() |>
+ mutate(
+ date_mid =as.POSIXct(
+ /1000, origin = "1970-01-01",tz = "GMT") |>
+ date_midas.Date()) |>
+ st_as_sf(
+ coords = c("decimalLongitude", "decimalLatitude"),
+ crs = 4326)
+ }
# species with most observations
-<- read_csv("data/obis_top-species.csv") |>
- sp_gull arrange(desc(n_obs)) |>
- slice(1)
-
- # non-bird species with most observations
-<- read_csv("data/obis_top-species.csv") |>
- sp_herring filter(class != "Aves") |>
- arrange(desc(n_obs)) |>
- slice(1)
-
-# species with ~100 observations (and most in Class)
-<- read_csv("data/obis_top-species.csv") |>
- sp_jelly filter(n_obs > 240) |>
- arrange(n_obs) |>
- slice(1)
# species with most observations
+<- read_csv("data/obis_top-species.csv") |>
+ sp_gull arrange(desc(n_obs)) |>
+ slice(1)
+
+ # non-bird species with most observations
+<- read_csv("data/obis_top-species.csv") |>
+ sp_herring filter(class != "Aves") |>
+ arrange(desc(n_obs)) |>
+ slice(1)
+
+# species with ~100 observations (and most in Class)
+<- read_csv("data/obis_top-species.csv") |>
+ sp_jelly filter(n_obs > 240) |>
+ arrange(n_obs) |>
+ slice(1)
sp_gull
: Larus fuscus lesser black-backed gull | WoRMS
@@ -226,21 +239,21 @@
N Atlantic right whale (Eubalaena glacialis)
# right whale: surface, migratory, endangered
-<- tibble(
- sp_rwhale AphiaID = 159023)
-
-# prep single species observations ---
-<- sp_rwhale
- sp <- sp$AphiaID
- aphia_id
-# get observations
-<- get_sp_occ_obis_prq(aphia_id)
- o o
# right whale: surface, migratory, endangered
+<- tibble(
+ sp_rwhale AphiaID = 159023)
+
+# prep single species observations ---
+<- sp_rwhale
+ sp <- sp$AphiaID
+ aphia_id
+# get observations
+<- get_sp_occ_obis_prq(aphia_id)
+ obs obs
Simple feature collection with 7359 features and 10 fields
Geometry type: POINT
@@ -250,25 +263,416 @@ N. Atlantic right
# A tibble: 7,359 × 11
id phylum class taxonRank scientificName AphiaID date_mid depth
* <chr> <chr> <chr> <chr> <chr> <int> <date> <dbl>
- 1 0096eb8c-eeaf… Chord… Mamm… Species Eubalaena gla… 159023 2017-06-15 NA
- 2 00be3393-fc00… Chord… Mamm… Species Eubalaena gla… 159023 2003-09-02 NA
- 3 00edac0b-4e7b… Chord… Mamm… Species Eubalaena gla… 159023 2002-08-27 NA
- 4 00f04c3a-702e… Chord… Mamm… Species Eubalaena gla… 159023 2020-09-13 NA
- 5 00f344c2-7c0e… Chord… Mamm… Species Eubalaena gla… 159023 2002-08-23 NA
- 6 011cda0b-d2c8… Chord… Mamm… Species Eubalaena gla… 159023 2019-08-24 NA
- 7 01ad0d52-7c61… Chord… Mamm… Species Eubalaena gla… 159023 2017-03-06 NA
- 8 02198ff2-acde… Chord… Mamm… Species Eubalaena gla… 159023 1998-09-12 NA
- 9 021bb218-68d1… Chord… Mamm… Species Eubalaena gla… 159023 2003-08-31 NA
-10 0220a6b3-6738… Chord… Mamm… Species Eubalaena gla… 159023 2018-05-31 NA
+ 1 6ed27cbe-b7d5… Chord… Mamm… Species Eubalaena gla… 159023 2009-08-28 NA
+ 2 6ef3fd6f-1396… Chord… Mamm… Species Eubalaena gla… 159023 2006-08-18 NA
+ 3 6ef6f965-ddb3… Chord… Mamm… Species Eubalaena gla… 159023 2019-08-09 NA
+ 4 6f3607da-d76f… Chord… Mamm… Species Eubalaena gla… 159023 2006-07-15 NA
+ 5 6f4d9844-ae21… Chord… Mamm… Species Eubalaena gla… 159023 2002-09-19 NA
+ 6 6f5eca54-a19b… Chord… Mamm… Species Eubalaena gla… 159023 2001-09-19 NA
+ 7 6f88b96c-61cd… Chord… Mamm… Species Eubalaena gla… 159023 2009-08-25 NA
+ 8 6f8dea57-f999… Chord… Mamm… Species Eubalaena gla… 159023 2002-08-30 NA
+ 9 6f93b0d9-e829… Chord… Mamm… Species Eubalaena gla… 159023 2006-09-05 NA
+10 6f971a91-e863… Chord… Mamm… Species Eubalaena gla… 159023 2007-09-17 NA
# ℹ 7,349 more rows
# ℹ 3 more variables: individualCount <chr>, flags <chr>, geometry <POINT [°]>
# plot observations
-mapView(o)
# plot observations
+mapView(obs) %>%
+@map |>
+ .::addFullscreenControl() leaflet.extras
sdmpredictors
::shelf(
+ librarian sdmpredictors, skimr, terra)
+ The 'cran_repo' argument in shelf() was not set, so it will use
+ cran_repo = 'https://cran.r-project.org' by default.
+
+ To avoid this message, set the 'cran_repo' argument to a CRAN
+ mirror URL (see https://cran.r-project.org/mirrors.html) or set
+ 'quiet = TRUE'.
+# see ../aquamaps-downscaled/index.qmd for creation
+<- here("../aquamaps-downscaled/data/bio-oracle.tif")
+ env_tif
+stopifnot(file.exists(env_tif))
+
+<- rast(env_tif)
+ env names(env) <- c(
+"Temp",
+ "Salinity",
+ "PrimProd",
+ "IceCon")
+ plot(env)
<- extract(env, obs, cells=T) |>
+ obs_env as_tibble() |>
+ mutate(
+ presence = 1)
+
+<- setdiff(cells(env), obs_env$cell)
+ bk_cells <- tibble(
+ bk_env presence = 0,
+ cell = bk_cells) |>
+ bind_cols(
+ values(env)[bk_cells,]) |>
+ distinct(pick(all_of(names(env))), .keep_all = T)
+ # rows: 6,181,644 -> 6,178,309 after distinct() and na.omit()
+
+set.seed(42)
+
+<- bind_rows(
+ d_env
+ obs_env,|>
+ bk_env slice(sample(1:nrow(bk_env), nrow(obs_env)) ) ) |>
+ select(
+
+ presence, cell,all_of(names(env))) |>
+ na.omit()
+
+tail(d_env)
# A tibble: 6 × 6
+ presence cell Temp Salinity PrimProd IceCon
+ <dbl> <dbl> <dbl> <dbl> <dbl> <dbl>
+1 0 4516596 28.0 34.5 0.00714 0
+2 0 5068209 25.4 35.2 0.0119 0
+3 0 7990275 -1.07 33.9 0.00173 0.422
+4 0 7580430 1.28 33.8 0.00241 0.000265
+5 0 7133196 8.96 34.2 0.00388 0
+6 0 4203555 27.7 34.4 0.00419 0
+# table(d_env$presence)
+# 0 1
+# 6178319 7355
+# 0 1
+# 7359 7355
+
+ d_env
# A tibble: 14,714 × 6
+ presence cell Temp Salinity PrimProd IceCon
+ <dbl> <dbl> <dbl> <dbl> <dbl> <dbl>
+ 1 1 2334160 8.54 30.0 0.0270 0.00000500
+ 2 1 2351442 8.72 30.5 0.0169 0.00000200
+ 3 1 2187314 7.11 27.3 0.0137 0.0297
+ 4 1 2442173 9.11 31.0 0.00347 0.00000200
+ 5 1 2364405 8.77 30.6 0.0119 0.00000100
+ 6 1 2364405 8.77 30.6 0.0119 0.00000100
+ 7 1 2334158 8.48 30.1 0.0253 0.00000600
+ 8 1 2351443 8.75 30.5 0.0162 0.00000200
+ 9 1 2355762 8.73 30.7 0.0144 0.00000100
+10 1 2442178 9.32 30.9 0.00338 0.00000200
+# ℹ 14,704 more rows
+predicts::maxent()
::shelf(predicts) librarian
+ The 'cran_repo' argument in shelf() was not set, so it will use
+ cran_repo = 'https://cran.r-project.org' by default.
+
+ To avoid this message, set the 'cran_repo' argument to a CRAN
+ mirror URL (see https://cran.r-project.org/mirrors.html) or set
+ 'quiet = TRUE'.
+Warning: package 'predicts' was built under R version 4.3.1
+#?predicts::MaxEnt
+# MaxEnt()
+# This is MaxEnt_model version 3.4.3
+
+# get predictor variables
+<- system.file("ex/bio.tif", package="predicts")
+ f <- rast(f)
+ preds plot(preds)
# file with presence points
+<- system.file("/ex/bradypus.csv", package="predicts")
+ occurence <- read.csv(occurence)[,-1]
+ occ
+# witholding a 20% sample for testing
+<- folds(occ, k=5)
+ fold <- occ[fold == 1, ]
+ occtest <- occ[fold != 1, ]
+ occtrain
+# fit model
+<- MaxEnt(preds, occtrain)
+ me
+# see the MaxEnt results in a browser:
+ me
class : MaxEnt_model
+variables: bio1 bio5 bio6 bio7 bio8 bio9 bio12 bio16 bio17
+# plot showing importance of each variable
+plot(me, main="me: Variable contribution")
# TODO: try categorical, not in preds
+# # use "args"
+# me2 <- MaxEnt(preds, occtrain, factors='biome', args=c("-J", "-P"))
+#
+# # plot showing importance of each variable
+# plot(me2, main="me2: Variable contribution")
+
+# response curves
+library(ggplot2)
+
+<- tibble()
+ d for (v in names(preds)){ # v = names(preds)[2]
+<- partialResponse(me, var=v)
+ pr <- bind_rows(
+ d
+ d, |>
+ pr rename(value = 1) |>
+ mutate(
+ var = v))
+ # plot(pr, type="l", las=1)
+ # TODO: lattice ggplot
+
+ }<- d |>
+ g ggplot(aes(x = value, y = p)) +
+ geom_line() +
+ facet_wrap(
+ ~var, scales = "free") +
+ theme_bw()
+ g
::ggplotly(g) plotly
# TODO: convert to function
+
+# pr2 <- partialResponse2(me, var="bio1", var2 = "bio5")
+# plot(pr2, type="l", las=1)
+
+# predict to entire dataset
+<- predict(me, preds)
+ r plot(r)
+points(occ)
# with some options:
+<- predict(me, preds, args=c("outputformat=raw"))
+ r plot(r)
+points(occ)
# get predictor variables
+<- env
+ preds plot(preds)
# witholding a 20% sample for testing
+<- obs |>
+ occ mutate(
+ lon = st_coordinates(geometry)[,1],
+ lat = st_coordinates(geometry)[,2]) |>
+ st_drop_geometry() |>
+ select(lon, lat)
+ <- folds(occ, k=5)
+ fold <- occ[fold == 1, ]
+ occtest <- occ[fold != 1, ]
+ occtrain
+# fit model
+system.time({
+<- MaxEnt(preds, occtrain)
+ me })
Warning in .local(x, p, ...): 2 (0.12%) of the presence points have NA
+predictor values
+ user system elapsed
+ 76.231 0.522 76.635
+# Warning message:
+# In .local(x, p, ...) :
+# 3 (0.19%) of the presence points have NA predictor values
+
+
+# see the MaxEnt results in a browser:
+ me
class : MaxEnt_model
+variables: Temp Salinity PrimProd IceCon
+# plot showing importance of each variable
+plot(me, main="me: Variable contribution")
# TODO: try categorical, not in preds
+# # use "args"
+# me2 <- MaxEnt(preds, occtrain, factors='biome', args=c("-J", "-P"))
+#
+# # plot showing importance of each variable
+# plot(me2, main="me2: Variable contribution")
+
+# response curves
+library(ggplot2)
+
+system.time({
+<- tibble()
+ d for (v in names(preds)){ # v = names(preds)[2]
+<- partialResponse(me, var=v)
+ pr <- bind_rows(
+ d
+ d, |>
+ pr rename(value = 1) |>
+ mutate(
+ var = v))
+ # plot(pr, type="l", las=1)
+ # TODO: lattice ggplot
+
+ }<- d |>
+ g ggplot(aes(x = value, y = p)) +
+ geom_line() +
+ facet_wrap(
+ ~var, scales = "free") +
+ theme_bw()
+
+ g })
user system elapsed
+ 18.749 0.200 18.875
+# plotly::ggplotly(g)
+# TODO: convert to function
+
+# pr2 <- partialResponse2(me, var="bio1", var2 = "bio5")
+# plot(pr2, type="l", las=1)
+
+# predict to entire dataset
+system.time({
+<- predict(me, preds)
+ r })
user system elapsed
+ 85.583 1.209 87.416
+plot(r)
+points(occ)
# with some options:
+# system.time({
+# r <- predict(me, preds, args=c("outputformat=raw"))
+# })
+# plot(r)
+# points(occ)
::shelf(
+ librarian
+ maxnet)
+system.time({
+<- maxnet(
+ m p = d_env |> pull(presence),
+ data = d_env |> select(-presence, -cell) |> as.data.frame())
+ # present/absent:7,359/7,355: 50.149s
+ })
+plot(m, type="cloglog")
+
+predict(m, new)
+
+|> terra::add()
+ env
+
+ env# 2160 * 4320 = 9331200, 5
+<- values(env, dataframe = T, na.rm=F)
+ d_env # d_env <- d_env |>
+# select(-pred)
+dim(d_env) # 9,331,200 4
+
+ncell(env) # 9,331,200
+
+<- na.omit(d_env)
+ d_env_notna dim(d_env_notna) # 6,183,457
+
+<- d_env_notna
+ x
+intersect(attr(x, "na.action"), attr(x, "row.names"))
+class(attr(x, "row.names"))
+
+
+<- predict(m, d_env_notna, clamp = T, type = "logistic") #, clamp=T, type=c("link","exponential","cloglog","logistic"), ...)
+ p length(p[,1]) # 6,183,457
+
+<- predict(m, raster::stack(env), clamp = F, type = "logistic") #, clamp=T,
+ p
+$pred <- NA
+ env$pred[attr(x, "row.names")] <- p[,1]
+ env
+plot(env$pred)
+setValues(env, p)
+
+# why are these different lengths?
+as.numeric(p)
+ncell(env)
+
+length(cells(env))
+length(as.numeric(p))
+
+plot(env$pred)
+<- maxnet(p, data, maxnet.formula(p, data, classes="lq"))
+ mod plot(mod, "tmp6190_ann")
::shelf(eks) librarian
+ The 'cran_repo' argument in shelf() was not set, so it will use
+ cran_repo = 'https://cran.r-project.org' by default.
-
-
+ To avoid this message, set the 'cran_repo' argument to a CRAN
+ mirror URL (see https://cran.r-project.org/mirrors.html) or set
+ 'quiet = TRUE'.
=i.length)return e;var n=[],o=a[r++];return e.forEach((function(e,i){n.push({key:e,values:t(i,r)})})),o?n.sort((function(t,e){return o(t.key,e.key)})):n}(o(t.map,e,0),0)},n.key=function(t){return i.push(t),n},n.sortKeys=function(t){return a[i.length-1]=t,n},n.sortValues=function(t){return e=t,n},n.rollup=function(t){return r=t,n},n},t.set=function(t){var e=new L;if(t)for(var r=0,n=t.length;r 360?t-=360:t<0&&(t+=360),t<60?n+(i-n)*t/60:t<180?i:t<240?n+(i-n)*(240-t)/60:n}(t))}return t=isNaN(t)?0:(t%=360)<0?t+360:t,e=isNaN(e)||e<0?0:e>1?1:e,n=2*(r=r<0?0:r>1?1:r)-(i=r<=.5?r*(1+e):r+e-r*e),new Qt(a(t+120),a(t),a(t-120))}function Ut(e,r,n){return this instanceof Ut?(this.h=+e,this.c=+r,void(this.l=+n)):arguments.length<2?e instanceof Ut?new Ut(e.h,e.c,e.l):Xt(e instanceof qt?e.l:(e=ae((e=t.rgb(e)).r,e.g,e.b)).l,e.a,e.b):new Ut(e,r,n)}Nt.brighter=function(t){return t=Math.pow(.7,arguments.length?t:1),new Bt(this.h,this.s,this.l/t)},Nt.darker=function(t){return t=Math.pow(.7,arguments.length?t:1),new Bt(this.h,this.s,t*this.l)},Nt.rgb=function(){return jt(this.h,this.s,this.l)},t.hcl=Ut;var Vt=Ut.prototype=new Ft;function Ht(t,e,r){return isNaN(t)&&(t=0),isNaN(e)&&(e=0),new qt(r,Math.cos(t*=Lt)*e,Math.sin(t)*e)}function qt(t,e,r){return this instanceof qt?(this.l=+t,this.a=+e,void(this.b=+r)):arguments.length<2?t instanceof qt?new qt(t.l,t.a,t.b):t instanceof Ut?Ht(t.h,t.c,t.l):ae((t=Qt(t)).r,t.g,t.b):new qt(t,e,r)}Vt.brighter=function(t){return new Ut(this.h,this.c,Math.min(100,this.l+Gt*(arguments.length?t:1)))},Vt.darker=function(t){return new Ut(this.h,this.c,Math.max(0,this.l-Gt*(arguments.length?t:1)))},Vt.rgb=function(){return Ht(this.h,this.c,this.l).rgb()},t.lab=qt;var Gt=18,Yt=qt.prototype=new Ft;function Wt(t,e,r){var n=(t+16)/116,i=n+e/500,a=n-r/200;return new Qt(Kt(3.2404542*(i=.95047*Zt(i))-1.5371385*(n=1*Zt(n))-.4985314*(a=1.08883*Zt(a))),Kt(-.969266*i+1.8760108*n+.041556*a),Kt(.0556434*i-.2040259*n+1.0572252*a))}function Xt(t,e,r){return t>0?new Ut(Math.atan2(r,e)*Ct,Math.sqrt(e*e+r*r),t):new Ut(NaN,NaN,t)}function Zt(t){return t>.206893034?t*t*t:(t-4/29)/7.787037}function Jt(t){return t>.008856?Math.pow(t,1/3):7.787037*t+4/29}function Kt(t){return Math.round(255*(t<=.00304?12.92*t:1.055*Math.pow(t,1/2.4)-.055))}function Qt(t,e,r){return this instanceof Qt?(this.r=~~t,this.g=~~e,void(this.b=~~r)):arguments.length<2?t instanceof Qt?new Qt(t.r,t.g,t.b):ne(""+t,Qt,jt):new Qt(t,e,r)}function $t(t){return new Qt(t>>16,t>>8&255,255&t)}function te(t){return $t(t)+""}Yt.brighter=function(t){return new qt(Math.min(100,this.l+Gt*(arguments.length?t:1)),this.a,this.b)},Yt.darker=function(t){return new qt(Math.max(0,this.l-Gt*(arguments.length?t:1)),this.a,this.b)},Yt.rgb=function(){return Wt(this.l,this.a,this.b)},t.rgb=Qt;var ee=Qt.prototype=new Ft;function re(t){return t<16?"0"+Math.max(0,t).toString(16):Math.min(255,t).toString(16)}function ne(t,e,r){var n,i,a,o=0,s=0,l=0;if(n=/([a-z]+)\((.*)\)/.exec(t=t.toLowerCase()))switch(i=n[2].split(","),n[1]){case"hsl":return r(parseFloat(i[0]),parseFloat(i[1])/100,parseFloat(i[2])/100);case"rgb":return e(se(i[0]),se(i[1]),se(i[2]))}return(a=le.get(t))?e(a.r,a.g,a.b):(null==t||"#"!==t.charAt(0)||isNaN(a=parseInt(t.slice(1),16))||(4===t.length?(o=(3840&a)>>4,o|=o>>4,s=240&a,s|=s>>4,l=15&a,l|=l<<4):7===t.length&&(o=(16711680&a)>>16,s=(65280&a)>>8,l=255&a)),e(o,s,l))}function ie(t,e,r){var n,i,a=Math.min(t/=255,e/=255,r/=255),o=Math.max(t,e,r),s=o-a,l=(o+a)/2;return s?(i=l<.5?s/(o+a):s/(2-o-a),n=t==o?(e-r)/s+(e =f[0]&&l<=f[1]&&((s=c[t.bisect(h,l,1,d)-1]).y+=m,s.push(a[o]));return c}return a.value=function(t){return arguments.length?(r=t,a):r},a.range=function(t){return arguments.length?(n=ce(t),a):n},a.bins=function(t){return arguments.length?(i="number"==typeof t?function(e){return vn(e,t)}:ce(t),a):i},a.frequency=function(t){return arguments.length?(e=!!t,a):e},a},t.layout.pack=function(){var e,r=t.layout.hierarchy().sort(xn),n=0,i=[1,1];function a(t,a){var o=r.call(this,t,a),s=o[0],l=i[0],c=i[1],u=null==e?Math.sqrt:"function"==typeof e?e:function(){return e};if(s.x=s.y=0,$r(s,(function(t){t.r=+u(t.value)})),$r(s,Tn),n){var f=n*(e?1:Math.max(2*s.r/l,2*s.r/c))/2;$r(s,(function(t){t.r+=f})),$r(s,Tn),$r(s,(function(t){t.r-=f}))}return function t(e,r,n,i){var a=e.children;if(e.x=r+=i*e.x,e.y=n+=i*e.y,e.r*=i,a)for(var o=-1,s=a.length;++o =r)for(n=r;++an&&(n=r)}else for(;++a=r)for(n=r;++an&&(n=r);return n},t.mean=function(t,e){var r,n=t.length,i=n,a=-1,o=0;if(null==e)for(;++a l.length)return r;var i,a=c[n-1];return null!=e&&n>=l.length?i=r.entries():(i=[],r.each((function(e,r){i.push({key:r,values:t(e,n)})}))),null!=a?i.sort((function(t,e){return a(t.key,e.key)})):i}(u(t,0,a,o),0)},key:function(t){return l.push(t),s},sortKeys:function(t){return c[l.length-1]=t,s},sortValues:function(e){return t=e,s},rollup:function(t){return e=t,s}}},t.set=c,t.map=r,t.keys=function(t){var e=[];for(var r in t)e.push(r);return e},t.values=function(t){var e=[];for(var r in t)e.push(t[r]);return e},t.entries=function(t){var e=[];for(var r in t)e.push({key:r,value:t[r]});return e},Object.defineProperty(t,"__esModule",{value:!0})}))},{}],104:[function(t,e,r){!function(t,n){"object"==typeof r&&void 0!==e?n(r):n((t=t||self).d3=t.d3||{})}(this,(function(t){"use strict";function e(t,e,r){t.prototype=e.prototype=r,r.constructor=t}function r(t,e){var r=Object.create(t.prototype);for(var n in e)r[n]=e[n];return r}function n(){}var i="\\s*([+-]?\\d+)\\s*",a="\\s*([+-]?\\d*\\.?\\d+(?:[eE][+-]?\\d+)?)\\s*",o="\\s*([+-]?\\d*\\.?\\d+(?:[eE][+-]?\\d+)?)%\\s*",s=/^#([0-9a-f]{3,8})$/,l=new RegExp("^rgb\\("+[i,i,i]+"\\)$"),c=new RegExp("^rgb\\("+[o,o,o]+"\\)$"),u=new RegExp("^rgba\\("+[i,i,i,a]+"\\)$"),f=new RegExp("^rgba\\("+[o,o,o,a]+"\\)$"),h=new RegExp("^hsl\\("+[a,o,o]+"\\)$"),p=new RegExp("^hsla\\("+[a,o,o,a]+"\\)$"),d={aliceblue:15792383,antiquewhite:16444375,aqua:65535,aquamarine:8388564,azure:15794175,beige:16119260,bisque:16770244,black:0,blanchedalmond:16772045,blue:255,blueviolet:9055202,brown:10824234,burlywood:14596231,cadetblue:6266528,chartreuse:8388352,chocolate:13789470,coral:16744272,cornflowerblue:6591981,cornsilk:16775388,crimson:14423100,cyan:65535,darkblue:139,darkcyan:35723,darkgoldenrod:12092939,darkgray:11119017,darkgreen:25600,darkgrey:11119017,darkkhaki:12433259,darkmagenta:9109643,darkolivegreen:5597999,darkorange:16747520,darkorchid:10040012,darkred:9109504,darksalmon:15308410,darkseagreen:9419919,darkslateblue:4734347,darkslategray:3100495,darkslategrey:3100495,darkturquoise:52945,darkviolet:9699539,deeppink:16716947,deepskyblue:49151,dimgray:6908265,dimgrey:6908265,dodgerblue:2003199,firebrick:11674146,floralwhite:16775920,forestgreen:2263842,fuchsia:16711935,gainsboro:14474460,ghostwhite:16316671,gold:16766720,goldenrod:14329120,gray:8421504,green:32768,greenyellow:11403055,grey:8421504,honeydew:15794160,hotpink:16738740,indianred:13458524,indigo:4915330,ivory:16777200,khaki:15787660,lavender:15132410,lavenderblush:16773365,lawngreen:8190976,lemonchiffon:16775885,lightblue:11393254,lightcoral:15761536,lightcyan:14745599,lightgoldenrodyellow:16448210,lightgray:13882323,lightgreen:9498256,lightgrey:13882323,lightpink:16758465,lightsalmon:16752762,lightseagreen:2142890,lightskyblue:8900346,lightslategray:7833753,lightslategrey:7833753,lightsteelblue:11584734,lightyellow:16777184,lime:65280,limegreen:3329330,linen:16445670,magenta:16711935,maroon:8388608,mediumaquamarine:6737322,mediumblue:205,mediumorchid:12211667,mediumpurple:9662683,mediumseagreen:3978097,mediumslateblue:8087790,mediumspringgreen:64154,mediumturquoise:4772300,mediumvioletred:13047173,midnightblue:1644912,mintcream:16121850,mistyrose:16770273,moccasin:16770229,navajowhite:16768685,navy:128,oldlace:16643558,olive:8421376,olivedrab:7048739,orange:16753920,orangered:16729344,orchid:14315734,palegoldenrod:15657130,palegreen:10025880,paleturquoise:11529966,palevioletred:14381203,papayawhip:16773077,peachpuff:16767673,peru:13468991,pink:16761035,plum:14524637,powderblue:11591910,purple:8388736,rebeccapurple:6697881,red:16711680,rosybrown:12357519,royalblue:4286945,saddlebrown:9127187,salmon:16416882,sandybrown:16032864,seagreen:3050327,seashell:16774638,sienna:10506797,silver:12632256,skyblue:8900331,slateblue:6970061,slategray:7372944,slategrey:7372944,snow:16775930,springgreen:65407,steelblue:4620980,tan:13808780,teal:32896,thistle:14204888,tomato:16737095,turquoise:4251856,violet:15631086,wheat:16113331,white:16777215,whitesmoke:16119285,yellow:16776960,yellowgreen:10145074};function m(){return this.rgb().formatHex()}function g(){return this.rgb().formatRgb()}function v(t){var e,r;return t=(t+"").trim().toLowerCase(),(e=s.exec(t))?(r=e[1].length,e=parseInt(e[1],16),6===r?y(e):3===r?new w(e>>8&15|e>>4&240,e>>4&15|240&e,(15&e)<<4|15&e,1):8===r?x(e>>24&255,e>>16&255,e>>8&255,(255&e)/255):4===r?x(e>>12&15|e>>8&240,e>>8&15|e>>4&240,e>>4&15|240&e,((15&e)<<4|15&e)/255):null):(e=l.exec(t))?new w(e[1],e[2],e[3],1):(e=c.exec(t))?new w(255*e[1]/100,255*e[2]/100,255*e[3]/100,1):(e=u.exec(t))?x(e[1],e[2],e[3],e[4]):(e=f.exec(t))?x(255*e[1]/100,255*e[2]/100,255*e[3]/100,e[4]):(e=h.exec(t))?M(e[1],e[2]/100,e[3]/100,1):(e=p.exec(t))?M(e[1],e[2]/100,e[3]/100,e[4]):d.hasOwnProperty(t)?y(d[t]):"transparent"===t?new w(NaN,NaN,NaN,0):null}function y(t){return new w(t>>16&255,t>>8&255,255&t,1)}function x(t,e,r,n){return n<=0&&(t=e=r=NaN),new w(t,e,r,n)}function b(t){return t instanceof n||(t=v(t)),t?new w((t=t.rgb()).r,t.g,t.b,t.opacity):new w}function _(t,e,r,n){return 1===arguments.length?b(t):new w(t,e,r,null==n?1:n)}function w(t,e,r,n){this.r=+t,this.g=+e,this.b=+r,this.opacity=+n}function T(){return"#"+A(this.r)+A(this.g)+A(this.b)}function k(){var t=this.opacity;return(1===(t=isNaN(t)?1:Math.max(0,Math.min(1,t)))?"rgb(":"rgba(")+Math.max(0,Math.min(255,Math.round(this.r)||0))+", "+Math.max(0,Math.min(255,Math.round(this.g)||0))+", "+Math.max(0,Math.min(255,Math.round(this.b)||0))+(1===t?")":", "+t+")")}function A(t){return((t=Math.max(0,Math.min(255,Math.round(t)||0)))<16?"0":"")+t.toString(16)}function M(t,e,r,n){return n<=0?t=e=r=NaN:r<=0||r>=1?t=e=NaN:e<=0&&(t=NaN),new L(t,e,r,n)}function S(t){if(t instanceof L)return new L(t.h,t.s,t.l,t.opacity);if(t instanceof n||(t=v(t)),!t)return new L;if(t instanceof L)return t;var e=(t=t.rgb()).r/255,r=t.g/255,i=t.b/255,a=Math.min(e,r,i),o=Math.max(e,r,i),s=NaN,l=o-a,c=(o+a)/2;return l?(s=e===o?(r-i)/l+6*(r0&&c<1?0:s,new L(s,l,c,t.opacity)}function E(t,e,r,n){return 1===arguments.length?S(t):new L(t,e,r,null==n?1:n)}function L(t,e,r,n){this.h=+t,this.s=+e,this.l=+r,this.opacity=+n}function C(t,e,r){return 255*(t<60?e+(r-e)*t/60:t<180?r:t<240?e+(r-e)*(240-t)/60:e)}e(n,v,{copy:function(t){return Object.assign(new this.constructor,this,t)},displayable:function(){return this.rgb().displayable()},hex:m,formatHex:m,formatHsl:function(){return S(this).formatHsl()},formatRgb:g,toString:g}),e(w,_,r(n,{brighter:function(t){return t=null==t?1/.7:Math.pow(1/.7,t),new w(this.r*t,this.g*t,this.b*t,this.opacity)},darker:function(t){return t=null==t?.7:Math.pow(.7,t),new w(this.r*t,this.g*t,this.b*t,this.opacity)},rgb:function(){return this},displayable:function(){return-.5<=this.r&&this.r<255.5&&-.5<=this.g&&this.g<255.5&&-.5<=this.b&&this.b<255.5&&0<=this.opacity&&this.opacity<=1},hex:T,formatHex:T,formatRgb:k,toString:k})),e(L,E,r(n,{brighter:function(t){return t=null==t?1/.7:Math.pow(1/.7,t),new L(this.h,this.s,this.l*t,this.opacity)},darker:function(t){return t=null==t?.7:Math.pow(.7,t),new L(this.h,this.s,this.l*t,this.opacity)},rgb:function(){var t=this.h%360+360*(this.h<0),e=isNaN(t)||isNaN(this.s)?0:this.s,r=this.l,n=r+(r<.5?r:1-r)*e,i=2*r-n;return new w(C(t>=240?t-240:t+120,i,n),C(t,i,n),C(t<120?t+240:t-120,i,n),this.opacity)},displayable:function(){return(0<=this.s&&this.s<=1||isNaN(this.s))&&0<=this.l&&this.l<=1&&0<=this.opacity&&this.opacity<=1},formatHsl:function(){var t=this.opacity;return(1===(t=isNaN(t)?1:Math.max(0,Math.min(1,t)))?"hsl(":"hsla(")+(this.h||0)+", "+100*(this.s||0)+"%, "+100*(this.l||0)+"%"+(1===t?")":", "+t+")")}}));var P=Math.PI/180,I=180/Math.PI,O=6/29,z=3*O*O;function D(t){if(t instanceof F)return new F(t.l,t.a,t.b,t.opacity);if(t instanceof q)return G(t);t instanceof w||(t=b(t));var e,r,n=U(t.r),i=U(t.g),a=U(t.b),o=B((.2225045*n+.7168786*i+.0606169*a)/1);return n===i&&i===a?e=r=o:(e=B((.4360747*n+.3850649*i+.1430804*a)/.96422),r=B((.0139322*n+.0971045*i+.7141733*a)/.82521)),new F(116*o-16,500*(e-o),200*(o-r),t.opacity)}function R(t,e,r,n){return 1===arguments.length?D(t):new F(t,e,r,null==n?1:n)}function F(t,e,r,n){this.l=+t,this.a=+e,this.b=+r,this.opacity=+n}function B(t){return t>.008856451679035631?Math.pow(t,1/3):t/z+4/29}function N(t){return t>O?t*t*t:z*(t-4/29)}function j(t){return 255*(t<=.0031308?12.92*t:1.055*Math.pow(t,1/2.4)-.055)}function U(t){return(t/=255)<=.04045?t/12.92:Math.pow((t+.055)/1.055,2.4)}function V(t){if(t instanceof q)return new q(t.h,t.c,t.l,t.opacity);if(t instanceof F||(t=D(t)),0===t.a&&0===t.b)return new q(NaN,0=0&&"xmlns"!==(r=t.slice(0,e))&&(t=t.slice(e+1)),J.hasOwnProperty(r)?{space:J[r],local:t}:t}},Y.attr=function(e,r){if(arguments.length<2){if("string"==typeof e){var n=this.node();return(e=t.ns.qualify(e)).local?n.getAttributeNS(e.space,e.local):n.getAttribute(e)}for(r in e)this.each(K(r,e[r]));return this}return this.each(K(e,r))},Y.classed=function(t,e){if(arguments.length<2){if("string"==typeof t){var r=this.node(),n=(t=tt(t)).length,i=-1;if(e=r.classList){for(;++i=1?1:t(e)}}function kr(t){return function(e){return 1-t(1-e)}}function Ar(t){return function(e){return.5*(e<.5?t(2*e):2-t(2-2*e))}}function Mr(t){return t*t}function Sr(t){return t*t*t}function Er(t){if(t<=0)return 0;if(t>=1)return 1;var e=t*t,r=e*t;return 4*(t<.5?r:3*(t-e)+r-.75)}function Lr(t){return 1-Math.cos(t*Et)}function Cr(t){return Math.pow(2,10*(t-1))}function Pr(t){return 1-Math.sqrt(1-t*t)}function Ir(t){return t<1/2.75?7.5625*t*t:t<2/2.75?7.5625*(t-=1.5/2.75)*t+.75:t<2.5/2.75?7.5625*(t-=2.25/2.75)*t+.9375:7.5625*(t-=2.625/2.75)*t+.984375}function Or(t,e){return e-=t,function(r){return Math.round(t+e*r)}}function zr(t){var e,r,n,i=[t.a,t.b],a=[t.c,t.d],o=Rr(i),s=Dr(i,a),l=Rr(((e=a)[0]+=(n=-s)*(r=i)[0],e[1]+=n*r[1],e))||0;i[0]*a[1]=0?t.slice(0,e):t,i=e>=0?t.slice(e+1):"in";return n=_r.get(n)||br,Tr((i=wr.get(i)||C)(n.apply(null,r.call(arguments,1))))},t.interpolateHcl=function(e,r){e=t.hcl(e),r=t.hcl(r);var n=e.h,i=e.c,a=e.l,o=r.h-n,s=r.c-i,l=r.l-a;isNaN(s)&&(s=0,i=isNaN(i)?r.c:i);isNaN(o)?(o=0,n=isNaN(n)?r.h:n):o>180?o-=360:o<-180&&(o+=360);return function(t){return Ht(n+o*t,i+s*t,a+l*t)+""}},t.interpolateHsl=function(e,r){e=t.hsl(e),r=t.hsl(r);var n=e.h,i=e.s,a=e.l,o=r.h-n,s=r.s-i,l=r.l-a;isNaN(s)&&(s=0,i=isNaN(i)?r.s:i);isNaN(o)?(o=0,n=isNaN(n)?r.h:n):o>180?o-=360:o<-180&&(o+=360);return function(t){return jt(n+o*t,i+s*t,a+l*t)+""}},t.interpolateLab=function(e,r){e=t.lab(e),r=t.lab(r);var n=e.l,i=e.a,a=e.b,o=r.l-n,s=r.a-i,l=r.b-a;return function(t){return Wt(n+o*t,i+s*t,a+l*t)+""}},t.interpolateRound=Or,t.transform=function(e){var r=i.createElementNS(t.ns.prefix.svg,"g");return(t.transform=function(t){if(null!=t){r.setAttribute("transform",t);var e=r.transform.baseVal.consolidate()}return new zr(e?e.matrix:Fr)})(e)},zr.prototype.toString=function(){return"translate("+this.translate+")rotate("+this.rotate+")skewX("+this.skew+")scale("+this.scale+")"};var Fr={a:1,b:0,c:0,d:1,e:0,f:0};function Br(t){return t.length?t.pop()+",":""}function Nr(e,r){var n=[],i=[];return e=t.transform(e),r=t.transform(r),function(t,e,r,n){if(t[0]!==e[0]||t[1]!==e[1]){var i=r.push("translate(",null,",",null,")");n.push({i:i-4,x:dr(t[0],e[0])},{i:i-2,x:dr(t[1],e[1])})}else(e[0]||e[1])&&r.push("translate("+e+")")}(e.translate,r.translate,n,i),function(t,e,r,n){t!==e?(t-e>180?e+=360:e-t>180&&(t+=360),n.push({i:r.push(Br(r)+"rotate(",null,")")-2,x:dr(t,e)})):e&&r.push(Br(r)+"rotate("+e+")")}(e.rotate,r.rotate,n,i),function(t,e,r,n){t!==e?n.push({i:r.push(Br(r)+"skewX(",null,")")-2,x:dr(t,e)}):e&&r.push(Br(r)+"skewX("+e+")")}(e.skew,r.skew,n,i),function(t,e,r,n){if(t[0]!==e[0]||t[1]!==e[1]){var i=r.push(Br(r)+"scale(",null,",",null,")");n.push({i:i-4,x:dr(t[0],e[0])},{i:i-2,x:dr(t[1],e[1])})}else 1===e[0]&&1===e[1]||r.push(Br(r)+"scale("+e+")")}(e.scale,r.scale,n,i),e=r=null,function(t){for(var e,r=-1,a=i.length;++r0?n=t:(e.c=null,e.t=NaN,e=null,l.end({type:"end",alpha:n=0})):t>0&&(l.start({type:"start",alpha:n=t}),e=ve(s.tick)),s):n},s.start=function(){var t,e,r,n=v.length,l=y.length,u=c[0],d=c[1];for(t=0;tp.x&&(p=t),t.depth>d.depth&&(d=t)}));var m=r(h,p)/2-h.x,g=n[0]/(p.x+r(p,h)/2+m),v=n[1]/(d.depth||1);Qr(u,(function(t){t.x=(t.x+m)*g,t.y=t.depth*v}))}return c}function o(t){var e=t.children,n=t.parent.children,i=t.i?n[t.i-1]:null;if(e.length){!function(t){var e,r=0,n=0,i=t.children,a=i.length;for(;--a>=0;)(e=i[a]).z+=r,e.m+=r,r+=e.s+(n+=e.c)}(t);var a=(e[0].z+e[e.length-1].z)/2;i?(t.z=i.z+r(t._,i._),t.m=t.z-a):t.z=a}else i&&(t.z=i.z+r(t._,i._));t.parent.A=function(t,e,n){if(e){for(var i,a=t,o=t,s=e,l=a.parent.children[0],c=a.m,u=o.m,f=s.m,h=l.m;s=Ln(s),a=En(a),s&&a;)l=En(l),(o=Ln(o)).a=t,(i=s.z+f-a.z-c+r(s._,a._))>0&&(Cn(Pn(s,t,n),t,i),c+=i,u+=i),f+=s.m,c+=a.m,h+=l.m,u+=o.m;s&&!Ln(o)&&(o.t=s,o.m+=f-u),a&&!En(l)&&(l.t=a,l.m+=c-h,n=t)}return n}(t,i,t.parent.A||n[0])}function s(t){t._.x=t.z+t.parent.m,t.m+=t.parent.m}function l(t){t.x*=n[0],t.y=t.depth*n[1]}return a.separation=function(t){return arguments.length?(r=t,a):r},a.size=function(t){return arguments.length?(i=null==(n=t)?l:null,a):i?null:n},a.nodeSize=function(t){return arguments.length?(i=null==(n=t)?null:l,a):i?n:null},Kr(a,e)},t.layout.cluster=function(){var e=t.layout.hierarchy().sort(null).value(null),r=Sn,n=[1,1],i=!1;function a(a,o){var s,l=e.call(this,a,o),c=l[0],u=0;$r(c,(function(e){var n=e.children;n&&n.length?(e.x=function(t){return t.reduce((function(t,e){return t+e.x}),0)/t.length}(n),e.y=function(e){return 1+t.max(e,(function(t){return t.y}))}(n)):(e.x=s?u+=r(e,s):0,e.y=0,s=e)}));var f=function t(e){var r=e.children;return r&&r.length?t(r[0]):e}(c),h=function t(e){var r,n=e.children;return n&&(r=n.length)?t(n[r-1]):e}(c),p=f.x-r(f,h)/2,d=h.x+r(h,f)/2;return $r(c,i?function(t){t.x=(t.x-c.x)*n[0],t.y=(c.y-t.y)*n[1]}:function(t){t.x=(t.x-p)/(d-p)*n[0],t.y=(1-(c.y?t.y/c.y:1))*n[1]}),l}return a.separation=function(t){return arguments.length?(r=t,a):r},a.size=function(t){return arguments.length?(i=null==(n=t),a):i?null:n},a.nodeSize=function(t){return arguments.length?(i=null!=(n=t),a):i?n:null},Kr(a,e)},t.layout.treemap=function(){var e,r=t.layout.hierarchy(),n=Math.round,i=[1,1],a=null,o=In,s=!1,l="squarify",c=.5*(1+Math.sqrt(5));function u(t,e){for(var r,n,i=-1,a=t.length;++i0;)s.push(r=c[i-1]),s.area+=r.area,"squarify"!==l||(n=p(s,m))<=h?(c.pop(),h=n):(s.area-=s.pop().area,d(s,m,a,!1),m=Math.min(a.dx,a.dy),s.length=s.area=0,h=1/0);s.length&&(d(s,m,a,!0),s.length=s.area=0),e.forEach(f)}}function h(t){var e=t.children;if(e&&e.length){var r,n=o(t),i=e.slice(),a=[];for(u(i,n.dx*n.dy/t.value),a.area=0;r=i.pop();)a.push(r),a.area+=r.area,null!=r.z&&(d(a,r.z?n.dx:n.dy,n,!i.length),a.length=a.area=0);e.forEach(h)}}function p(t,e){for(var r,n=t.area,i=0,a=1/0,o=-1,s=t.length;++oi&&(i=r));return e*=e,(n*=n)?Math.max(e*i*c/n,n/(e*a*c)):1/0}function d(t,e,r,i){var a,o=-1,s=t.length,l=r.x,c=r.y,u=e?n(t.area/e):0;if(e==r.dx){for((i||u>r.dy)&&(u=r.dy);++or.dx)&&(u=r.dx);++o1);return t+e*r*Math.sqrt(-2*Math.log(i)/i)}},logNormal:function(){var e=t.random.normal.apply(t,arguments);return function(){return Math.exp(e())}},bates:function(e){var r=t.random.irwinHall(e);return function(){return r()/e}},irwinHall:function(t){return function(){for(var e=0,r=0;rl;u--);e=e.slice(c,u)}return e},s.copy=function(){return t(e.copy(),r,n,i)},Un(s,e)}(t.scale.linear().domain([0,1]),10,!0,[1,10])};var Gn={floor:function(t){return-Math.ceil(-t)},ceil:function(t){return-Math.floor(-t)}};function Yn(t){return function(e){return e<0?-Math.pow(-e,t):Math.pow(e,t)}}t.scale.pow=function(){return function t(e,r,n){var i=Yn(r),a=Yn(1/r);function o(t){return e(i(t))}return o.invert=function(t){return a(e.invert(t))},o.domain=function(t){return arguments.length?(e.domain((n=t.map(Number)).map(i)),o):n},o.ticks=function(t){return qn(n,t)},o.tickFormat=function(t,e){return d3_scale_linearTickFormat(n,t,e)},o.nice=function(t){return o.domain(Vn(n,t))},o.exponent=function(t){return arguments.length?(i=Yn(r=t),a=Yn(1/r),e.domain(n.map(i)),o):r},o.copy=function(){return t(e.copy(),r,n)},Un(o,e)}(t.scale.linear(),1,[0,1])},t.scale.sqrt=function(){return t.scale.pow().exponent(.5)},t.scale.ordinal=function(){return function e(r,n){var i,a,o;function s(t){return a[((i.get(t)||("range"===n.t?i.set(t,r.push(t)):NaN))-1)%a.length]}function l(e,n){return t.range(r.length).map((function(t){return e+n*t}))}return s.domain=function(t){if(!arguments.length)return r;r=[],i=new _;for(var e,a=-1,o=t.length;++a=St)return l(c,p)+(s?l(s,1-p):"")+"Z";var d,m,g,v,y,x,b,_,w,T,k,A,M=0,S=0,E=[];if((v=(+o.apply(this,arguments)||0)/2)&&(g=n===Qn?Math.sqrt(s*s+c*c):+n.apply(this,arguments),p||(S*=-1),c&&(S=Pt(g/c*Math.sin(v))),s&&(M=Pt(g/s*Math.sin(v)))),c){y=c*Math.cos(u+S),x=c*Math.sin(u+S),b=c*Math.cos(f-S),_=c*Math.sin(f-S);var L=Math.abs(f-u-2*S)<=At?0:1;if(S&&ii(y,x,b,_)===p^L){var C=(u+f)/2;y=c*Math.cos(C),x=c*Math.sin(C),b=_=null}}else y=x=0;if(s){w=s*Math.cos(f-M),T=s*Math.sin(f-M),k=s*Math.cos(u+M),A=s*Math.sin(u+M);var P=Math.abs(u-f+2*M)<=At?0:1;if(M&&ii(w,T,k,A)===1-p^P){var I=(u+f)/2;w=s*Math.cos(I),T=s*Math.sin(I),k=A=null}}else w=T=0;if(h>kt&&(d=Math.min(Math.abs(c-s)/2,+r.apply(this,arguments)))>.001){m=s=0&&0,t+e.replace(/\u001b\[\d\d?m/g,"").length+1}),0)>60)return r[0]+(""===e?"":e+"\n ")+" "+t.join(",\n ")+" "+r[1];return r[0]+e+" "+t.join(", ")+" "+r[1]}(c,b,A)):A[0]+b+A[1]}function f(t){return"["+Error.prototype.toString.call(t)+"]"}function h(t,e,r,n,i,a){var o,s,l;if((l=Object.getOwnPropertyDescriptor(e,i)||{value:e[i]}).get?s=l.set?t.stylize("[Getter/Setter]","special"):t.stylize("[Getter]","special"):l.set&&(s=t.stylize("[Setter]","special")),E(n,i)||(o="["+i+"]"),s||(t.seen.indexOf(l.value)<0?(s=m(r)?u(t,l.value,null):u(t,l.value,r-1)).indexOf("\n")>-1&&(s=a?s.split("\n").map((function(t){return" "+t})).join("\n").substr(2):"\n"+s.split("\n").map((function(t){return" "+t})).join("\n")):s=t.stylize("[Circular]","special")),y(o)){if(a&&i.match(/^\d+$/))return s;(o=JSON.stringify(""+i)).match(/^"([a-zA-Z_][a-zA-Z_0-9]*)"$/)?(o=o.substr(1,o.length-2),o=t.stylize(o,"name")):(o=o.replace(/'/g,"\\'").replace(/\\"/g,'"').replace(/(^"|"$)/g,"'"),o=t.stylize(o,"string"))}return o+": "+s}function p(t){return Array.isArray(t)}function d(t){return"boolean"==typeof t}function m(t){return null===t}function g(t){return"number"==typeof t}function v(t){return"string"==typeof t}function y(t){return void 0===t}function x(t){return b(t)&&"[object RegExp]"===k(t)}function b(t){return"object"==typeof t&&null!==t}function _(t){return b(t)&&"[object Date]"===k(t)}function w(t){return b(t)&&("[object Error]"===k(t)||t instanceof Error)}function T(t){return"function"==typeof t}function k(t){return Object.prototype.toString.call(t)}function A(t){return t<10?"0"+t.toString(10):t.toString(10)}r.debuglog=function(t){if(y(a)&&(a=e.env.NODE_DEBUG||""),t=t.toUpperCase(),!o[t])if(new RegExp("\\b"+t+"\\b","i").test(a)){var n=e.pid;o[t]=function(){var e=r.format.apply(r,arguments);console.error("%s %d: %s",t,n,e)}}else o[t]=function(){};return o[t]},r.inspect=s,s.colors={bold:[1,22],italic:[3,23],underline:[4,24],inverse:[7,27],white:[37,39],grey:[90,39],black:[30,39],blue:[34,39],cyan:[36,39],green:[32,39],magenta:[35,39],red:[31,39],yellow:[33,39]},s.styles={special:"cyan",number:"yellow",boolean:"yellow",undefined:"grey",null:"bold",string:"green",date:"magenta",regexp:"red"},r.isArray=p,r.isBoolean=d,r.isNull=m,r.isNullOrUndefined=function(t){return null==t},r.isNumber=g,r.isString=v,r.isSymbol=function(t){return"symbol"==typeof t},r.isUndefined=y,r.isRegExp=x,r.isObject=b,r.isDate=_,r.isError=w,r.isFunction=T,r.isPrimitive=function(t){return null===t||"boolean"==typeof t||"number"==typeof t||"string"==typeof t||"symbol"==typeof t||void 0===t},r.isBuffer=t("./support/isBuffer");var M=["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"];function S(){var t=new Date,e=[A(t.getHours()),A(t.getMinutes()),A(t.getSeconds())].join(":");return[t.getDate(),M[t.getMonth()],e].join(" ")}function E(t,e){return Object.prototype.hasOwnProperty.call(t,e)}r.log=function(){console.log("%s - %s",S(),r.format.apply(r,arguments))},r.inherits=t("inherits"),r._extend=function(t,e){if(!e||!b(e))return t;for(var r=Object.keys(e),n=r.length;n--;)t[r[n]]=e[r[n]];return t}}).call(this)}).call(this,t("_process"),"undefined"!=typeof global?global:"undefined"!=typeof self?self:"undefined"!=typeof window?window:{})},{"./support/isBuffer":73,_process:272,inherits:72}],75:[function(t,e,r){"use strict";r.byteLength=function(t){var e=c(t),r=e[0],n=e[1];return 3*(r+n)/4-n},r.toByteArray=function(t){var e,r,n=c(t),o=n[0],s=n[1],l=new a(function(t,e,r){return 3*(e+r)/4-r}(0,o,s)),u=0,f=s>0?o-4:o;for(r=0;rs?s:o+16383));1===i?(e=t[r-1],a.push(n[e>>2]+n[e<<4&63]+"==")):2===i&&(e=(t[r-2]<<8)+t[r-1],a.push(n[e>>10]+n[e>>4&63]+n[e<<2&63]+"="));return a.join("")};for(var n=[],i=[],a="undefined"!=typeof Uint8Array?Uint8Array:Array,o="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",s=0,l=o.length;ss&&(r=s-l),a=r;a>=0;a--){for(var f=!0,h=0;hf;)h.pop(),--p;var d,m=new Array(p+1);for(a=0;a<=p;++a)(d=m[a]=[]).x0=a>0?h[a-1]:u,d.x1=a(l=t.charCodeAt(a))||l>57){u=(46===l?p+t.slice(a+1):t.slice(a))+u,t=t.slice(0,a);break}}x&&!f&&(t=o(t,1/0));var S=c.length+t.length+u.length,E=Sa[o][2][0];++o);var l=t(e-a[o][1][0],n);return l[0]+=t(a[o][1][0],i*n>i*a[o][0][1]?a[o][0][1]:n)[0],l}n?o.invert=n(o):t.invert&&(o.invert=function(e,n){for(var i=a[+(n<0)],s=r[+(n<0)],l=0,c=i.length;l1.790857183?e=1.790857183:e<-1.790857183&&(e=-1.790857183);var r,i=e;do{var a=i*i;i-=r=(i*(1.0148+a*a*(.23185+a*(.02406*a-.14499)))-e)/(1.0148+a*a*(5*.23185+a*(.21654*a-1.01493)))}while(n(r)>v);return[t,i]},Fe.invert=function(t,e){if(n(e)pr&&p0?y-l:l)*A],u=e.geoProjection(t(s)).rotate(c),f=e.geoRotation(c),h=u.center;return delete u.rotate,u.center=function(t){return arguments.length?h(f(t)):f.invert(h())},u.clipAngle(90)}function Mr(t){var r=o(t);function n(t,n){var i=e.geoGnomonicRaw(t,n);return i[0]*=r,i}return n.invert=function(t,n){return e.geoGnomonicRaw.invert(t/r,n)},n}function Sr(t,e){return Ar(Mr,t,e)}function Er(t){if(!(t*=2))return e.geoAzimuthalEquidistantRaw;var r=-t/2,n=-r,i=t*t,s=g(n),l=.5/m(n);function c(e,a){var s=E(o(a)*o(e-r)),l=E(o(a)*o(e-n));return[((s*=s)-(l*=l))/(2*t),(a<0?-1:1)*L(4*i*l-(i-s+l)*(i-s+l))/(2*t)]}return c.invert=function(t,e){var i,c,u=e*e,f=o(L(u+(i=t+r)*i)),h=o(L(u+(i=t+n)*i));return[a(c=f-h,i=(f+h)*s),(e<0?-1:1)*E(L(i*i+c*c)*l)]},c}function Lr(t,e){return Ar(Er,t,e)}function Cr(t,e){if(n(e)nt&&(nt=e)),c?trr&&(rr=t);e