Skip to content

Instantly share code, notes, and snippets.

@scottyhq
Created April 19, 2021 12:23
Show Gist options
  • Save scottyhq/c4a4e889b58a0a153dd5fb18bad9f3e8 to your computer and use it in GitHub Desktop.
Save scottyhq/c4a4e889b58a0a153dd5fb18bad9f3e8 to your computer and use it in GitHub Desktop.
stackstac with nsidc data
Display the source blob
Display the rendered blob
Raw
{
"cells": [
{
"cell_type": "markdown",
"id": "b31b00b6",
"metadata": {},
"source": [
"# StackSTAC + Greenland measures"
]
},
{
"cell_type": "code",
"execution_count": 1,
"id": "d8b22221",
"metadata": {},
"outputs": [],
"source": [
"#!pip install --no-deps stackstac"
]
},
{
"cell_type": "code",
"execution_count": 2,
"id": "b77187f1",
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>id</th>\n",
" <th>stac_version</th>\n",
" <th>license</th>\n",
" <th>title</th>\n",
" <th>description</th>\n",
" <th>links</th>\n",
" <th>extent</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>ABLVIS0.v1</td>\n",
" <td>1.0.0-beta.2</td>\n",
" <td>not-provided</td>\n",
" <td>ABoVE LVIS L0 Raw Ranges V001</td>\n",
" <td>This data set contains raw Inertial Measuremen...</td>\n",
" <td>[{'rel': 'self', 'href': 'https://cmr.earthdat...</td>\n",
" <td>{'crs': 'http://www.opengis.net/def/crs/OGC/1....</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>ABOLVIS1A.v1</td>\n",
" <td>1.0.0-beta.2</td>\n",
" <td>not-provided</td>\n",
" <td>ABoVE LVIS L1A Geotagged Images V001</td>\n",
" <td>This data set contains geotagged images collec...</td>\n",
" <td>[{'rel': 'self', 'href': 'https://cmr.earthdat...</td>\n",
" <td>{'crs': 'http://www.opengis.net/def/crs/OGC/1....</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>ABLVIS1B.v1</td>\n",
" <td>1.0.0-beta.2</td>\n",
" <td>not-provided</td>\n",
" <td>ABoVE LVIS L1B Geolocated Return Energy Wavefo...</td>\n",
" <td>This data set contains return energy waveform ...</td>\n",
" <td>[{'rel': 'self', 'href': 'https://cmr.earthdat...</td>\n",
" <td>{'crs': 'http://www.opengis.net/def/crs/OGC/1....</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>ABLVIS2.v1</td>\n",
" <td>1.0.0-beta.2</td>\n",
" <td>not-provided</td>\n",
" <td>ABoVE LVIS L2 Geolocated Surface Elevation Pro...</td>\n",
" <td>This data set contains surface elevation data ...</td>\n",
" <td>[{'rel': 'self', 'href': 'https://cmr.earthdat...</td>\n",
" <td>{'crs': 'http://www.opengis.net/def/crs/OGC/1....</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>AFLVIS0.v1</td>\n",
" <td>1.0.0-beta.2</td>\n",
" <td>not-provided</td>\n",
" <td>AfriSAR LVIS L0 Raw Ranges V001</td>\n",
" <td>This data set contains raw Inertial Measuremen...</td>\n",
" <td>[{'rel': 'self', 'href': 'https://cmr.earthdat...</td>\n",
" <td>{'crs': 'http://www.opengis.net/def/crs/OGC/1....</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" id stac_version license \\\n",
"0 ABLVIS0.v1 1.0.0-beta.2 not-provided \n",
"1 ABOLVIS1A.v1 1.0.0-beta.2 not-provided \n",
"2 ABLVIS1B.v1 1.0.0-beta.2 not-provided \n",
"3 ABLVIS2.v1 1.0.0-beta.2 not-provided \n",
"4 AFLVIS0.v1 1.0.0-beta.2 not-provided \n",
"\n",
" title \\\n",
"0 ABoVE LVIS L0 Raw Ranges V001 \n",
"1 ABoVE LVIS L1A Geotagged Images V001 \n",
"2 ABoVE LVIS L1B Geolocated Return Energy Wavefo... \n",
"3 ABoVE LVIS L2 Geolocated Surface Elevation Pro... \n",
"4 AfriSAR LVIS L0 Raw Ranges V001 \n",
"\n",
" description \\\n",
"0 This data set contains raw Inertial Measuremen... \n",
"1 This data set contains geotagged images collec... \n",
"2 This data set contains return energy waveform ... \n",
"3 This data set contains surface elevation data ... \n",
"4 This data set contains raw Inertial Measuremen... \n",
"\n",
" links \\\n",
"0 [{'rel': 'self', 'href': 'https://cmr.earthdat... \n",
"1 [{'rel': 'self', 'href': 'https://cmr.earthdat... \n",
"2 [{'rel': 'self', 'href': 'https://cmr.earthdat... \n",
"3 [{'rel': 'self', 'href': 'https://cmr.earthdat... \n",
"4 [{'rel': 'self', 'href': 'https://cmr.earthdat... \n",
"\n",
" extent \n",
"0 {'crs': 'http://www.opengis.net/def/crs/OGC/1.... \n",
"1 {'crs': 'http://www.opengis.net/def/crs/OGC/1.... \n",
"2 {'crs': 'http://www.opengis.net/def/crs/OGC/1.... \n",
"3 {'crs': 'http://www.opengis.net/def/crs/OGC/1.... \n",
"4 {'crs': 'http://www.opengis.net/def/crs/OGC/1.... "
]
},
"execution_count": 2,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"#Use pystac-api to list all collections\n",
"# Can up number of returned results\n",
"import intake\n",
"import pandas as pd\n",
"limit = 500\n",
"cat = intake.open_stac_catalog(f'https://cmr.earthdata.nasa.gov/stac/NSIDC_ECS/collections?limit={limit}')\n",
"col_info = pd.DataFrame(cat.metadata['collections'])\n",
"col_info.head()"
]
},
{
"cell_type": "code",
"execution_count": 3,
"id": "979ab6be",
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>id</th>\n",
" <th>stac_version</th>\n",
" <th>license</th>\n",
" <th>title</th>\n",
" <th>description</th>\n",
" <th>links</th>\n",
" <th>extent</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>234</th>\n",
" <td>NSIDC-0723.v3</td>\n",
" <td>1.0.0-beta.2</td>\n",
" <td>not-provided</td>\n",
" <td>MEaSUREs Greenland Image Mosaics from Sentinel...</td>\n",
" <td>This data set, part of the NASA Making Earth S...</td>\n",
" <td>[{'rel': 'self', 'href': 'https://cmr.earthdat...</td>\n",
" <td>{'crs': 'http://www.opengis.net/def/crs/OGC/1....</td>\n",
" </tr>\n",
" <tr>\n",
" <th>369</th>\n",
" <td>SPL2SMAP_S.v003</td>\n",
" <td>1.0.0-beta.2</td>\n",
" <td>not-provided</td>\n",
" <td>SMAP/Sentinel-1 L2 Radiometer/Radar 30-Second ...</td>\n",
" <td>This Level-2 (L2) soil moisture product provid...</td>\n",
" <td>[{'rel': 'self', 'href': 'https://cmr.earthdat...</td>\n",
" <td>{'crs': 'http://www.opengis.net/def/crs/OGC/1....</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" id stac_version license \\\n",
"234 NSIDC-0723.v3 1.0.0-beta.2 not-provided \n",
"369 SPL2SMAP_S.v003 1.0.0-beta.2 not-provided \n",
"\n",
" title \\\n",
"234 MEaSUREs Greenland Image Mosaics from Sentinel... \n",
"369 SMAP/Sentinel-1 L2 Radiometer/Radar 30-Second ... \n",
"\n",
" description \\\n",
"234 This data set, part of the NASA Making Earth S... \n",
"369 This Level-2 (L2) soil moisture product provid... \n",
"\n",
" links \\\n",
"234 [{'rel': 'self', 'href': 'https://cmr.earthdat... \n",
"369 [{'rel': 'self', 'href': 'https://cmr.earthdat... \n",
"\n",
" extent \n",
"234 {'crs': 'http://www.opengis.net/def/crs/OGC/1.... \n",
"369 {'crs': 'http://www.opengis.net/def/crs/OGC/1.... "
]
},
"execution_count": 3,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"col_info[col_info.title.str.contains('Sentinel')]"
]
},
{
"cell_type": "code",
"execution_count": 4,
"id": "74c6312e",
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"46"
]
},
"execution_count": 4,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"from satsearch import Search\n",
"results = Search(url='https://cmr.earthdata.nasa.gov/stac/NSIDC_ECS',\n",
" collections=['NSIDC-0723.v3'], \n",
" bbox = '-54.85,69.31,-52.18,70.26',\n",
" datetime='2020-01-01/2020-03-01', \n",
" )\n",
"\n",
"results.found()"
]
},
{
"cell_type": "code",
"execution_count": 5,
"id": "dcc5bb91",
"metadata": {},
"outputs": [],
"source": [
"items = results.items()"
]
},
{
"cell_type": "code",
"execution_count": 6,
"id": "8ddbb465",
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"{'1': {'href': 'https://n5eil01u.ecs.nsidc.org/DP4/MEASURES/NSIDC-0723.003/2019.12.30/GL_S1bks_mosaic_30Dec19_04Jan20_gamma0_50m_v03.1.tif',\n",
" 'type': 'application/x-geotiff'},\n",
" 'aux': {'href': 'https://n5eil01u.ecs.nsidc.org/DP4/MEASURES/NSIDC-0723.003/2019.12.30/GL_S1bks_mosaic_30Dec19_04Jan20_gamma0_500m_v03.1.jpg.aux.xml',\n",
" 'type': 'application/x-geotiff'},\n",
" 'metadata': {'href': 'https://cmr.earthdata.nasa.gov/search/concepts/G1997906334-NSIDC_ECS.xml',\n",
" 'type': 'application/xml'}}"
]
},
"execution_count": 6,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"# unfortunately items here can be geotiffs, movies, shapefiles etc\n",
"i = items[4] # gamma0 asset\n",
"i.assets"
]
},
{
"cell_type": "code",
"execution_count": 7,
"id": "8f7da690",
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"{'type': 'Feature',\n",
" 'id': 'G1997906334-NSIDC_ECS',\n",
" 'stac_version': '1.0.0-beta.2',\n",
" 'stac_extensions': [],\n",
" 'collection': 'NSIDC-0723.v3',\n",
" 'geometry': {'type': 'Polygon',\n",
" 'coordinates': [[[-30.78714, 58.80463],\n",
" [5.72895, 79.88964],\n",
" [-87.00998, 81.38105],\n",
" [-55.56604, 59.21797],\n",
" [-30.78714, 58.80463]]]},\n",
" 'bbox': [-87.00998, 58.80463, 5.72895, 83.568293],\n",
" 'links': [{'rel': 'self',\n",
" 'href': 'https://cmr.earthdata.nasa.gov/stac/NSIDC_ECS/collections/NSIDC-0723.v3/items/G1997906334-NSIDC_ECS'},\n",
" {'rel': 'parent',\n",
" 'href': 'https://cmr.earthdata.nasa.gov/stac/NSIDC_ECS/collections/NSIDC-0723.v3'},\n",
" {'rel': 'collection',\n",
" 'href': 'https://cmr.earthdata.nasa.gov/stac/NSIDC_ECS/collections/NSIDC-0723.v3'},\n",
" {'rel': 'root', 'href': 'https://cmr.earthdata.nasa.gov/stac/'},\n",
" {'rel': 'provider', 'href': 'https://cmr.earthdata.nasa.gov/stac/NSIDC_ECS'},\n",
" {'rel': 'via',\n",
" 'href': 'https://cmr.earthdata.nasa.gov/search/concepts/G1997906334-NSIDC_ECS.json'},\n",
" {'rel': 'via',\n",
" 'href': 'https://cmr.earthdata.nasa.gov/search/concepts/G1997906334-NSIDC_ECS.umm_json'}],\n",
" 'properties': {'datetime': '2019-12-30T00:00:01.000Z',\n",
" 'start_datetime': '2019-12-30T00:00:01.000Z',\n",
" 'end_datetime': '2020-01-04T23:59:59.000Z'},\n",
" 'assets': {'1': {'href': 'https://n5eil01u.ecs.nsidc.org/DP4/MEASURES/NSIDC-0723.003/2019.12.30/GL_S1bks_mosaic_30Dec19_04Jan20_gamma0_50m_v03.1.tif',\n",
" 'type': 'application/x-geotiff'},\n",
" 'aux': {'href': 'https://n5eil01u.ecs.nsidc.org/DP4/MEASURES/NSIDC-0723.003/2019.12.30/GL_S1bks_mosaic_30Dec19_04Jan20_gamma0_500m_v03.1.jpg.aux.xml',\n",
" 'type': 'application/x-geotiff'},\n",
" 'metadata': {'href': 'https://cmr.earthdata.nasa.gov/search/concepts/G1997906334-NSIDC_ECS.xml',\n",
" 'type': 'application/xml'}}}"
]
},
"execution_count": 7,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"# Full STAC record\n",
"i._data"
]
},
{
"cell_type": "code",
"execution_count": 8,
"id": "b98feaa9",
"metadata": {},
"outputs": [],
"source": [
"# Gett all the items with gamma0 assets\n",
"#gamma0s = [i for i in items if i.assets.get('1')['href'].contains('gamma0')]\n",
"#gamma0s[0]\n",
"# No great way to filter by asset type currently (gamma0, sigma0, thumbnail), so need a function\n",
"def filter_items(items, key='1', pattern='gamma0'):\n",
" images = [i for i in items if i.assets.get(key)]\n",
" filtered = [i for i in images if pattern in i.assets.get(key).get('href')]\n",
" \n",
" return filtered"
]
},
{
"cell_type": "code",
"execution_count": 9,
"id": "69037a4a",
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"11\n"
]
}
],
"source": [
"gamma0s = filter_items(items)\n",
"print(len(gamma0s))"
]
},
{
"cell_type": "code",
"execution_count": 10,
"id": "1b5c827f",
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"'https://n5eil01u.ecs.nsidc.org/DP4/MEASURES/NSIDC-0723.003/2019.12.30/GL_S1bks_mosaic_30Dec19_04Jan20_gamma0_50m_v03.1.tif'"
]
},
"execution_count": 10,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"gamma0s[0].assets['1']['href']"
]
},
{
"cell_type": "code",
"execution_count": 11,
"id": "18a241b3",
"metadata": {},
"outputs": [],
"source": [
"# Only works for LocalCluster (NEED NASA URS credentials in ~/.netrc for GDAL to access these urls)\n",
"import os\n",
"env = dict(GDAL_DISABLE_READDIR_ON_OPEN='EMPTY_DIR', \n",
" AWS_NO_SIGN_REQUEST='YES',\n",
" GDAL_MAX_RAW_BLOCK_CACHE_SIZE='200000000',\n",
" GDAL_SWATH_SIZE='200000000',\n",
" VSI_CURL_CACHE_SIZE='200000000',\n",
" GDAL_HTTP_COOKIEFILE=os.path.expanduser('~/cookies.txt'),\n",
" GDAL_HTTP_COOKIEJAR=os.path.expanduser('~/cookies.txt'))\n",
"\n",
"\n",
"os.environ.update(env)"
]
},
{
"cell_type": "code",
"execution_count": 12,
"id": "9fe4c348",
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"[{'href': 'https://n5eil01u.ecs.nsidc.org/DP4/MEASURES/NSIDC-0723.003/2019.12.30/GL_S1bks_mosaic_30Dec19_04Jan20_gamma0_50m_v03.1.tif',\n",
" 'type': 'application/x-geotiff'},\n",
" {'href': 'https://n5eil01u.ecs.nsidc.org/DP4/MEASURES/NSIDC-0723.003/2020.01.05/GL_S1bks_mosaic_05Jan20_10Jan20_gamma0_50m_v03.1.tif',\n",
" 'type': 'application/x-geotiff'},\n",
" {'href': 'https://n5eil01u.ecs.nsidc.org/DP4/MEASURES/NSIDC-0723.003/2020.01.11/GL_S1bks_mosaic_11Jan20_16Jan20_gamma0_50m_v03.1.tif',\n",
" 'type': 'application/x-geotiff'},\n",
" {'href': 'https://n5eil01u.ecs.nsidc.org/DP4/MEASURES/NSIDC-0723.003/2020.01.17/GL_S1bks_mosaic_17Jan20_22Jan20_gamma0_50m_v03.1.tif',\n",
" 'type': 'application/x-geotiff'},\n",
" {'href': 'https://n5eil01u.ecs.nsidc.org/DP4/MEASURES/NSIDC-0723.003/2020.01.23/GL_S1bks_mosaic_23Jan20_28Jan20_gamma0_50m_v03.1.tif',\n",
" 'type': 'application/x-geotiff'},\n",
" {'href': 'https://n5eil01u.ecs.nsidc.org/DP4/MEASURES/NSIDC-0723.003/2020.01.29/GL_S1bks_mosaic_29Jan20_03Feb20_gamma0_50m_v03.1.tif',\n",
" 'type': 'application/x-geotiff'},\n",
" {'href': 'https://n5eil01u.ecs.nsidc.org/DP4/MEASURES/NSIDC-0723.003/2020.02.04/GL_S1bks_mosaic_04Feb20_09Feb20_gamma0_50m_v03.1.tif',\n",
" 'type': 'application/x-geotiff'},\n",
" {'href': 'https://n5eil01u.ecs.nsidc.org/DP4/MEASURES/NSIDC-0723.003/2020.02.10/GL_S1bks_mosaic_10Feb20_15Feb20_gamma0_50m_v03.1.tif',\n",
" 'type': 'application/x-geotiff'},\n",
" {'href': 'https://n5eil01u.ecs.nsidc.org/DP4/MEASURES/NSIDC-0723.003/2020.02.16/GL_S1bks_mosaic_16Feb20_21Feb20_gamma0_50m_v03.1.tif',\n",
" 'type': 'application/x-geotiff'},\n",
" {'href': 'https://n5eil01u.ecs.nsidc.org/DP4/MEASURES/NSIDC-0723.003/2020.02.22/GL_S1bks_mosaic_22Feb20_27Feb20_gamma0_50m_v03.1.tif',\n",
" 'type': 'application/x-geotiff'},\n",
" {'href': 'https://n5eil01u.ecs.nsidc.org/DP4/MEASURES/NSIDC-0723.003/2020.02.28/GL_S1bks_mosaic_28Feb20_04Mar20_gamma0_50m_v03.1.tif',\n",
" 'type': 'application/x-geotiff'}]"
]
},
"execution_count": 12,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"[g.assets['1'] for g in gamma0s]"
]
},
{
"cell_type": "code",
"execution_count": 13,
"id": "61be8714",
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"{'driver': 'GTiff', 'dtype': 'float32', 'nodata': -30.0, 'width': 29520, 'height': 53220, 'count': 1, 'crs': CRS.from_epsg(3413), 'transform': Affine(50.0, 0.0, -626000.0,\n",
" 0.0, -50.0, -695000.0), 'blockxsize': 512, 'blockysize': 512, 'tiled': True, 'compress': 'deflate', 'interleave': 'band'}\n",
"[-626000.0, -3356000.0, 850000.0, -695000.0]\n"
]
}
],
"source": [
"# open 1st file to get 'proj' extension and other info \n",
"import rasterio\n",
"with rasterio.open(gamma0s[0].assets['1']['href']) as src:\n",
" print(src.profile)\n",
" bounds = list(src.bounds)\n",
" print(bounds)"
]
},
{
"cell_type": "code",
"execution_count": 17,
"id": "9672d46d",
"metadata": {},
"outputs": [],
"source": [
"# NOTE: need to \n",
"import stackstac\n",
"da = stackstac.stack(gamma0s, assets=[\"1\"], \n",
" epsg=3413, resolution=50, bounds=bounds, #explicity specify keywords if proj extension not in metadata\n",
" #chunksize='auto', #dtype=np.float32, #dtype='float32', #Bug? # want dask chunks ~100MB for data-proximate computing # TypeError: DType must be known for auto-chunking\n",
" chunksize=1e4, # NOTE: reported array bytes is uncompressed (there are lots of nans!)\n",
" )\n",
"da['time'] = pd.to_datetime(da.time) # hack until https://github.com/gjoseph92/stackstac/issues/2 sorted"
]
},
{
"cell_type": "code",
"execution_count": 18,
"id": "8cf5c4c2",
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div><svg style=\"position: absolute; width: 0; height: 0; overflow: hidden\">\n",
"<defs>\n",
"<symbol id=\"icon-database\" viewBox=\"0 0 32 32\">\n",
"<path d=\"M16 0c-8.837 0-16 2.239-16 5v4c0 2.761 7.163 5 16 5s16-2.239 16-5v-4c0-2.761-7.163-5-16-5z\"></path>\n",
"<path d=\"M16 17c-8.837 0-16-2.239-16-5v6c0 2.761 7.163 5 16 5s16-2.239 16-5v-6c0 2.761-7.163 5-16 5z\"></path>\n",
"<path d=\"M16 26c-8.837 0-16-2.239-16-5v6c0 2.761 7.163 5 16 5s16-2.239 16-5v-6c0 2.761-7.163 5-16 5z\"></path>\n",
"</symbol>\n",
"<symbol id=\"icon-file-text2\" viewBox=\"0 0 32 32\">\n",
"<path d=\"M28.681 7.159c-0.694-0.947-1.662-2.053-2.724-3.116s-2.169-2.030-3.116-2.724c-1.612-1.182-2.393-1.319-2.841-1.319h-15.5c-1.378 0-2.5 1.121-2.5 2.5v27c0 1.378 1.122 2.5 2.5 2.5h23c1.378 0 2.5-1.122 2.5-2.5v-19.5c0-0.448-0.137-1.23-1.319-2.841zM24.543 5.457c0.959 0.959 1.712 1.825 2.268 2.543h-4.811v-4.811c0.718 0.556 1.584 1.309 2.543 2.268zM28 29.5c0 0.271-0.229 0.5-0.5 0.5h-23c-0.271 0-0.5-0.229-0.5-0.5v-27c0-0.271 0.229-0.5 0.5-0.5 0 0 15.499-0 15.5 0v7c0 0.552 0.448 1 1 1h7v19.5z\"></path>\n",
"<path d=\"M23 26h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"<path d=\"M23 22h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"<path d=\"M23 18h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"</symbol>\n",
"</defs>\n",
"</svg>\n",
"<style>/* CSS stylesheet for displaying xarray objects in jupyterlab.\n",
" *\n",
" */\n",
"\n",
":root {\n",
" --xr-font-color0: var(--jp-content-font-color0, rgba(0, 0, 0, 1));\n",
" --xr-font-color2: var(--jp-content-font-color2, rgba(0, 0, 0, 0.54));\n",
" --xr-font-color3: var(--jp-content-font-color3, rgba(0, 0, 0, 0.38));\n",
" --xr-border-color: var(--jp-border-color2, #e0e0e0);\n",
" --xr-disabled-color: var(--jp-layout-color3, #bdbdbd);\n",
" --xr-background-color: var(--jp-layout-color0, white);\n",
" --xr-background-color-row-even: var(--jp-layout-color1, white);\n",
" --xr-background-color-row-odd: var(--jp-layout-color2, #eeeeee);\n",
"}\n",
"\n",
"html[theme=dark],\n",
"body.vscode-dark {\n",
" --xr-font-color0: rgba(255, 255, 255, 1);\n",
" --xr-font-color2: rgba(255, 255, 255, 0.54);\n",
" --xr-font-color3: rgba(255, 255, 255, 0.38);\n",
" --xr-border-color: #1F1F1F;\n",
" --xr-disabled-color: #515151;\n",
" --xr-background-color: #111111;\n",
" --xr-background-color-row-even: #111111;\n",
" --xr-background-color-row-odd: #313131;\n",
"}\n",
"\n",
".xr-wrap {\n",
" display: block;\n",
" min-width: 300px;\n",
" max-width: 700px;\n",
"}\n",
"\n",
".xr-text-repr-fallback {\n",
" /* fallback to plain text repr when CSS is not injected (untrusted notebook) */\n",
" display: none;\n",
"}\n",
"\n",
".xr-header {\n",
" padding-top: 6px;\n",
" padding-bottom: 6px;\n",
" margin-bottom: 4px;\n",
" border-bottom: solid 1px var(--xr-border-color);\n",
"}\n",
"\n",
".xr-header > div,\n",
".xr-header > ul {\n",
" display: inline;\n",
" margin-top: 0;\n",
" margin-bottom: 0;\n",
"}\n",
"\n",
".xr-obj-type,\n",
".xr-array-name {\n",
" margin-left: 2px;\n",
" margin-right: 10px;\n",
"}\n",
"\n",
".xr-obj-type {\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-sections {\n",
" padding-left: 0 !important;\n",
" display: grid;\n",
" grid-template-columns: 150px auto auto 1fr 20px 20px;\n",
"}\n",
"\n",
".xr-section-item {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-section-item input {\n",
" display: none;\n",
"}\n",
"\n",
".xr-section-item input + label {\n",
" color: var(--xr-disabled-color);\n",
"}\n",
"\n",
".xr-section-item input:enabled + label {\n",
" cursor: pointer;\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-section-item input:enabled + label:hover {\n",
" color: var(--xr-font-color0);\n",
"}\n",
"\n",
".xr-section-summary {\n",
" grid-column: 1;\n",
" color: var(--xr-font-color2);\n",
" font-weight: 500;\n",
"}\n",
"\n",
".xr-section-summary > span {\n",
" display: inline-block;\n",
" padding-left: 0.5em;\n",
"}\n",
"\n",
".xr-section-summary-in:disabled + label {\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-section-summary-in + label:before {\n",
" display: inline-block;\n",
" content: '►';\n",
" font-size: 11px;\n",
" width: 15px;\n",
" text-align: center;\n",
"}\n",
"\n",
".xr-section-summary-in:disabled + label:before {\n",
" color: var(--xr-disabled-color);\n",
"}\n",
"\n",
".xr-section-summary-in:checked + label:before {\n",
" content: '▼';\n",
"}\n",
"\n",
".xr-section-summary-in:checked + label > span {\n",
" display: none;\n",
"}\n",
"\n",
".xr-section-summary,\n",
".xr-section-inline-details {\n",
" padding-top: 4px;\n",
" padding-bottom: 4px;\n",
"}\n",
"\n",
".xr-section-inline-details {\n",
" grid-column: 2 / -1;\n",
"}\n",
"\n",
".xr-section-details {\n",
" display: none;\n",
" grid-column: 1 / -1;\n",
" margin-bottom: 5px;\n",
"}\n",
"\n",
".xr-section-summary-in:checked ~ .xr-section-details {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-array-wrap {\n",
" grid-column: 1 / -1;\n",
" display: grid;\n",
" grid-template-columns: 20px auto;\n",
"}\n",
"\n",
".xr-array-wrap > label {\n",
" grid-column: 1;\n",
" vertical-align: top;\n",
"}\n",
"\n",
".xr-preview {\n",
" color: var(--xr-font-color3);\n",
"}\n",
"\n",
".xr-array-preview,\n",
".xr-array-data {\n",
" padding: 0 5px !important;\n",
" grid-column: 2;\n",
"}\n",
"\n",
".xr-array-data,\n",
".xr-array-in:checked ~ .xr-array-preview {\n",
" display: none;\n",
"}\n",
"\n",
".xr-array-in:checked ~ .xr-array-data,\n",
".xr-array-preview {\n",
" display: inline-block;\n",
"}\n",
"\n",
".xr-dim-list {\n",
" display: inline-block !important;\n",
" list-style: none;\n",
" padding: 0 !important;\n",
" margin: 0;\n",
"}\n",
"\n",
".xr-dim-list li {\n",
" display: inline-block;\n",
" padding: 0;\n",
" margin: 0;\n",
"}\n",
"\n",
".xr-dim-list:before {\n",
" content: '(';\n",
"}\n",
"\n",
".xr-dim-list:after {\n",
" content: ')';\n",
"}\n",
"\n",
".xr-dim-list li:not(:last-child):after {\n",
" content: ',';\n",
" padding-right: 5px;\n",
"}\n",
"\n",
".xr-has-index {\n",
" font-weight: bold;\n",
"}\n",
"\n",
".xr-var-list,\n",
".xr-var-item {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-var-item > div,\n",
".xr-var-item label,\n",
".xr-var-item > .xr-var-name span {\n",
" background-color: var(--xr-background-color-row-even);\n",
" margin-bottom: 0;\n",
"}\n",
"\n",
".xr-var-item > .xr-var-name:hover span {\n",
" padding-right: 5px;\n",
"}\n",
"\n",
".xr-var-list > li:nth-child(odd) > div,\n",
".xr-var-list > li:nth-child(odd) > label,\n",
".xr-var-list > li:nth-child(odd) > .xr-var-name span {\n",
" background-color: var(--xr-background-color-row-odd);\n",
"}\n",
"\n",
".xr-var-name {\n",
" grid-column: 1;\n",
"}\n",
"\n",
".xr-var-dims {\n",
" grid-column: 2;\n",
"}\n",
"\n",
".xr-var-dtype {\n",
" grid-column: 3;\n",
" text-align: right;\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-var-preview {\n",
" grid-column: 4;\n",
"}\n",
"\n",
".xr-var-name,\n",
".xr-var-dims,\n",
".xr-var-dtype,\n",
".xr-preview,\n",
".xr-attrs dt {\n",
" white-space: nowrap;\n",
" overflow: hidden;\n",
" text-overflow: ellipsis;\n",
" padding-right: 10px;\n",
"}\n",
"\n",
".xr-var-name:hover,\n",
".xr-var-dims:hover,\n",
".xr-var-dtype:hover,\n",
".xr-attrs dt:hover {\n",
" overflow: visible;\n",
" width: auto;\n",
" z-index: 1;\n",
"}\n",
"\n",
".xr-var-attrs,\n",
".xr-var-data {\n",
" display: none;\n",
" background-color: var(--xr-background-color) !important;\n",
" padding-bottom: 5px !important;\n",
"}\n",
"\n",
".xr-var-attrs-in:checked ~ .xr-var-attrs,\n",
".xr-var-data-in:checked ~ .xr-var-data {\n",
" display: block;\n",
"}\n",
"\n",
".xr-var-data > table {\n",
" float: right;\n",
"}\n",
"\n",
".xr-var-name span,\n",
".xr-var-data,\n",
".xr-attrs {\n",
" padding-left: 25px !important;\n",
"}\n",
"\n",
".xr-attrs,\n",
".xr-var-attrs,\n",
".xr-var-data {\n",
" grid-column: 1 / -1;\n",
"}\n",
"\n",
"dl.xr-attrs {\n",
" padding: 0;\n",
" margin: 0;\n",
" display: grid;\n",
" grid-template-columns: 125px auto;\n",
"}\n",
"\n",
".xr-attrs dt,\n",
".xr-attrs dd {\n",
" padding: 0;\n",
" margin: 0;\n",
" float: left;\n",
" padding-right: 10px;\n",
" width: auto;\n",
"}\n",
"\n",
".xr-attrs dt {\n",
" font-weight: normal;\n",
" grid-column: 1;\n",
"}\n",
"\n",
".xr-attrs dt:hover span {\n",
" display: inline-block;\n",
" background: var(--xr-background-color);\n",
" padding-right: 10px;\n",
"}\n",
"\n",
".xr-attrs dd {\n",
" grid-column: 2;\n",
" white-space: pre-wrap;\n",
" word-break: break-all;\n",
"}\n",
"\n",
".xr-icon-database,\n",
".xr-icon-file-text2 {\n",
" display: inline-block;\n",
" vertical-align: middle;\n",
" width: 1em;\n",
" height: 1.5em !important;\n",
" stroke-width: 0;\n",
" stroke: currentColor;\n",
" fill: currentColor;\n",
"}\n",
"</style><pre class='xr-text-repr-fallback'>&lt;xarray.DataArray &#x27;stackstac-84614e9d7ad83aeb5826fb5877c337d0&#x27; (time: 11, band: 1, y: 53220, x: 29520)&gt;\n",
"dask.array&lt;fetch_raster_window, shape=(11, 1, 53220, 29520), dtype=float64, chunksize=(1, 1, 10000, 10000), chunktype=numpy.ndarray&gt;\n",
"Coordinates:\n",
" * time (time) datetime64[ns] 2019-12-30T00:00:01 ... 2020-02-28T...\n",
" id (time) &lt;U21 &#x27;G1997906334-NSIDC_ECS&#x27; ... &#x27;G1997905960-NSID...\n",
" * band (band) &lt;U1 &#x27;1&#x27;\n",
" * x (x) float64 -6.26e+05 -6.259e+05 ... 8.499e+05 8.5e+05\n",
" * y (y) float64 -6.95e+05 -6.95e+05 ... -3.356e+06 -3.356e+06\n",
" end_datetime (time) &lt;U24 &#x27;2020-01-04T23:59:59.000Z&#x27; ... &#x27;2020-03-04T23...\n",
" start_datetime (time) &lt;U24 &#x27;2019-12-30T00:00:01.000Z&#x27; ... &#x27;2020-02-28T00...\n",
"Attributes:\n",
" spec: RasterSpec(epsg=3413, bounds=(-626000, -3356000, 850000, -69...\n",
" crs: epsg:3413\n",
" transform: | 50.00, 0.00,-626000.00|\\n| 0.00,-50.00,-695000.00|\\n| 0.00...\n",
" resolution: 50</pre><div class='xr-wrap' hidden><div class='xr-header'><div class='xr-obj-type'>xarray.DataArray</div><div class='xr-array-name'>'stackstac-84614e9d7ad83aeb5826fb5877c337d0'</div><ul class='xr-dim-list'><li><span class='xr-has-index'>time</span>: 11</li><li><span class='xr-has-index'>band</span>: 1</li><li><span class='xr-has-index'>y</span>: 53220</li><li><span class='xr-has-index'>x</span>: 29520</li></ul></div><ul class='xr-sections'><li class='xr-section-item'><div class='xr-array-wrap'><input id='section-5a7aa804-4ff6-4f3a-a2a0-57ab7ed5fab7' class='xr-array-in' type='checkbox' checked><label for='section-5a7aa804-4ff6-4f3a-a2a0-57ab7ed5fab7' title='Show/hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-array-preview xr-preview'><span>dask.array&lt;chunksize=(1, 1, 10000, 10000), meta=np.ndarray&gt;</span></div><div class='xr-array-data'><table>\n",
"<tr>\n",
"<td>\n",
"<table>\n",
" <thead>\n",
" <tr><td> </td><th> Array </th><th> Chunk </th></tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr><th> Bytes </th><td> 128.76 GiB </td> <td> 762.94 MiB </td></tr>\n",
" <tr><th> Shape </th><td> (11, 1, 53220, 29520) </td> <td> (1, 1, 10000, 10000) </td></tr>\n",
" <tr><th> Count </th><td> 238 Tasks </td><td> 198 Chunks </td></tr>\n",
" <tr><th> Type </th><td> float64 </td><td> numpy.ndarray </td></tr>\n",
" </tbody>\n",
"</table>\n",
"</td>\n",
"<td>\n",
"<svg width=\"321\" height=\"184\" style=\"stroke:rgb(0,0,0);stroke-width:1\" >\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"0\" y1=\"0\" x2=\"25\" y2=\"0\" style=\"stroke-width:2\" />\n",
" <line x1=\"0\" y1=\"25\" x2=\"25\" y2=\"25\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"0\" y1=\"0\" x2=\"0\" y2=\"25\" style=\"stroke-width:2\" />\n",
" <line x1=\"2\" y1=\"0\" x2=\"2\" y2=\"25\" />\n",
" <line x1=\"4\" y1=\"0\" x2=\"4\" y2=\"25\" />\n",
" <line x1=\"6\" y1=\"0\" x2=\"6\" y2=\"25\" />\n",
" <line x1=\"9\" y1=\"0\" x2=\"9\" y2=\"25\" />\n",
" <line x1=\"11\" y1=\"0\" x2=\"11\" y2=\"25\" />\n",
" <line x1=\"13\" y1=\"0\" x2=\"13\" y2=\"25\" />\n",
" <line x1=\"16\" y1=\"0\" x2=\"16\" y2=\"25\" />\n",
" <line x1=\"18\" y1=\"0\" x2=\"18\" y2=\"25\" />\n",
" <line x1=\"20\" y1=\"0\" x2=\"20\" y2=\"25\" />\n",
" <line x1=\"23\" y1=\"0\" x2=\"23\" y2=\"25\" />\n",
" <line x1=\"25\" y1=\"0\" x2=\"25\" y2=\"25\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"0.0,0.0 25.412616514582485,0.0 25.412616514582485,25.412616514582485 0.0,25.412616514582485\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Text -->\n",
" <text x=\"12.706308\" y=\"45.412617\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" >11</text>\n",
" <text x=\"45.412617\" y=\"12.706308\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" transform=\"rotate(0,45.412617,12.706308)\">1</text>\n",
"\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"95\" y1=\"0\" x2=\"109\" y2=\"14\" style=\"stroke-width:2\" />\n",
" <line x1=\"95\" y1=\"22\" x2=\"109\" y2=\"37\" />\n",
" <line x1=\"95\" y1=\"45\" x2=\"109\" y2=\"60\" />\n",
" <line x1=\"95\" y1=\"67\" x2=\"109\" y2=\"82\" />\n",
" <line x1=\"95\" y1=\"90\" x2=\"109\" y2=\"105\" />\n",
" <line x1=\"95\" y1=\"112\" x2=\"109\" y2=\"127\" />\n",
" <line x1=\"95\" y1=\"120\" x2=\"109\" y2=\"134\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"95\" y1=\"0\" x2=\"95\" y2=\"120\" style=\"stroke-width:2\" />\n",
" <line x1=\"109\" y1=\"14\" x2=\"109\" y2=\"134\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"95.0,0.0 109.9485979497544,14.948597949754403 109.9485979497544,134.9485979497544 95.0,120.0\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"95\" y1=\"0\" x2=\"161\" y2=\"0\" style=\"stroke-width:2\" />\n",
" <line x1=\"109\" y1=\"14\" x2=\"176\" y2=\"14\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"95\" y1=\"0\" x2=\"109\" y2=\"14\" style=\"stroke-width:2\" />\n",
" <line x1=\"117\" y1=\"0\" x2=\"132\" y2=\"14\" />\n",
" <line x1=\"140\" y1=\"0\" x2=\"155\" y2=\"14\" />\n",
" <line x1=\"161\" y1=\"0\" x2=\"176\" y2=\"14\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"95.0,0.0 161.56144306651635,0.0 176.51004101627075,14.948597949754403 109.9485979497544,14.948597949754403\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"109\" y1=\"14\" x2=\"176\" y2=\"14\" style=\"stroke-width:2\" />\n",
" <line x1=\"109\" y1=\"37\" x2=\"176\" y2=\"37\" />\n",
" <line x1=\"109\" y1=\"60\" x2=\"176\" y2=\"60\" />\n",
" <line x1=\"109\" y1=\"82\" x2=\"176\" y2=\"82\" />\n",
" <line x1=\"109\" y1=\"105\" x2=\"176\" y2=\"105\" />\n",
" <line x1=\"109\" y1=\"127\" x2=\"176\" y2=\"127\" />\n",
" <line x1=\"109\" y1=\"134\" x2=\"176\" y2=\"134\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"109\" y1=\"14\" x2=\"109\" y2=\"134\" style=\"stroke-width:2\" />\n",
" <line x1=\"132\" y1=\"14\" x2=\"132\" y2=\"134\" />\n",
" <line x1=\"155\" y1=\"14\" x2=\"155\" y2=\"134\" />\n",
" <line x1=\"176\" y1=\"14\" x2=\"176\" y2=\"134\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"109.9485979497544,14.948597949754403 176.51004101627075,14.948597949754403 176.51004101627075,134.9485979497544 109.9485979497544,134.9485979497544\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Text -->\n",
" <text x=\"143.229319\" y=\"154.948598\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" >29520</text>\n",
" <text x=\"196.510041\" y=\"74.948598\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" transform=\"rotate(-90,196.510041,74.948598)\">53220</text>\n",
" <text x=\"92.474299\" y=\"147.474299\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" transform=\"rotate(45,92.474299,147.474299)\">1</text>\n",
"</svg>\n",
"</td>\n",
"</tr>\n",
"</table></div></div></li><li class='xr-section-item'><input id='section-cf0af553-7487-4ba2-885a-42893b6b196d' class='xr-section-summary-in' type='checkbox' checked><label for='section-cf0af553-7487-4ba2-885a-42893b6b196d' class='xr-section-summary' >Coordinates: <span>(7)</span></label><div class='xr-section-inline-details'></div><div class='xr-section-details'><ul class='xr-var-list'><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>time</span></div><div class='xr-var-dims'>(time)</div><div class='xr-var-dtype'>datetime64[ns]</div><div class='xr-var-preview xr-preview'>2019-12-30T00:00:01 ... 2020-02-...</div><input id='attrs-7aa13c34-48cd-493a-8fe4-1baaa48a29c3' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-7aa13c34-48cd-493a-8fe4-1baaa48a29c3' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-f9d10cfa-1a55-49ca-9e1a-4851f9ec12bb' class='xr-var-data-in' type='checkbox'><label for='data-f9d10cfa-1a55-49ca-9e1a-4851f9ec12bb' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'></dl></div><div class='xr-var-data'><pre>array([&#x27;2019-12-30T00:00:01.000000000&#x27;, &#x27;2020-01-05T00:00:01.000000000&#x27;,\n",
" &#x27;2020-01-11T00:00:01.000000000&#x27;, &#x27;2020-01-17T00:00:01.000000000&#x27;,\n",
" &#x27;2020-01-23T00:00:01.000000000&#x27;, &#x27;2020-01-29T00:00:01.000000000&#x27;,\n",
" &#x27;2020-02-04T00:00:01.000000000&#x27;, &#x27;2020-02-10T00:00:01.000000000&#x27;,\n",
" &#x27;2020-02-16T00:00:01.000000000&#x27;, &#x27;2020-02-22T00:00:01.000000000&#x27;,\n",
" &#x27;2020-02-28T00:00:01.000000000&#x27;], dtype=&#x27;datetime64[ns]&#x27;)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span>id</span></div><div class='xr-var-dims'>(time)</div><div class='xr-var-dtype'>&lt;U21</div><div class='xr-var-preview xr-preview'>&#x27;G1997906334-NSIDC_ECS&#x27; ... &#x27;G19...</div><input id='attrs-24f054a4-2edb-47e2-bc11-752f60973adc' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-24f054a4-2edb-47e2-bc11-752f60973adc' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-d6bd3cbf-9192-4fdf-8ec2-6b691cc6fa98' class='xr-var-data-in' type='checkbox'><label for='data-d6bd3cbf-9192-4fdf-8ec2-6b691cc6fa98' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'></dl></div><div class='xr-var-data'><pre>array([&#x27;G1997906334-NSIDC_ECS&#x27;, &#x27;G1997906345-NSIDC_ECS&#x27;,\n",
" &#x27;G1997907280-NSIDC_ECS&#x27;, &#x27;G1997907228-NSIDC_ECS&#x27;,\n",
" &#x27;G1997907185-NSIDC_ECS&#x27;, &#x27;G1997907344-NSIDC_ECS&#x27;,\n",
" &#x27;G1997906393-NSIDC_ECS&#x27;, &#x27;G1997906322-NSIDC_ECS&#x27;,\n",
" &#x27;G1997906391-NSIDC_ECS&#x27;, &#x27;G1997907333-NSIDC_ECS&#x27;,\n",
" &#x27;G1997905960-NSIDC_ECS&#x27;], dtype=&#x27;&lt;U21&#x27;)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>band</span></div><div class='xr-var-dims'>(band)</div><div class='xr-var-dtype'>&lt;U1</div><div class='xr-var-preview xr-preview'>&#x27;1&#x27;</div><input id='attrs-b959cea2-57d7-455c-97b1-231fa25a6945' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-b959cea2-57d7-455c-97b1-231fa25a6945' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-7ffdd811-424e-444e-a6a3-2fc730caafa8' class='xr-var-data-in' type='checkbox'><label for='data-7ffdd811-424e-444e-a6a3-2fc730caafa8' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'></dl></div><div class='xr-var-data'><pre>array([&#x27;1&#x27;], dtype=&#x27;&lt;U1&#x27;)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>x</span></div><div class='xr-var-dims'>(x)</div><div class='xr-var-dtype'>float64</div><div class='xr-var-preview xr-preview'>-6.26e+05 -6.259e+05 ... 8.5e+05</div><input id='attrs-61df1666-93b1-4fa4-934b-5c58f13323f6' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-61df1666-93b1-4fa4-934b-5c58f13323f6' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-1db77e1f-73ee-47a6-8326-c68ea25e8c16' class='xr-var-data-in' type='checkbox'><label for='data-1db77e1f-73ee-47a6-8326-c68ea25e8c16' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'></dl></div><div class='xr-var-data'><pre>array([-625975., -625925., -625875., ..., 849875., 849925., 849975.])</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>y</span></div><div class='xr-var-dims'>(y)</div><div class='xr-var-dtype'>float64</div><div class='xr-var-preview xr-preview'>-6.95e+05 -6.95e+05 ... -3.356e+06</div><input id='attrs-6128ef3e-41a9-4506-9afa-86063b76b5c8' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-6128ef3e-41a9-4506-9afa-86063b76b5c8' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-76bf45eb-8b89-4994-919e-5827507da631' class='xr-var-data-in' type='checkbox'><label for='data-76bf45eb-8b89-4994-919e-5827507da631' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'></dl></div><div class='xr-var-data'><pre>array([ -694975., -695025., -695075., ..., -3355825., -3355875., -3355925.])</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span>end_datetime</span></div><div class='xr-var-dims'>(time)</div><div class='xr-var-dtype'>&lt;U24</div><div class='xr-var-preview xr-preview'>&#x27;2020-01-04T23:59:59.000Z&#x27; ... &#x27;...</div><input id='attrs-9be935fe-b561-416d-bc80-51f341f7446c' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-9be935fe-b561-416d-bc80-51f341f7446c' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-2c1df496-e94f-4a19-b2d8-48454fe9b15f' class='xr-var-data-in' type='checkbox'><label for='data-2c1df496-e94f-4a19-b2d8-48454fe9b15f' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'></dl></div><div class='xr-var-data'><pre>array([&#x27;2020-01-04T23:59:59.000Z&#x27;, &#x27;2020-01-10T23:59:59.000Z&#x27;,\n",
" &#x27;2020-01-16T23:59:59.000Z&#x27;, &#x27;2020-01-22T23:59:59.000Z&#x27;,\n",
" &#x27;2020-01-28T23:59:59.000Z&#x27;, &#x27;2020-02-03T23:59:59.000Z&#x27;,\n",
" &#x27;2020-02-09T23:59:59.000Z&#x27;, &#x27;2020-02-15T23:59:59.000Z&#x27;,\n",
" &#x27;2020-02-21T23:59:59.000Z&#x27;, &#x27;2020-02-27T23:59:59.000Z&#x27;,\n",
" &#x27;2020-03-04T23:59:59.000Z&#x27;], dtype=&#x27;&lt;U24&#x27;)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span>start_datetime</span></div><div class='xr-var-dims'>(time)</div><div class='xr-var-dtype'>&lt;U24</div><div class='xr-var-preview xr-preview'>&#x27;2019-12-30T00:00:01.000Z&#x27; ... &#x27;...</div><input id='attrs-511ab227-e732-455d-9dd7-7550ca8b55a2' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-511ab227-e732-455d-9dd7-7550ca8b55a2' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-e146e3bb-9e97-4fc8-945a-fb43ddcc9ed3' class='xr-var-data-in' type='checkbox'><label for='data-e146e3bb-9e97-4fc8-945a-fb43ddcc9ed3' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'></dl></div><div class='xr-var-data'><pre>array([&#x27;2019-12-30T00:00:01.000Z&#x27;, &#x27;2020-01-05T00:00:01.000Z&#x27;,\n",
" &#x27;2020-01-11T00:00:01.000Z&#x27;, &#x27;2020-01-17T00:00:01.000Z&#x27;,\n",
" &#x27;2020-01-23T00:00:01.000Z&#x27;, &#x27;2020-01-29T00:00:01.000Z&#x27;,\n",
" &#x27;2020-02-04T00:00:01.000Z&#x27;, &#x27;2020-02-10T00:00:01.000Z&#x27;,\n",
" &#x27;2020-02-16T00:00:01.000Z&#x27;, &#x27;2020-02-22T00:00:01.000Z&#x27;,\n",
" &#x27;2020-02-28T00:00:01.000Z&#x27;], dtype=&#x27;&lt;U24&#x27;)</pre></div></li></ul></div></li><li class='xr-section-item'><input id='section-f74cc407-d35c-4398-b170-cf625ff86c51' class='xr-section-summary-in' type='checkbox' checked><label for='section-f74cc407-d35c-4398-b170-cf625ff86c51' class='xr-section-summary' >Attributes: <span>(4)</span></label><div class='xr-section-inline-details'></div><div class='xr-section-details'><dl class='xr-attrs'><dt><span>spec :</span></dt><dd>RasterSpec(epsg=3413, bounds=(-626000, -3356000, 850000, -695000), resolutions_xy=(50, 50))</dd><dt><span>crs :</span></dt><dd>epsg:3413</dd><dt><span>transform :</span></dt><dd>| 50.00, 0.00,-626000.00|\n",
"| 0.00,-50.00,-695000.00|\n",
"| 0.00, 0.00, 1.00|</dd><dt><span>resolution :</span></dt><dd>50</dd></dl></div></li></ul></div></div>"
],
"text/plain": [
"<xarray.DataArray 'stackstac-84614e9d7ad83aeb5826fb5877c337d0' (time: 11, band: 1, y: 53220, x: 29520)>\n",
"dask.array<fetch_raster_window, shape=(11, 1, 53220, 29520), dtype=float64, chunksize=(1, 1, 10000, 10000), chunktype=numpy.ndarray>\n",
"Coordinates:\n",
" * time (time) datetime64[ns] 2019-12-30T00:00:01 ... 2020-02-28T...\n",
" id (time) <U21 'G1997906334-NSIDC_ECS' ... 'G1997905960-NSID...\n",
" * band (band) <U1 '1'\n",
" * x (x) float64 -6.26e+05 -6.259e+05 ... 8.499e+05 8.5e+05\n",
" * y (y) float64 -6.95e+05 -6.95e+05 ... -3.356e+06 -3.356e+06\n",
" end_datetime (time) <U24 '2020-01-04T23:59:59.000Z' ... '2020-03-04T23...\n",
" start_datetime (time) <U24 '2019-12-30T00:00:01.000Z' ... '2020-02-28T00...\n",
"Attributes:\n",
" spec: RasterSpec(epsg=3413, bounds=(-626000, -3356000, 850000, -69...\n",
" crs: epsg:3413\n",
" transform: | 50.00, 0.00,-626000.00|\\n| 0.00,-50.00,-695000.00|\\n| 0.00...\n",
" resolution: 50"
]
},
"execution_count": 18,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"da"
]
},
{
"cell_type": "code",
"execution_count": 19,
"id": "e1add5ad",
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div><svg style=\"position: absolute; width: 0; height: 0; overflow: hidden\">\n",
"<defs>\n",
"<symbol id=\"icon-database\" viewBox=\"0 0 32 32\">\n",
"<path d=\"M16 0c-8.837 0-16 2.239-16 5v4c0 2.761 7.163 5 16 5s16-2.239 16-5v-4c0-2.761-7.163-5-16-5z\"></path>\n",
"<path d=\"M16 17c-8.837 0-16-2.239-16-5v6c0 2.761 7.163 5 16 5s16-2.239 16-5v-6c0 2.761-7.163 5-16 5z\"></path>\n",
"<path d=\"M16 26c-8.837 0-16-2.239-16-5v6c0 2.761 7.163 5 16 5s16-2.239 16-5v-6c0 2.761-7.163 5-16 5z\"></path>\n",
"</symbol>\n",
"<symbol id=\"icon-file-text2\" viewBox=\"0 0 32 32\">\n",
"<path d=\"M28.681 7.159c-0.694-0.947-1.662-2.053-2.724-3.116s-2.169-2.030-3.116-2.724c-1.612-1.182-2.393-1.319-2.841-1.319h-15.5c-1.378 0-2.5 1.121-2.5 2.5v27c0 1.378 1.122 2.5 2.5 2.5h23c1.378 0 2.5-1.122 2.5-2.5v-19.5c0-0.448-0.137-1.23-1.319-2.841zM24.543 5.457c0.959 0.959 1.712 1.825 2.268 2.543h-4.811v-4.811c0.718 0.556 1.584 1.309 2.543 2.268zM28 29.5c0 0.271-0.229 0.5-0.5 0.5h-23c-0.271 0-0.5-0.229-0.5-0.5v-27c0-0.271 0.229-0.5 0.5-0.5 0 0 15.499-0 15.5 0v7c0 0.552 0.448 1 1 1h7v19.5z\"></path>\n",
"<path d=\"M23 26h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"<path d=\"M23 22h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"<path d=\"M23 18h-14c-0.552 0-1-0.448-1-1s0.448-1 1-1h14c0.552 0 1 0.448 1 1s-0.448 1-1 1z\"></path>\n",
"</symbol>\n",
"</defs>\n",
"</svg>\n",
"<style>/* CSS stylesheet for displaying xarray objects in jupyterlab.\n",
" *\n",
" */\n",
"\n",
":root {\n",
" --xr-font-color0: var(--jp-content-font-color0, rgba(0, 0, 0, 1));\n",
" --xr-font-color2: var(--jp-content-font-color2, rgba(0, 0, 0, 0.54));\n",
" --xr-font-color3: var(--jp-content-font-color3, rgba(0, 0, 0, 0.38));\n",
" --xr-border-color: var(--jp-border-color2, #e0e0e0);\n",
" --xr-disabled-color: var(--jp-layout-color3, #bdbdbd);\n",
" --xr-background-color: var(--jp-layout-color0, white);\n",
" --xr-background-color-row-even: var(--jp-layout-color1, white);\n",
" --xr-background-color-row-odd: var(--jp-layout-color2, #eeeeee);\n",
"}\n",
"\n",
"html[theme=dark],\n",
"body.vscode-dark {\n",
" --xr-font-color0: rgba(255, 255, 255, 1);\n",
" --xr-font-color2: rgba(255, 255, 255, 0.54);\n",
" --xr-font-color3: rgba(255, 255, 255, 0.38);\n",
" --xr-border-color: #1F1F1F;\n",
" --xr-disabled-color: #515151;\n",
" --xr-background-color: #111111;\n",
" --xr-background-color-row-even: #111111;\n",
" --xr-background-color-row-odd: #313131;\n",
"}\n",
"\n",
".xr-wrap {\n",
" display: block;\n",
" min-width: 300px;\n",
" max-width: 700px;\n",
"}\n",
"\n",
".xr-text-repr-fallback {\n",
" /* fallback to plain text repr when CSS is not injected (untrusted notebook) */\n",
" display: none;\n",
"}\n",
"\n",
".xr-header {\n",
" padding-top: 6px;\n",
" padding-bottom: 6px;\n",
" margin-bottom: 4px;\n",
" border-bottom: solid 1px var(--xr-border-color);\n",
"}\n",
"\n",
".xr-header > div,\n",
".xr-header > ul {\n",
" display: inline;\n",
" margin-top: 0;\n",
" margin-bottom: 0;\n",
"}\n",
"\n",
".xr-obj-type,\n",
".xr-array-name {\n",
" margin-left: 2px;\n",
" margin-right: 10px;\n",
"}\n",
"\n",
".xr-obj-type {\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-sections {\n",
" padding-left: 0 !important;\n",
" display: grid;\n",
" grid-template-columns: 150px auto auto 1fr 20px 20px;\n",
"}\n",
"\n",
".xr-section-item {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-section-item input {\n",
" display: none;\n",
"}\n",
"\n",
".xr-section-item input + label {\n",
" color: var(--xr-disabled-color);\n",
"}\n",
"\n",
".xr-section-item input:enabled + label {\n",
" cursor: pointer;\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-section-item input:enabled + label:hover {\n",
" color: var(--xr-font-color0);\n",
"}\n",
"\n",
".xr-section-summary {\n",
" grid-column: 1;\n",
" color: var(--xr-font-color2);\n",
" font-weight: 500;\n",
"}\n",
"\n",
".xr-section-summary > span {\n",
" display: inline-block;\n",
" padding-left: 0.5em;\n",
"}\n",
"\n",
".xr-section-summary-in:disabled + label {\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-section-summary-in + label:before {\n",
" display: inline-block;\n",
" content: '►';\n",
" font-size: 11px;\n",
" width: 15px;\n",
" text-align: center;\n",
"}\n",
"\n",
".xr-section-summary-in:disabled + label:before {\n",
" color: var(--xr-disabled-color);\n",
"}\n",
"\n",
".xr-section-summary-in:checked + label:before {\n",
" content: '▼';\n",
"}\n",
"\n",
".xr-section-summary-in:checked + label > span {\n",
" display: none;\n",
"}\n",
"\n",
".xr-section-summary,\n",
".xr-section-inline-details {\n",
" padding-top: 4px;\n",
" padding-bottom: 4px;\n",
"}\n",
"\n",
".xr-section-inline-details {\n",
" grid-column: 2 / -1;\n",
"}\n",
"\n",
".xr-section-details {\n",
" display: none;\n",
" grid-column: 1 / -1;\n",
" margin-bottom: 5px;\n",
"}\n",
"\n",
".xr-section-summary-in:checked ~ .xr-section-details {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-array-wrap {\n",
" grid-column: 1 / -1;\n",
" display: grid;\n",
" grid-template-columns: 20px auto;\n",
"}\n",
"\n",
".xr-array-wrap > label {\n",
" grid-column: 1;\n",
" vertical-align: top;\n",
"}\n",
"\n",
".xr-preview {\n",
" color: var(--xr-font-color3);\n",
"}\n",
"\n",
".xr-array-preview,\n",
".xr-array-data {\n",
" padding: 0 5px !important;\n",
" grid-column: 2;\n",
"}\n",
"\n",
".xr-array-data,\n",
".xr-array-in:checked ~ .xr-array-preview {\n",
" display: none;\n",
"}\n",
"\n",
".xr-array-in:checked ~ .xr-array-data,\n",
".xr-array-preview {\n",
" display: inline-block;\n",
"}\n",
"\n",
".xr-dim-list {\n",
" display: inline-block !important;\n",
" list-style: none;\n",
" padding: 0 !important;\n",
" margin: 0;\n",
"}\n",
"\n",
".xr-dim-list li {\n",
" display: inline-block;\n",
" padding: 0;\n",
" margin: 0;\n",
"}\n",
"\n",
".xr-dim-list:before {\n",
" content: '(';\n",
"}\n",
"\n",
".xr-dim-list:after {\n",
" content: ')';\n",
"}\n",
"\n",
".xr-dim-list li:not(:last-child):after {\n",
" content: ',';\n",
" padding-right: 5px;\n",
"}\n",
"\n",
".xr-has-index {\n",
" font-weight: bold;\n",
"}\n",
"\n",
".xr-var-list,\n",
".xr-var-item {\n",
" display: contents;\n",
"}\n",
"\n",
".xr-var-item > div,\n",
".xr-var-item label,\n",
".xr-var-item > .xr-var-name span {\n",
" background-color: var(--xr-background-color-row-even);\n",
" margin-bottom: 0;\n",
"}\n",
"\n",
".xr-var-item > .xr-var-name:hover span {\n",
" padding-right: 5px;\n",
"}\n",
"\n",
".xr-var-list > li:nth-child(odd) > div,\n",
".xr-var-list > li:nth-child(odd) > label,\n",
".xr-var-list > li:nth-child(odd) > .xr-var-name span {\n",
" background-color: var(--xr-background-color-row-odd);\n",
"}\n",
"\n",
".xr-var-name {\n",
" grid-column: 1;\n",
"}\n",
"\n",
".xr-var-dims {\n",
" grid-column: 2;\n",
"}\n",
"\n",
".xr-var-dtype {\n",
" grid-column: 3;\n",
" text-align: right;\n",
" color: var(--xr-font-color2);\n",
"}\n",
"\n",
".xr-var-preview {\n",
" grid-column: 4;\n",
"}\n",
"\n",
".xr-var-name,\n",
".xr-var-dims,\n",
".xr-var-dtype,\n",
".xr-preview,\n",
".xr-attrs dt {\n",
" white-space: nowrap;\n",
" overflow: hidden;\n",
" text-overflow: ellipsis;\n",
" padding-right: 10px;\n",
"}\n",
"\n",
".xr-var-name:hover,\n",
".xr-var-dims:hover,\n",
".xr-var-dtype:hover,\n",
".xr-attrs dt:hover {\n",
" overflow: visible;\n",
" width: auto;\n",
" z-index: 1;\n",
"}\n",
"\n",
".xr-var-attrs,\n",
".xr-var-data {\n",
" display: none;\n",
" background-color: var(--xr-background-color) !important;\n",
" padding-bottom: 5px !important;\n",
"}\n",
"\n",
".xr-var-attrs-in:checked ~ .xr-var-attrs,\n",
".xr-var-data-in:checked ~ .xr-var-data {\n",
" display: block;\n",
"}\n",
"\n",
".xr-var-data > table {\n",
" float: right;\n",
"}\n",
"\n",
".xr-var-name span,\n",
".xr-var-data,\n",
".xr-attrs {\n",
" padding-left: 25px !important;\n",
"}\n",
"\n",
".xr-attrs,\n",
".xr-var-attrs,\n",
".xr-var-data {\n",
" grid-column: 1 / -1;\n",
"}\n",
"\n",
"dl.xr-attrs {\n",
" padding: 0;\n",
" margin: 0;\n",
" display: grid;\n",
" grid-template-columns: 125px auto;\n",
"}\n",
"\n",
".xr-attrs dt,\n",
".xr-attrs dd {\n",
" padding: 0;\n",
" margin: 0;\n",
" float: left;\n",
" padding-right: 10px;\n",
" width: auto;\n",
"}\n",
"\n",
".xr-attrs dt {\n",
" font-weight: normal;\n",
" grid-column: 1;\n",
"}\n",
"\n",
".xr-attrs dt:hover span {\n",
" display: inline-block;\n",
" background: var(--xr-background-color);\n",
" padding-right: 10px;\n",
"}\n",
"\n",
".xr-attrs dd {\n",
" grid-column: 2;\n",
" white-space: pre-wrap;\n",
" word-break: break-all;\n",
"}\n",
"\n",
".xr-icon-database,\n",
".xr-icon-file-text2 {\n",
" display: inline-block;\n",
" vertical-align: middle;\n",
" width: 1em;\n",
" height: 1.5em !important;\n",
" stroke-width: 0;\n",
" stroke: currentColor;\n",
" fill: currentColor;\n",
"}\n",
"</style><pre class='xr-text-repr-fallback'>&lt;xarray.DataArray &#x27;G1997906334-NSIDC_ECS&#x27; (time: 1, y: 817, x: 1885)&gt;\n",
"dask.array&lt;getitem, shape=(1, 817, 1885), dtype=float64, chunksize=(1, 817, 1885), chunktype=numpy.ndarray&gt;\n",
"Coordinates:\n",
" * time (time) datetime64[ns] 2019-12-30T00:00:01\n",
" id (time) &lt;U21 &#x27;G1997906334-NSIDC_ECS&#x27;\n",
" band &lt;U1 &#x27;1&#x27;\n",
" * x (x) float64 -2.435e+05 -2.435e+05 ... -1.494e+05 -1.493e+05\n",
" * y (y) float64 -2.255e+06 -2.255e+06 ... -2.296e+06 -2.296e+06\n",
" end_datetime (time) &lt;U24 &#x27;2020-01-04T23:59:59.000Z&#x27;\n",
" start_datetime (time) &lt;U24 &#x27;2019-12-30T00:00:01.000Z&#x27;\n",
"Attributes:\n",
" spec: RasterSpec(epsg=3413, bounds=(-626000, -3356000, 850000, -69...\n",
" crs: epsg:3413\n",
" transform: | 50.00, 0.00,-626000.00|\\n| 0.00,-50.00,-695000.00|\\n| 0.00...\n",
" resolution: 50</pre><div class='xr-wrap' hidden><div class='xr-header'><div class='xr-obj-type'>xarray.DataArray</div><div class='xr-array-name'>'G1997906334-NSIDC_ECS'</div><ul class='xr-dim-list'><li><span class='xr-has-index'>time</span>: 1</li><li><span class='xr-has-index'>y</span>: 817</li><li><span class='xr-has-index'>x</span>: 1885</li></ul></div><ul class='xr-sections'><li class='xr-section-item'><div class='xr-array-wrap'><input id='section-ebb7bfc1-5478-4d76-87a7-9859f579f9cc' class='xr-array-in' type='checkbox' checked><label for='section-ebb7bfc1-5478-4d76-87a7-9859f579f9cc' title='Show/hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-array-preview xr-preview'><span>dask.array&lt;chunksize=(1, 817, 1885), meta=np.ndarray&gt;</span></div><div class='xr-array-data'><table>\n",
"<tr>\n",
"<td>\n",
"<table>\n",
" <thead>\n",
" <tr><td> </td><th> Array </th><th> Chunk </th></tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr><th> Bytes </th><td> 11.75 MiB </td> <td> 11.75 MiB </td></tr>\n",
" <tr><th> Shape </th><td> (1, 817, 1885) </td> <td> (1, 817, 1885) </td></tr>\n",
" <tr><th> Count </th><td> 239 Tasks </td><td> 1 Chunks </td></tr>\n",
" <tr><th> Type </th><td> float64 </td><td> numpy.ndarray </td></tr>\n",
" </tbody>\n",
"</table>\n",
"</td>\n",
"<td>\n",
"<svg width=\"194\" height=\"116\" style=\"stroke:rgb(0,0,0);stroke-width:1\" >\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"24\" y2=\"14\" style=\"stroke-width:2\" />\n",
" <line x1=\"10\" y1=\"52\" x2=\"24\" y2=\"66\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"10\" y2=\"52\" style=\"stroke-width:2\" />\n",
" <line x1=\"24\" y1=\"14\" x2=\"24\" y2=\"66\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"10.0,0.0 24.9485979497544,14.948597949754403 24.9485979497544,66.95920802933 10.0,52.0106100795756\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"130\" y2=\"0\" style=\"stroke-width:2\" />\n",
" <line x1=\"24\" y1=\"14\" x2=\"144\" y2=\"14\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"10\" y1=\"0\" x2=\"24\" y2=\"14\" style=\"stroke-width:2\" />\n",
" <line x1=\"130\" y1=\"0\" x2=\"144\" y2=\"14\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"10.0,0.0 130.0,0.0 144.9485979497544,14.948597949754403 24.9485979497544,14.948597949754403\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Horizontal lines -->\n",
" <line x1=\"24\" y1=\"14\" x2=\"144\" y2=\"14\" style=\"stroke-width:2\" />\n",
" <line x1=\"24\" y1=\"66\" x2=\"144\" y2=\"66\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Vertical lines -->\n",
" <line x1=\"24\" y1=\"14\" x2=\"24\" y2=\"66\" style=\"stroke-width:2\" />\n",
" <line x1=\"144\" y1=\"14\" x2=\"144\" y2=\"66\" style=\"stroke-width:2\" />\n",
"\n",
" <!-- Colored Rectangle -->\n",
" <polygon points=\"24.9485979497544,14.948597949754403 144.9485979497544,14.948597949754403 144.9485979497544,66.95920802933 24.9485979497544,66.95920802933\" style=\"fill:#ECB172A0;stroke-width:0\"/>\n",
"\n",
" <!-- Text -->\n",
" <text x=\"84.948598\" y=\"86.959208\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" >1885</text>\n",
" <text x=\"164.948598\" y=\"40.953903\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" transform=\"rotate(-90,164.948598,40.953903)\">817</text>\n",
" <text x=\"7.474299\" y=\"79.484909\" font-size=\"1.0rem\" font-weight=\"100\" text-anchor=\"middle\" transform=\"rotate(45,7.474299,79.484909)\">1</text>\n",
"</svg>\n",
"</td>\n",
"</tr>\n",
"</table></div></div></li><li class='xr-section-item'><input id='section-0a1ce59c-ea1b-459e-825f-85abca3269c1' class='xr-section-summary-in' type='checkbox' checked><label for='section-0a1ce59c-ea1b-459e-825f-85abca3269c1' class='xr-section-summary' >Coordinates: <span>(7)</span></label><div class='xr-section-inline-details'></div><div class='xr-section-details'><ul class='xr-var-list'><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>time</span></div><div class='xr-var-dims'>(time)</div><div class='xr-var-dtype'>datetime64[ns]</div><div class='xr-var-preview xr-preview'>2019-12-30T00:00:01</div><input id='attrs-fffaa38d-3051-43d9-b2f2-3f2fc72ce782' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-fffaa38d-3051-43d9-b2f2-3f2fc72ce782' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-6aa59800-c119-4567-a2c9-f1f2fe871d43' class='xr-var-data-in' type='checkbox'><label for='data-6aa59800-c119-4567-a2c9-f1f2fe871d43' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'></dl></div><div class='xr-var-data'><pre>array([&#x27;2019-12-30T00:00:01.000000000&#x27;], dtype=&#x27;datetime64[ns]&#x27;)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span>id</span></div><div class='xr-var-dims'>(time)</div><div class='xr-var-dtype'>&lt;U21</div><div class='xr-var-preview xr-preview'>&#x27;G1997906334-NSIDC_ECS&#x27;</div><input id='attrs-f7fb4d87-47fc-4882-aa79-094408277bb5' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-f7fb4d87-47fc-4882-aa79-094408277bb5' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-ba3dc2ff-2695-4fbc-9bc7-38b197a2add0' class='xr-var-data-in' type='checkbox'><label for='data-ba3dc2ff-2695-4fbc-9bc7-38b197a2add0' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'></dl></div><div class='xr-var-data'><pre>array([&#x27;G1997906334-NSIDC_ECS&#x27;], dtype=&#x27;&lt;U21&#x27;)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span>band</span></div><div class='xr-var-dims'>()</div><div class='xr-var-dtype'>&lt;U1</div><div class='xr-var-preview xr-preview'>&#x27;1&#x27;</div><input id='attrs-2cd23dea-3177-4ecb-bc13-924531340af3' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-2cd23dea-3177-4ecb-bc13-924531340af3' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-ae014bcf-72b0-4887-857c-773332848d31' class='xr-var-data-in' type='checkbox'><label for='data-ae014bcf-72b0-4887-857c-773332848d31' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'></dl></div><div class='xr-var-data'><pre>array(&#x27;1&#x27;, dtype=&#x27;&lt;U1&#x27;)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>x</span></div><div class='xr-var-dims'>(x)</div><div class='xr-var-dtype'>float64</div><div class='xr-var-preview xr-preview'>-2.435e+05 ... -1.493e+05</div><input id='attrs-b4e52ee5-4cd6-40b8-938c-b7146a27f0f9' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-b4e52ee5-4cd6-40b8-938c-b7146a27f0f9' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-35470700-d903-4d60-b688-3430771e051d' class='xr-var-data-in' type='checkbox'><label for='data-35470700-d903-4d60-b688-3430771e051d' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'></dl></div><div class='xr-var-data'><pre>array([-243525., -243475., -243425., ..., -149425., -149375., -149325.])</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span class='xr-has-index'>y</span></div><div class='xr-var-dims'>(y)</div><div class='xr-var-dtype'>float64</div><div class='xr-var-preview xr-preview'>-2.255e+06 ... -2.296e+06</div><input id='attrs-0f2056eb-8a34-4ab0-94bd-2c6e754b7de7' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-0f2056eb-8a34-4ab0-94bd-2c6e754b7de7' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-355ce774-a3bd-422f-a101-2e0ff6f2590a' class='xr-var-data-in' type='checkbox'><label for='data-355ce774-a3bd-422f-a101-2e0ff6f2590a' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'></dl></div><div class='xr-var-data'><pre>array([-2254875., -2254925., -2254975., ..., -2295575., -2295625., -2295675.])</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span>end_datetime</span></div><div class='xr-var-dims'>(time)</div><div class='xr-var-dtype'>&lt;U24</div><div class='xr-var-preview xr-preview'>&#x27;2020-01-04T23:59:59.000Z&#x27;</div><input id='attrs-9084d235-cf1e-44c7-91a3-aa2cb8784c98' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-9084d235-cf1e-44c7-91a3-aa2cb8784c98' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-50241dfe-6336-4dce-99c2-b127d62124e5' class='xr-var-data-in' type='checkbox'><label for='data-50241dfe-6336-4dce-99c2-b127d62124e5' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'></dl></div><div class='xr-var-data'><pre>array([&#x27;2020-01-04T23:59:59.000Z&#x27;], dtype=&#x27;&lt;U24&#x27;)</pre></div></li><li class='xr-var-item'><div class='xr-var-name'><span>start_datetime</span></div><div class='xr-var-dims'>(time)</div><div class='xr-var-dtype'>&lt;U24</div><div class='xr-var-preview xr-preview'>&#x27;2019-12-30T00:00:01.000Z&#x27;</div><input id='attrs-adc49a43-9e51-4eb6-bc7c-04dd9fe65648' class='xr-var-attrs-in' type='checkbox' disabled><label for='attrs-adc49a43-9e51-4eb6-bc7c-04dd9fe65648' title='Show/Hide attributes'><svg class='icon xr-icon-file-text2'><use xlink:href='#icon-file-text2'></use></svg></label><input id='data-ef497fd0-617a-49c7-ad2b-87d128e1eb17' class='xr-var-data-in' type='checkbox'><label for='data-ef497fd0-617a-49c7-ad2b-87d128e1eb17' title='Show/Hide data repr'><svg class='icon xr-icon-database'><use xlink:href='#icon-database'></use></svg></label><div class='xr-var-attrs'><dl class='xr-attrs'></dl></div><div class='xr-var-data'><pre>array([&#x27;2019-12-30T00:00:01.000Z&#x27;], dtype=&#x27;&lt;U24&#x27;)</pre></div></li></ul></div></li><li class='xr-section-item'><input id='section-5f89fafe-0a2e-41b7-9d3d-268bce2eba74' class='xr-section-summary-in' type='checkbox' checked><label for='section-5f89fafe-0a2e-41b7-9d3d-268bce2eba74' class='xr-section-summary' >Attributes: <span>(4)</span></label><div class='xr-section-inline-details'></div><div class='xr-section-details'><dl class='xr-attrs'><dt><span>spec :</span></dt><dd>RasterSpec(epsg=3413, bounds=(-626000, -3356000, 850000, -695000), resolutions_xy=(50, 50))</dd><dt><span>crs :</span></dt><dd>epsg:3413</dd><dt><span>transform :</span></dt><dd>| 50.00, 0.00,-626000.00|\n",
"| 0.00,-50.00,-695000.00|\n",
"| 0.00, 0.00, 1.00|</dd><dt><span>resolution :</span></dt><dd>50</dd></dl></div></li></ul></div></div>"
],
"text/plain": [
"<xarray.DataArray 'G1997906334-NSIDC_ECS' (time: 1, y: 817, x: 1885)>\n",
"dask.array<getitem, shape=(1, 817, 1885), dtype=float64, chunksize=(1, 817, 1885), chunktype=numpy.ndarray>\n",
"Coordinates:\n",
" * time (time) datetime64[ns] 2019-12-30T00:00:01\n",
" id (time) <U21 'G1997906334-NSIDC_ECS'\n",
" band <U1 '1'\n",
" * x (x) float64 -2.435e+05 -2.435e+05 ... -1.494e+05 -1.493e+05\n",
" * y (y) float64 -2.255e+06 -2.255e+06 ... -2.296e+06 -2.296e+06\n",
" end_datetime (time) <U24 '2020-01-04T23:59:59.000Z'\n",
" start_datetime (time) <U24 '2019-12-30T00:00:01.000Z'\n",
"Attributes:\n",
" spec: RasterSpec(epsg=3413, bounds=(-626000, -3356000, 850000, -69...\n",
" crs: epsg:3413\n",
" transform: | 50.00, 0.00,-626000.00|\\n| 0.00,-50.00,-695000.00|\\n| 0.00...\n",
" resolution: 50"
]
},
"execution_count": 19,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"subset = da.sel(time='2019-12-30', band='1', y=slice(-2254858,-2295690), x=slice(-243538,-149311)) \n",
"subset.name = subset.id.values[0] # the dask ids are strange\n",
"subset"
]
},
{
"cell_type": "code",
"execution_count": 20,
"id": "ffd7a916",
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"CPU times: user 3.93 s, sys: 1.89 s, total: 5.82 s\n",
"Wall time: 31.4 s\n"
]
}
],
"source": [
"%%time\n",
"local_subset = subset.persist()"
]
},
{
"cell_type": "code",
"execution_count": 21,
"id": "e84e88f7",
"metadata": {},
"outputs": [
{
"data": {
"image/png": "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\n",
"text/plain": [
"<Figure size 432x288 with 2 Axes>"
]
},
"metadata": {
"needs_background": "light"
},
"output_type": "display_data"
}
],
"source": [
"local_subset.isel(time=0).plot.imshow();"
]
},
{
"cell_type": "code",
"execution_count": 22,
"id": "854f9a99",
"metadata": {},
"outputs": [
{
"data": {
"application/javascript": [
"\n",
"(function(root) {\n",
" function now() {\n",
" return new Date();\n",
" }\n",
"\n",
" var force = true;\n",
"\n",
" if (typeof root._bokeh_onload_callbacks === \"undefined\" || force === true) {\n",
" root._bokeh_onload_callbacks = [];\n",
" root._bokeh_is_loading = undefined;\n",
" }\n",
"\n",
" if (typeof (root._bokeh_timeout) === \"undefined\" || force === true) {\n",
" root._bokeh_timeout = Date.now() + 5000;\n",
" root._bokeh_failed_load = false;\n",
" }\n",
"\n",
" function run_callbacks() {\n",
" try {\n",
" root._bokeh_onload_callbacks.forEach(function(callback) {\n",
" if (callback != null)\n",
" callback();\n",
" });\n",
" } finally {\n",
" delete root._bokeh_onload_callbacks\n",
" }\n",
" console.debug(\"Bokeh: all callbacks have finished\");\n",
" }\n",
"\n",
" function load_libs(css_urls, js_urls, js_modules, callback) {\n",
" if (css_urls == null) css_urls = [];\n",
" if (js_urls == null) js_urls = [];\n",
" if (js_modules == null) js_modules = [];\n",
"\n",
" root._bokeh_onload_callbacks.push(callback);\n",
" if (root._bokeh_is_loading > 0) {\n",
" console.debug(\"Bokeh: BokehJS is being loaded, scheduling callback at\", now());\n",
" return null;\n",
" }\n",
" if (js_urls.length === 0 && js_modules.length === 0) {\n",
" run_callbacks();\n",
" return null;\n",
" }\n",
" console.debug(\"Bokeh: BokehJS not loaded, scheduling load and callback at\", now());\n",
" root._bokeh_is_loading = css_urls.length + js_urls.length + js_modules.length;\n",
"\n",
" function on_load() {\n",
" root._bokeh_is_loading--;\n",
" if (root._bokeh_is_loading === 0) {\n",
" console.debug(\"Bokeh: all BokehJS libraries/stylesheets loaded\");\n",
" run_callbacks()\n",
" }\n",
" }\n",
"\n",
" function on_error() {\n",
" console.error(\"failed to load \" + url);\n",
" }\n",
"\n",
" for (var i = 0; i < css_urls.length; i++) {\n",
" var url = css_urls[i];\n",
" const element = document.createElement(\"link\");\n",
" element.onload = on_load;\n",
" element.onerror = on_error;\n",
" element.rel = \"stylesheet\";\n",
" element.type = \"text/css\";\n",
" element.href = url;\n",
" console.debug(\"Bokeh: injecting link tag for BokehJS stylesheet: \", url);\n",
" document.body.appendChild(element);\n",
" }\n",
"\n",
" var skip = [];\n",
" if (window.requirejs) {\n",
" window.requirejs.config({'paths': {'tabulator': 'https://unpkg.com/tabulator-tables@4.9.3/dist/js/tabulator'}});\n",
" require([\"tabulator\"], function(Tabulator,) {\n",
" window.Tabulator = Tabulator;\n",
" })\n",
" }\n",
" if (((window['tabulator'] !== undefined) && (!(window['tabulator'] instanceof HTMLElement))) || window.requirejs) {\n",
" var urls = ['https://unpkg.com/tabulator-tables@4.9.3/dist/js/tabulator.js', 'https://unpkg.com/moment@2.27.0/moment.js'];\n",
" for (var i = 0; i < urls.length; i++) {\n",
" skip.push(urls[i])\n",
" }\n",
" }\n",
" for (var i = 0; i < js_urls.length; i++) {\n",
" var url = js_urls[i];\n",
" if (skip.indexOf(url) >= 0) { on_load(); continue; }\n",
" var element = document.createElement('script');\n",
" element.onload = on_load;\n",
" element.onerror = on_error;\n",
" element.async = false;\n",
" element.src = url;\n",
" console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n",
" document.head.appendChild(element);\n",
" }\n",
" for (var i = 0; i < js_modules.length; i++) {\n",
" var url = js_modules[i];\n",
" if (skip.indexOf(url) >= 0) { on_load(); continue; }\n",
" var element = document.createElement('script');\n",
" element.onload = on_load;\n",
" element.onerror = on_error;\n",
" element.async = false;\n",
" element.src = url;\n",
" element.type = \"module\";\n",
" console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n",
" document.head.appendChild(element);\n",
" }\n",
" if (!js_urls.length && !js_modules.length) {\n",
" on_load()\n",
" }\n",
" };\n",
"\n",
" function inject_raw_css(css) {\n",
" const element = document.createElement(\"style\");\n",
" element.appendChild(document.createTextNode(css));\n",
" document.body.appendChild(element);\n",
" }\n",
"\n",
" var js_urls = [\"https://unpkg.com/tabulator-tables@4.9.3/dist/js/tabulator.js\", \"https://unpkg.com/moment@2.27.0/moment.js\"];\n",
" var js_modules = [];\n",
" var css_urls = [\"https://unpkg.com/tabulator-tables@4.9.3/dist/css/tabulator_simple.min.css\"];\n",
" var inline_js = [\n",
" function(Bokeh) {\n",
" inject_raw_css(\".bk.alert {\\n padding: 0.75rem 1.25rem;\\n border: 1px solid transparent;\\n border-radius: 0.25rem;\\n /* Don't set margin because that will not render correctly! */\\n /* margin-bottom: 1rem; */\\n margin-top: 15px;\\n margin-bottom: 15px;\\n}\\n.bk.alert a {\\n color: rgb(11, 46, 19); /* #002752; */\\n font-weight: 700;\\n text-decoration: rgb(11, 46, 19);\\n text-decoration-color: rgb(11, 46, 19);\\n text-decoration-line: none;\\n text-decoration-style: solid;\\n text-decoration-thickness: auto;\\n }\\n.bk.alert a:hover {\\n color: rgb(11, 46, 19);\\n font-weight: 700;\\n text-decoration: underline;\\n}\\n\\n.bk.alert-primary {\\n color: #004085;\\n background-color: #cce5ff;\\n border-color: #b8daff;\\n}\\n.bk.alert-primary hr {\\n border-top-color: #9fcdff;\\n}\\n\\n.bk.alert-secondary {\\n color: #383d41;\\n background-color: #e2e3e5;\\n border-color: #d6d8db;\\n }\\n.bk.alert-secondary hr {\\n border-top-color: #c8cbcf;\\n}\\n\\n.bk.alert-success {\\n color: #155724;\\n background-color: #d4edda;\\n border-color: #c3e6cb;\\n }\\n\\n.bk.alert-success hr {\\n border-top-color: #b1dfbb;\\n}\\n\\n.bk.alert-info {\\n color: #0c5460;\\n background-color: #d1ecf1;\\n border-color: #bee5eb;\\n }\\n.bk.alert-info hr {\\n border-top-color: #abdde5;\\n}\\n\\n.bk.alert-warning {\\n color: #856404;\\n background-color: #fff3cd;\\n border-color: #ffeeba;\\n }\\n\\n.bk.alert-warning hr {\\n border-top-color: #ffe8a1;\\n}\\n\\n.bk.alert-danger {\\n color: #721c24;\\n background-color: #f8d7da;\\n border-color: #f5c6cb;\\n}\\n.bk.alert-danger hr {\\n border-top-color: #f1b0b7;\\n}\\n\\n.bk.alert-light {\\n color: #818182;\\n background-color: #fefefe;\\n border-color: #fdfdfe;\\n }\\n.bk.alert-light hr {\\n border-top-color: #ececf6;\\n}\\n\\n.bk.alert-dark {\\n color: #1b1e21;\\n background-color: #d6d8d9;\\n border-color: #c6c8ca;\\n }\\n.bk.alert-dark hr {\\n border-top-color: #b9bbbe;\\n}\\n\\n\\n/* adjf\\u00e6l */\\n\\n.bk.alert-primary a {\\n color: #002752;\\n}\\n\\n.bk.alert-secondary a {\\n color: #202326;\\n}\\n\\n\\n.bk.alert-success a {\\n color: #0b2e13;\\n}\\n\\n\\n.bk.alert-info a {\\n color: #062c33;\\n}\\n\\n\\n.bk.alert-warning a {\\n color: #533f03;\\n}\\n\\n\\n.bk.alert-danger a {\\n color: #491217;\\n}\\n\\n.bk.alert-light a {\\n color: #686868;\\n}\\n\\n.bk.alert-dark a {\\n color: #040505;\\n}\");\n",
" },\n",
" function(Bokeh) {\n",
" inject_raw_css(\".bk.card {\\n border: 1px solid rgba(0,0,0,.125);\\n border-radius: 0.25rem;\\n}\\n.bk.accordion {\\n border: 1px solid rgba(0,0,0,.125);\\n}\\n.bk.card-header {\\n align-items: center;\\n background-color: rgba(0, 0, 0, 0.03);\\n border-radius: 0.25rem;\\n display: flex;\\n justify-content: space-between;\\n padding: 0 1.25rem 0 0;\\n width: 100%;\\n}\\n.bk.accordion-header {\\n align-items: center;\\n background-color: rgba(0, 0, 0, 0.03);\\n border-radius: 0;\\n display: flex;\\n justify-content: space-between;\\n padding: 0 1.25rem 0 0;\\n width: 100%;\\n}\\np.bk.card-button {\\n background-color: transparent;\\n font-size: 1.25rem;\\n font-weight: 700;\\n margin: 0;\\n margin-left: -15px;\\n}\\n.bk.card-header-row {\\n position: relative !important;\\n}\\n.bk.card-title {\\n align-items: center;\\n display: flex !important;\\n font-size: 1.4em;\\n font-weight: bold;\\n padding: 0.25em;\\n position: relative !important;\\n}\\n\");\n",
" },\n",
" function(Bokeh) {\n",
" inject_raw_css(\"table.panel-df {\\n margin-left: auto;\\n margin-right: auto;\\n border: none;\\n border-collapse: collapse;\\n border-spacing: 0;\\n color: black;\\n font-size: 12px;\\n table-layout: fixed;\\n width: 100%;\\n}\\n\\n.panel-df tr, .panel-df th, .panel-df td {\\n text-align: right;\\n vertical-align: middle;\\n padding: 0.5em 0.5em !important;\\n line-height: normal;\\n white-space: normal;\\n max-width: none;\\n border: none;\\n}\\n\\n.panel-df tbody {\\n display: table-row-group;\\n vertical-align: middle;\\n border-color: inherit;\\n}\\n\\n.panel-df tbody tr:nth-child(odd) {\\n background: #f5f5f5;\\n}\\n\\n.panel-df thead {\\n border-bottom: 1px solid black;\\n vertical-align: bottom;\\n}\\n\\n.panel-df tr:hover {\\n background: lightblue !important;\\n cursor: pointer;\\n}\\n\");\n",
" },\n",
" function(Bokeh) {\n",
" inject_raw_css(\".json-formatter-row {\\n font-family: monospace;\\n}\\n.json-formatter-row,\\n.json-formatter-row a,\\n.json-formatter-row a:hover {\\n color: black;\\n text-decoration: none;\\n}\\n.json-formatter-row .json-formatter-row {\\n margin-left: 1rem;\\n}\\n.json-formatter-row .json-formatter-children.json-formatter-empty {\\n opacity: 0.5;\\n margin-left: 1rem;\\n}\\n.json-formatter-row .json-formatter-children.json-formatter-empty:after {\\n display: none;\\n}\\n.json-formatter-row .json-formatter-children.json-formatter-empty.json-formatter-object:after {\\n content: \\\"No properties\\\";\\n}\\n.json-formatter-row .json-formatter-children.json-formatter-empty.json-formatter-array:after {\\n content: \\\"[]\\\";\\n}\\n.json-formatter-row .json-formatter-string,\\n.json-formatter-row .json-formatter-stringifiable {\\n color: green;\\n white-space: pre;\\n word-wrap: break-word;\\n}\\n.json-formatter-row .json-formatter-number {\\n color: blue;\\n}\\n.json-formatter-row .json-formatter-boolean {\\n color: red;\\n}\\n.json-formatter-row .json-formatter-null {\\n color: #855A00;\\n}\\n.json-formatter-row .json-formatter-undefined {\\n color: #ca0b69;\\n}\\n.json-formatter-row .json-formatter-function {\\n color: #FF20ED;\\n}\\n.json-formatter-row .json-formatter-date {\\n background-color: rgba(0, 0, 0, 0.05);\\n}\\n.json-formatter-row .json-formatter-url {\\n text-decoration: underline;\\n color: blue;\\n cursor: pointer;\\n}\\n.json-formatter-row .json-formatter-bracket {\\n color: blue;\\n}\\n.json-formatter-row .json-formatter-key {\\n color: #00008B;\\n padding-right: 0.2rem;\\n}\\n.json-formatter-row .json-formatter-toggler-link {\\n cursor: pointer;\\n}\\n.json-formatter-row .json-formatter-toggler {\\n line-height: 1.2rem;\\n font-size: 0.7rem;\\n vertical-align: middle;\\n opacity: 0.6;\\n cursor: pointer;\\n padding-right: 0.2rem;\\n}\\n.json-formatter-row .json-formatter-toggler:after {\\n display: inline-block;\\n transition: transform 100ms ease-in;\\n content: \\\"\\\\25BA\\\";\\n}\\n.json-formatter-row > a > .json-formatter-preview-text {\\n opacity: 0;\\n transition: opacity 0.15s ease-in;\\n font-style: italic;\\n}\\n.json-formatter-row:hover > a > .json-formatter-preview-text {\\n opacity: 0.6;\\n}\\n.json-formatter-row.json-formatter-open > .json-formatter-toggler-link .json-formatter-toggler:after {\\n transform: rotate(90deg);\\n}\\n.json-formatter-row.json-formatter-open > .json-formatter-children:after {\\n display: inline-block;\\n}\\n.json-formatter-row.json-formatter-open > a > .json-formatter-preview-text {\\n display: none;\\n}\\n.json-formatter-row.json-formatter-open.json-formatter-empty:after {\\n display: block;\\n}\\n.json-formatter-dark.json-formatter-row {\\n font-family: monospace;\\n}\\n.json-formatter-dark.json-formatter-row,\\n.json-formatter-dark.json-formatter-row a,\\n.json-formatter-dark.json-formatter-row a:hover {\\n color: white;\\n text-decoration: none;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-row {\\n margin-left: 1rem;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-children.json-formatter-empty {\\n opacity: 0.5;\\n margin-left: 1rem;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-children.json-formatter-empty:after {\\n display: none;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-children.json-formatter-empty.json-formatter-object:after {\\n content: \\\"No properties\\\";\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-children.json-formatter-empty.json-formatter-array:after {\\n content: \\\"[]\\\";\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-string,\\n.json-formatter-dark.json-formatter-row .json-formatter-stringifiable {\\n color: #31F031;\\n white-space: pre;\\n word-wrap: break-word;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-number {\\n color: #66C2FF;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-boolean {\\n color: #EC4242;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-null {\\n color: #EEC97D;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-undefined {\\n color: #ef8fbe;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-function {\\n color: #FD48CB;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-date {\\n background-color: rgba(255, 255, 255, 0.05);\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-url {\\n text-decoration: underline;\\n color: #027BFF;\\n cursor: pointer;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-bracket {\\n color: #9494FF;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-key {\\n color: #23A0DB;\\n padding-right: 0.2rem;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-toggler-link {\\n cursor: pointer;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-toggler {\\n line-height: 1.2rem;\\n font-size: 0.7rem;\\n vertical-align: middle;\\n opacity: 0.6;\\n cursor: pointer;\\n padding-right: 0.2rem;\\n}\\n.json-formatter-dark.json-formatter-row .json-formatter-toggler:after {\\n display: inline-block;\\n transition: transform 100ms ease-in;\\n content: \\\"\\\\25BA\\\";\\n}\\n.json-formatter-dark.json-formatter-row > a > .json-formatter-preview-text {\\n opacity: 0;\\n transition: opacity 0.15s ease-in;\\n font-style: italic;\\n}\\n.json-formatter-dark.json-formatter-row:hover > a > .json-formatter-preview-text {\\n opacity: 0.6;\\n}\\n.json-formatter-dark.json-formatter-row.json-formatter-open > .json-formatter-toggler-link .json-formatter-toggler:after {\\n transform: rotate(90deg);\\n}\\n.json-formatter-dark.json-formatter-row.json-formatter-open > .json-formatter-children:after {\\n display: inline-block;\\n}\\n.json-formatter-dark.json-formatter-row.json-formatter-open > a > .json-formatter-preview-text {\\n display: none;\\n}\\n.json-formatter-dark.json-formatter-row.json-formatter-open.json-formatter-empty:after {\\n display: block;\\n}\\n\");\n",
" },\n",
" function(Bokeh) {\n",
" inject_raw_css(\".bk.pn-loading:before {\\n position: absolute;\\n height: 100%;\\n width: 100%;\\n content: '';\\n z-index: 1000;\\n background-color: rgb(255,255,255,0.50);\\n border-color: lightgray;\\n background-repeat: no-repeat;\\n background-position: center;\\n background-size: auto 50%;\\n border-width: 1px;\\n cursor: progress;\\n}\\n.bk.pn-loading.arcs:hover:before {\\n cursor: progress;\\n}\\n\");\n",
" },\n",
" function(Bokeh) {\n",
" inject_raw_css(\".codehilite .hll { background-color: #ffffcc }\\n.codehilite { background: #f8f8f8; }\\n.codehilite .c { color: #408080; font-style: italic } /* Comment */\\n.codehilite .err { border: 1px solid #FF0000 } /* Error */\\n.codehilite .k { color: #008000; font-weight: bold } /* Keyword */\\n.codehilite .o { color: #666666 } /* Operator */\\n.codehilite .ch { color: #408080; font-style: italic } /* Comment.Hashbang */\\n.codehilite .cm { color: #408080; font-style: italic } /* Comment.Multiline */\\n.codehilite .cp { color: #BC7A00 } /* Comment.Preproc */\\n.codehilite .cpf { color: #408080; font-style: italic } /* Comment.PreprocFile */\\n.codehilite .c1 { color: #408080; font-style: italic } /* Comment.Single */\\n.codehilite .cs { color: #408080; font-style: italic } /* Comment.Special */\\n.codehilite .gd { color: #A00000 } /* Generic.Deleted */\\n.codehilite .ge { font-style: italic } /* Generic.Emph */\\n.codehilite .gr { color: #FF0000 } /* Generic.Error */\\n.codehilite .gh { color: #000080; font-weight: bold } /* Generic.Heading */\\n.codehilite .gi { color: #00A000 } /* Generic.Inserted */\\n.codehilite .go { color: #888888 } /* Generic.Output */\\n.codehilite .gp { color: #000080; font-weight: bold } /* Generic.Prompt */\\n.codehilite .gs { font-weight: bold } /* Generic.Strong */\\n.codehilite .gu { color: #800080; font-weight: bold } /* Generic.Subheading */\\n.codehilite .gt { color: #0044DD } /* Generic.Traceback */\\n.codehilite .kc { color: #008000; font-weight: bold } /* Keyword.Constant */\\n.codehilite .kd { color: #008000; font-weight: bold } /* Keyword.Declaration */\\n.codehilite .kn { color: #008000; font-weight: bold } /* Keyword.Namespace */\\n.codehilite .kp { color: #008000 } /* Keyword.Pseudo */\\n.codehilite .kr { color: #008000; font-weight: bold } /* Keyword.Reserved */\\n.codehilite .kt { color: #B00040 } /* Keyword.Type */\\n.codehilite .m { color: #666666 } /* Literal.Number */\\n.codehilite .s { color: #BA2121 } /* Literal.String */\\n.codehilite .na { color: #7D9029 } /* Name.Attribute */\\n.codehilite .nb { color: #008000 } /* Name.Builtin */\\n.codehilite .nc { color: #0000FF; font-weight: bold } /* Name.Class */\\n.codehilite .no { color: #880000 } /* Name.Constant */\\n.codehilite .nd { color: #AA22FF } /* Name.Decorator */\\n.codehilite .ni { color: #999999; font-weight: bold } /* Name.Entity */\\n.codehilite .ne { color: #D2413A; font-weight: bold } /* Name.Exception */\\n.codehilite .nf { color: #0000FF } /* Name.Function */\\n.codehilite .nl { color: #A0A000 } /* Name.Label */\\n.codehilite .nn { color: #0000FF; font-weight: bold } /* Name.Namespace */\\n.codehilite .nt { color: #008000; font-weight: bold } /* Name.Tag */\\n.codehilite .nv { color: #19177C } /* Name.Variable */\\n.codehilite .ow { color: #AA22FF; font-weight: bold } /* Operator.Word */\\n.codehilite .w { color: #bbbbbb } /* Text.Whitespace */\\n.codehilite .mb { color: #666666 } /* Literal.Number.Bin */\\n.codehilite .mf { color: #666666 } /* Literal.Number.Float */\\n.codehilite .mh { color: #666666 } /* Literal.Number.Hex */\\n.codehilite .mi { color: #666666 } /* Literal.Number.Integer */\\n.codehilite .mo { color: #666666 } /* Literal.Number.Oct */\\n.codehilite .sa { color: #BA2121 } /* Literal.String.Affix */\\n.codehilite .sb { color: #BA2121 } /* Literal.String.Backtick */\\n.codehilite .sc { color: #BA2121 } /* Literal.String.Char */\\n.codehilite .dl { color: #BA2121 } /* Literal.String.Delimiter */\\n.codehilite .sd { color: #BA2121; font-style: italic } /* Literal.String.Doc */\\n.codehilite .s2 { color: #BA2121 } /* Literal.String.Double */\\n.codehilite .se { color: #BB6622; font-weight: bold } /* Literal.String.Escape */\\n.codehilite .sh { color: #BA2121 } /* Literal.String.Heredoc */\\n.codehilite .si { color: #BB6688; font-weight: bold } /* Literal.String.Interpol */\\n.codehilite .sx { color: #008000 } /* Literal.String.Other */\\n.codehilite .sr { color: #BB6688 } /* Literal.String.Regex */\\n.codehilite .s1 { color: #BA2121 } /* Literal.String.Single */\\n.codehilite .ss { color: #19177C } /* Literal.String.Symbol */\\n.codehilite .bp { color: #008000 } /* Name.Builtin.Pseudo */\\n.codehilite .fm { color: #0000FF } /* Name.Function.Magic */\\n.codehilite .vc { color: #19177C } /* Name.Variable.Class */\\n.codehilite .vg { color: #19177C } /* Name.Variable.Global */\\n.codehilite .vi { color: #19177C } /* Name.Variable.Instance */\\n.codehilite .vm { color: #19177C } /* Name.Variable.Magic */\\n.codehilite .il { color: #666666 } /* Literal.Number.Integer.Long */\\n\\n.markdown h1 { margin-block-start: 0.34em }\\n.markdown h2 { margin-block-start: 0.42em }\\n.markdown h3 { margin-block-start: 0.5em }\\n.markdown h4 { margin-block-start: 0.67em }\\n.markdown h5 { margin-block-start: 0.84em }\\n.markdown h6 { margin-block-start: 1.17em }\\n.markdown ul { padding-inline-start: 2em }\\n.markdown ol { padding-inline-start: 2em }\\n.markdown strong { font-weight: 600 }\\n.markdown a { color: -webkit-link }\\n.markdown a { color: -moz-hyperlinkText }\\n\");\n",
" },\n",
" function(Bokeh) {\n",
" inject_raw_css(\".bk.panel-widget-box {\\n min-height: 20px;\\n background-color: #f5f5f5;\\n border: 1px solid #e3e3e3;\\n border-radius: 4px;\\n -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.05);\\n box-shadow: inset 0 1px 1px rgba(0,0,0,.05);\\n overflow-x: hidden;\\n overflow-y: hidden;\\n}\\n\\n.scrollable {\\n overflow: scroll;\\n}\\n\\nprogress {\\n appearance: none;\\n -moz-appearance: none;\\n -webkit-appearance: none;\\n border: none;\\n height: 20px;\\n background-color: whiteSmoke;\\n border-radius: 3px;\\n box-shadow: 0 2px 3px rgba(0,0,0,.5) inset;\\n color: royalblue;\\n position: relative;\\n margin: 0 0 1.5em;\\n}\\n\\nprogress[value]::-webkit-progress-bar {\\n background-color: whiteSmoke;\\n border-radius: 3px;\\n box-shadow: 0 2px 3px rgba(0,0,0,.5) inset;\\n}\\n\\nprogress[value]::-webkit-progress-value {\\n position: relative;\\n background-size: 35px 20px, 100% 100%, 100% 100%;\\n border-radius:3px;\\n}\\n\\nprogress.active:not([value])::before {\\n background-position: 10%;\\n animation-name: stripes;\\n animation-duration: 3s;\\n animation-timing-function: linear;\\n animation-iteration-count: infinite;\\n}\\n\\nprogress[value]::-moz-progress-bar {\\n background-size: 35px 20px, 100% 100%, 100% 100%;\\n border-radius:3px;\\n}\\n\\nprogress:not([value])::-moz-progress-bar {\\n border-radius:3px;\\n background: linear-gradient(-45deg, transparent 33%, rgba(0, 0, 0, 0.2) 33%, rgba(0, 0, 0, 0.2) 66%, transparent 66%) left/2.5em 1.5em;\\n}\\n\\nprogress.active:not([value])::-moz-progress-bar {\\n background-position: 10%;\\n animation-name: stripes;\\n animation-duration: 3s;\\n animation-timing-function: linear;\\n animation-iteration-count: infinite;\\n}\\n\\nprogress.active:not([value])::-webkit-progress-bar {\\n background-position: 10%;\\n animation-name: stripes;\\n animation-duration: 3s;\\n animation-timing-function: linear;\\n animation-iteration-count: infinite;\\n}\\n\\nprogress.primary[value]::-webkit-progress-value { background-color: #007bff; }\\nprogress.primary:not([value])::before { background-color: #007bff; }\\nprogress.primary:not([value])::-webkit-progress-bar { background-color: #007bff; }\\nprogress.primary::-moz-progress-bar { background-color: #007bff; }\\n\\nprogress.secondary[value]::-webkit-progress-value { background-color: #6c757d; }\\nprogress.secondary:not([value])::before { background-color: #6c757d; }\\nprogress.secondary:not([value])::-webkit-progress-bar { background-color: #6c757d; }\\nprogress.secondary::-moz-progress-bar { background-color: #6c757d; }\\n\\nprogress.success[value]::-webkit-progress-value { background-color: #28a745; }\\nprogress.success:not([value])::before { background-color: #28a745; }\\nprogress.success:not([value])::-webkit-progress-bar { background-color: #28a745; }\\nprogress.success::-moz-progress-bar { background-color: #28a745; }\\n\\nprogress.danger[value]::-webkit-progress-value { background-color: #dc3545; }\\nprogress.danger:not([value])::before { background-color: #dc3545; }\\nprogress.danger:not([value])::-webkit-progress-bar { background-color: #dc3545; }\\nprogress.danger::-moz-progress-bar { background-color: #dc3545; }\\n\\nprogress.warning[value]::-webkit-progress-value { background-color: #ffc107; }\\nprogress.warning:not([value])::before { background-color: #ffc107; }\\nprogress.warning:not([value])::-webkit-progress-bar { background-color: #ffc107; }\\nprogress.warning::-moz-progress-bar { background-color: #ffc107; }\\n\\nprogress.info[value]::-webkit-progress-value { background-color: #17a2b8; }\\nprogress.info:not([value])::before { background-color: #17a2b8; }\\nprogress.info:not([value])::-webkit-progress-bar { background-color: #17a2b8; }\\nprogress.info::-moz-progress-bar { background-color: #17a2b8; }\\n\\nprogress.light[value]::-webkit-progress-value { background-color: #f8f9fa; }\\nprogress.light:not([value])::before { background-color: #f8f9fa; }\\nprogress.light:not([value])::-webkit-progress-bar { background-color: #f8f9fa; }\\nprogress.light::-moz-progress-bar { background-color: #f8f9fa; }\\n\\nprogress.dark[value]::-webkit-progress-value { background-color: #343a40; }\\nprogress.dark:not([value])::-webkit-progress-bar { background-color: #343a40; }\\nprogress.dark:not([value])::before { background-color: #343a40; }\\nprogress.dark::-moz-progress-bar { background-color: #343a40; }\\n\\nprogress:not([value])::-webkit-progress-bar {\\n border-radius: 3px;\\n background: linear-gradient(-45deg, transparent 33%, rgba(0, 0, 0, 0.2) 33%, rgba(0, 0, 0, 0.2) 66%, transparent 66%) left/2.5em 1.5em;\\n}\\nprogress:not([value])::before {\\n content:\\\" \\\";\\n position:absolute;\\n height: 20px;\\n top:0;\\n left:0;\\n right:0;\\n bottom:0;\\n border-radius: 3px;\\n background: linear-gradient(-45deg, transparent 33%, rgba(0, 0, 0, 0.2) 33%, rgba(0, 0, 0, 0.2) 66%, transparent 66%) left/2.5em 1.5em;\\n}\\n\\n@keyframes stripes {\\n from {background-position: 0%}\\n to {background-position: 100%}\\n}\\n\\n.bk-root .bk.loader {\\n overflow: hidden;\\n}\\n\\n.bk.loader::after {\\n content: \\\"\\\";\\n border-radius: 50%;\\n -webkit-mask-image: radial-gradient(transparent 50%, rgba(0, 0, 0, 1) 54%);\\n width: 100%;\\n height: 100%;\\n left: 0;\\n top: 0;\\n position: absolute;\\n}\\n\\n.bk-root .bk.loader.dark::after {\\n background: #0f0f0f;\\n}\\n\\n.bk-root .bk.loader.light::after {\\n background: #f0f0f0;\\n}\\n\\n.bk-root .bk.loader.spin::after {\\n animation: spin 2s linear infinite;\\n}\\n\\n.bk-root div.bk.loader.spin.primary-light::after {\\n background: linear-gradient(135deg, #f0f0f0 50%, transparent 50%), linear-gradient(45deg, #f0f0f0 50%, #007bff 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.secondary-light::after {\\n background: linear-gradient(135deg, #f0f0f0 50%, transparent 50%), linear-gradient(45deg, #f0f0f0 50%, #6c757d 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.success-light::after {\\n background: linear-gradient(135deg, #f0f0f0 50%, transparent 50%), linear-gradient(45deg, #f0f0f0 50%, #28a745 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.danger-light::after {\\n background: linear-gradient(135deg, #f0f0f0 50%, transparent 50%), linear-gradient(45deg, #f0f0f0 50%, #dc3545 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.warning-light::after {\\n background: linear-gradient(135deg, #f0f0f0 50%, transparent 50%), linear-gradient(45deg, #f0f0f0 50%, #ffc107 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.info-light::after {\\n background: linear-gradient(135deg, #f0f0f0 50%, transparent 50%), linear-gradient(45deg, #f0f0f0 50%, #17a2b8 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.light-light::after {\\n background: linear-gradient(135deg, #f0f0f0 50%, transparent 50%), linear-gradient(45deg, #f0f0f0 50%, #f8f9fa 50%);\\n}\\n\\n.bk-root div.bk.loader.dark-light::after {\\n background: linear-gradient(135deg, #f0f0f0 50%, transparent 50%), linear-gradient(45deg, #f0f0f0 50%, #343a40 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.primary-dark::after {\\n background: linear-gradient(135deg, #0f0f0f 50%, transparent 50%), linear-gradient(45deg, #0f0f0f 50%, #007bff 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.secondary-dark::after {\\n background: linear-gradient(135deg, #0f0f0f 50%, transparent 50%), linear-gradient(45deg, #0f0f0f 50%, #6c757d 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.success-dark::after {\\n background: linear-gradient(135deg, #0f0f0f 50%, transparent 50%), linear-gradient(45deg, #0f0f0f 50%, #28a745 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.danger-dark::after {\\n background: linear-gradient(135deg, #0f0f0f 50%, transparent 50%), linear-gradient(45deg, #0f0f0f 50%, #dc3545 50%)\\n}\\n\\n.bk-root div.bk.loader.spin.warning-dark::after {\\n background: linear-gradient(135deg, #0f0f0f 50%, transparent 50%), linear-gradient(45deg, #0f0f0f 50%, #ffc107 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.info-dark::after {\\n background: linear-gradient(135deg, #0f0f0f 50%, transparent 50%), linear-gradient(45deg, #0f0f0f 50%, #17a2b8 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.light-dark::after {\\n background: linear-gradient(135deg, #0f0f0f 50%, transparent 50%), linear-gradient(45deg, #0f0f0f 50%, #f8f9fa 50%);\\n}\\n\\n.bk-root div.bk.loader.spin.dark-dark::after {\\n background: linear-gradient(135deg, #0f0f0f 50%, transparent 50%), linear-gradient(45deg, #0f0f0f 50%, #343a40 50%);\\n}\\n\\n/* Safari */\\n@-webkit-keyframes spin {\\n 0% { -webkit-transform: rotate(0deg); }\\n 100% { -webkit-transform: rotate(360deg); }\\n}\\n\\n@keyframes spin {\\n 0% { transform: rotate(0deg); }\\n 100% { transform: rotate(360deg); }\\n}\\n\\n.dot div {\\n height: 100%;\\n width: 100%;\\n border: 1px solid #000 !important;\\n background-color: #fff;\\n border-radius: 50%;\\n display: inline-block;\\n}\\n\\n.dot-filled div {\\n height: 100%;\\n width: 100%;\\n border: 1px solid #000 !important;\\n border-radius: 50%;\\n display: inline-block;\\n}\\n\\n.dot-filled.primary div {\\n background-color: #007bff;\\n}\\n\\n.dot-filled.secondary div {\\n background-color: #6c757d;\\n}\\n\\n.dot-filled.success div {\\n background-color: #28a745;\\n}\\n\\n.dot-filled.danger div {\\n background-color: #dc3545;\\n}\\n\\n.dot-filled.warning div {\\n background-color: #ffc107;\\n}\\n\\n.dot-filled.info div {\\n background-color: #17a2b8;\\n}\\n\\n.dot-filled.dark div {\\n background-color: #343a40;\\n}\\n\\n.dot-filled.light div {\\n background-color: #f8f9fa;\\n}\\n\");\n",
" },\n",
" function(Bokeh) {\n",
" inject_raw_css(\"\\n .bk.pn-loading.arcs:before {\\n background-image: url(\\\"\\\")\\n }\\n \");\n",
" },\n",
" function(Bokeh) {\n",
" /* BEGIN bokeh.min.js */\n",
" /*!\n",
" * Copyright (c) 2012 - 2021, Anaconda, Inc., and Bokeh Contributors\n",
" * All rights reserved.\n",
" * \n",
" * Redistribution and use in source and binary forms, with or without modification,\n",
" * are permitted provided that the following conditions are met:\n",
" * \n",
" * Redistributions of source code must retain the above copyright notice,\n",
" * this list of conditions and the following disclaimer.\n",
" * \n",
" * Redistributions in binary form must reproduce the above copyright notice,\n",
" * this list of conditions and the following disclaimer in the documentation\n",
" * and/or other materials provided with the distribution.\n",
" * \n",
" * Neither the name of Anaconda nor the names of any contributors\n",
" * may be used to endorse or promote products derived from this software\n",
" * without specific prior written permission.\n",
" * \n",
" * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS \"AS IS\"\n",
" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE\n",
" * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE\n",
" * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE\n",
" * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR\n",
" * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF\n",
" * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS\n",
" * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN\n",
" * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)\n",
" * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF\n",
" * THE POSSIBILITY OF SUCH DAMAGE.\n",
" */\n",
" (function(root, factory) {\n",
" const bokeh = factory();\n",
" bokeh.__bokeh__ = true;\n",
" if (typeof root.Bokeh === \"undefined\" || typeof root.Bokeh.__bokeh__ === \"undefined\") {\n",
" root.Bokeh = bokeh;\n",
" }\n",
" const Bokeh = root.Bokeh;\n",
" Bokeh[bokeh.version] = bokeh;\n",
" })(this, function() {\n",
" var define;\n",
" var parent_require = typeof require === \"function\" && require\n",
" return (function(modules, entry, aliases, externals) {\n",
" if (aliases === undefined) aliases = {};\n",
" if (externals === undefined) externals = {};\n",
"\n",
" var cache = {};\n",
"\n",
" var normalize = function(name) {\n",
" if (typeof name === \"number\")\n",
" return name;\n",
"\n",
" if (name === \"bokehjs\")\n",
" return entry;\n",
"\n",
" if (!externals[name]) {\n",
" var prefix = \"@bokehjs/\"\n",
" if (name.slice(0, prefix.length) === prefix)\n",
" name = name.slice(prefix.length)\n",
" }\n",
"\n",
" var alias = aliases[name]\n",
" if (alias != null)\n",
" return alias;\n",
"\n",
" var trailing = name.length > 0 && name[name.lenght-1] === \"/\";\n",
" var index = aliases[name + (trailing ? \"\" : \"/\") + \"index\"];\n",
" if (index != null)\n",
" return index;\n",
"\n",
" return name;\n",
" }\n",
"\n",
" var require = function(name) {\n",
" var mod = cache[name];\n",
" if (!mod) {\n",
" var id = normalize(name);\n",
"\n",
" mod = cache[id];\n",
" if (!mod) {\n",
" if (!modules[id]) {\n",
" if (externals[id] === false || (externals[id] == true && parent_require)) {\n",
" try {\n",
" mod = {exports: externals[id] ? parent_require(id) : {}};\n",
" cache[id] = cache[name] = mod;\n",
" return mod.exports;\n",
" } catch (e) {}\n",
" }\n",
"\n",
" var err = new Error(\"Cannot find module '\" + name + \"'\");\n",
" err.code = 'MODULE_NOT_FOUND';\n",
" throw err;\n",
" }\n",
"\n",
" mod = {exports: {}};\n",
" cache[id] = cache[name] = mod;\n",
"\n",
" function __esModule() {\n",
" Object.defineProperty(mod.exports, \"__esModule\", {value: true});\n",
" }\n",
"\n",
" function __esExport(name, value) {\n",
" Object.defineProperty(mod.exports, name, {\n",
" enumerable: true, get: function () { return value; }\n",
" });\n",
" }\n",
"\n",
" modules[id].call(mod.exports, require, mod, mod.exports, __esModule, __esExport);\n",
" } else {\n",
" cache[name] = mod;\n",
" }\n",
" }\n",
"\n",
" return mod.exports;\n",
" }\n",
" require.resolve = function(name) {\n",
" return \"\"\n",
" }\n",
"\n",
" var main = require(entry);\n",
" main.require = require;\n",
"\n",
" if (typeof Proxy !== \"undefined\") {\n",
" // allow Bokeh.loader[\"@bokehjs/module/name\"] syntax\n",
" main.loader = new Proxy({}, {\n",
" get: function(_obj, module) {\n",
" return require(module);\n",
" }\n",
" });\n",
" }\n",
"\n",
" main.register_plugin = function(plugin_modules, plugin_entry, plugin_aliases, plugin_externals) {\n",
" if (plugin_aliases === undefined) plugin_aliases = {};\n",
" if (plugin_externals === undefined) plugin_externals = {};\n",
"\n",
" for (var name in plugin_modules) {\n",
" modules[name] = plugin_modules[name];\n",
" }\n",
"\n",
" for (var name in plugin_aliases) {\n",
" aliases[name] = plugin_aliases[name];\n",
" }\n",
"\n",
" for (var name in plugin_externals) {\n",
" externals[name] = plugin_externals[name];\n",
" }\n",
"\n",
" var plugin = require(plugin_entry);\n",
"\n",
" for (var name in plugin) {\n",
" main[name] = plugin[name];\n",
" }\n",
"\n",
" return plugin;\n",
" }\n",
"\n",
" return main;\n",
" })\n",
" ([\n",
" function _(t,_,n,o,r){o();t(1).__exportStar(t(2),n)},\n",
" function _(t,e,n,r,o){r();var a=function(t,e){return(a=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var n in e)Object.prototype.hasOwnProperty.call(e,n)&&(t[n]=e[n])})(t,e)};n.__extends=function(t,e){function n(){this.constructor=t}a(t,e),t.prototype=null===e?Object.create(e):(n.prototype=e.prototype,new n)};function i(t){var e=\"function\"==typeof Symbol&&Symbol.iterator,n=e&&t[e],r=0;if(n)return n.call(t);if(t&&\"number\"==typeof t.length)return{next:function(){return t&&r>=t.length&&(t=void 0),{value:t&&t[r++],done:!t}}};throw new TypeError(e?\"Object is not iterable.\":\"Symbol.iterator is not defined.\")}function c(t,e){var n=\"function\"==typeof Symbol&&t[Symbol.iterator];if(!n)return t;var r,o,a=n.call(t),i=[];try{for(;(void 0===e||e-- >0)&&!(r=a.next()).done;)i.push(r.value)}catch(t){o={error:t}}finally{try{r&&!r.done&&(n=a.return)&&n.call(a)}finally{if(o)throw o.error}}return i}function u(t){return this instanceof u?(this.v=t,this):new u(t)}n.__assign=function(){return n.__assign=Object.assign||function(t){for(var e,n=1,r=arguments.length;n<r;n++)for(var o in e=arguments[n])Object.prototype.hasOwnProperty.call(e,o)&&(t[o]=e[o]);return t},n.__assign.apply(this,arguments)},n.__rest=function(t,e){var n={};for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&e.indexOf(r)<0&&(n[r]=t[r]);if(null!=t&&\"function\"==typeof Object.getOwnPropertySymbols){var o=0;for(r=Object.getOwnPropertySymbols(t);o<r.length;o++)e.indexOf(r[o])<0&&Object.prototype.propertyIsEnumerable.call(t,r[o])&&(n[r[o]]=t[r[o]])}return n},n.__decorate=function(t,e,n,r){var o,a=arguments.length,i=a<3?e:null===r?r=Object.getOwnPropertyDescriptor(e,n):r;if(\"object\"==typeof Reflect&&\"function\"==typeof Reflect.decorate)i=Reflect.decorate(t,e,n,r);else for(var c=t.length-1;c>=0;c--)(o=t[c])&&(i=(a<3?o(i):a>3?o(e,n,i):o(e,n))||i);return a>3&&i&&Object.defineProperty(e,n,i),i},n.__param=function(t,e){return function(n,r){e(n,r,t)}},n.__metadata=function(t,e){if(\"object\"==typeof Reflect&&\"function\"==typeof Reflect.metadata)return Reflect.metadata(t,e)},n.__awaiter=function(t,e,n,r){return new(n||(n=Promise))((function(o,a){function i(t){try{u(r.next(t))}catch(t){a(t)}}function c(t){try{u(r.throw(t))}catch(t){a(t)}}function u(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,c)}u((r=r.apply(t,e||[])).next())}))},n.__generator=function(t,e){var n,r,o,a,i={label:0,sent:function(){if(1&o[0])throw o[1];return o[1]},trys:[],ops:[]};return a={next:c(0),throw:c(1),return:c(2)},\"function\"==typeof Symbol&&(a[Symbol.iterator]=function(){return this}),a;function c(a){return function(c){return function(a){if(n)throw new TypeError(\"Generator is already executing.\");for(;i;)try{if(n=1,r&&(o=2&a[0]?r.return:a[0]?r.throw||((o=r.return)&&o.call(r),0):r.next)&&!(o=o.call(r,a[1])).done)return o;switch(r=0,o&&(a=[2&a[0],o.value]),a[0]){case 0:case 1:o=a;break;case 4:return i.label++,{value:a[1],done:!1};case 5:i.label++,r=a[1],a=[0];continue;case 7:a=i.ops.pop(),i.trys.pop();continue;default:if(!(o=i.trys,(o=o.length>0&&o[o.length-1])||6!==a[0]&&2!==a[0])){i=0;continue}if(3===a[0]&&(!o||a[1]>o[0]&&a[1]<o[3])){i.label=a[1];break}if(6===a[0]&&i.label<o[1]){i.label=o[1],o=a;break}if(o&&i.label<o[2]){i.label=o[2],i.ops.push(a);break}o[2]&&i.ops.pop(),i.trys.pop();continue}a=e.call(t,i)}catch(t){a=[6,t],r=0}finally{n=o=0}if(5&a[0])throw a[1];return{value:a[0]?a[1]:void 0,done:!0}}([a,c])}}},n.__createBinding=Object.create?function(t,e,n,r){void 0===r&&(r=n),Object.defineProperty(t,r,{enumerable:!0,get:function(){return e[n]}})}:function(t,e,n,r){void 0===r&&(r=n),t[r]=e[n]},n.__exportStar=function(t,e){for(var r in t)\"default\"===r||Object.prototype.hasOwnProperty.call(e,r)||n.__createBinding(e,t,r)},n.__values=i,n.__read=c,n.__spread=function(){for(var t=[],e=0;e<arguments.length;e++)t=t.concat(c(arguments[e]));return t},n.__spreadArrays=function(){for(var t=0,e=0,n=arguments.length;e<n;e++)t+=arguments[e].length;var r=Array(t),o=0;for(e=0;e<n;e++)for(var a=arguments[e],i=0,c=a.length;i<c;i++,o++)r[o]=a[i];return r},n.__await=u,n.__asyncGenerator=function(t,e,n){if(!Symbol.asyncIterator)throw new TypeError(\"Symbol.asyncIterator is not defined.\");var r,o=n.apply(t,e||[]),a=[];return r={},i(\"next\"),i(\"throw\"),i(\"return\"),r[Symbol.asyncIterator]=function(){return this},r;function i(t){o[t]&&(r[t]=function(e){return new Promise((function(n,r){a.push([t,e,n,r])>1||c(t,e)}))})}function c(t,e){try{(n=o[t](e)).value instanceof u?Promise.resolve(n.value.v).then(f,l):s(a[0][2],n)}catch(t){s(a[0][3],t)}var n}function f(t){c(\"next\",t)}function l(t){c(\"throw\",t)}function s(t,e){t(e),a.shift(),a.length&&c(a[0][0],a[0][1])}},n.__asyncDelegator=function(t){var e,n;return e={},r(\"next\"),r(\"throw\",(function(t){throw t})),r(\"return\"),e[Symbol.iterator]=function(){return this},e;function r(r,o){e[r]=t[r]?function(e){return(n=!n)?{value:u(t[r](e)),done:\"return\"===r}:o?o(e):e}:o}},n.__asyncValues=function(t){if(!Symbol.asyncIterator)throw new TypeError(\"Symbol.asyncIterator is not defined.\");var e,n=t[Symbol.asyncIterator];return n?n.call(t):(t=i(t),e={},r(\"next\"),r(\"throw\"),r(\"return\"),e[Symbol.asyncIterator]=function(){return this},e);function r(n){e[n]=t[n]&&function(e){return new Promise((function(r,o){(function(t,e,n,r){Promise.resolve(r).then((function(e){t({value:e,done:n})}),e)})(r,o,(e=t[n](e)).done,e.value)}))}}},n.__makeTemplateObject=function(t,e){return Object.defineProperty?Object.defineProperty(t,\"raw\",{value:e}):t.raw=e,t};var f=Object.create?function(t,e){Object.defineProperty(t,\"default\",{enumerable:!0,value:e})}:function(t,e){t.default=e};n.__importStar=function(t){if(t&&t.__esModule)return t;var e={};if(null!=t)for(var r in t)\"default\"!==r&&Object.prototype.hasOwnProperty.call(t,r)&&n.__createBinding(e,t,r);return f(e,t),e},n.__importDefault=function(t){return t&&t.__esModule?t:{default:t}},n.__classPrivateFieldGet=function(t,e){if(!e.has(t))throw new TypeError(\"attempted to get private field on non-instance\");return e.get(t)},n.__classPrivateFieldSet=function(t,e,n){if(!e.has(t))throw new TypeError(\"attempted to set private field on non-instance\");return e.set(t,n),n}},\n",
" function _(e,t,o,s,l){s();const n=e(1);l(\"version\",e(3).version),l(\"index\",e(4).index),o.embed=n.__importStar(e(4)),o.protocol=n.__importStar(e(404)),o._testing=n.__importStar(e(405));var r=e(19);l(\"logger\",r.logger),l(\"set_log_level\",r.set_log_level),l(\"settings\",e(28).settings),l(\"Models\",e(7).Models),l(\"documents\",e(5).documents),l(\"safely\",e(406).safely)},\n",
" function _(n,i,o,c,e){c(),o.version=\"2.3.1\"},\n",
" function _(e,o,t,n,s){n();const d=e(5),r=e(19),_=e(34),c=e(13),i=e(8),a=e(16),u=e(395),l=e(397),m=e(396);var f=e(395);s(\"add_document_standalone\",f.add_document_standalone),s(\"index\",f.index),s(\"add_document_from_session\",e(397).add_document_from_session);var g=e(402);async function w(e,o,t,n){i.isString(e)&&(e=JSON.parse(_.unescape(e)));const s={};for(const[o,t]of c.entries(e))s[o]=d.Document.from_json(t);const a=[];for(const e of o){const o=m._resolve_element(e),d=m._resolve_root_elements(e);if(null!=e.docid)a.push(await u.add_document_standalone(s[e.docid],o,d,e.use_for_title));else{if(null==e.token)throw new Error(\"Error rendering Bokeh items: either 'docid' or 'token' was expected.\");{const s=l._get_ws_url(t,n);r.logger.debug(`embed: computed ws url: ${s}`);try{a.push(await l.add_document_from_session(s,e.token,o,d,e.use_for_title)),console.log(\"Bokeh items were rendered successfully\")}catch(e){console.log(\"Error rendering Bokeh items:\",e)}}}}return a}s(\"embed_items_notebook\",g.embed_items_notebook),s(\"kernels\",g.kernels),s(\"BOKEH_ROOT\",e(396).BOKEH_ROOT),t.embed_item=async function(e,o){const t={},n=_.uuid4();t[n]=e.doc,null==o&&(o=e.target_id);const s=document.getElementById(o);null!=s&&s.classList.add(m.BOKEH_ROOT);const d={roots:{[e.root_id]:o},root_ids:[e.root_id],docid:n};await a.defer();const[r]=await w(t,[d]);return r},t.embed_items=async function(e,o,t,n){return await a.defer(),w(e,o,t,n)}},\n",
" function _(t,_,o,r,n){r();const a=t(1);a.__exportStar(t(6),o),a.__exportStar(t(35),o)},\n",
" function _(e,t,s,o,n){o();const r=e(1),i=e(7),l=e(3),_=e(19),a=e(264),c=e(14),d=e(30),h=e(15),f=e(17),u=e(31),m=e(9),g=e(13),v=r.__importStar(e(132)),w=e(26),p=e(8),b=e(319),y=e(130),k=e(53),M=e(394),j=e(35);class S{constructor(e){this.document=e,this.session=null,this.subscribed_models=new Set}send_event(e){const t=new j.MessageSentEvent(this.document,\"bokeh_event\",e.to_json());this.document._trigger_on_change(t)}trigger(e){for(const t of this.subscribed_models)null!=e.origin&&e.origin!=t||t._process_event(e)}}s.EventManager=S,S.__name__=\"EventManager\",s.documents=[],s.DEFAULT_TITLE=\"Bokeh Application\";class E{constructor(e){var t;s.documents.push(this),this._init_timestamp=Date.now(),this._resolver=null!==(t=null==e?void 0:e.resolver)&&void 0!==t?t:new i.ModelResolver,this._title=s.DEFAULT_TITLE,this._roots=[],this._all_models=new Map,this._all_models_freeze_count=0,this._callbacks=new Map,this._message_callbacks=new Map,this.event_manager=new S(this),this.idle=new h.Signal0(this,\"idle\"),this._idle_roots=new WeakMap,this._interactive_timestamp=null,this._interactive_plot=null}get layoutables(){return this._roots.filter((e=>e instanceof b.LayoutDOM))}get is_idle(){for(const e of this.layoutables)if(!this._idle_roots.has(e))return!1;return!0}notify_idle(e){this._idle_roots.set(e,!0),this.is_idle&&(_.logger.info(`document idle at ${Date.now()-this._init_timestamp} ms`),this.event_manager.send_event(new a.DocumentReady),this.idle.emit())}clear(){this._push_all_models_freeze();try{for(;this._roots.length>0;)this.remove_root(this._roots[0])}finally{this._pop_all_models_freeze()}}interactive_start(e){null==this._interactive_plot&&(this._interactive_plot=e,this._interactive_plot.trigger_event(new a.LODStart)),this._interactive_timestamp=Date.now()}interactive_stop(){null!=this._interactive_plot&&this._interactive_plot.trigger_event(new a.LODEnd),this._interactive_plot=null,this._interactive_timestamp=null}interactive_duration(){return null==this._interactive_timestamp?-1:Date.now()-this._interactive_timestamp}destructively_move(e){if(e===this)throw new Error(\"Attempted to overwrite a document with itself\");e.clear();const t=m.copy(this._roots);this.clear();for(const e of t)if(null!=e.document)throw new Error(`Somehow we didn't detach ${e}`);if(0!=this._all_models.size)throw new Error(`this._all_models still had stuff in it: ${this._all_models}`);for(const s of t)e.add_root(s);e.set_title(this._title)}_push_all_models_freeze(){this._all_models_freeze_count+=1}_pop_all_models_freeze(){this._all_models_freeze_count-=1,0===this._all_models_freeze_count&&this._recompute_all_models()}_invalidate_all_models(){_.logger.debug(\"invalidating document models\"),0===this._all_models_freeze_count&&this._recompute_all_models()}_recompute_all_models(){let e=new Set;for(const t of this._roots)e=v.union(e,t.references());const t=new Set(this._all_models.values()),s=v.difference(t,e),o=v.difference(e,t),n=new Map;for(const t of e)n.set(t.id,t);for(const e of s)e.detach_document();for(const e of o)e.attach_document(this);this._all_models=n}roots(){return this._roots}add_root(e,t){if(_.logger.debug(`Adding root: ${e}`),!m.includes(this._roots,e)){this._push_all_models_freeze();try{this._roots.push(e)}finally{this._pop_all_models_freeze()}this._trigger_on_change(new j.RootAddedEvent(this,e,t))}}remove_root(e,t){const s=this._roots.indexOf(e);if(!(s<0)){this._push_all_models_freeze();try{this._roots.splice(s,1)}finally{this._pop_all_models_freeze()}this._trigger_on_change(new j.RootRemovedEvent(this,e,t))}}title(){return this._title}set_title(e,t){e!==this._title&&(this._title=e,this._trigger_on_change(new j.TitleChangedEvent(this,e,t)))}get_model_by_id(e){var t;return null!==(t=this._all_models.get(e))&&void 0!==t?t:null}get_model_by_name(e){const t=[];for(const s of this._all_models.values())s instanceof k.Model&&s.name==e&&t.push(s);switch(t.length){case 0:return null;case 1:return t[0];default:throw new Error(`Multiple models are named '${e}'`)}}on_message(e,t){const s=this._message_callbacks.get(e);null==s?this._message_callbacks.set(e,new Set([t])):s.add(t)}remove_on_message(e,t){var s;null===(s=this._message_callbacks.get(e))||void 0===s||s.delete(t)}_trigger_on_message(e,t){const s=this._message_callbacks.get(e);if(null!=s)for(const e of s)e(t)}on_change(e,t=!1){this._callbacks.has(e)||this._callbacks.set(e,t)}remove_on_change(e){this._callbacks.delete(e)}_trigger_on_change(e){for(const[t,s]of this._callbacks)if(!s&&e instanceof j.DocumentEventBatch)for(const s of e.events)t(s);else t(e)}_notify_change(e,t,s,o,n){this._trigger_on_change(new j.ModelChangedEvent(this,e,t,s,o,null==n?void 0:n.setter_id,null==n?void 0:n.hint))}static _instantiate_object(e,t,s,o){const n=Object.assign(Object.assign({},s),{id:e,__deferred__:!0});return new(o.get(t))(n)}static _instantiate_references_json(e,t,s){var o;const n=new Map;for(const r of e){const e=r.id,i=r.type,l=null!==(o=r.attributes)&&void 0!==o?o:{};let _=t.get(e);null==_&&(_=E._instantiate_object(e,i,l,s),null!=r.subtype&&_.set_subtype(r.subtype)),n.set(_.id,_)}return n}static _resolve_refs(e,t,s,o){function n(e){var r;if(f.is_ref(e)){const o=null!==(r=t.get(e.id))&&void 0!==r?r:s.get(e.id);if(null!=o)return o;throw new Error(`reference ${JSON.stringify(e)} isn't known (not in Document?)`)}return u.is_NDArray_ref(e)?u.decode_NDArray(e,o):p.isArray(e)?function(e){const t=[];for(const s of e)t.push(n(s));return t}(e):p.isPlainObject(e)?function(e){const t={};for(const[s,o]of g.entries(e))t[s]=n(o);return t}(e):e}return n(e)}static _initialize_references_json(e,t,s,o){const n=new Map;for(const{id:r,attributes:i}of e){const e=!t.has(r),l=e?s.get(r):t.get(r),_=E._resolve_refs(i,t,s,o);l.setv(_,{silent:!0}),n.set(r,{instance:l,is_new:e})}const r=[],i=new Set;function l(e){if(e instanceof c.HasProps){if(n.has(e.id)&&!i.has(e.id)){i.add(e.id);const{instance:t,is_new:s}=n.get(e.id),{attributes:o}=t;for(const e of g.values(o))l(e);s&&(t.finalize(),r.push(t))}}else if(p.isArray(e))for(const t of e)l(t);else if(p.isPlainObject(e))for(const t of g.values(e))l(t)}for(const e of n.values())l(e.instance);for(const e of r)e.connect_signals()}static _event_for_attribute_change(e,t,s,o,n){if(o.get_model_by_id(e.id).property(t).syncable){const r={kind:\"ModelChanged\",model:{id:e.id},attr:t,new:s};return c.HasProps._json_record_references(o,s,n,{recursive:!0}),r}return null}static _events_to_sync_objects(e,t,s,o){const n=Object.keys(e.attributes),r=Object.keys(t.attributes),i=m.difference(n,r),l=m.difference(r,n),a=m.intersection(n,r),c=[];for(const e of i)_.logger.warn(`Server sent key ${e} but we don't seem to have it in our JSON`);for(const n of l){const r=t.attributes[n];c.push(E._event_for_attribute_change(e,n,r,s,o))}for(const n of a){const r=e.attributes[n],i=t.attributes[n];null==r&&null==i||(null==r||null==i?c.push(E._event_for_attribute_change(e,n,i,s,o)):w.is_equal(r,i)||c.push(E._event_for_attribute_change(e,n,i,s,o)))}return c.filter((e=>null!=e))}static _compute_patch_since_json(e,t){const s=t.to_json(!1);function o(e){const t=new Map;for(const s of e.roots.references)t.set(s.id,s);return t}const n=o(e),r=new Map,i=[];for(const t of e.roots.root_ids)r.set(t,n.get(t)),i.push(t);const l=o(s),_=new Map,a=[];for(const e of s.roots.root_ids)_.set(e,l.get(e)),a.push(e);if(i.sort(),a.sort(),m.difference(i,a).length>0||m.difference(a,i).length>0)throw new Error(\"Not implemented: computing add/remove of document roots\");const c=new Set;let h=[];for(const e of t._all_models.keys())if(n.has(e)){const s=E._events_to_sync_objects(n.get(e),l.get(e),t,c);h=h.concat(s)}const f=new d.Serializer({include_defaults:!1});return f.to_serializable([...c]),{references:[...f.definitions],events:h}}to_json_string(e=!0){return JSON.stringify(this.to_json(e))}to_json(e=!0){const t=new d.Serializer({include_defaults:e}),s=t.to_serializable(this._roots);return{version:l.version,title:this._title,roots:{root_ids:s.map((e=>e.id)),references:[...t.definitions]}}}static from_json_string(e){const t=JSON.parse(e);return E.from_json(t)}static from_json(e){_.logger.debug(\"Creating Document from JSON\");const t=e.version,s=-1!==t.indexOf(\"+\")||-1!==t.indexOf(\"-\"),o=`Library versions: JS (${l.version}) / Python (${t})`;s||l.version.replace(/-(dev|rc)\\./,\"$1\")==t?_.logger.debug(o):(_.logger.warn(\"JS/Python version mismatch\"),_.logger.warn(o));const n=new i.ModelResolver;null!=e.defs&&M.resolve_defs(e.defs,n);const r=e.roots,a=r.root_ids,c=r.references,d=E._instantiate_references_json(c,new Map,n);E._initialize_references_json(c,new Map,d,new Map);const h=new E({resolver:n});for(const e of a){const t=d.get(e);null!=t&&h.add_root(t)}return h.set_title(e.title),h}replace_with_json(e){E.from_json(e).destructively_move(this)}create_json_patch_string(e){return JSON.stringify(this.create_json_patch(e))}create_json_patch(e){for(const t of e)if(t.document!=this)throw new Error(\"Cannot create a patch using events from a different document\");const t=new d.Serializer,s=t.to_serializable(e);for(const e of this._all_models.values())t.remove_def(e);return{events:s,references:[...t.definitions]}}apply_json_patch(e,t=new Map,s){const o=e.references,n=e.events,r=E._instantiate_references_json(o,this._all_models,this._resolver);t instanceof Map||(t=new Map(t));for(const e of n)switch(e.kind){case\"RootAdded\":case\"RootRemoved\":case\"ModelChanged\":{const t=e.model.id,s=this._all_models.get(t);if(null!=s)r.set(t,s);else if(!r.has(t))throw _.logger.warn(`Got an event for unknown model ${e.model}\"`),new Error(\"event model wasn't known\");break}}const i=new Map(this._all_models),l=new Map;for(const[e,t]of r)i.has(e)||l.set(e,t);E._initialize_references_json(o,i,l,t);for(const e of n)switch(e.kind){case\"MessageSent\":{const{msg_type:s,msg_data:o}=e;let n;if(void 0===o){if(1!=t.size)throw new Error(\"expected exactly one buffer\");{const[[,e]]=t;n=e}}else n=E._resolve_refs(o,i,l,t);this._trigger_on_message(s,n);break}case\"ModelChanged\":{const o=e.model.id,n=this._all_models.get(o);if(null==n)throw new Error(`Cannot apply patch to ${o} which is not in the document`);const r=e.attr,_=E._resolve_refs(e.new,i,l,t);n.setv({[r]:_},{setter_id:s});break}case\"ColumnDataChanged\":{const o=e.column_source.id,n=this._all_models.get(o);if(null==n)throw new Error(`Cannot stream to ${o} which is not in the document`);const r=E._resolve_refs(e.new,new Map,new Map,t);if(null!=e.cols)for(const e in n.data)e in r||(r[e]=n.data[e]);n.setv({data:r},{setter_id:s,check_eq:!1});break}case\"ColumnsStreamed\":{const t=e.column_source.id,o=this._all_models.get(t);if(null==o)throw new Error(`Cannot stream to ${t} which is not in the document`);if(!(o instanceof y.ColumnDataSource))throw new Error(\"Cannot stream to non-ColumnDataSource\");const n=e.data,r=e.rollover;o.stream(n,r,s);break}case\"ColumnsPatched\":{const t=e.column_source.id,o=this._all_models.get(t);if(null==o)throw new Error(`Cannot patch ${t} which is not in the document`);if(!(o instanceof y.ColumnDataSource))throw new Error(\"Cannot patch non-ColumnDataSource\");const n=e.patches;o.patch(n,s);break}case\"RootAdded\":{const t=e.model.id,o=r.get(t);this.add_root(o,s);break}case\"RootRemoved\":{const t=e.model.id,o=r.get(t);this.remove_root(o,s);break}case\"TitleChanged\":this.set_title(e.title,s);break;default:throw new Error(\"Unknown patch event \"+JSON.stringify(e))}}}s.Document=E,E.__name__=\"Document\"},\n",
" function _(e,o,s,r,t){r();const l=e(1),d=e(8),i=e(13),n=e(14);s.overrides={};const a=new Map;s.Models=e=>{const o=s.Models.get(e);if(null!=o)return o;throw new Error(`Model '${e}' does not exist. This could be due to a widget or a custom model not being registered before first usage.`)},s.Models.get=e=>{var o;return null!==(o=s.overrides[e])&&void 0!==o?o:a.get(e)},s.Models.register=(e,o)=>{s.overrides[e]=o},s.Models.unregister=e=>{delete s.overrides[e]},s.Models.register_models=(e,o=!1,s)=>{var r;if(null!=e)for(const t of d.isArray(e)?e:i.values(e))if(r=t,d.isObject(r)&&r.prototype instanceof n.HasProps){const e=t.__qualified__;o||!a.has(e)?a.set(e,t):null!=s?s(e):console.warn(`Model '${e}' was already registered`)}},s.register_models=s.Models.register_models,s.Models.registered_names=()=>[...a.keys()];class u{constructor(){this._known_models=new Map}get(e,o){var r;const t=null!==(r=s.Models.get(e))&&void 0!==r?r:this._known_models.get(e);if(null!=t)return t;if(void 0!==o)return o;throw new Error(`Model '${e}' does not exist. This could be due to a widget or a custom model not being registered before first usage.`)}register(e){const o=e.__qualified__;null==this.get(o,null)?this._known_models.set(o,e):console.warn(`Model '${o}' was already registered with this resolver`)}}s.ModelResolver=u,u.__name__=\"ModelResolver\";const _=l.__importStar(e(38));s.register_models(_)},\n",
" function _(n,r,t,e,i){e();\n",
" // (c) 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n",
" // Underscore may be freely distributed under the MIT license.\n",
" const o=n(9),u=Object.prototype.toString;function c(n){return!0===n||!1===n||\"[object Boolean]\"===u.call(n)}function f(n){return\"[object Number]\"===u.call(n)}function a(n){return\"[object String]\"===u.call(n)}function l(n){const r=typeof n;return\"function\"===r||\"object\"===r&&!!n}function s(n){return l(n)&&void 0!==n[Symbol.iterator]}t.isBoolean=c,t.isNumber=f,t.isInteger=function(n){return f(n)&&Number.isInteger(n)},t.isString=a,t.isPrimitive=function(n){return null===n||c(n)||f(n)||a(n)},t.isFunction=function(n){return\"[object Function]\"===u.call(n)},t.isArray=function(n){return Array.isArray(n)},t.isArrayOf=function(n,r){return o.every(n,r)},t.isArrayableOf=function(n,r){for(let t=0,e=n.length;t<e;t++)if(!r(n[t]))return!1;return!0},t.isTypedArray=function(n){return ArrayBuffer.isView(n)&&!(n instanceof DataView)},t.isObject=l,t.isPlainObject=function(n){return l(n)&&(null==n.constructor||n.constructor===Object)},t.isIterable=s,t.isArrayable=function(n){return s(n)&&\"length\"in n}},\n",
" function _(n,t,e,r,o){r();\n",
" // (c) 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n",
" // Underscore may be freely distributed under the MIT license.\n",
" const i=n(10),u=n(11),c=n(12);o(\"map\",c.map),o(\"reduce\",c.reduce),o(\"min\",c.min),o(\"min_by\",c.min_by),o(\"max\",c.max),o(\"max_by\",c.max_by),o(\"sum\",c.sum),o(\"cumsum\",c.cumsum),o(\"every\",c.every),o(\"some\",c.some),o(\"find\",c.find),o(\"find_last\",c.find_last),o(\"find_index\",c.find_index),o(\"find_last_index\",c.find_last_index),o(\"sorted_index\",c.sorted_index),o(\"is_empty\",c.is_empty);const f=Array.prototype.slice;function s(n){return f.call(n)}function a(n){return[].concat(...n)}function l(n,t){return-1!==n.indexOf(t)}function m(n,t,e=1){u.assert(e>0,\"'step' must be a positive number\"),null==t&&(t=n,n=0);const{max:r,ceil:o,abs:i}=Math,c=n<=t?e:-e,f=r(o(i(t-n)/e),0),s=new Array(f);for(let t=0;t<f;t++,n+=c)s[t]=n;return s}e.head=function(n){return n[0]},e.tail=function(n){return n[n.length-1]},e.last=function(n){return n[n.length-1]},e.copy=s,e.concat=a,e.includes=l,e.contains=l,e.nth=function(n,t){return n[t>=0?t:n.length+t]},e.zip=function(...n){if(0==n.length)return[];const t=c.min(n.map((n=>n.length))),e=n.length,r=new Array(t);for(let o=0;o<t;o++){r[o]=new Array(e);for(let t=0;t<e;t++)r[o][t]=n[t][o]}return r},e.unzip=function(n){const t=n.length,e=c.min(n.map((n=>n.length))),r=Array(e);for(let n=0;n<e;n++)r[n]=new Array(t);for(let o=0;o<t;o++)for(let t=0;t<e;t++)r[t][o]=n[o][t];return r},e.range=m,e.linspace=function(n,t,e=100){const r=(t-n)/(e-1),o=new Array(e);for(let t=0;t<e;t++)o[t]=n+r*t;return o},e.transpose=function(n){const t=n.length,e=n[0].length,r=[];for(let o=0;o<e;o++){r[o]=[];for(let e=0;e<t;e++)r[o][e]=n[e][o]}return r},e.argmin=function(n){return c.min_by(m(n.length),(t=>n[t]))},e.argmax=function(n){return c.max_by(m(n.length),(t=>n[t]))},e.sort_by=function(n,t){const e=n.map(((n,e)=>({value:n,index:e,key:t(n)})));return e.sort(((n,t)=>{const e=n.key,r=t.key;if(e!==r){if(e>r||void 0===e)return 1;if(e<r||void 0===r)return-1}return n.index-t.index})),e.map((n=>n.value))},e.uniq=function(n){const t=new Set;for(const e of n)t.add(e);return[...t]},e.uniq_by=function(n,t){const e=[],r=[];for(const o of n){const n=t(o);l(r,n)||(r.push(n),e.push(o))}return e},e.union=function(...n){const t=new Set;for(const e of n)for(const n of e)t.add(n);return[...t]},e.intersection=function(n,...t){const e=[];n:for(const r of n)if(!l(e,r)){for(const n of t)if(!l(n,r))continue n;e.push(r)}return e},e.difference=function(n,...t){const e=a(t);return n.filter((n=>!l(e,n)))},e.remove_at=function(n,t){const e=s(n);return e.splice(t,1),e},e.remove_by=function(n,t){for(let e=0;e<n.length;)t(n[e])?n.splice(e,1):e++},e.shuffle=function(n){const t=n.length,e=new Array(t);for(let r=0;r<t;r++){const t=i.randomIn(0,r);t!==r&&(e[r]=e[t]),e[t]=n[r]}return e},e.pairwise=function(n,t){const e=n.length,r=new Array(e-1);for(let o=0;o<e-1;o++)r[o]=t(n[o],n[o+1]);return r},e.reversed=function(n){const t=n.length,e=new Array(t);for(let r=0;r<t;r++)e[t-r-1]=n[r];return e},e.repeat=function(n,t){const e=new Array(t);for(let r=0;r<t;r++)e[r]=n;return e}},\n",
" function _(n,r,t,e,o){e();const{PI:u}=Math;function a(n){if(0==n)return 0;for(;n<=0;)n+=2*u;for(;n>2*u;)n-=2*u;return n}function c(n,r){return a(n-r)}function f(){return Math.random()}function i(n){switch(n){case\"deg\":return u/180;case\"rad\":return 1;case\"grad\":return u/200;case\"turn\":return 2*u}}t.angle_norm=a,t.angle_dist=c,t.angle_between=function(n,r,t,e=!1){const o=c(r,t);if(0==o)return!1;if(o==2*u)return!0;const f=a(n),i=c(r,f)<=o&&c(f,t)<=o;return e?!i:i},t.random=f,t.randomIn=function(n,r){return null==r&&(r=n,n=0),n+Math.floor(Math.random()*(r-n+1))},t.atan2=function(n,r){return Math.atan2(r[1]-n[1],r[0]-n[0])},t.radians=function(n){return n*(u/180)},t.degrees=function(n){return n/(u/180)},t.resolve_angle=function(n,r){return-i(r)*n},t.to_radians_coeff=i,t.rnorm=function(n,r){let t,e;for(;t=f(),e=f(),e=(2*e-1)*Math.sqrt(1/Math.E*2),!(-4*t*t*Math.log(t)>=e*e););let o=e/t;return o=n+r*o,o},t.clamp=function(n,r,t){return n<r?r:n>t?t:n},t.log=function(n,r=Math.E){return Math.log(n)/Math.log(r)}},\n",
" function _(r,n,e,o,s){o();class t extends Error{}e.AssertionError=t,t.__name__=\"AssertionError\",e.assert=function(r,n){if(!(!0===r||!1!==r&&r()))throw new t(null!=n?n:\"Assertion failed\")},e.unreachable=function(){throw new Error(\"unreachable code\")}},\n",
" function _(n,t,e,r,o){r();const i=n(10);function l(n,t,e,...r){const o=n.length;t<0&&(t+=o),t<0?t=0:t>o&&(t=o),null==e||e>o-t?e=o-t:e<0&&(e=0);const i=o-e+r.length,l=new n.constructor(i);let u=0;for(;u<t;u++)l[u]=n[u];for(const n of r)l[u++]=n;for(let r=t+e;r<o;r++)l[u++]=n[r];return l}function u(n,t){return l(n,t,n.length-t)}function c(n,t){const e=n.length,r=new n.constructor(e);for(let o=0;o<e;o++)r[o]=t(n[o],o,n);return r}function f(n,t,e){const r=n.length;if(void 0===e&&0==r)throw new Error(\"can't reduce an empty array without an initial value\");let o,i;for(void 0===e?(o=n[0],i=1):(o=e,i=0);i<r;i++)o=t(o,n[i],i,n);return o}function s(n){return function(t,e){const r=t.length;let o=n>0?0:r-1;for(;o>=0&&o<r;o+=n)if(e(t[o]))return o;return-1}}function h(n,t){let e=0,r=n.length;for(;e<r;){const o=Math.floor((e+r)/2);n[o]<t?e=o+1:r=o}return e}function a(n,t,e,r,o){const i=(o-e)/(r-t);let l=i*(n-t)+e;return isFinite(l)||(l=i*(n-r)+o,isFinite(l)||e!=o||(l=e)),l}function g(n,t){if(n<t[0])return-1;if(n>t[t.length-1])return t.length;let e=0,r=t.length-1;for(;r-e!=1;){const o=e+Math.floor((r-e)/2);n>=t[o]?e=o:r=o}return e}e.is_empty=function(n){return 0==n.length},e.copy=function(n){return Array.isArray(n)?n.slice():new n.constructor(n)},e.splice=l,e.head=u,e.insert=function(n,t,e){return l(n,e,0,t)},e.append=function(n,t){return l(n,n.length,0,t)},e.prepend=function(n,t){return l(n,0,0,t)},e.indexOf=function(n,t){for(let e=0,r=n.length;e<r;e++)if(n[e]===t)return e;return-1},e.subselect=function(n,t){const e=t.length,r=new n.constructor(e);for(let o=0;o<e;o++)r[o]=n[t[o]];return r},e.mul=function(n,t,e){const r=n.length,o=null!=e?e:new n.constructor(r);for(let e=0;e<r;e++)o[e]=n[e]*t;return o},e.map=c,e.inplace_map=function(n,t,e){const r=n.length,o=null!=e?e:n;for(let e=0;e<r;e++)o[e]=t(n[e],e)},e.filter=function(n,t){const e=n.length,r=new n.constructor(e);let o=0;for(let i=0;i<e;i++){const e=n[i];t(e,i,n)&&(r[o++]=e)}return u(r,o)},e.reduce=f,e.min=function(n){let t,e=1/0;for(let r=0,o=n.length;r<o;r++)t=n[r],!isNaN(t)&&t<e&&(e=t);return e},e.max=function(n){let t,e=-1/0;for(let r=0,o=n.length;r<o;r++)t=n[r],!isNaN(t)&&t>e&&(e=t);return e},e.minmax=function(n){let t,e=1/0,r=-1/0;for(let o=0,i=n.length;o<i;o++)t=n[o],isNaN(t)||(t<e&&(e=t),t>r&&(r=t));return[e,r]},e.min_by=function(n,t){if(0==n.length)throw new Error(\"min_by() called with an empty array\");let e=n[0],r=t(e);for(let o=1,i=n.length;o<i;o++){const i=n[o],l=t(i);l<r&&(e=i,r=l)}return e},e.max_by=function(n,t){if(0==n.length)throw new Error(\"max_by() called with an empty array\");let e=n[0],r=t(e);for(let o=1,i=n.length;o<i;o++){const i=n[o],l=t(i);l>r&&(e=i,r=l)}return e},e.sum=function(n){let t=0;for(let e=0,r=n.length;e<r;e++)t+=n[e];return t},e.cumsum=function(n){const t=new n.constructor(n.length);return f(n,((n,e,r)=>t[r]=n+e),0),t},e.every=function(n,t){for(let e=0,r=n.length;e<r;e++)if(!t(n[e]))return!1;return!0},e.some=function(n,t){for(let e=0,r=n.length;e<r;e++)if(t(n[e]))return!0;return!1},e.index_of=function(n,t){for(let e=0,r=n.length;e<r;e++)if(n[e]===t)return e;return-1},e.find_index=s(1),e.find_last_index=s(-1),e.find=function(n,t){const r=e.find_index(n,t);return-1==r?void 0:n[r]},e.find_last=function(n,t){const r=e.find_last_index(n,t);return-1==r?void 0:n[r]},e.sorted_index=h,e.bin_counts=function(n,t){const e=t.length-1,r=Array(e).fill(0);for(let o=0;o<n.length;o++){const l=h(t,n[o]);r[i.clamp(l-1,0,e-1)]+=1}return r},e.interpolate=function(n,t,e){const r=n.length,o=new Array(r);for(let i=0;i<r;i++){const r=n[i];if(isNaN(r)){o[i]=r;continue}const l=g(r,t);if(-1==l)o[i]=e[0];else if(l==t.length)o[i]=e[e.length-1];else if(l==t.length-1||t[l]==r)o[i]=e[l];else{const n=t[l],u=e[l],c=t[l+1],f=e[l+1];o[i]=a(r,n,u,c,f)}}return o},e.left_edge_index=g,e.norm=function(n,t,e){const r=e-t;return c(n,(n=>(n-t)/r))}},\n",
" function _(t,e,n,c,o){c();const s=t(9),{hasOwnProperty:r}=Object.prototype;function u(t){return Object.keys(t).length}n.keys=Object.keys,n.values=Object.values,n.entries=Object.entries,n.extend=Object.assign,n.clone=function(t){return Object.assign({},t)},n.merge=function(t,e){const n=Object.create(Object.prototype),c=s.concat([Object.keys(t),Object.keys(e)]);for(const o of c){const c=r.call(t,o)?t[o]:[],u=r.call(e,o)?e[o]:[];n[o]=s.union(c,u)}return n},n.size=u,n.isEmpty=function(t){return 0==u(t)},n.to_object=function(t){const e={};for(const[n,c]of t)e[n]=c;return e}},\n",
" function _(t,e,s,n,r){n();const i=t(1),o=t(15),c=t(17),a=i.__importStar(t(18)),_=i.__importStar(t(21)),h=t(34),u=t(13),l=t(8),f=t(26),p=t(30),d=t(35),g=t(26),y=t(36),v=t(37),m=i.__importStar(t(21));class b extends(o.Signalable()){constructor(t={}){var e,s;super(),this._subtype=void 0,this.document=null,this.destroyed=new o.Signal0(this,\"destroyed\"),this.change=new o.Signal0(this,\"change\"),this.transformchange=new o.Signal0(this,\"transformchange\"),this.exprchange=new o.Signal0(this,\"exprchange\"),this.properties={},this._pending=!1,this._changing=!1;const n=t instanceof Map?t.get.bind(t):e=>t[e];this.id=null!==(e=n(\"id\"))&&void 0!==e?e:h.uniqueId();for(const[t,{type:e,default_value:s,options:r}]of u.entries(this._props)){let i;e instanceof a.PropertyAlias?Object.defineProperty(this.properties,t,{get:()=>this.properties[e.attr],configurable:!1,enumerable:!1}):(i=e instanceof _.Kind?new a.PrimitiveProperty(this,t,e,s,n(t),r):new e(this,t,_.Any,s,n(t),r),this.properties[t]=i)}null!==(s=n(\"__deferred__\"))&&void 0!==s&&s||(this.finalize(),this.connect_signals())}get is_syncable(){return!0}set type(t){console.warn(\"prototype.type = 'ModelName' is deprecated, use static __name__ instead\"),this.constructor.__name__=t}get type(){return this.constructor.__qualified__}static get __qualified__(){const{__module__:t,__name__:e}=this;return null!=t?`${t}.${e}`:e}static get[Symbol.toStringTag](){return this.__name__}static init_HasProps(){this.prototype._props={},this.prototype._mixins=[]}static _fix_default(t,e){if(void 0===t||l.isFunction(t))return t;if(l.isPrimitive(t))return()=>t;{const e=new v.Cloner;return()=>e.clone(t)}}static define(t){for(const[e,s]of u.entries(l.isFunction(t)?t(m):t)){if(null!=this.prototype._props[e])throw new Error(`attempted to redefine property '${this.prototype.type}.${e}'`);if(null!=this.prototype[e])throw new Error(`attempted to redefine attribute '${this.prototype.type}.${e}'`);Object.defineProperty(this.prototype,e,{get(){return this.properties[e].get_value()},set(t){return this.setv({[e]:t}),this},configurable:!1,enumerable:!0});const[t,n,r={}]=s,i={type:t,default_value:this._fix_default(n,e),options:r},o=Object.assign({},this.prototype._props);o[e]=i,this.prototype._props=o}}static internal(t){const e={};for(const[s,n]of u.entries(l.isFunction(t)?t(m):t)){const[t,r,i={}]=n;e[s]=[t,r,Object.assign(Object.assign({},i),{internal:!0})]}this.define(e)}static mixins(t){function e(t,e){const s={};for(const[n,r]of u.entries(e))s[t+n]=r;return s}const s={},n=[];for(const r of l.isArray(t)?t:[t])if(l.isArray(r)){const[t,i]=r;u.extend(s,e(t,i)),n.push([t,i])}else{const t=r;u.extend(s,t),n.push([\"\",t])}this.define(s),this.prototype._mixins=[...this.prototype._mixins,...n]}static override(t){for(const[e,s]of u.entries(t)){const t=this._fix_default(s,e),n=this.prototype._props[e];if(null==n)throw new Error(`attempted to override nonexistent '${this.prototype.type}.${e}'`);const r=Object.assign({},this.prototype._props);r[e]=Object.assign(Object.assign({},n),{default_value:t}),this.prototype._props=r}}toString(){return`${this.type}(${this.id})`}property(t){const e=this.properties[t];if(null!=e)return e;throw new Error(`unknown property ${this.type}.${t}`)}get attributes(){const t={};for(const e of this)t[e.attr]=e.get_value();return t}[v.clone](t){const e=new Map;for(const s of this)s.dirty&&e.set(s.attr,t.clone(s.get_value()));return new this.constructor(e)}[g.equals](t,e){for(const s of this){const n=t.property(s.attr);if(e.eq(s.get_value(),n.get_value()))return!1}return!0}[y.pretty](t){const e=t.token,s=[];for(const n of this)if(n.dirty){const r=n.get_value();s.push(`${n.attr}${e(\":\")} ${t.to_string(r)}`)}return`${this.constructor.__qualified__}${e(\"(\")}${e(\"{\")}${s.join(`${e(\",\")} `)}${e(\"}\")}${e(\")\")}`}[p.serialize](t){const e=this.ref();t.add_ref(this,e);const s=this.struct();for(const e of this)e.syncable&&(t.include_defaults||e.dirty)&&(s.attributes[e.attr]=t.to_serializable(e.get_value()));return t.add_def(this,s),e}finalize(){for(const t of this){if(!(t instanceof a.VectorSpec||t instanceof a.ScalarSpec))continue;const e=t.get_value();if(null!=e){const{transform:t,expr:s}=e;null!=t&&this.connect(t.change,(()=>this.transformchange.emit())),null!=s&&this.connect(s.change,(()=>this.exprchange.emit()))}}this.initialize()}initialize(){}connect_signals(){}disconnect_signals(){o.Signal.disconnectReceiver(this)}destroy(){this.disconnect_signals(),this.destroyed.emit()}clone(){return(new v.Cloner).clone(this)}_setv(t,e){const s=e.check_eq,n=[],r=this._changing;this._changing=!0;for(const[e,r]of t)!1!==s&&f.is_equal(e.get_value(),r)||(e.set_value(r),n.push(e));n.length>0&&(this._pending=!0);for(const t of n)t.change.emit();if(!r){if(!e.no_change)for(;this._pending;)this._pending=!1,this.change.emit();this._pending=!1,this._changing=!1}}setv(t,e={}){const s=u.entries(t);if(0==s.length)return;if(!0===e.silent){for(const[t,e]of s)this.properties[t].set_value(e);return}const n=new Map,r=new Map;for(const[t,e]of s){const s=this.properties[t];n.set(s,e),r.set(s,s.get_value())}this._setv(n,e);const{document:i}=this;if(null!=i){const t=[];for(const[e,s]of r)t.push([e,s,e.get_value()]);for(const[,e,s]of t)if(this._needs_invalidate(e,s)){i._invalidate_all_models();break}this._push_changes(t,e)}}getv(t){return this.property(t).get_value()}ref(){return{id:this.id}}struct(){const t={type:this.type,id:this.id,attributes:{}};return null!=this._subtype&&(t.subtype=this._subtype),t}set_subtype(t){this._subtype=t}*[Symbol.iterator](){yield*u.values(this.properties)}*syncable_properties(){for(const t of this)t.syncable&&(yield t)}serializable_attributes(){const t={};for(const e of this.syncable_properties())t[e.attr]=e.get_value();return t}static _json_record_references(t,e,s,n){const{recursive:r}=n;if(c.is_ref(e)){const n=t.get_model_by_id(e.id);null==n||s.has(n)||b._value_record_references(n,s,{recursive:r})}else if(l.isArray(e))for(const n of e)b._json_record_references(t,n,s,{recursive:r});else if(l.isPlainObject(e))for(const n of u.values(e))b._json_record_references(t,n,s,{recursive:r})}static _value_record_references(t,e,s){const{recursive:n}=s;if(t instanceof b){if(!e.has(t)&&(e.add(t),n))for(const s of t.syncable_properties()){const t=s.get_value();b._value_record_references(t,e,{recursive:n})}}else if(l.isArray(t))for(const s of t)b._value_record_references(s,e,{recursive:n});else if(l.isPlainObject(t))for(const s of u.values(t))b._value_record_references(s,e,{recursive:n})}references(){const t=new Set;return b._value_record_references(this,t,{recursive:!0}),t}_doc_attached(){}_doc_detached(){}attach_document(t){if(null!=this.document&&this.document!=t)throw new Error(\"models must be owned by only a single document\");this.document=t,this._doc_attached()}detach_document(){this._doc_detached(),this.document=null}_needs_invalidate(t,e){const s=new Set;b._value_record_references(e,s,{recursive:!1});const n=new Set;b._value_record_references(t,n,{recursive:!1});for(const t of s)if(!n.has(t))return!0;for(const t of n)if(!s.has(t))return!0;return!1}_push_changes(t,e={}){if(!this.is_syncable)return;const{document:s}=this;if(null==s)return;const{setter_id:n}=e,r=[];for(const[e,i,o]of t)e.syncable&&r.push(new d.ModelChangedEvent(s,this,e.attr,i,o,n));if(0!=r.length){let t;1==r.length?[t]=r:t=new d.DocumentEventBatch(s,r,n),s._trigger_on_change(t)}}on_change(t,e){for(const s of l.isArray(t)?t:[t])this.connect(s.change,e)}}s.HasProps=b,b.init_HasProps()},\n",
" function _(n,t,e,l,s){l();const i=n(16),o=n(9);class c{constructor(n,t){this.sender=n,this.name=t}connect(n,t=null){u.has(this.sender)||u.set(this.sender,[]);const e=u.get(this.sender);if(null!=g(e,this,n,t))return!1;const l=null!=t?t:n;a.has(l)||a.set(l,[]);const s=a.get(l),i={signal:this,slot:n,context:t};return e.push(i),s.push(i),!0}disconnect(n,t=null){const e=u.get(this.sender);if(null==e||0===e.length)return!1;const l=g(e,this,n,t);if(null==l)return!1;const s=null!=t?t:n,i=a.get(s);return l.signal=null,d(e),d(i),!0}emit(n){var t;const e=null!==(t=u.get(this.sender))&&void 0!==t?t:[];for(const{signal:t,slot:l,context:s}of e)t===this&&l.call(s,n,this.sender)}}e.Signal=c,c.__name__=\"Signal\";class r extends c{emit(){super.emit(void 0)}}e.Signal0=r,r.__name__=\"Signal0\",function(n){function t(n,t){const e=u.get(n);if(null==e||0===e.length)return;const l=a.get(t);if(null!=l&&0!==l.length){for(const t of l){if(null==t.signal)return;t.signal.sender===n&&(t.signal=null)}d(e),d(l)}}function e(n){var t;const e=u.get(n);if(null!=e&&0!==e.length){for(const n of e){if(null==n.signal)return;const e=null!==(t=n.context)&&void 0!==t?t:n.slot;n.signal=null,d(a.get(e))}d(e)}}function l(n,t,e){const l=a.get(n);if(null!=l&&0!==l.length){for(const n of l){if(null==n.signal)return;if(null!=t&&n.slot!=t)continue;const l=n.signal.sender;null!=e&&e.has(l)||(n.signal=null,d(u.get(l)))}d(l)}}function s(n){const t=u.get(n);if(null!=t&&0!==t.length){for(const n of t)n.signal=null;d(t)}const e=a.get(n);if(null!=e&&0!==e.length){for(const n of e)n.signal=null;d(e)}}n.disconnect_between=t,n.disconnect_sender=e,n.disconnect_receiver=l,n.disconnect_all=s,n.disconnectBetween=t,n.disconnectSender=e,n.disconnectReceiver=l,n.disconnectAll=s}(c||(e.Signal=c={})),e.Signalable=function(){return class{connect(n,t){return n.connect(t,this)}disconnect(n,t){return n.disconnect(t,this)}}};const u=new WeakMap,a=new WeakMap;function g(n,t,e,l){return o.find(n,(n=>n.signal===t&&n.slot===e&&n.context===l))}const f=new Set;function d(n){0===f.size&&(async()=>{await i.defer(),function(){for(const n of f)o.remove_by(n,(n=>null==n.signal));f.clear()}()})(),f.add(n)}},\n",
" function _(e,n,t,s,o){s();const a=new MessageChannel,l=new Map;a.port1.onmessage=e=>{const n=e.data,t=l.get(n);if(null!=t)try{t()}finally{l.delete(n)}};let r=1;t.defer=function(){return new Promise((e=>{const n=r++;l.set(n,e),a.port2.postMessage(n)}))}},\n",
" function _(n,t,i,e,c){e();const r=n(8),s=n(13);i.is_ref=function(n){if(r.isPlainObject(n)){const t=s.keys(n);return 1==t.length&&\"id\"==t[0]}return!1}},\n",
" function _(e,t,n,a,r){a(),n.YCoordinateSeqSeqSeqSpec=n.XCoordinateSeqSeqSeqSpec=n.YCoordinateSeqSpec=n.XCoordinateSeqSpec=n.YCoordinateSpec=n.XCoordinateSpec=n.CoordinateSeqSeqSeqSpec=n.CoordinateSeqSpec=n.CoordinateSpec=n.BaseCoordinateSpec=n.NumberUnitsSpec=n.UnitsSpec=n.DataSpec=n.VectorSpec=n.TextBaselineScalar=n.TextAlignScalar=n.FontStyleScalar=n.FontSizeScalar=n.FontScalar=n.LineDashScalar=n.LineCapScalar=n.LineJoinScalar=n.ArrayScalar=n.NullStringScalar=n.StringScalar=n.NumberScalar=n.ColorScalar=n.AnyScalar=n.ScalarSpec=n.VerticalAlign=n.UpdateMode=n.TooltipAttachment=n.TickLabelOrientation=n.TextureRepetition=n.TextBaseline=n.TextAlign=n.TapBehavior=n.StepMode=n.StartEnd=n.SpatialUnits=n.Sort=n.SizingMode=n.Side=n.RoundingFunction=n.ResetPolicy=n.RenderMode=n.RenderLevel=n.RadiusDimension=n.PointPolicy=n.Place=void 0,n.TextBaselineSpec=n.TextAlignSpec=n.FontStyleSpec=n.FontSizeSpec=n.FontSpec=n.LineDashSpec=n.LineCapSpec=n.LineJoinSpec=n.MarkerSpec=n.ArraySpec=n.NullStringSpec=n.StringSpec=n.AnySpec=n.NDArraySpec=n.ColorSpec=n.NumberSpec=n.BooleanSpec=n.ScreenDistanceSpec=n.NullDistanceSpec=n.DistanceSpec=n.AngleSpec=void 0;const i=e(1),s=e(15),l=e(19),o=i.__importStar(e(20)),c=e(24),_=e(9),u=e(12),d=e(10),S=e(22),p=e(27),m=e(8),h=e(28),v=e(29),y=e(33);function x(e){try{return JSON.stringify(e)}catch(t){return e.toString()}}function g(e){return m.isPlainObject(e)&&(void 0===e.value?0:1)+(void 0===e.field?0:1)+(void 0===e.expr?0:1)==1}r(\"Uniform\",y.Uniform),r(\"UniformScalar\",y.UniformScalar),r(\"UniformVector\",y.UniformVector),n.isSpec=g;class f{constructor(e,t,n,a,r,i={}){var l;let o;if(this.obj=e,this.attr=t,this.kind=n,this.default_value=a,this._dirty=!1,this.change=new s.Signal0(this.obj,\"change\"),this.internal=null!==(l=i.internal)&&void 0!==l&&l,this.on_update=i.on_update,void 0!==r)o=r,this._dirty=!0;else{const t=this._default_override();if(void 0!==t)o=t;else{if(void 0===a)return void(this.spec={value:null});o=a(e)}}this._update(o)}get is_value(){return void 0!==this.spec.value}get syncable(){return!this.internal}get_value(){return this.spec.value}set_value(e){this._update(e),this._dirty=!0}_default_override(){}get dirty(){return this._dirty}_update(e){var t;this.validate(e),this.spec={value:e},null===(t=this.on_update)||void 0===t||t.call(this,e,this.obj)}toString(){return`Prop(${this.obj}.${this.attr}, spec: ${x(this.spec)})`}normalize(e){return e}validate(e){if(!this.valid(e))throw new Error(`${this.obj}.${this.attr} given invalid value: ${x(e)}`)}valid(e){return this.kind.valid(e)}_value(e=!0){if(!this.is_value)throw new Error(\"attempted to retrieve property value for property without value specification\");let t=this.normalize([this.spec.value])[0];return null!=this.spec.transform&&e&&(t=this.spec.transform.compute(t)),t}}n.Property=f,f.__name__=\"Property\";class A{constructor(e){this.attr=e}}n.PropertyAlias=A,A.__name__=\"PropertyAlias\",n.Alias=function(e){return new A(e)};class C extends f{}n.PrimitiveProperty=C,C.__name__=\"PrimitiveProperty\";class L extends f{}n.Any=L,L.__name__=\"Any\";class T extends f{valid(e){return m.isArray(e)||m.isTypedArray(e)}}n.Array=T,T.__name__=\"Array\";class P extends f{valid(e){return m.isBoolean(e)}}n.Boolean=P,P.__name__=\"Boolean\";class b extends f{valid(e){return S.is_Color(e)}}n.Color=b,b.__name__=\"Color\";class w extends f{}n.Instance=w,w.__name__=\"Instance\";class q extends f{valid(e){return m.isNumber(e)}}n.Number=q,q.__name__=\"Number\";class N extends q{valid(e){return m.isNumber(e)&&(0|e)==e}}n.Int=N,N.__name__=\"Int\";class B extends q{}n.Angle=B,B.__name__=\"Angle\";class D extends q{valid(e){return m.isNumber(e)&&0<=e&&e<=1}}n.Percent=D,D.__name__=\"Percent\";class F extends f{valid(e){return m.isString(e)}}n.String=F,F.__name__=\"String\";class z extends f{valid(e){return null===e||m.isString(e)}}n.NullString=z,z.__name__=\"NullString\";class U extends F{}n.FontSize=U,U.__name__=\"FontSize\";class M extends F{_default_override(){return h.settings.dev?\"Bokeh\":void 0}}n.Font=M,M.__name__=\"Font\";class R extends f{valid(e){return m.isString(e)&&_.includes(this.enum_values,e)}}function k(e){return class extends R{get enum_values(){return[...e]}}}n.EnumProperty=R,R.__name__=\"EnumProperty\",n.Enum=k;class O extends R{get enum_values(){return[...o.Direction]}normalize(e){const t=new Uint8Array(e.length);for(let n=0;n<e.length;n++)switch(e[n]){case\"clock\":t[n]=0;break;case\"anticlock\":t[n]=1}return t}}n.Direction=O,O.__name__=\"Direction\",n.Anchor=k(o.Anchor),n.AngleUnits=k(o.AngleUnits),n.BoxOrigin=k(o.BoxOrigin),n.ButtonType=k(o.ButtonType),n.CalendarPosition=k(o.CalendarPosition),n.Dimension=k(o.Dimension),n.Dimensions=k(o.Dimensions),n.Distribution=k(o.Distribution),n.FontStyle=k(o.FontStyle),n.HatchPatternType=k(o.HatchPatternType),n.HTTPMethod=k(o.HTTPMethod),n.HexTileOrientation=k(o.HexTileOrientation),n.HoverMode=k(o.HoverMode),n.LatLon=k(o.LatLon),n.LegendClickPolicy=k(o.LegendClickPolicy),n.LegendLocation=k(o.LegendLocation),n.LineCap=k(o.LineCap),n.LineJoin=k(o.LineJoin),n.LinePolicy=k(o.LinePolicy),n.Location=k(o.Location),n.Logo=k(o.Logo),n.MarkerType=k(o.MarkerType),n.MutedPolicy=k(o.MutedPolicy),n.Orientation=k(o.Orientation),n.OutputBackend=k(o.OutputBackend),n.PaddingUnits=k(o.PaddingUnits),n.Place=k(o.Place),n.PointPolicy=k(o.PointPolicy),n.RadiusDimension=k(o.RadiusDimension),n.RenderLevel=k(o.RenderLevel),n.RenderMode=k(o.RenderMode),n.ResetPolicy=k(o.ResetPolicy),n.RoundingFunction=k(o.RoundingFunction),n.Side=k(o.Side),n.SizingMode=k(o.SizingMode),n.Sort=k(o.Sort),n.SpatialUnits=k(o.SpatialUnits),n.StartEnd=k(o.StartEnd),n.StepMode=k(o.StepMode),n.TapBehavior=k(o.TapBehavior),n.TextAlign=k(o.TextAlign),n.TextBaseline=k(o.TextBaseline),n.TextureRepetition=k(o.TextureRepetition),n.TickLabelOrientation=k(o.TickLabelOrientation),n.TooltipAttachment=k(o.TooltipAttachment),n.UpdateMode=k(o.UpdateMode),n.VerticalAlign=k(o.VerticalAlign);class E extends f{get_value(){const{value:e,expr:t,transform:n}=this.spec;return null!=t||null!=n?this.spec:e}_update(e){g(e)?this.spec=e:this.spec={value:e},null!=this.spec.value&&this.validate(this.spec.value)}materialize(e){return e}scalar(e,t){return new y.UniformScalar(e,t)}uniform(e){var t;const{expr:n,value:a,transform:r}=this.spec,i=null!==(t=e.get_length())&&void 0!==t?t:1;if(null!=n){let t=n.compute(e);return null!=r&&(t=r.compute(t)),t=this.materialize(t),this.scalar(t,i)}{let e=a;return null!=r&&(e=r.compute(e)),e=this.materialize(e),this.scalar(e,i)}}}n.ScalarSpec=E,E.__name__=\"ScalarSpec\";class V extends E{}n.AnyScalar=V,V.__name__=\"AnyScalar\";class $ extends E{}n.ColorScalar=$,$.__name__=\"ColorScalar\";class J extends E{}n.NumberScalar=J,J.__name__=\"NumberScalar\";class X extends E{}n.StringScalar=X,X.__name__=\"StringScalar\";class Y extends E{}n.NullStringScalar=Y,Y.__name__=\"NullStringScalar\";class H extends E{}n.ArrayScalar=H,H.__name__=\"ArrayScalar\";class j extends E{}n.LineJoinScalar=j,j.__name__=\"LineJoinScalar\";class G extends E{}n.LineCapScalar=G,G.__name__=\"LineCapScalar\";class I extends E{}n.LineDashScalar=I,I.__name__=\"LineDashScalar\";class K extends E{_default_override(){return h.settings.dev?\"Bokeh\":void 0}}n.FontScalar=K,K.__name__=\"FontScalar\";class Q extends E{}n.FontSizeScalar=Q,Q.__name__=\"FontSizeScalar\";class W extends E{}n.FontStyleScalar=W,W.__name__=\"FontStyleScalar\";class Z extends E{}n.TextAlignScalar=Z,Z.__name__=\"TextAlignScalar\";class ee extends E{}n.TextBaselineScalar=ee,ee.__name__=\"TextBaselineScalar\";class te extends f{get_value(){return null===this.spec.value?null:this.spec}_update(e){g(e)?this.spec=e:this.spec={value:e},null!=this.spec.value&&this.validate(this.spec.value)}materialize(e){return e}v_materialize(e){return e}scalar(e,t){return new y.UniformScalar(e,t)}vector(e){return new y.UniformVector(e)}uniform(e){var t;const{field:n,expr:a,value:r,transform:i}=this.spec,s=null!==(t=e.get_length())&&void 0!==t?t:1;if(null!=n){let t=e.get_column(n);return null!=t?(null!=i&&(t=i.v_compute(t)),t=this.v_materialize(t),this.vector(t)):(l.logger.warn(`attempted to retrieve property array for nonexistent field '${n}'`),this.scalar(null,s))}if(null!=a){let t=a.v_compute(e);return null!=i&&(t=i.v_compute(t)),t=this.v_materialize(t),this.vector(t)}{let e=r;return null!=i&&(e=i.compute(e)),e=this.materialize(e),this.scalar(e,s)}}array(e){var t;let n;const a=null!==(t=e.get_length())&&void 0!==t?t:1;if(null!=this.spec.field){const t=e.get_column(this.spec.field);if(null!=t)n=this.normalize(t);else{l.logger.warn(`attempted to retrieve property array for nonexistent field '${this.spec.field}'`);const e=new Float64Array(a);e.fill(NaN),n=e}}else if(null!=this.spec.expr)n=this.normalize(this.spec.expr.v_compute(e));else{const e=this._value(!1);if(m.isNumber(e)){const t=new Float64Array(a);t.fill(e),n=t}else n=_.repeat(e,a)}return null!=this.spec.transform&&(n=this.spec.transform.v_compute(n)),n}}n.VectorSpec=te,te.__name__=\"VectorSpec\";class ne extends te{}n.DataSpec=ne,ne.__name__=\"DataSpec\";class ae extends te{_update(e){super._update(e);const{units:t}=this.spec;if(null!=t&&!_.includes(this.valid_units,t))throw new Error(`units must be one of ${this.valid_units.join(\", \")}; got: ${t}`)}get units(){var e;return null!==(e=this.spec.units)&&void 0!==e?e:this.default_units}set units(e){e!=this.default_units?this.spec.units=e:delete this.spec.units}}n.UnitsSpec=ae,ae.__name__=\"UnitsSpec\";class re extends ae{array(e){return new Float64Array(super.array(e))}}n.NumberUnitsSpec=re,re.__name__=\"NumberUnitsSpec\";class ie extends ne{}n.BaseCoordinateSpec=ie,ie.__name__=\"BaseCoordinateSpec\";class se extends ie{}n.CoordinateSpec=se,se.__name__=\"CoordinateSpec\";class le extends ie{}n.CoordinateSeqSpec=le,le.__name__=\"CoordinateSeqSpec\";class oe extends ie{}n.CoordinateSeqSeqSeqSpec=oe,oe.__name__=\"CoordinateSeqSeqSeqSpec\";class ce extends se{constructor(){super(...arguments),this.dimension=\"x\"}}n.XCoordinateSpec=ce,ce.__name__=\"XCoordinateSpec\";class _e extends se{constructor(){super(...arguments),this.dimension=\"y\"}}n.YCoordinateSpec=_e,_e.__name__=\"YCoordinateSpec\";class ue extends le{constructor(){super(...arguments),this.dimension=\"x\"}}n.XCoordinateSeqSpec=ue,ue.__name__=\"XCoordinateSeqSpec\";class de extends le{constructor(){super(...arguments),this.dimension=\"y\"}}n.YCoordinateSeqSpec=de,de.__name__=\"YCoordinateSeqSpec\";class Se extends oe{constructor(){super(...arguments),this.dimension=\"x\"}}n.XCoordinateSeqSeqSeqSpec=Se,Se.__name__=\"XCoordinateSeqSeqSeqSpec\";class pe extends oe{constructor(){super(...arguments),this.dimension=\"y\"}}n.YCoordinateSeqSeqSeqSpec=pe,pe.__name__=\"YCoordinateSeqSeqSeqSpec\";class me extends re{get default_units(){return\"rad\"}get valid_units(){return[...o.AngleUnits]}materialize(e){return e*-d.to_radians_coeff(this.units)}v_materialize(e){const t=-d.to_radians_coeff(this.units),n=new Float32Array(e.length);return u.mul(e,t,n),n}array(e){throw new Error(\"not supported\")}}n.AngleSpec=me,me.__name__=\"AngleSpec\";class he extends re{get default_units(){return\"data\"}get valid_units(){return[...o.SpatialUnits]}}n.DistanceSpec=he,he.__name__=\"DistanceSpec\";class ve extends he{materialize(e){return null!=e?e:NaN}}n.NullDistanceSpec=ve,ve.__name__=\"NullDistanceSpec\";class ye extends he{get default_units(){return\"screen\"}}n.ScreenDistanceSpec=ye,ye.__name__=\"ScreenDistanceSpec\";class xe extends ne{v_materialize(e){return new Uint8Array(e)}array(e){return new Uint8Array(super.array(e))}}n.BooleanSpec=xe,xe.__name__=\"BooleanSpec\";class ge extends ne{v_materialize(e){return m.isTypedArray(e)?e:new Float64Array(e)}array(e){return new Float64Array(super.array(e))}}n.NumberSpec=ge,ge.__name__=\"NumberSpec\";class fe extends ne{materialize(e){return S.encode_rgba(S.color2rgba(e))}v_materialize(e){if(!v.is_NDArray(e)){const t=e.length,n=new c.RGBAArray(4*t);let a=0;for(const t of e){const[e,r,i,s]=S.color2rgba(t);n[a++]=e,n[a++]=r,n[a++]=i,n[a++]=s}return new c.ColorArray(n.buffer)}if(\"uint32\"==e.dtype&&1==e.dimension)return p.to_big_endian(e);if(\"uint8\"==e.dtype&&1==e.dimension){const[t]=e.shape,n=new c.RGBAArray(4*t);let a=0;for(const t of e)n[a++]=t,n[a++]=t,n[a++]=t,n[a++]=255;return new c.ColorArray(n.buffer)}if(\"uint8\"==e.dtype&&2==e.dimension){const[t,n]=e.shape;if(4==n)return new c.ColorArray(e.buffer);if(3==n){const a=new c.RGBAArray(4*t);for(let r=0,i=0;r<n*t;)a[i++]=e[r++],a[i++]=e[r++],a[i++]=e[r++],a[i++]=255;return new c.ColorArray(a.buffer)}}else if((\"float32\"==e.dtype||\"float64\"==e.dtype)&&2==e.dimension){const[t,n]=e.shape;if(3==n||4==n){const a=new c.RGBAArray(4*t);for(let r=0,i=0;r<n*t;)a[i++]=255*e[r++],a[i++]=255*e[r++],a[i++]=255*e[r++],a[i++]=255*(3==n?1:e[r++]);return new c.ColorArray(a.buffer)}}throw new Error(\"invalid color array\")}vector(e){return new y.ColorUniformVector(e)}}n.ColorSpec=fe,fe.__name__=\"ColorSpec\";class Ae extends ne{}n.NDArraySpec=Ae,Ae.__name__=\"NDArraySpec\";class Ce extends ne{}n.AnySpec=Ce,Ce.__name__=\"AnySpec\";class Le extends ne{}n.StringSpec=Le,Le.__name__=\"StringSpec\";class Te extends ne{}n.NullStringSpec=Te,Te.__name__=\"NullStringSpec\";class Pe extends ne{}n.ArraySpec=Pe,Pe.__name__=\"ArraySpec\";class be extends ne{}n.MarkerSpec=be,be.__name__=\"MarkerSpec\";class we extends ne{}n.LineJoinSpec=we,we.__name__=\"LineJoinSpec\";class qe extends ne{}n.LineCapSpec=qe,qe.__name__=\"LineCapSpec\";class Ne extends ne{}n.LineDashSpec=Ne,Ne.__name__=\"LineDashSpec\";class Be extends ne{_default_override(){return h.settings.dev?\"Bokeh\":void 0}}n.FontSpec=Be,Be.__name__=\"FontSpec\";class De extends ne{}n.FontSizeSpec=De,De.__name__=\"FontSizeSpec\";class Fe extends ne{}n.FontStyleSpec=Fe,Fe.__name__=\"FontStyleSpec\";class ze extends ne{}n.TextAlignSpec=ze,ze.__name__=\"TextAlignSpec\";class Ue extends ne{}n.TextBaselineSpec=Ue,Ue.__name__=\"TextBaselineSpec\"},\n",
" function _(e,l,o,n,t){n();const s=e(8),g=e(13),r={};class i{constructor(e,l){this.name=e,this.level=l}}o.LogLevel=i,i.__name__=\"LogLevel\";class v{constructor(e,l=v.INFO){this._name=e,this.set_level(l)}static get levels(){return Object.keys(v.log_levels)}static get(e,l=v.INFO){if(e.length>0){let o=r[e];return null==o&&(r[e]=o=new v(e,l)),o}throw new TypeError(\"Logger.get() expects a non-empty string name and an optional log-level\")}get level(){return this.get_level()}get_level(){return this._log_level}set_level(e){if(e instanceof i)this._log_level=e;else{if(!s.isString(e)||null==v.log_levels[e])throw new Error(\"Logger.set_level() expects a log-level object or a string name of a log-level\");this._log_level=v.log_levels[e]}const l=`[${this._name}]`;for(const[e,o]of g.entries(v.log_levels))o.level<this._log_level.level||this._log_level.level===v.OFF.level?this[e]=function(){}:this[e]=_(e,l)}trace(...e){}debug(...e){}info(...e){}warn(...e){}error(...e){}}function _(e,l){return null!=console[e]?console[e].bind(console,l):null!=console.log?console.log.bind(console,l):function(){}}function c(e){const l=o.logger.level;return s.isString(e)&&null==v.log_levels[e]?(console.log(`[bokeh] unrecognized logging level '${e}' passed to Bokeh.set_log_level(), ignoring`),console.log(`[bokeh] valid log levels are: ${v.levels.join(\", \")}`)):(console.log(`[bokeh] setting log level to: '${s.isString(e)?e:e.level}'`),o.logger.set_level(e)),l}o.Logger=v,v.__name__=\"Logger\",v.TRACE=new i(\"trace\",0),v.DEBUG=new i(\"debug\",1),v.INFO=new i(\"info\",2),v.WARN=new i(\"warn\",6),v.ERROR=new i(\"error\",7),v.FATAL=new i(\"fatal\",8),v.OFF=new i(\"off\",9),v.log_levels={trace:v.TRACE,debug:v.DEBUG,info:v.INFO,warn:v.WARN,error:v.ERROR,fatal:v.FATAL,off:v.OFF},o.logger=v.get(\"bokeh\"),o.set_log_level=c,o.with_log_level=function(e,l){const o=c(e);try{l()}finally{c(o)}}},\n",
" function _(e,n,t,o,i){o(),t.VerticalAlign=void 0;const a=e(21);t.Align=a.Enum(\"start\",\"center\",\"end\"),t.Anchor=a.Enum(\"top_left\",\"top_center\",\"top_right\",\"center_left\",\"center_center\",\"center_right\",\"bottom_left\",\"bottom_center\",\"bottom_right\",\"top\",\"left\",\"center\",\"right\",\"bottom\"),t.AngleUnits=a.Enum(\"deg\",\"rad\",\"grad\",\"turn\"),t.BoxOrigin=a.Enum(\"corner\",\"center\"),t.ButtonType=a.Enum(\"default\",\"primary\",\"success\",\"warning\",\"danger\",\"light\"),t.CalendarPosition=a.Enum(\"auto\",\"above\",\"below\"),t.Dimension=a.Enum(\"width\",\"height\"),t.Dimensions=a.Enum(\"width\",\"height\",\"both\"),t.Direction=a.Enum(\"clock\",\"anticlock\"),t.Distribution=a.Enum(\"uniform\",\"normal\"),t.FontStyle=a.Enum(\"normal\",\"italic\",\"bold\",\"bold italic\"),t.HatchPatternType=a.Enum(\"blank\",\"dot\",\"ring\",\"horizontal_line\",\"vertical_line\",\"cross\",\"horizontal_dash\",\"vertical_dash\",\"spiral\",\"right_diagonal_line\",\"left_diagonal_line\",\"diagonal_cross\",\"right_diagonal_dash\",\"left_diagonal_dash\",\"horizontal_wave\",\"vertical_wave\",\"criss_cross\",\" \",\".\",\"o\",\"-\",\"|\",\"+\",'\"',\":\",\"@\",\"/\",\"\\\\\",\"x\",\",\",\"`\",\"v\",\">\",\"*\"),t.HTTPMethod=a.Enum(\"POST\",\"GET\"),t.HexTileOrientation=a.Enum(\"pointytop\",\"flattop\"),t.HoverMode=a.Enum(\"mouse\",\"hline\",\"vline\"),t.LatLon=a.Enum(\"lat\",\"lon\"),t.LegendClickPolicy=a.Enum(\"none\",\"hide\",\"mute\"),t.LegendLocation=t.Anchor,t.LineCap=a.Enum(\"butt\",\"round\",\"square\"),t.LineJoin=a.Enum(\"miter\",\"round\",\"bevel\"),t.LineDash=a.Enum(\"solid\",\"dashed\",\"dotted\",\"dotdash\",\"dashdot\"),t.LinePolicy=a.Enum(\"prev\",\"next\",\"nearest\",\"interp\",\"none\"),t.Location=a.Enum(\"above\",\"below\",\"left\",\"right\"),t.Logo=a.Enum(\"normal\",\"grey\"),t.MarkerType=a.Enum(\"asterisk\",\"circle\",\"circle_cross\",\"circle_dot\",\"circle_x\",\"circle_y\",\"cross\",\"dash\",\"diamond\",\"diamond_cross\",\"diamond_dot\",\"dot\",\"hex\",\"hex_dot\",\"inverted_triangle\",\"plus\",\"square\",\"square_cross\",\"square_dot\",\"square_pin\",\"square_x\",\"star\",\"star_dot\",\"triangle\",\"triangle_dot\",\"triangle_pin\",\"x\",\"y\"),t.MutedPolicy=a.Enum(\"show\",\"ignore\"),t.Orientation=a.Enum(\"vertical\",\"horizontal\"),t.OutputBackend=a.Enum(\"canvas\",\"svg\",\"webgl\"),t.PaddingUnits=a.Enum(\"percent\",\"absolute\"),t.Place=a.Enum(\"above\",\"below\",\"left\",\"right\",\"center\"),t.PointPolicy=a.Enum(\"snap_to_data\",\"follow_mouse\",\"none\"),t.RadiusDimension=a.Enum(\"x\",\"y\",\"max\",\"min\"),t.RenderLevel=a.Enum(\"image\",\"underlay\",\"glyph\",\"guide\",\"annotation\",\"overlay\"),t.RenderMode=a.Enum(\"canvas\",\"css\"),t.ResetPolicy=a.Enum(\"standard\",\"event_only\"),t.RoundingFunction=a.Enum(\"round\",\"nearest\",\"floor\",\"rounddown\",\"ceil\",\"roundup\"),t.SelectionMode=a.Enum(\"replace\",\"append\",\"intersect\",\"subtract\"),t.Side=a.Enum(\"above\",\"below\",\"left\",\"right\"),t.SizingMode=a.Enum(\"stretch_width\",\"stretch_height\",\"stretch_both\",\"scale_width\",\"scale_height\",\"scale_both\",\"fixed\"),t.Sort=a.Enum(\"ascending\",\"descending\"),t.SpatialUnits=a.Enum(\"screen\",\"data\"),t.StartEnd=a.Enum(\"start\",\"end\"),t.StepMode=a.Enum(\"after\",\"before\",\"center\"),t.TapBehavior=a.Enum(\"select\",\"inspect\"),t.TextAlign=a.Enum(\"left\",\"right\",\"center\"),t.TextBaseline=a.Enum(\"top\",\"middle\",\"bottom\",\"alphabetic\",\"hanging\",\"ideographic\"),t.TextureRepetition=a.Enum(\"repeat\",\"repeat_x\",\"repeat_y\",\"no_repeat\"),t.TickLabelOrientation=a.Enum(\"vertical\",\"horizontal\",\"parallel\",\"normal\"),t.TooltipAttachment=a.Enum(\"horizontal\",\"vertical\",\"left\",\"right\",\"above\",\"below\"),t.UpdateMode=a.Enum(\"replace\",\"append\"),t.VerticalAlign=a.Enum(\"top\",\"middle\",\"bottom\")},\n",
" function _(e,n,t,s,r){s();const i=e(1).__importStar(e(8)),a=e(22),l=e(13),_=window.Map,{hasOwnProperty:u}=Object.prototype;class d{}t.Kind=d,d.__name__=\"Kind\",function(e){class n extends d{valid(e){return!0}}n.__name__=\"Any\",e.Any=n;class t extends d{valid(e){return!0}}t.__name__=\"Unknown\",e.Unknown=t;class s extends d{valid(e){return i.isBoolean(e)}}s.__name__=\"Boolean\",e.Boolean=s;class r extends d{constructor(e){super(),this.obj_type=e}valid(e){return!0}}r.__name__=\"Ref\",e.Ref=r;class c extends d{valid(e){return!0}}c.__name__=\"AnyRef\",e.AnyRef=c;class o extends d{valid(e){return i.isNumber(e)}}o.__name__=\"Number\",e.Number=o;class p extends o{valid(e){return super.valid(e)&&i.isInteger(e)}}p.__name__=\"Int\",e.Int=p;class y extends o{valid(e){return super.valid(e)&&0<=e&&e<=1}}y.__name__=\"Percent\",e.Percent=y;class m extends d{constructor(e){super(),this.types=e,this.types=e}valid(e){return this.types.some((n=>n.valid(e)))}}m.__name__=\"Or\",e.Or=m;class v extends d{constructor(e){super(),this.types=e,this.types=e}valid(e){if(!i.isArray(e))return!1;for(let n=0;n<this.types.length;n++){const t=this.types[n],s=e[n];if(!t.valid(s))return!1}return!0}}v.__name__=\"Tuple\",e.Tuple=v;class w extends d{constructor(e){super(),this.struct_type=e}valid(e){if(!i.isPlainObject(e))return!1;const{struct_type:n}=this;if(l.size(n)!=l.size(e))return!1;for(const t in n)if(u.call(n,t)){if(!u.call(e,t))return!1;const s=n[t],r=e[t];if(!s.valid(r))return!1}return!0}}w.__name__=\"Struct\",e.Struct=w;class h extends d{valid(e){return i.isArray(e)||i.isTypedArray(e)}}h.__name__=\"Arrayable\",e.Arrayable=h;class f extends d{constructor(e){super(),this.item_type=e}valid(e){return i.isArray(e)&&e.every((e=>this.item_type.valid(e)))}}f.__name__=\"Array\",e.Array=f;class K extends d{valid(e){return null===e}}K.__name__=\"Null\",e.Null=K;class b extends d{constructor(e){super(),this.base_type=e}valid(e){return null===e||this.base_type.valid(e)}}b.__name__=\"Nullable\",e.Nullable=b;class A extends d{constructor(e){super(),this.base_type=e}valid(e){return void 0===e||this.base_type.valid(e)}}A.__name__=\"Opt\",e.Opt=A;class x extends d{valid(e){return i.isString(e)}}x.__name__=\"String\",e.String=x;class S extends d{constructor(e){super(),this.values=new Set(e)}valid(e){return this.values.has(e)}*[Symbol.iterator](){yield*this.values}}S.__name__=\"Enum\",e.Enum=S;class N extends d{constructor(e){super(),this.item_type=e}valid(e){if(!i.isPlainObject(e))return!1;for(const n in e)if(u.call(e,n)){const t=e[n];if(!this.item_type.valid(t))return!1}return!0}}N.__name__=\"Dict\",e.Dict=N;class O extends d{constructor(e,n){super(),this.key_type=e,this.item_type=n}valid(e){if(!(e instanceof _))return!1;for(const[n,t]of e.entries())if(!this.key_type.valid(n)||!this.item_type.valid(t))return!1;return!0}}O.__name__=\"Map\",e.Map=O;class g extends d{valid(e){return a.is_Color(e)}}g.__name__=\"Color\",e.Color=g;class P extends d{valid(e){return i.isFunction(e)}}P.__name__=\"Function\",e.Function=P}(t.Kinds||(t.Kinds={})),t.Any=new t.Kinds.Any,t.Unknown=new t.Kinds.Unknown,t.Boolean=new t.Kinds.Boolean,t.Number=new t.Kinds.Number,t.Int=new t.Kinds.Int,t.String=new t.Kinds.String,t.Null=new t.Kinds.Null;t.Nullable=e=>new t.Kinds.Nullable(e);t.Opt=e=>new t.Kinds.Opt(e);t.Or=(...e)=>new t.Kinds.Or(e);t.Tuple=(...e)=>new t.Kinds.Tuple(e);t.Struct=e=>new t.Kinds.Struct(e),t.Arrayable=new t.Kinds.Arrayable;t.Array=e=>new t.Kinds.Array(e);t.Dict=e=>new t.Kinds.Dict(e);t.Map=(e,n)=>new t.Kinds.Map(e,n);t.Enum=(...e)=>new t.Kinds.Enum(e);t.Ref=e=>new t.Kinds.Ref(e);t.AnyRef=()=>new t.Kinds.AnyRef;t.Function=()=>new t.Kinds.Function,t.Percent=new t.Kinds.Percent,t.Alpha=t.Percent,t.Color=new t.Kinds.Color,t.Auto=t.Enum(\"auto\"),t.FontSize=t.String,t.Font=t.String,t.Angle=t.Number},\n",
" function _(n,t,r,e,s){e();const u=n(23),c=n(10),l=n(8),{round:i}=Math;function o(n){return c.clamp(i(n),0,255)}function a(){return[0,0,0,0]}function f(n){return[n>>24&255,n>>16&255,n>>8&255,255&n]}function d(n,t){var r;let e,s,u,c;return null==n?[e,s,u,c]=[0,0,0,0]:l.isInteger(n)?[e,s,u,c]=f(n):l.isString(n)?[e,s,u,c]=null!==(r=_(n))&&void 0!==r?r:[0,0,0,0]:([e,s,u,c=1]=n,c=o(255*c)),255==c&&null!=t&&(c=o(255*t)),[e,s,u,c]}r.transparent=a,r.encode_rgba=function([n,t,r,e]){return n<<24|t<<16|r<<8|e},r.decode_rgba=f,r.compose_alpha=function(n,t){return 255==(255&n)?4294967040&n|o(255*t):n},r.color2rgba=d;const h={0:\"0\",1:\"1\",2:\"2\",3:\"3\",4:\"4\",5:\"5\",6:\"6\",7:\"7\",8:\"8\",9:\"9\",10:\"a\",11:\"b\",12:\"c\",13:\"d\",14:\"e\",15:\"f\"};function g(n){return h[n>>4]+h[15&n]}r.color2css=function(n,t){const[r,e,s,u]=d(n,t);return`rgba(${r}, ${e}, ${s}, ${u/255})`},r.color2hex=function(n,t){const[r,e,s,u]=d(n,t),c=`#${g(r)}${g(e)}${g(s)}`;return 255==u?c:`${c}${g(u)}`},r.color2hexrgb=function(n){const[t,r,e]=d(n);return`#${g(t)}${g(r)}${g(e)}`};const b=/^rgba?\\(\\s*([^\\s,]+?)\\s+([^\\s,]+?)\\s+([^\\s,]+?)(?:\\s*\\/\\s*([^\\s,]+?))?\\s*\\)$/,m=/^rgba?\\(\\s*([^\\s,]+?)\\s*,\\s*([^\\s,]+?)\\s*,\\s*([^\\s,]+?)(?:\\s*,\\s*([^\\s,]+?))?\\s*\\)$/,$=(()=>{const n=document.createElement(\"canvas\");n.width=1,n.height=1;const t=n.getContext(\"2d\"),r=t.createLinearGradient(0,0,1,1);return n=>{t.fillStyle=r,t.fillStyle=n;const e=t.fillStyle;return e!=r?e:null}})();function _(n){var t;if(!(n=n.trim().toLowerCase()))return null;if(\"transparent\"==n)return[0,0,0,0];if(u.is_named_color(n))return f(u.named_colors[n]);if(\"#\"==n[0]){const t=Number(\"0x\"+n.substr(1));if(isNaN(t))return null;switch(n.length-1){case 3:{const n=t>>8&15,r=t>>4&15,e=t>>0&15;return[n<<4|n,r<<4|r,e<<4|e,255]}case 4:{const n=t>>12&15,r=t>>8&15,e=t>>4&15,s=t>>0&15;return[n<<4|n,r<<4|r,e<<4|e,s<<4|s]}case 6:return[t>>16&255,t>>8&255,t>>0&255,255];case 8:return[t>>24&255,t>>16&255,t>>8&255,t>>0&255]}}else if(n.startsWith(\"rgb\")){const r=null!==(t=n.match(b))&&void 0!==t?t:n.match(m);if(null!=r){let[,n,t,e,s=\"1\"]=r;const u=n.endsWith(\"%\"),c=t.endsWith(\"%\"),l=e.endsWith(\"%\"),i=s.endsWith(\"%\");if(!(u&&c&&l)&&(u||c||l))return null;u&&(n=n.slice(0,-1)),c&&(t=t.slice(0,-1)),l&&(e=e.slice(0,-1)),i&&(s=s.slice(0,-1));let a=Number(n),f=Number(t),d=Number(e),h=Number(s);return isNaN(a+f+d+h)?null:(u&&(a=a/100*255),c&&(f=f/100*255),l&&(d=d/100*255),h=255*(i?h/100:h),a=o(a),f=o(f),d=o(d),h=o(h),[a,f,d,h])}}else{const t=$(n);if(null!=t)return _(t)}return null}r.css4_parse=_,r.is_Color=function(n){return!!l.isInteger(n)||(!(!l.isString(n)||null==_(n))||!(!l.isArray(n)||3!=n.length&&4!=n.length))},r.is_dark=function([n,t,r]){return 1-(.299*n+.587*t+.114*r)/255>=.6}},\n",
" function _(e,r,l,a,i){a();l.named_colors={aliceblue:4042850303,antiquewhite:4209760255,aqua:16777215,aquamarine:2147472639,azure:4043309055,beige:4126530815,bisque:4293182719,black:255,blanchedalmond:4293643775,blue:65535,blueviolet:2318131967,brown:2771004159,burlywood:3736635391,cadetblue:1604231423,chartreuse:2147418367,chocolate:3530104575,coral:4286533887,cornflowerblue:1687547391,cornsilk:4294499583,crimson:3692313855,cyan:16777215,darkblue:35839,darkcyan:9145343,darkgoldenrod:3095792639,darkgray:2846468607,darkgreen:6553855,darkgrey:2846468607,darkkhaki:3182914559,darkmagenta:2332068863,darkolivegreen:1433087999,darkorange:4287365375,darkorchid:2570243327,darkred:2332033279,darksalmon:3918953215,darkseagreen:2411499519,darkslateblue:1211993087,darkslategray:793726975,darkslategrey:793726975,darkturquoise:13554175,darkviolet:2483082239,deeppink:4279538687,deepskyblue:12582911,dimgray:1768516095,dimgrey:1768516095,dodgerblue:512819199,firebrick:2988581631,floralwhite:4294635775,forestgreen:579543807,fuchsia:4278255615,gainsboro:3705462015,ghostwhite:4177068031,gold:4292280575,goldenrod:3668254975,gray:2155905279,green:8388863,greenyellow:2919182335,grey:2155905279,honeydew:4043305215,hotpink:4285117695,indianred:3445382399,indigo:1258324735,ivory:4294963455,khaki:4041641215,lavender:3873897215,lavenderblush:4293981695,lawngreen:2096890111,lemonchiffon:4294626815,lightblue:2916673279,lightcoral:4034953471,lightcyan:3774873599,lightgoldenrodyellow:4210742015,lightgray:3553874943,lightgreen:2431553791,lightgrey:3553874943,lightpink:4290167295,lightsalmon:4288707327,lightseagreen:548580095,lightskyblue:2278488831,lightslategray:2005441023,lightslategrey:2005441023,lightsteelblue:2965692159,lightyellow:4294959359,lime:16711935,limegreen:852308735,linen:4210091775,magenta:4278255615,maroon:2147483903,mediumaquamarine:1724754687,mediumblue:52735,mediumorchid:3126187007,mediumpurple:2473647103,mediumseagreen:1018393087,mediumslateblue:2070474495,mediumspringgreen:16423679,mediumturquoise:1221709055,mediumvioletred:3340076543,midnightblue:421097727,mintcream:4127193855,mistyrose:4293190143,moccasin:4293178879,navajowhite:4292783615,navy:33023,oldlace:4260751103,olive:2155872511,olivedrab:1804477439,orange:4289003775,orangered:4282712319,orchid:3664828159,palegoldenrod:4008225535,palegreen:2566625535,paleturquoise:2951671551,palevioletred:3681588223,papayawhip:4293907967,peachpuff:4292524543,peru:3448061951,pink:4290825215,plum:3718307327,powderblue:2967529215,purple:2147516671,rebeccapurple:1714657791,red:4278190335,rosybrown:3163525119,royalblue:1097458175,saddlebrown:2336560127,salmon:4202722047,sandybrown:4104413439,seagreen:780883967,seashell:4294307583,sienna:2689740287,silver:3233857791,skyblue:2278484991,slateblue:1784335871,slategray:1887473919,slategrey:1887473919,snow:4294638335,springgreen:16744447,steelblue:1182971135,tan:3535047935,teal:8421631,thistle:3636451583,tomato:4284696575,turquoise:1088475391,violet:4001558271,wheat:4125012991,white:4294967295,whitesmoke:4126537215,yellow:4294902015,yellowgreen:2597139199},l.is_named_color=function(e){return e in l.named_colors}},\n",
" function _(r,t,n,a,o){a(),n.GeneratorFunction=Object.getPrototypeOf((function*(){})).constructor,n.ColorArray=Uint32Array,n.RGBAArray=Uint8ClampedArray,n.infer_type=function(r,t){return r instanceof Float64Array||r instanceof Array||t instanceof Float64Array||t instanceof Array?Float64Array:Float32Array},n.ScreenArray=Float32Array,n.to_screen=function(r){return r instanceof Float32Array?r:new Float32Array(r)},o(\"Indices\",r(25).BitSet)},\n",
" function _(t,s,r,e,i){e();const n=t(26),o=t(11);class a{constructor(t,s=0){this.size=t,this[Symbol.toStringTag]=\"BitSet\",this._count=null,this._nwords=Math.ceil(t/32),0==s||1==s?(this._array=new Uint32Array(this._nwords),1==s&&this._array.fill(4294967295)):(o.assert(s.length==this._nwords,\"Initializer size mismatch\"),this._array=s)}clone(){return new a(this.size,new Uint32Array(this._array))}[n.equals](t,s){if(!s.eq(this.size,t.size))return!1;const{_nwords:r}=this,e=this.size%r,i=0==e?r:r-1;for(let s=0;s<i;s++)if(this._array[s]!=t._array[s])return!1;if(0==e)return!0;{const s=1<<e-1,r=s-1^s;return(this._array[i]&r)==(t._array[i]&r)}}static all_set(t){return new a(t,1)}static all_unset(t){return new a(t,0)}static from_indices(t,s){const r=new a(t);for(const t of s)r.set(t);return r}static from_booleans(t,s){const r=new a(t),e=Math.min(t,s.length);for(let t=0;t<e;t++)s[t]&&r.set(t);return r}_check_bounds(t){o.assert(0<=t&&t<this.size,`Out of bounds: 0 <= ${t} < ${this.size}`)}get(t){this._check_bounds(t);const s=t>>>5,r=31&t;return!!(this._array[s]>>r&1)}set(t,s=!0){this._check_bounds(t),this._count=null;const r=t>>>5,e=31&t;s?this._array[r]|=1<<e:this._array[r]&=~(1<<e)}unset(t){this.set(t,!1)}*[Symbol.iterator](){yield*this.ones()}get count(){let t=this._count;return null==t&&(this._count=t=this._get_count()),t}_get_count(){const{_array:t,_nwords:s,size:r}=this;let e=0;for(let i=0,n=0;n<s;n++){const s=t[n];if(0==s)i+=32;else for(let t=0;t<32&&i<r;t++,i++)s>>>t&1&&(e+=1)}return e}*ones(){const{_array:t,_nwords:s,size:r}=this;for(let e=0,i=0;i<s;i++){const s=t[i];if(0!=s)for(let t=0;t<32&&e<r;t++,e++)s>>>t&1&&(yield e);else e+=32}}*zeros(){const{_array:t,_nwords:s,size:r}=this;for(let e=0,i=0;i<s;i++){const s=t[i];if(4294967295!=s)for(let t=0;t<32&&e<r;t++,e++)s>>>t&1||(yield e);else e+=32}}_check_size(t){o.assert(this.size==t.size,\"Size mismatch\")}add(t){this._check_size(t);for(let s=0;s<this._nwords;s++)this._array[s]|=t._array[s]}intersect(t){this._check_size(t);for(let s=0;s<this._nwords;s++)this._array[s]&=t._array[s]}subtract(t){this._check_size(t);for(let s=0;s<this._nwords;s++){const r=this._array[s],e=t._array[s];this._array[s]=(r^e)&r}}union(t){this._check_size(t);const s=this.clone();for(let r=0;r<this._nwords;r++)s._array[r]|=t._array[r];return s}intersection(t){this._check_size(t);const s=this.clone();for(let r=0;r<this._nwords;r++)s._array[r]&=t._array[r];return s}difference(t){this._check_size(t);const s=this.clone();for(let r=0;r<this._nwords;r++){const e=this._array[r],i=t._array[r];s._array[r]=(e^i)&e}return s}select(t){o.assert(this.size<=t.length,\"Size mismatch\");const s=this.count,r=new t.constructor(s);let e=0;for(const s of this)r[e++]=t[s];return r}}r.BitSet=a,a.__name__=\"BitSet\"},\n",
" function _(t,e,r,n,s){n();const o=t(8),{hasOwnProperty:c}=Object.prototype;function a(t){return o.isObject(t)&&void 0!==t[r.equals]}r.equals=Symbol(\"equals\"),r.wildcard=Symbol(\"wildcard\");const i=Object.prototype.toString;class u{constructor(){this.a_stack=[],this.b_stack=[]}eq(t,e){if(Object.is(t,e))return!0;if(t===r.wildcard||e===r.wildcard)return!0;if(null==t||null==e)return t===e;const n=i.call(t);if(n!=i.call(e))return!1;switch(n){case\"[object Number]\":return this.numbers(t,e);case\"[object RegExp]\":case\"[object String]\":return`${t}`==`${e}`;case\"[object Date]\":case\"[object Boolean]\":return+t==+e}const{a_stack:s,b_stack:o}=this;let c=s.length;for(;c--;)if(s[c]===t)return o[c]===e;s.push(t),o.push(e);const u=(()=>{if(a(t)&&a(e))return t[r.equals](e,this);switch(n){case\"[object Array]\":case\"[object Uint8Array]\":case\"[object Int8Array]\":case\"[object Uint16Array]\":case\"[object Int16Array]\":case\"[object Uint32Array]\":case\"[object Int32Array]\":case\"[object Float32Array]\":case\"[object Float64Array]\":return this.arrays(t,e);case\"[object Map]\":return this.maps(t,e);case\"[object Set]\":return this.sets(t,e);case\"[object Object]\":if(t.constructor==e.constructor&&(null==t.constructor||t.constructor===Object))return this.objects(t,e);case\"[object Function]\":if(t.constructor==e.constructor&&t.constructor===Function)return this.eq(`${t}`,`${e}`)}if(t instanceof Node)return this.nodes(t,e);throw Error(`can't compare objects of type ${n}`)})();return s.pop(),o.pop(),u}numbers(t,e){return Object.is(t,e)}arrays(t,e){const{length:r}=t;if(r!=e.length)return!1;for(let n=0;n<r;n++)if(!this.eq(t[n],e[n]))return!1;return!0}iterables(t,e){const r=t[Symbol.iterator](),n=e[Symbol.iterator]();for(;;){const t=r.next(),e=n.next();if(t.done&&e.done)return!0;if(t.done||e.done)return!1;if(!this.eq(t.value,e.value))return!1}}maps(t,e){if(t.size!=e.size)return!1;for(const[r,n]of t)if(!e.has(r)||!this.eq(n,e.get(r)))return!1;return!0}sets(t,e){if(t.size!=e.size)return!1;for(const r of t)if(!e.has(r))return!1;return!0}objects(t,e){const r=Object.keys(t);if(r.length!=Object.keys(e).length)return!1;for(const n of r)if(!c.call(e,n)||!this.eq(t[n],e[n]))return!1;return!0}nodes(t,e){return t.nodeType==e.nodeType&&(t.textContent==e.textContent&&!!this.iterables(t.childNodes,e.childNodes))}}r.Comparator=u,u.__name__=\"Comparator\";const{abs:l}=Math;class b extends u{constructor(t=1e-4){super(),this.tolerance=t}numbers(t,e){return super.numbers(t,e)||l(t-e)<this.tolerance}}function f(t,e){return(new u).eq(t,e)}r.SimilarComparator=b,b.__name__=\"SimilarComparator\",r.is_equal=f,r.is_similar=function(t,e,r){return new b(r).eq(t,e)},r.isEqual=f},\n",
" function _(n,i,e,t,r){t(),e.is_windows=navigator.appVersion.includes(\"Windows\"),e.is_ie=(()=>{const n=navigator.userAgent;return n.includes(\"MSIE\")||n.includes(\"Trident\")||n.includes(\"Edge\")})(),e.is_mobile=\"undefined\"!=typeof window&&(\"ontouchstart\"in window||navigator.maxTouchPoints>0),e.is_little_endian=(()=>{const n=new ArrayBuffer(4),i=new Uint8Array(n);new Uint32Array(n)[1]=168496141;let e=!0;return 10==i[4]&&11==i[5]&&12==i[6]&&13==i[7]&&(e=!1),e})(),e.BYTE_ORDER=e.is_little_endian?\"little\":\"big\",e.to_big_endian=function(n){if(e.is_little_endian){const i=new Uint32Array(n.length),e=new DataView(i.buffer);let t=0;for(const i of n)e.setUint32(t,i),t+=4;return i}return n}},\n",
" function _(e,t,r,i,s){i();class _{constructor(){this._dev=!1,this._wireframe=!1}set dev(e){this._dev=e}get dev(){return this._dev}set wireframe(e){this._wireframe=e}get wireframe(){return this._wireframe}}r.Settings=_,_.__name__=\"Settings\",r.settings=new _},\n",
" function _(t,e,s,r,n){var a,i,h,u,l,c,o,y;r();const p=t(8),_=t(11),A=t(26),d=t(30),D=t(31),N=Symbol(\"__ndarray__\");class f extends Uint8Array{constructor(t,e){super(t),this[a]=!0,this.dtype=\"uint8\",this.shape=null!=e?e:z(t)?t.shape:[this.length],this.dimension=this.shape.length}[(a=N,A.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[d.serialize](t){return D.encode_NDArray(this)}}s.Uint8NDArray=f,f.__name__=\"Uint8NDArray\";class m extends Int8Array{constructor(t,e){super(t),this[i]=!0,this.dtype=\"int8\",this.shape=null!=e?e:z(t)?t.shape:[this.length],this.dimension=this.shape.length}[(i=N,A.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[d.serialize](t){return D.encode_NDArray(this)}}s.Int8NDArray=m,m.__name__=\"Int8NDArray\";class g extends Uint16Array{constructor(t,e){super(t),this[h]=!0,this.dtype=\"uint16\",this.shape=null!=e?e:z(t)?t.shape:[this.length],this.dimension=this.shape.length}[(h=N,A.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[d.serialize](t){return D.encode_NDArray(this)}}s.Uint16NDArray=g,g.__name__=\"Uint16NDArray\";class q extends Int16Array{constructor(t,e){super(t),this[u]=!0,this.dtype=\"int16\",this.shape=null!=e?e:z(t)?t.shape:[this.length],this.dimension=this.shape.length}[(u=N,A.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[d.serialize](t){return D.encode_NDArray(this)}}s.Int16NDArray=q,q.__name__=\"Int16NDArray\";class I extends Uint32Array{constructor(t,e){super(t),this[l]=!0,this.dtype=\"uint32\",this.shape=null!=e?e:z(t)?t.shape:[this.length],this.dimension=this.shape.length}[(l=N,A.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[d.serialize](t){return D.encode_NDArray(this)}}s.Uint32NDArray=I,I.__name__=\"Uint32NDArray\";class U extends Int32Array{constructor(t,e){super(t),this[c]=!0,this.dtype=\"int32\",this.shape=null!=e?e:z(t)?t.shape:[this.length],this.dimension=this.shape.length}[(c=N,A.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[d.serialize](t){return D.encode_NDArray(this)}}s.Int32NDArray=U,U.__name__=\"Int32NDArray\";class w extends Float32Array{constructor(t,e){super(t),this[o]=!0,this.dtype=\"float32\",this.shape=null!=e?e:z(t)?t.shape:[this.length],this.dimension=this.shape.length}[(o=N,A.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[d.serialize](t){return D.encode_NDArray(this)}}s.Float32NDArray=w,w.__name__=\"Float32NDArray\";class x extends Float64Array{constructor(t,e){super(t),this[y]=!0,this.dtype=\"float64\",this.shape=null!=e?e:z(t)?t.shape:[this.length],this.dimension=this.shape.length}[(y=N,A.equals)](t,e){return e.eq(this.shape,t.shape)&&e.arrays(this,t)}[d.serialize](t){return D.encode_NDArray(this)}}function z(t){return p.isObject(t)&&void 0!==t[N]}s.Float64NDArray=x,x.__name__=\"Float64NDArray\",s.is_NDArray=z,s.ndarray=function(t,e={}){let{dtype:s}=e;null==s&&(s=t instanceof ArrayBuffer||p.isArray(t)?\"float64\":(()=>{switch(!0){case t instanceof Uint8Array:return\"uint8\";case t instanceof Int8Array:return\"int8\";case t instanceof Uint16Array:return\"uint16\";case t instanceof Int16Array:return\"int16\";case t instanceof Uint32Array:return\"uint32\";case t instanceof Int32Array:return\"int32\";case t instanceof Float32Array:return\"float32\";case t instanceof Float64Array:return\"float64\";default:_.unreachable()}})());const{shape:r}=e;switch(s){case\"uint8\":return new f(t,r);case\"int8\":return new m(t,r);case\"uint16\":return new g(t,r);case\"int16\":return new q(t,r);case\"uint32\":return new I(t,r);case\"int32\":return new U(t,r);case\"float32\":return new w(t,r);case\"float64\":return new x(t,r)}}},\n",
" function _(e,r,t,i,s){i();const n=e(11),a=e(13),l=e(8);t.serialize=Symbol(\"serialize\");class o extends Error{}t.SerializationError=o,o.__name__=\"SerializationError\";class f{constructor(e){var r;this._references=new Map,this._definitions=new Map,this._refmap=new Map,this.include_defaults=null===(r=null==e?void 0:e.include_defaults)||void 0===r||r}get_ref(e){return this._references.get(e)}add_ref(e,r){n.assert(!this._references.has(e)),this._references.set(e,r)}add_def(e,r){const t=this.get_ref(e);n.assert(null!=t),this._definitions.set(e,r),this._refmap.set(t,r)}get objects(){return new Set(this._references.keys())}get references(){return new Set(this._references.values())}get definitions(){return new Set(this._definitions.values())}resolve_ref(e){return this._refmap.get(e)}remove_ref(e){return this._references.delete(e)}remove_def(e){return this._definitions.delete(e)}to_serializable(e){const r=this.get_ref(e);if(null!=r)return r;if(function(e){return l.isObject(e)&&void 0!==e[t.serialize]}(e))return e[t.serialize](this);if(l.isArray(e)||l.isTypedArray(e)){const r=e.length,t=new Array(r);for(let i=0;i<r;i++){const r=e[i];t[i]=this.to_serializable(r)}return t}if(l.isPlainObject(e)){const r={};for(const[t,i]of a.entries(e))r[t]=this.to_serializable(i);return r}if(null===e||l.isBoolean(e)||l.isNumber(e)||l.isString(e))return e;throw new o(`${Object.prototype.toString.call(e)} is not serializable`)}}t.Serializer=f,f.__name__=\"Serializer\"},\n",
" function _(r,e,n,t,_){t();const a=r(1),f=r(8),u=a.__importStar(r(29)),s=r(27),i=r(32);n.is_NDArray_ref=function(r){return f.isPlainObject(r)&&(\"__buffer__\"in r||\"__ndarray__\"in r)},n.decode_NDArray=function(r,e){const{shape:n,dtype:t,order:_}=r;let a;if(\"__buffer__\"in r){const n=e.get(r.__buffer__);if(null==n)throw new Error(`buffer for ${r.__buffer__} not found`);a=n}else a=i.base64_to_buffer(r.__ndarray__);const f=(()=>{switch(t){case\"uint8\":return new u.Uint8NDArray(a,n);case\"int8\":return new u.Int8NDArray(a,n);case\"uint16\":return new u.Uint16NDArray(a,n);case\"int16\":return new u.Int16NDArray(a,n);case\"uint32\":return new u.Uint32NDArray(a,n);case\"int32\":return new u.Int32NDArray(a,n);case\"float32\":return new u.Float32NDArray(a,n);case\"float64\":return new u.Float64NDArray(a,n)}})();return _!==s.BYTE_ORDER&&i.swap(f),f},n.encode_NDArray=function(r,e){const n={order:s.BYTE_ORDER,dtype:r.dtype,shape:r.shape};if(null!=e){const t=`${e.size}`;return e.set(t,r.buffer),Object.assign({__buffer__:t},n)}{const e=i.buffer_to_base64(r.buffer);return Object.assign({__ndarray__:e},n)}}},\n",
" function _(t,e,n,r,f){r(),n.buffer_to_base64=function(t){const e=new Uint8Array(t),n=Array.from(e).map((t=>String.fromCharCode(t)));return btoa(n.join(\"\"))},n.base64_to_buffer=function(t){const e=atob(t),n=e.length,r=new Uint8Array(n);for(let t=0,f=n;t<f;t++)r[t]=e.charCodeAt(t);return r.buffer},n.swap=function(t){switch(t.BYTES_PER_ELEMENT){case 2:!function(t){const e=new Uint8Array(t.buffer,t.byteOffset,2*t.length);for(let t=0,n=e.length;t<n;t+=2){const n=e[t];e[t]=e[t+1],e[t+1]=n}}(t);break;case 4:!function(t){const e=new Uint8Array(t.buffer,t.byteOffset,4*t.length);for(let t=0,n=e.length;t<n;t+=4){let n=e[t];e[t]=e[t+3],e[t+3]=n,n=e[t+1],e[t+1]=e[t+2],e[t+2]=n}}(t);break;case 8:!function(t){const e=new Uint8Array(t.buffer,t.byteOffset,8*t.length);for(let t=0,n=e.length;t<n;t+=8){let n=e[t];e[t]=e[t+7],e[t+7]=n,n=e[t+1],e[t+1]=e[t+6],e[t+6]=n,n=e[t+2],e[t+2]=e[t+5],e[t+5]=n,n=e[t+3],e[t+3]=e[t+4],e[t+4]=n}}(t)}}},\n",
" function _(t,r,e,s,a){s();const i=t(26);class n{is_Scalar(){return this.is_scalar}is_Vector(){return!this.is_scalar}}e.Uniform=n,n.__name__=\"Uniform\";class l extends n{constructor(t,r){super(),this.value=t,this.length=r,this.is_scalar=!0}get(t){return this.value}*[Symbol.iterator](){const{length:t,value:r}=this;for(let e=0;e<t;e++)yield r}select(t){return new l(this.value,t.count)}[i.equals](t,r){return r.eq(this.length,t.length)&&r.eq(this.value,t.value)}}e.UniformScalar=l,l.__name__=\"UniformScalar\";class o extends n{constructor(t){super(),this.array=t,this.is_scalar=!1,this.length=this.array.length}get(t){return this.array[t]}*[Symbol.iterator](){yield*this.array}select(t){const r=t.select(this.array);return new this.constructor(r)}[i.equals](t,r){return r.eq(this.length,t.length)&&r.eq(this.array,t.array)}}e.UniformVector=o,o.__name__=\"UniformVector\";class h extends o{constructor(t){super(t),this.array=t,this._view=new DataView(t.buffer)}get(t){return this._view.getUint32(4*t)}*[Symbol.iterator](){const t=this.length;for(let r=0;r<t;r++)yield this.get(r)}}e.ColorUniformVector=h,h.__name__=\"ColorUniformVector\"},\n",
" function _(t,e,r,n,u){n();const c=t(28);function s(){const t=new Array(32),e=\"0123456789ABCDEF\";for(let r=0;r<32;r++)t[r]=e.substr(Math.floor(16*Math.random()),1);return t[12]=\"4\",t[16]=e.substr(3&t[16].charCodeAt(0)|8,1),t.join(\"\")}r.startsWith=function(t,e,r=0){return t.substr(r,e.length)==e},r.uuid4=s;let a=1e3;r.uniqueId=function(t){const e=c.settings.dev?\"j\"+a++:s();return null!=t?`${t}-${e}`:e},r.escape=function(t){return t.replace(/(?:[&<>\"'`])/g,(t=>{switch(t){case\"&\":return\"&amp;\";case\"<\":return\"&lt;\";case\">\":return\"&gt;\";case'\"':return\"&quot;\";case\"'\":return\"&#x27;\";case\"`\":return\"&#x60;\";default:return t}}))},r.unescape=function(t){return t.replace(/&(amp|lt|gt|quot|#x27|#x60);/g,((t,e)=>{switch(e){case\"amp\":return\"&\";case\"lt\":return\"<\";case\"gt\":return\">\";case\"quot\":return'\"';case\"#x27\":return\"'\";case\"#x60\":return\"`\";default:return e}}))},r.use_strict=function(t){return`'use strict';\\n${t}`},r.to_fixed=function(t,e){return t.toFixed(e).replace(/(\\.[0-9]*?)0+$/,\"$1\").replace(/\\.$/,\"\")}},\n",
" function _(e,t,s,n,o){n();const i=e(30);class r{constructor(e){this.document=e}}s.DocumentEvent=r,r.__name__=\"DocumentEvent\";class a extends r{constructor(e,t,s){super(e),this.events=t,this.setter_id=s}}s.DocumentEventBatch=a,a.__name__=\"DocumentEventBatch\";class d extends r{}s.DocumentChangedEvent=d,d.__name__=\"DocumentChangedEvent\";class l extends d{constructor(e,t,s){super(e),this.msg_type=t,this.msg_data=s}[i.serialize](e){const t=this.msg_data,s=e.to_serializable(t);return{kind:\"MessageSent\",msg_type:this.msg_type,msg_data:s}}}s.MessageSentEvent=l,l.__name__=\"MessageSentEvent\";class _ extends d{constructor(e,t,s,n,o,i,r){super(e),this.model=t,this.attr=s,this.old=n,this.new_=o,this.setter_id=i,this.hint=r}[i.serialize](e){if(null!=this.hint)return e.to_serializable(this.hint);const t=this.new_,s=e.to_serializable(t);return this.model!=t&&e.remove_def(this.model),{kind:\"ModelChanged\",model:this.model.ref(),attr:this.attr,new:s}}}s.ModelChangedEvent=_,_.__name__=\"ModelChangedEvent\";class c extends d{constructor(e,t,s){super(e),this.column_source=t,this.patches=s}[i.serialize](e){return{kind:\"ColumnsPatched\",column_source:this.column_source,patches:this.patches}}}s.ColumnsPatchedEvent=c,c.__name__=\"ColumnsPatchedEvent\";class h extends d{constructor(e,t,s,n){super(e),this.column_source=t,this.data=s,this.rollover=n}[i.serialize](e){return{kind:\"ColumnsStreamed\",column_source:this.column_source,data:this.data,rollover:this.rollover}}}s.ColumnsStreamedEvent=h,h.__name__=\"ColumnsStreamedEvent\";class m extends d{constructor(e,t,s){super(e),this.title=t,this.setter_id=s}[i.serialize](e){return{kind:\"TitleChanged\",title:this.title}}}s.TitleChangedEvent=m,m.__name__=\"TitleChangedEvent\";class u extends d{constructor(e,t,s){super(e),this.model=t,this.setter_id=s}[i.serialize](e){return{kind:\"RootAdded\",model:e.to_serializable(this.model)}}}s.RootAddedEvent=u,u.__name__=\"RootAddedEvent\";class v extends d{constructor(e,t,s){super(e),this.model=t,this.setter_id=s}[i.serialize](e){return{kind:\"RootRemoved\",model:this.model.ref()}}}s.RootRemovedEvent=v,v.__name__=\"RootRemovedEvent\"},\n",
" function _(t,r,n,i,e){i();const s=t(8),o=t(13);n.pretty=Symbol(\"pretty\");class c{constructor(t){this.precision=null==t?void 0:t.precision}to_string(t){return function(t){return s.isObject(t)&&void 0!==t[n.pretty]}(t)?t[n.pretty](this):s.isBoolean(t)?this.boolean(t):s.isNumber(t)?this.number(t):s.isString(t)?this.string(t):s.isArray(t)?this.array(t):s.isIterable(t)?this.iterable(t):s.isPlainObject(t)?this.object(t):`${t}`}token(t){return t}boolean(t){return`${t}`}number(t){return null!=this.precision?t.toFixed(this.precision):`${t}`}string(t){return`\"${t.replace(/'/g,\"\\\\'\")}\"`}array(t){const r=this.token,n=[];for(const r of t)n.push(this.to_string(r));return`${r(\"[\")}${n.join(`${r(\",\")} `)}${r(\"]\")}`}iterable(t){var r;const n=this.token,i=null!==(r=Object(t)[Symbol.toStringTag])&&void 0!==r?r:\"Object\",e=this.array(t);return`${i}${n(\"(\")}${e}${n(\")\")}`}object(t){const r=this.token,n=[];for(const[i,e]of o.entries(t))n.push(`${i}${r(\":\")} ${this.to_string(e)}`);return`${r(\"{\")}${n.join(`${r(\",\")} `)}${r(\"}\")}`}}n.Printer=c,c.__name__=\"Printer\",n.to_string=function(t,r){return new c(r).to_string(t)}},\n",
" function _(n,o,r,e,t){e();const l=n(13),i=n(8);function c(n){return i.isObject(n)&&void 0!==n[r.clone]}r.clone=Symbol(\"clone\"),r.is_Cloneable=c;class s extends Error{}r.CloningError=s,s.__name__=\"CloningError\";class a{constructor(){}clone(n){if(c(n))return n[r.clone](this);if(i.isArray(n)){const o=n.length,r=new Array(o);for(let e=0;e<o;e++){const o=n[e];r[e]=this.clone(o)}return r}if(i.isPlainObject(n)){const o={};for(const[r,e]of l.entries(n))o[r]=this.clone(e);return o}if(null===n||i.isBoolean(n)||i.isNumber(n)||i.isString(n))return n;throw new s(`${Object.prototype.toString.call(n)} is not cloneable`)}}r.Cloner=a,a.__name__=\"Cloner\"},\n",
" function _(t,_,r,o,a){o();const e=t(1);e.__exportStar(t(39),r),e.__exportStar(t(162),r),e.__exportStar(t(257),r),e.__exportStar(t(261),r),e.__exportStar(t(266),r),e.__exportStar(t(272),r),e.__exportStar(t(205),r),e.__exportStar(t(277),r),e.__exportStar(t(313),r),e.__exportStar(t(315),r),e.__exportStar(t(317),r),e.__exportStar(t(209),r),e.__exportStar(t(147),r),e.__exportStar(t(330),r),e.__exportStar(t(338),r),e.__exportStar(t(220),r),e.__exportStar(t(339),r),e.__exportStar(t(217),r),e.__exportStar(t(340),r),e.__exportStar(t(341),r),e.__exportStar(t(198),r),e.__exportStar(t(346),r),e.__exportStar(t(356),r),e.__exportStar(t(360),r)},\n",
" function _(e,o,n,a,t){a(),t(\"Annotation\",e(40).Annotation),t(\"Arrow\",e(55).Arrow),t(\"ArrowHead\",e(133).ArrowHead),t(\"OpenHead\",e(133).OpenHead),t(\"NormalHead\",e(133).NormalHead),t(\"TeeHead\",e(133).TeeHead),t(\"VeeHead\",e(133).VeeHead),t(\"Band\",e(134).Band),t(\"BoxAnnotation\",e(136).BoxAnnotation),t(\"ColorBar\",e(137).ColorBar),t(\"Label\",e(226).Label),t(\"LabelSet\",e(227).LabelSet),t(\"Legend\",e(228).Legend),t(\"LegendItem\",e(229).LegendItem),t(\"PolyAnnotation\",e(231).PolyAnnotation),t(\"Slope\",e(232).Slope),t(\"Span\",e(233).Span),t(\"TextAnnotation\",e(139).TextAnnotation),t(\"Title\",e(138).Title),t(\"ToolbarPanel\",e(234).ToolbarPanel),t(\"Tooltip\",e(254).Tooltip),t(\"Whisker\",e(256).Whisker)},\n",
" function _(t,e,i,n,s){n();const o=t(41);class a extends o.RendererView{get_size(){if(this.model.visible){const{width:t,height:e}=this._get_size();return{width:Math.round(t),height:Math.round(e)}}return{width:0,height:0}}_get_size(){throw new Error(\"not implemented\")}connect_signals(){super.connect_signals();const t=this.model.properties;this.on_change(t.visible,(()=>{null!=this.layout&&(this.layout.visible=this.model.visible,this.plot_view.request_layout())}))}get needs_clip(){return null==this.layout}serializable_state(){const t=super.serializable_state();return null==this.layout?t:Object.assign(Object.assign({},t),{bbox:this.layout.bbox.box})}}i.AnnotationView=a,a.__name__=\"AnnotationView\";class l extends o.Renderer{constructor(t){super(t)}static init_Annotation(){this.override({level:\"annotation\"})}}i.Annotation=l,l.__name__=\"Annotation\",l.init_Annotation()},\n",
" function _(e,i,t,n,s){n();const r=e(1),a=e(42),_=r.__importStar(e(45)),o=e(20),l=e(53),d=e(54);class h extends a.View{get coordinates(){const{_coordinates:e}=this;return null!=e?e:this._coordinates=this._initialize_coordinates()}initialize(){super.initialize(),this.visuals=new _.Visuals(this),this.needs_webgl_blit=!1}connect_signals(){super.connect_signals();const{x_range_name:e,y_range_name:i}=this.model.properties;this.on_change([e,i],(()=>this._initialize_coordinates()))}_initialize_coordinates(){const{x_range_name:e,y_range_name:i}=this.model,{frame:t}=this.plot_view,n=t.x_scales.get(e),s=t.y_scales.get(i);return new d.CoordinateTransform(n,s)}get plot_view(){return this.parent}get plot_model(){return this.parent.model}get layer(){const{overlays:e,primary:i}=this.canvas;return\"overlay\"==this.model.level?e:i}get canvas(){return this.plot_view.canvas_view}request_render(){this.request_paint()}request_paint(){this.plot_view.request_paint(this)}notify_finished(){this.plot_view.notify_finished()}get needs_clip(){return!1}get has_webgl(){return!1}render(){this.model.visible&&this._render(),this._has_finished=!0}renderer_view(e){}}t.RendererView=h,h.__name__=\"RendererView\";class c extends l.Model{constructor(e){super(e)}static init_Renderer(){this.define((({Boolean:e,String:i})=>({level:[o.RenderLevel,\"image\"],visible:[e,!0],x_range_name:[i,\"default\"],y_range_name:[i,\"default\"]})))}}t.Renderer=c,c.__name__=\"Renderer\",c.init_Renderer()},\n",
" function _(t,e,s,i,n){i();const r=t(1),o=t(15),h=t(43),l=t(8),a=r.__importDefault(t(44));class _{constructor(t){this.removed=new o.Signal0(this,\"removed\"),this._ready=Promise.resolve(void 0),this._slots=new WeakMap;const{model:e,parent:s}=t;this.model=e,this.parent=s,this.root=null==s?this:s.root,this.removed.emit()}get ready(){return this._ready}connect(t,e){let s=this._slots.get(e);return null==s&&(s=(t,s)=>{const i=Promise.resolve(e.call(this,t,s));this._ready=this._ready.then((()=>i))},this._slots.set(e,s)),t.connect(s,this)}disconnect(t,e){return t.disconnect(e,this)}initialize(){this._has_finished=!1,this.is_root&&(this._stylesheet=h.stylesheet);for(const t of this.styles())this.stylesheet.append(t)}async lazy_initialize(){}remove(){this.disconnect_signals(),this.removed.emit()}toString(){return`${this.model.type}View(${this.model.id})`}serializable_state(){return{type:this.model.type}}get is_root(){return null==this.parent}assert_root(){if(!this.is_root)throw new Error(`${this.toString()} is not a root layout`)}has_finished(){return this._has_finished}get is_idle(){return this.has_finished()}connect_signals(){}disconnect_signals(){o.Signal.disconnect_receiver(this)}on_change(t,e){for(const s of l.isArray(t)?t:[t])this.connect(s.change,e)}cursor(t,e){return null}get stylesheet(){return this.is_root?this._stylesheet:this.root.stylesheet}styles(){return[a.default]}}s.View=_,_.__name__=\"View\"},\n",
" function _(t,e,n,i,o){i();const s=t(8),l=t(13),r=t=>(e={},...n)=>{const i=document.createElement(t);i.classList.add(\"bk\");for(let[t,n]of l.entries(e))if(null!=n&&(!s.isBoolean(n)||n))if(\"class\"===t&&(s.isString(n)&&(n=n.split(/\\s+/)),s.isArray(n)))for(const t of n)null!=t&&i.classList.add(t);else if(\"style\"===t&&s.isPlainObject(n))for(const[t,e]of l.entries(n))i.style[t]=e;else if(\"data\"===t&&s.isPlainObject(n))for(const[t,e]of l.entries(n))i.dataset[t]=e;else i.setAttribute(t,n);function o(t){if(s.isString(t))i.appendChild(document.createTextNode(t));else if(t instanceof Node)i.appendChild(t);else if(t instanceof NodeList||t instanceof HTMLCollection)for(const e of t)i.appendChild(e);else if(null!=t&&!1!==t)throw new Error(`expected a DOM element, string, false or null, got ${JSON.stringify(t)}`)}for(const t of n)if(s.isArray(t))for(const e of t)o(e);else o(t);return i};function a(t){const e=t.parentNode;null!=e&&e.removeChild(t)}function c(t,...e){const n=t.firstChild;for(const i of e)t.insertBefore(i,n)}function d(t,e){var n,i,o;const s=Element.prototype;return(null!==(o=null!==(i=null!==(n=s.matches)&&void 0!==n?n:s.webkitMatchesSelector)&&void 0!==i?i:s.mozMatchesSelector)&&void 0!==o?o:s.msMatchesSelector).call(t,e)}function h(t){return parseFloat(t)||0}function u(t){const e=getComputedStyle(t);return{border:{top:h(e.borderTopWidth),bottom:h(e.borderBottomWidth),left:h(e.borderLeftWidth),right:h(e.borderRightWidth)},margin:{top:h(e.marginTop),bottom:h(e.marginBottom),left:h(e.marginLeft),right:h(e.marginRight)},padding:{top:h(e.paddingTop),bottom:h(e.paddingBottom),left:h(e.paddingLeft),right:h(e.paddingRight)}}}function f(t){const e=t.getBoundingClientRect();return{width:Math.ceil(e.width),height:Math.ceil(e.height)}}n.createElement=function(t,e,...n){return r(t)(e,...n)},n.div=r(\"div\"),n.span=r(\"span\"),n.canvas=r(\"canvas\"),n.link=r(\"link\"),n.style=r(\"style\"),n.a=r(\"a\"),n.p=r(\"p\"),n.i=r(\"i\"),n.pre=r(\"pre\"),n.button=r(\"button\"),n.label=r(\"label\"),n.input=r(\"input\"),n.select=r(\"select\"),n.option=r(\"option\"),n.optgroup=r(\"optgroup\"),n.textarea=r(\"textarea\"),n.nbsp=function(){return document.createTextNode(\" \")},n.append=function(t,...e){for(const n of e)t.appendChild(n)},n.remove=a,n.removeElement=a,n.replaceWith=function(t,e){const n=t.parentNode;null!=n&&n.replaceChild(e,t)},n.prepend=c,n.empty=function(t,e=!1){let n;for(;n=t.firstChild;)t.removeChild(n);if(e&&t instanceof Element)for(const e of t.attributes)t.removeAttributeNode(e)},n.display=function(t){t.style.display=\"\"},n.undisplay=function(t){t.style.display=\"none\"},n.show=function(t){t.style.visibility=\"\"},n.hide=function(t){t.style.visibility=\"hidden\"},n.offset=function(t){const e=t.getBoundingClientRect();return{top:e.top+window.pageYOffset-document.documentElement.clientTop,left:e.left+window.pageXOffset-document.documentElement.clientLeft}},n.matches=d,n.parent=function(t,e){let n=t;for(;n=n.parentElement;)if(d(n,e))return n;return null},n.extents=u,n.size=f,n.scroll_size=function(t){return{width:Math.ceil(t.scrollWidth),height:Math.ceil(t.scrollHeight)}},n.outer_size=function(t){const{margin:{left:e,right:n,top:i,bottom:o}}=u(t),{width:s,height:l}=f(t);return{width:Math.ceil(s+e+n),height:Math.ceil(l+i+o)}},n.content_size=function(t){const{left:e,top:n}=t.getBoundingClientRect(),{padding:i}=u(t);let o=0,s=0;for(const l of t.children){const t=l.getBoundingClientRect();o=Math.max(o,Math.ceil(t.left-e-i.left+t.width)),s=Math.max(s,Math.ceil(t.top-n-i.top+t.height))}return{width:o,height:s}},n.position=function(t,e,n){const{style:i}=t;if(i.left=`${e.x}px`,i.top=`${e.y}px`,i.width=`${e.width}px`,i.height=`${e.height}px`,null==n)i.margin=\"\";else{const{top:t,right:e,bottom:o,left:s}=n;i.margin=`${t}px ${e}px ${o}px ${s}px`}},n.children=function(t){return Array.from(t.children)};class p{constructor(t){this.el=t,this.classList=t.classList}get values(){const t=[];for(let e=0;e<this.classList.length;e++){const n=this.classList.item(e);null!=n&&t.push(n)}return t}has(t){return this.classList.contains(t)}add(...t){for(const e of t)this.classList.add(e);return this}remove(...t){for(const e of t)this.classList.remove(e);return this}clear(){for(const t of this.values)\"bk\"!=t&&this.classList.remove(t);return this}toggle(t,e){return(null!=e?e:!this.has(t))?this.add(t):this.remove(t),this}}var g;function m(t,e,n){const{width:i,height:o,position:s,display:l}=t.style;t.style.position=\"absolute\",t.style.display=\"\",t.style.width=null!=e.width&&e.width!=1/0?`${e.width}px`:\"auto\",t.style.height=null!=e.height&&e.height!=1/0?`${e.height}px`:\"auto\";try{return n()}finally{t.style.position=s,t.style.display=l,t.style.width=i,t.style.height=o}}n.ClassList=p,p.__name__=\"ClassList\",n.classes=function(t){return new p(t)},n.toggle_attribute=function(t,e,n){null==n&&(n=!t.hasAttribute(e)),n?t.setAttribute(e,\"true\"):t.removeAttribute(e)},(g=n.Keys||(n.Keys={}))[g.Backspace=8]=\"Backspace\",g[g.Tab=9]=\"Tab\",g[g.Enter=13]=\"Enter\",g[g.Esc=27]=\"Esc\",g[g.PageUp=33]=\"PageUp\",g[g.PageDown=34]=\"PageDown\",g[g.Left=37]=\"Left\",g[g.Up=38]=\"Up\",g[g.Right=39]=\"Right\",g[g.Down=40]=\"Down\",g[g.Delete=46]=\"Delete\",n.undisplayed=function(t,e){const{display:n}=t.style;t.style.display=\"none\";try{return e()}finally{t.style.display=n}},n.unsized=function(t,e){return m(t,{},e)},n.sized=m;class y{constructor(t){this.root=t,this.known=new Set,this.style=n.style({type:\"text/css\"}),c(t,this.style)}append(t){this.known.has(t)||(this.style.appendChild(document.createTextNode(t)),this.known.add(t))}}n.StyleSheet=y,y.__name__=\"StyleSheet\",n.stylesheet=new y(document.head),n.dom_ready=async function(){if(\"loading\"==document.readyState)return new Promise(((t,e)=>{document.addEventListener(\"DOMContentLoaded\",(()=>t()),{once:!0})}))}},\n",
" function _(o,i,t,e,r){e(),t.root=\"bk-root\",t.default=\".bk-root{position:relative;width:auto;height:auto;z-index:0;box-sizing:border-box;font-family:Helvetica, Arial, sans-serif;font-size:13px;}.bk-root .bk,.bk-root .bk:before,.bk-root .bk:after{box-sizing:inherit;margin:0;border:0;padding:0;background-image:none;font-family:inherit;font-size:100%;line-height:1.42857143;}.bk-root pre.bk{font-family:Courier, monospace;}\"},\n",
" function _(e,t,r,a,c){a();const l=e(1),n=e(46);c(\"Line\",n.Line),c(\"LineScalar\",n.LineScalar),c(\"LineVector\",n.LineVector);const i=e(49);c(\"Fill\",i.Fill),c(\"FillScalar\",i.FillScalar),c(\"FillVector\",i.FillVector);const s=e(50);c(\"Text\",s.Text),c(\"TextScalar\",s.TextScalar),c(\"TextVector\",s.TextVector);const o=e(51);c(\"Hatch\",o.Hatch),c(\"HatchScalar\",o.HatchScalar),c(\"HatchVector\",o.HatchVector);const u=l.__importStar(e(48)),V=e(47);c(\"VisualProperties\",V.VisualProperties),c(\"VisualUniforms\",V.VisualUniforms);class h{constructor(e){this._visuals=[];for(const[t,r]of e.model._mixins){const a=(()=>{switch(r){case u.Line:return new n.Line(e,t);case u.LineScalar:return new n.LineScalar(e,t);case u.LineVector:return new n.LineVector(e,t);case u.Fill:return new i.Fill(e,t);case u.FillScalar:return new i.FillScalar(e,t);case u.FillVector:return new i.FillVector(e,t);case u.Text:return new s.Text(e,t);case u.TextScalar:return new s.TextScalar(e,t);case u.TextVector:return new s.TextVector(e,t);case u.Hatch:return new o.Hatch(e,t);case u.HatchScalar:return new o.HatchScalar(e,t);case u.HatchVector:return new o.HatchVector(e,t);default:throw new Error(\"unknown visual\")}})();this._visuals.push(a),Object.defineProperty(this,t+a.type,{get:()=>a,configurable:!1,enumerable:!0})}}*[Symbol.iterator](){yield*this._visuals}}r.Visuals=h,h.__name__=\"Visuals\"},\n",
" function _(e,t,i,l,s){l();const n=e(1),a=e(47),o=n.__importStar(e(48)),r=e(22),_=e(8);function h(e){if(_.isArray(e))return e;switch(e){case\"solid\":return[];case\"dashed\":return[6];case\"dotted\":return[2,4];case\"dotdash\":return[2,4,6,4];case\"dashdot\":return[6,4,2,4];default:return e.split(\" \").map(Number).filter(_.isInteger)}}i.resolve_line_dash=h;class c extends a.VisualProperties{get doit(){const e=this.line_color.get_value(),t=this.line_alpha.get_value(),i=this.line_width.get_value();return!(null==e||0==t||0==i)}set_value(e){const t=this.line_color.get_value(),i=this.line_alpha.get_value();e.strokeStyle=r.color2css(t,i),e.lineWidth=this.line_width.get_value(),e.lineJoin=this.line_join.get_value(),e.lineCap=this.line_cap.get_value(),e.lineDash=h(this.line_dash.get_value()),e.lineDashOffset=this.line_dash_offset.get_value()}}i.Line=c,c.__name__=\"Line\";class u extends a.VisualUniforms{get doit(){const e=this.line_color.value,t=this.line_alpha.value,i=this.line_width.value;return!(0==e||0==t||0==i)}set_value(e){const t=this.line_color.value,i=this.line_alpha.value;e.strokeStyle=r.color2css(t,i),e.lineWidth=this.line_width.value,e.lineJoin=this.line_join.value,e.lineCap=this.line_cap.value,e.lineDash=h(this.line_dash.value),e.lineDashOffset=this.line_dash_offset.value}}i.LineScalar=u,u.__name__=\"LineScalar\";class d extends a.VisualUniforms{get doit(){const{line_color:e}=this;if(e.is_Scalar()&&0==e.value)return!1;const{line_alpha:t}=this;if(t.is_Scalar()&&0==t.value)return!1;const{line_width:i}=this;return!i.is_Scalar()||0!=i.value}set_vectorize(e,t){const i=this.line_color.get(t),l=this.line_alpha.get(t),s=this.line_width.get(t),n=this.line_join.get(t),a=this.line_cap.get(t),o=this.line_dash.get(t),_=this.line_dash_offset.get(t);e.strokeStyle=r.color2css(i,l),e.lineWidth=s,e.lineJoin=n,e.lineCap=a,e.lineDash=h(o),e.lineDashOffset=_}}i.LineVector=d,d.__name__=\"LineVector\",c.prototype.type=\"line\",c.prototype.attrs=Object.keys(o.Line),u.prototype.type=\"line\",u.prototype.attrs=Object.keys(o.LineScalar),d.prototype.type=\"line\",d.prototype.attrs=Object.keys(o.LineVector)},\n",
" function _(t,s,o,i,r){i();class e{constructor(t,s=\"\"){this.obj=t,this.prefix=s;const o=this;this._props=[];for(const i of this.attrs){const r=t.model.properties[s+i];r.change.connect((()=>this.update())),o[i]=r,this._props.push(r)}this.update()}*[Symbol.iterator](){yield*this._props}update(){}}o.VisualProperties=e,e.__name__=\"VisualProperties\";class p{constructor(t,s=\"\"){this.obj=t,this.prefix=s;for(const o of this.attrs)Object.defineProperty(this,o,{get:()=>t[s+o]})}*[Symbol.iterator](){for(const t of this.attrs)yield this.obj.model.properties[this.prefix+t]}update(){}}o.VisualUniforms=p,p.__name__=\"VisualUniforms\"},\n",
" function _(e,l,t,a,c){a();const r=e(1),o=r.__importStar(e(18)),n=e(20),i=r.__importStar(e(21)),_=e(13);t.Line={line_color:[i.Nullable(i.Color),\"black\"],line_alpha:[i.Alpha,1],line_width:[i.Number,1],line_join:[n.LineJoin,\"bevel\"],line_cap:[n.LineCap,\"butt\"],line_dash:[i.Or(n.LineDash,i.Array(i.Number)),[]],line_dash_offset:[i.Number,0]},t.Fill={fill_color:[i.Nullable(i.Color),\"gray\"],fill_alpha:[i.Alpha,1]},t.Hatch={hatch_color:[i.Nullable(i.Color),\"black\"],hatch_alpha:[i.Alpha,1],hatch_scale:[i.Number,12],hatch_pattern:[i.Nullable(i.Or(n.HatchPatternType,i.String)),null],hatch_weight:[i.Number,1],hatch_extra:[i.Dict(i.AnyRef()),{}]},t.Text={text_color:[i.Nullable(i.Color),\"#444444\"],text_alpha:[i.Alpha,1],text_font:[o.Font,\"helvetica\"],text_font_size:[i.FontSize,\"16px\"],text_font_style:[n.FontStyle,\"normal\"],text_align:[n.TextAlign,\"left\"],text_baseline:[n.TextBaseline,\"bottom\"],text_line_height:[i.Number,1.2]},t.LineScalar={line_color:[o.ColorScalar,\"black\"],line_alpha:[o.NumberScalar,1],line_width:[o.NumberScalar,1],line_join:[o.LineJoinScalar,\"bevel\"],line_cap:[o.LineCapScalar,\"butt\"],line_dash:[o.LineDashScalar,[]],line_dash_offset:[o.NumberScalar,0]},t.FillScalar={fill_color:[o.ColorScalar,\"gray\"],fill_alpha:[o.NumberScalar,1]},t.HatchScalar={hatch_color:[o.ColorScalar,\"black\"],hatch_alpha:[o.NumberScalar,1],hatch_scale:[o.NumberScalar,12],hatch_pattern:[o.NullStringScalar,null],hatch_weight:[o.NumberScalar,1],hatch_extra:[o.AnyScalar,{}]},t.TextScalar={text_color:[o.ColorScalar,\"#444444\"],text_alpha:[o.NumberScalar,1],text_font:[o.FontScalar,\"helvetica\"],text_font_size:[o.FontSizeScalar,\"16px\"],text_font_style:[o.FontStyleScalar,\"normal\"],text_align:[o.TextAlignScalar,\"left\"],text_baseline:[o.TextBaselineScalar,\"bottom\"],text_line_height:[o.NumberScalar,1.2]},t.LineVector={line_color:[o.ColorSpec,\"black\"],line_alpha:[o.NumberSpec,1],line_width:[o.NumberSpec,1],line_join:[o.LineJoinSpec,\"bevel\"],line_cap:[o.LineCapSpec,\"butt\"],line_dash:[o.LineDashSpec,[]],line_dash_offset:[o.NumberSpec,0]},t.FillVector={fill_color:[o.ColorSpec,\"gray\"],fill_alpha:[o.NumberSpec,1]},t.HatchVector={hatch_color:[o.ColorSpec,\"black\"],hatch_alpha:[o.NumberSpec,1],hatch_scale:[o.NumberSpec,12],hatch_pattern:[o.NullStringSpec,null],hatch_weight:[o.NumberSpec,1],hatch_extra:[o.AnyScalar,{}]},t.TextVector={text_color:[o.ColorSpec,\"#444444\"],text_alpha:[o.NumberSpec,1],text_font:[o.FontSpec,\"helvetica\"],text_font_size:[o.FontSizeSpec,\"16px\"],text_font_style:[o.FontStyleSpec,\"normal\"],text_align:[o.TextAlignSpec,\"left\"],text_baseline:[o.TextBaselineSpec,\"bottom\"],text_line_height:[o.NumberSpec,1.2]},t.attrs_of=function(e,l,t,a=!1){const c={};for(const r of _.keys(t)){const t=`${l}${r}`,o=e[t];c[a?t:r]=o}return c}},\n",
" function _(l,t,e,i,s){i();const o=l(1),a=l(47),r=o.__importStar(l(48)),c=l(22);class _ extends a.VisualProperties{get doit(){const l=this.fill_color.get_value(),t=this.fill_alpha.get_value();return!(null==l||0==t)}set_value(l){const t=this.fill_color.get_value(),e=this.fill_alpha.get_value();l.fillStyle=c.color2css(t,e)}}e.Fill=_,_.__name__=\"Fill\";class n extends a.VisualUniforms{get doit(){const l=this.fill_color.value,t=this.fill_alpha.value;return!(0==l||0==t)}set_value(l){const t=this.fill_color.value,e=this.fill_alpha.value;l.fillStyle=c.color2css(t,e)}}e.FillScalar=n,n.__name__=\"FillScalar\";class p extends a.VisualUniforms{get doit(){const{fill_color:l}=this;if(l.is_Scalar()&&0==l.value)return!1;const{fill_alpha:t}=this;return!t.is_Scalar()||0!=t.value}set_vectorize(l,t){const e=this.fill_color.get(t),i=this.fill_alpha.get(t);l.fillStyle=c.color2css(e,i)}}e.FillVector=p,p.__name__=\"FillVector\",_.prototype.type=\"fill\",_.prototype.attrs=Object.keys(r.Fill),n.prototype.type=\"fill\",n.prototype.attrs=Object.keys(r.FillScalar),p.prototype.type=\"fill\",p.prototype.attrs=Object.keys(r.FillVector)},\n",
" function _(t,e,s,l,a){l();const o=t(1),_=t(47),i=o.__importStar(t(48)),n=t(22);class x extends _.VisualProperties{get doit(){const t=this.text_color.get_value(),e=this.text_alpha.get_value();return!(null==t||0==e)}set_value(t){const e=this.text_color.get_value(),s=this.text_alpha.get_value();t.fillStyle=n.color2css(e,s),t.font=this.font_value(),t.textAlign=this.text_align.get_value(),t.textBaseline=this.text_baseline.get_value()}font_value(){return`${this.text_font_style.get_value()} ${this.text_font_size.get_value()} ${this.text_font.get_value()}`}}s.Text=x,x.__name__=\"Text\";class r extends _.VisualUniforms{get doit(){const t=this.text_color.value,e=this.text_alpha.value;return!(0==t||0==e)}set_value(t){const e=this.text_color.value,s=this.text_alpha.value,l=this.font_value(),a=this.text_align.value,o=this.text_baseline.value;t.fillStyle=n.color2css(e,s),t.font=l,t.textAlign=a,t.textBaseline=o}font_value(){return`${this.text_font_style.value} ${this.text_font_size.value} ${this.text_font.value}`}}s.TextScalar=r,r.__name__=\"TextScalar\";class u extends _.VisualUniforms{get doit(){const{text_color:t}=this;if(t.is_Scalar()&&0==t.value)return!1;const{text_alpha:e}=this;return!e.is_Scalar()||0!=e.value}set_vectorize(t,e){const s=this.text_color.get(e),l=this.text_alpha.get(e),a=this.font_value(e),o=this.text_align.get(e),_=this.text_baseline.get(e);t.fillStyle=n.color2css(s,l),t.font=a,t.textAlign=o,t.textBaseline=_}font_value(t){return`${this.text_font_style.get(t)} ${this.text_font_size.get(t)} ${this.text_font.get(t)}`}}s.TextVector=u,u.__name__=\"TextVector\",x.prototype.type=\"text\",x.prototype.attrs=Object.keys(i.Text),r.prototype.type=\"text\",r.prototype.attrs=Object.keys(i.TextScalar),u.prototype.type=\"text\",u.prototype.attrs=Object.keys(i.TextVector)},\n",
" function _(t,e,a,h,r){h();const i=t(1),s=t(47),c=t(52),n=i.__importStar(t(18)),_=i.__importStar(t(48));class l extends s.VisualProperties{constructor(){super(...arguments),this._update_iteration=0}update(){if(this._update_iteration++,this._hatch_image=null,!this.doit)return;const t=this.hatch_color.get_value(),e=this.hatch_alpha.get_value(),a=this.hatch_scale.get_value(),h=this.hatch_pattern.get_value(),r=this.hatch_weight.get_value(),i=t=>{this._hatch_image=t},s=this.hatch_extra.get_value()[h];if(null!=s){const h=s.get_pattern(t,e,a,r);if(h instanceof Promise){const{_update_iteration:t}=this;h.then((e=>{this._update_iteration==t&&(i(e),this.obj.request_render())}))}else i(h)}else{const s=this.obj.canvas.create_layer(),n=c.get_pattern(s,h,t,e,a,r);i(n)}}get doit(){const t=this.hatch_color.get_value(),e=this.hatch_alpha.get_value(),a=this.hatch_pattern.get_value();return!(null==t||0==e||\" \"==a||\"blank\"==a||null==a)}set_value(t){const e=this.pattern(t);t.fillStyle=null!=e?e:\"transparent\"}pattern(t){const e=this._hatch_image;return null==e?null:t.createPattern(e,this.repetition())}repetition(){const t=this.hatch_pattern.get_value(),e=this.hatch_extra.get_value()[t];if(null==e)return\"repeat\";switch(e.repetition){case\"repeat\":return\"repeat\";case\"repeat_x\":return\"repeat-x\";case\"repeat_y\":return\"repeat-y\";case\"no_repeat\":return\"no-repeat\"}}}a.Hatch=l,l.__name__=\"Hatch\";class o extends s.VisualUniforms{constructor(){super(...arguments),this._static_doit=!1,this._update_iteration=0}_compute_static_doit(){const t=this.hatch_color.value,e=this.hatch_alpha.value,a=this.hatch_pattern.value;return!(null==t||0==e||\" \"==a||\"blank\"==a||null==a)}update(){this._update_iteration++;const t=this.hatch_color.length;if(this._hatch_image=new n.UniformScalar(null,t),this._static_doit=this._compute_static_doit(),!this._static_doit)return;const e=this.hatch_color.value,a=this.hatch_alpha.value,h=this.hatch_scale.value,r=this.hatch_pattern.value,i=this.hatch_weight.value,s=e=>{this._hatch_image=new n.UniformScalar(e,t)},_=this.hatch_extra.value[r];if(null!=_){const t=_.get_pattern(e,a,h,i);if(t instanceof Promise){const{_update_iteration:e}=this;t.then((t=>{this._update_iteration==e&&(s(t),this.obj.request_render())}))}else s(t)}else{const t=this.obj.canvas.create_layer(),n=c.get_pattern(t,r,e,a,h,i);s(n)}}get doit(){return this._static_doit}set_value(t){var e;t.fillStyle=null!==(e=this.pattern(t))&&void 0!==e?e:\"transparent\"}pattern(t){const e=this._hatch_image.value;return null==e?null:t.createPattern(e,this.repetition())}repetition(){const t=this.hatch_pattern.value,e=this.hatch_extra.value[t];if(null==e)return\"repeat\";switch(e.repetition){case\"repeat\":return\"repeat\";case\"repeat_x\":return\"repeat-x\";case\"repeat_y\":return\"repeat-y\";case\"no_repeat\":return\"no-repeat\"}}}a.HatchScalar=o,o.__name__=\"HatchScalar\";class u extends s.VisualUniforms{constructor(){super(...arguments),this._static_doit=!1,this._update_iteration=0}_compute_static_doit(){const{hatch_color:t}=this;if(t.is_Scalar()&&0==t.value)return!1;const{hatch_alpha:e}=this;if(e.is_Scalar()&&0==e.value)return!1;const{hatch_pattern:a}=this;if(a.is_Scalar()){const t=a.value;if(\" \"==t||\"blank\"==t||null==t)return!1}return!0}update(){this._update_iteration++;const t=this.hatch_color.length;if(this._hatch_image=new n.UniformScalar(null,t),this._static_doit=this._compute_static_doit(),!this._static_doit)return;const e=(t,e,a,h,r,i)=>{const s=this.hatch_extra.value[t];if(null!=s){const t=s.get_pattern(e,a,h,r);if(t instanceof Promise){const{_update_iteration:e}=this;t.then((t=>{this._update_iteration==e&&(i(t),this.obj.request_render())}))}else i(t)}else{const s=this.obj.canvas.create_layer(),n=c.get_pattern(s,t,e,a,h,r);i(n)}};if(this.hatch_color.is_Scalar()&&this.hatch_alpha.is_Scalar()&&this.hatch_scale.is_Scalar()&&this.hatch_pattern.is_Scalar()&&this.hatch_weight.is_Scalar()){const a=this.hatch_color.value,h=this.hatch_alpha.value,r=this.hatch_scale.value;e(this.hatch_pattern.value,a,h,r,this.hatch_weight.value,(e=>{this._hatch_image=new n.UniformScalar(e,t)}))}else{const a=new Array(t);a.fill(null),this._hatch_image=new n.UniformVector(a);for(let h=0;h<t;h++){const t=this.hatch_color.get(h),r=this.hatch_alpha.get(h),i=this.hatch_scale.get(h);e(this.hatch_pattern.get(h),t,r,i,this.hatch_weight.get(h),(t=>{a[h]=t}))}}}get doit(){return this._static_doit}set_vectorize(t,e){var a;t.fillStyle=null!==(a=this.pattern(t,e))&&void 0!==a?a:\"transparent\"}pattern(t,e){const a=this._hatch_image.get(e);return null==a?null:t.createPattern(a,this.repetition(e))}repetition(t){const e=this.hatch_pattern.get(t),a=this.hatch_extra.value[e];if(null==a)return\"repeat\";switch(a.repetition){case\"repeat\":return\"repeat\";case\"repeat_x\":return\"repeat-x\";case\"repeat_y\":return\"repeat-y\";case\"no_repeat\":return\"no-repeat\"}}}a.HatchVector=u,u.__name__=\"HatchVector\",l.prototype.type=\"hatch\",l.prototype.attrs=Object.keys(_.Hatch),o.prototype.type=\"hatch\",o.prototype.attrs=Object.keys(_.HatchScalar),u.prototype.type=\"hatch\",u.prototype.attrs=Object.keys(_.HatchVector)},\n",
" function _(e,o,a,s,r){s();const i=e(22);function l(e,o,a){e.moveTo(0,a+.5),e.lineTo(o,a+.5),e.stroke()}function n(e,o,a){e.moveTo(a+.5,0),e.lineTo(a+.5,o),e.stroke()}function t(e,o){e.moveTo(0,o),e.lineTo(o,0),e.stroke(),e.moveTo(0,0),e.lineTo(o,o),e.stroke()}a.hatch_aliases={\" \":\"blank\",\".\":\"dot\",o:\"ring\",\"-\":\"horizontal_line\",\"|\":\"vertical_line\",\"+\":\"cross\",'\"':\"horizontal_dash\",\":\":\"vertical_dash\",\"@\":\"spiral\",\"/\":\"right_diagonal_line\",\"\\\\\":\"left_diagonal_line\",x:\"diagonal_cross\",\",\":\"right_diagonal_dash\",\"`\":\"left_diagonal_dash\",v:\"horizontal_wave\",\">\":\"vertical_wave\",\"*\":\"criss_cross\"},a.get_pattern=function(e,o,s,r,c,k){return e.resize(c,c),e.prepare(),function(e,o,s,r,c,k){var _;const T=c,v=T/2,h=v/2,d=i.color2css(s,r);switch(e.strokeStyle=d,e.fillStyle=d,e.lineCap=\"square\",e.lineWidth=k,null!==(_=a.hatch_aliases[o])&&void 0!==_?_:o){case\"blank\":break;case\"dot\":e.arc(v,v,v/2,0,2*Math.PI,!0),e.fill();break;case\"ring\":e.arc(v,v,v/2,0,2*Math.PI,!0),e.stroke();break;case\"horizontal_line\":l(e,T,v);break;case\"vertical_line\":n(e,T,v);break;case\"cross\":l(e,T,v),n(e,T,v);break;case\"horizontal_dash\":l(e,v,v);break;case\"vertical_dash\":n(e,v,v);break;case\"spiral\":{const o=T/30;e.moveTo(v,v);for(let a=0;a<360;a++){const s=.1*a,r=v+o*s*Math.cos(s),i=v+o*s*Math.sin(s);e.lineTo(r,i)}e.stroke();break}case\"right_diagonal_line\":e.moveTo(.5-h,T),e.lineTo(h+.5,0),e.stroke(),e.moveTo(h+.5,T),e.lineTo(3*h+.5,0),e.stroke(),e.moveTo(3*h+.5,T),e.lineTo(5*h+.5,0),e.stroke(),e.stroke();break;case\"left_diagonal_line\":e.moveTo(h+.5,T),e.lineTo(.5-h,0),e.stroke(),e.moveTo(3*h+.5,T),e.lineTo(h+.5,0),e.stroke(),e.moveTo(5*h+.5,T),e.lineTo(3*h+.5,0),e.stroke(),e.stroke();break;case\"diagonal_cross\":t(e,T);break;case\"right_diagonal_dash\":e.moveTo(h+.5,3*h+.5),e.lineTo(3*h+.5,h+.5),e.stroke();break;case\"left_diagonal_dash\":e.moveTo(h+.5,h+.5),e.lineTo(3*h+.5,3*h+.5),e.stroke();break;case\"horizontal_wave\":e.moveTo(0,h),e.lineTo(v,3*h),e.lineTo(T,h),e.stroke();break;case\"vertical_wave\":e.moveTo(h,0),e.lineTo(3*h,v),e.lineTo(h,T),e.stroke();break;case\"criss_cross\":t(e,T),l(e,T,v),n(e,T,v)}}(e.ctx,o,s,r,c,k),e.canvas}},\n",
" function _(e,t,s,n,c){n();const a=e(14),i=e(8),r=e(13),l=e(19);class o extends a.HasProps{constructor(e){super(e)}get is_syncable(){return this.syncable}static init_Model(){this.define((({Any:e,Unknown:t,Boolean:s,String:n,Array:c,Dict:a,Nullable:i})=>({tags:[c(t),[]],name:[i(n),null],js_property_callbacks:[a(c(e)),{}],js_event_callbacks:[a(c(e)),{}],subscribed_events:[c(n),[]],syncable:[s,!0]})))}initialize(){super.initialize(),this._js_callbacks=new Map}connect_signals(){super.connect_signals(),this._update_property_callbacks(),this.connect(this.properties.js_property_callbacks.change,(()=>this._update_property_callbacks())),this.connect(this.properties.js_event_callbacks.change,(()=>this._update_event_callbacks())),this.connect(this.properties.subscribed_events.change,(()=>this._update_event_callbacks()))}_process_event(e){var t;for(const s of null!==(t=this.js_event_callbacks[e.event_name])&&void 0!==t?t:[])s.execute(e);null!=this.document&&this.subscribed_events.some((t=>t==e.event_name))&&this.document.event_manager.send_event(e)}trigger_event(e){null!=this.document&&(e.origin=this,this.document.event_manager.trigger(e))}_update_event_callbacks(){null!=this.document?this.document.event_manager.subscribed_models.add(this):l.logger.warn(\"WARNING: Document not defined for updating event callbacks\")}_update_property_callbacks(){const e=e=>{const[t,s=null]=e.split(\":\");return null!=s?this.properties[s][t]:this[t]};for(const[t,s]of this._js_callbacks){const n=e(t);for(const e of s)this.disconnect(n,e)}this._js_callbacks.clear();for(const[t,s]of r.entries(this.js_property_callbacks)){const n=s.map((e=>()=>e.execute(this)));this._js_callbacks.set(t,n);const c=e(t);for(const e of n)this.connect(c,e)}}_doc_attached(){r.isEmpty(this.js_event_callbacks)&&0==this.subscribed_events.length||this._update_event_callbacks()}_doc_detached(){this.document.event_manager.subscribed_models.delete(this)}select(e){if(i.isString(e))return[...this.references()].filter((t=>t instanceof o&&t.name===e));if(e.prototype instanceof a.HasProps)return[...this.references()].filter((t=>t instanceof e));throw new Error(\"invalid selector\")}select_one(e){const t=this.select(e);switch(t.length){case 0:return null;case 1:return t[0];default:throw new Error(\"found more than one object matching given selector\")}}}s.Model=o,o.__name__=\"Model\",o.init_Model()},\n",
" function _(s,e,_,t,a){t();class r{constructor(s,e){this.x_scale=s,this.y_scale=e,this.x_range=this.x_scale.source_range,this.y_range=this.y_scale.source_range,this.ranges=[this.x_range,this.y_range],this.scales=[this.x_scale,this.y_scale]}map_to_screen(s,e){return[this.x_scale.v_compute(s),this.y_scale.v_compute(e)]}map_from_screen(s,e){return[this.x_scale.v_invert(s),this.y_scale.v_invert(e)]}}_.CoordinateTransform=r,r.__name__=\"CoordinateTransform\"},\n",
" function _(t,e,s,a,i){a();const n=t(1),_=t(56),r=t(133),o=t(48),l=t(20),d=t(24),h=t(122),c=n.__importStar(t(18)),u=t(10);class v extends _.DataAnnotationView{async lazy_initialize(){await super.lazy_initialize();const{start:t,end:e}=this.model;null!=t&&(this.start=await h.build_view(t,{parent:this})),null!=e&&(this.end=await h.build_view(e,{parent:this}))}set_data(t){var e,s;super.set_data(t),null===(e=this.start)||void 0===e||e.set_data(t),null===(s=this.end)||void 0===s||s.set_data(t)}remove(){var t,e;null===(t=this.start)||void 0===t||t.remove(),null===(e=this.end)||void 0===e||e.remove(),super.remove()}map_data(){const{frame:t}=this.plot_view;\"data\"==this.model.start_units?(this._sx_start=this.coordinates.x_scale.v_compute(this._x_start),this._sy_start=this.coordinates.y_scale.v_compute(this._y_start)):(this._sx_start=t.bbox.xview.v_compute(this._x_start),this._sy_start=t.bbox.yview.v_compute(this._y_start)),\"data\"==this.model.end_units?(this._sx_end=this.coordinates.x_scale.v_compute(this._x_end),this._sy_end=this.coordinates.y_scale.v_compute(this._y_end)):(this._sx_end=t.bbox.xview.v_compute(this._x_end),this._sy_end=t.bbox.yview.v_compute(this._y_end));const{_sx_start:e,_sy_start:s,_sx_end:a,_sy_end:i}=this,n=e.length,_=this._angles=new d.ScreenArray(n);for(let t=0;t<n;t++)_[t]=Math.PI/2+u.atan2([e[t],s[t]],[a[t],i[t]])}paint(t){const{start:e,end:s}=this,{_sx_start:a,_sy_start:i,_sx_end:n,_sy_end:_,_angles:r}=this,{x:o,y:l,width:d,height:h}=this.plot_view.frame.bbox;for(let c=0,u=a.length;c<u;c++)null!=s&&(t.save(),t.translate(n[c],_[c]),t.rotate(r[c]),s.render(t,c),t.restore()),null!=e&&(t.save(),t.translate(a[c],i[c]),t.rotate(r[c]+Math.PI),e.render(t,c),t.restore()),this.visuals.line.doit&&(t.save(),null==e&&null==s||(t.beginPath(),t.rect(o,l,d,h),null!=s&&(t.save(),t.translate(n[c],_[c]),t.rotate(r[c]),s.clip(t,c),t.restore()),null!=e&&(t.save(),t.translate(a[c],i[c]),t.rotate(r[c]+Math.PI),e.clip(t,c),t.restore()),t.closePath(),t.clip()),this.visuals.line.set_vectorize(t,c),t.beginPath(),t.moveTo(a[c],i[c]),t.lineTo(n[c],_[c]),t.stroke(),t.restore())}}s.ArrowView=v,v.__name__=\"ArrowView\";class p extends _.DataAnnotation{constructor(t){super(t)}static init_Arrow(){this.prototype.default_view=v,this.mixins(o.LineVector),this.define((({Ref:t,Nullable:e})=>({x_start:[c.XCoordinateSpec,{field:\"x_start\"}],y_start:[c.YCoordinateSpec,{field:\"y_start\"}],start_units:[l.SpatialUnits,\"data\"],start:[e(t(r.ArrowHead)),null],x_end:[c.XCoordinateSpec,{field:\"x_end\"}],y_end:[c.YCoordinateSpec,{field:\"y_end\"}],end_units:[l.SpatialUnits,\"data\"],end:[e(t(r.ArrowHead)),()=>new r.OpenHead]})))}}s.Arrow=p,p.__name__=\"Arrow\",p.init_Arrow()},\n",
" function _(t,n,s,a,e){a();const i=t(1),o=t(40),c=t(57),_=t(130),r=t(65),l=i.__importStar(t(18));class h extends o.AnnotationView{constructor(){super(...arguments),this._initial_set_data=!1}connect_signals(){super.connect_signals();const t=()=>{this.set_data(this.model.source),this.request_render()};this.connect(this.model.change,t),this.connect(this.model.source.streaming,t),this.connect(this.model.source.patching,t),this.connect(this.model.source.change,t)}set_data(t){const n=this;for(const s of this.model)if(s instanceof l.VectorSpec||s instanceof l.ScalarSpec)if(s instanceof l.BaseCoordinateSpec){const a=s.array(t);n[`_${s.attr}`]=a}else{const a=s.uniform(t);n[`${s.attr}`]=a}this.plot_model.use_map&&(null!=n._x&&r.inplace.project_xy(n._x,n._y),null!=n._xs&&r.inplace.project_xsys(n._xs,n._ys));for(const t of this.visuals)t.update()}_render(){this._initial_set_data||(this.set_data(this.model.source),this._initial_set_data=!0),this.map_data(),this.paint(this.layer.ctx)}}s.DataAnnotationView=h,h.__name__=\"DataAnnotationView\";class u extends o.Annotation{constructor(t){super(t)}static init_DataAnnotation(){this.define((({Ref:t})=>({source:[t(c.ColumnarDataSource),()=>new _.ColumnDataSource]})))}}s.DataAnnotation=u,u.__name__=\"DataAnnotation\",u.init_DataAnnotation()},\n",
" function _(t,e,n,a,i){a();const s=t(58),r=t(15),l=t(19),o=t(60),c=t(8),u=t(9),h=t(13),g=t(59),d=t(129),_=t(29);class m extends s.DataSource{constructor(t){super(t)}get_array(t){let e=this.data[t];return null==e?this.data[t]=e=[]:c.isArray(e)||(this.data[t]=e=Array.from(e)),e}static init_ColumnarDataSource(){this.define((({Ref:t})=>({selection_policy:[t(d.SelectionPolicy),()=>new d.UnionRenderers]}))),this.internal((({AnyRef:t})=>({selection_manager:[t(),t=>new o.SelectionManager({source:t})],inspected:[t(),()=>new g.Selection]})))}initialize(){super.initialize(),this._select=new r.Signal0(this,\"select\"),this.inspect=new r.Signal(this,\"inspect\"),this.streaming=new r.Signal0(this,\"streaming\"),this.patching=new r.Signal(this,\"patching\")}get_column(t){const e=this.data[t];return null!=e?e:null}columns(){return h.keys(this.data)}get_length(t=!0){const e=u.uniq(h.values(this.data).map((t=>_.is_NDArray(t)?t.shape[0]:t.length)));switch(e.length){case 0:return null;case 1:return e[0];default:{const n=\"data source has columns of inconsistent lengths\";if(t)return l.logger.warn(n),e.sort()[0];throw new Error(n)}}}get length(){var t;return null!==(t=this.get_length())&&void 0!==t?t:0}clear(){const t={};for(const e of this.columns())t[e]=new this.data[e].constructor(0);this.data=t}}n.ColumnarDataSource=m,m.__name__=\"ColumnarDataSource\",m.init_ColumnarDataSource()},\n",
" function _(e,t,c,n,a){n();const o=e(53),i=e(59);class s extends o.Model{constructor(e){super(e)}static init_DataSource(){this.define((({Ref:e})=>({selected:[e(i.Selection),()=>new i.Selection]})))}}c.DataSource=s,s.__name__=\"DataSource\",s.init_DataSource()},\n",
" function _(i,e,s,t,n){t();const l=i(53),c=i(9),h=i(13);class d extends l.Model{constructor(i){super(i)}get_view(){return this.view}static init_Selection(){this.define((({Int:i,Array:e,Dict:s})=>({indices:[e(i),[]],line_indices:[e(i),[]],multiline_indices:[s(e(i)),{}]}))),this.internal((({Int:i,Array:e,AnyRef:s,Struct:t,Nullable:n})=>({selected_glyphs:[e(s()),[]],view:[n(s()),null],image_indices:[e(t({index:i,dim1:i,dim2:i,flat_index:i})),[]]})))}get selected_glyph(){return this.selected_glyphs.length>0?this.selected_glyphs[0]:null}add_to_selected_glyphs(i){this.selected_glyphs.push(i)}update(i,e=!0,s=\"replace\"){switch(s){case\"replace\":this.indices=i.indices,this.line_indices=i.line_indices,this.selected_glyphs=i.selected_glyphs,this.view=i.view,this.multiline_indices=i.multiline_indices,this.image_indices=i.image_indices;break;case\"append\":this.update_through_union(i);break;case\"intersect\":this.update_through_intersection(i);break;case\"subtract\":this.update_through_subtraction(i)}}clear(){this.indices=[],this.line_indices=[],this.multiline_indices={},this.view=null,this.selected_glyphs=[]}is_empty(){return 0==this.indices.length&&0==this.line_indices.length&&0==this.image_indices.length}update_through_union(i){this.indices=c.union(this.indices,i.indices),this.selected_glyphs=c.union(i.selected_glyphs,this.selected_glyphs),this.line_indices=c.union(i.line_indices,this.line_indices),this.view=i.view,this.multiline_indices=h.merge(i.multiline_indices,this.multiline_indices)}update_through_intersection(i){this.indices=c.intersection(this.indices,i.indices),this.selected_glyphs=c.union(i.selected_glyphs,this.selected_glyphs),this.line_indices=c.union(i.line_indices,this.line_indices),this.view=i.view,this.multiline_indices=h.merge(i.multiline_indices,this.multiline_indices)}update_through_subtraction(i){this.indices=c.difference(this.indices,i.indices),this.selected_glyphs=c.union(i.selected_glyphs,this.selected_glyphs),this.line_indices=c.union(i.line_indices,this.line_indices),this.view=i.view,this.multiline_indices=h.merge(i.multiline_indices,this.multiline_indices)}}s.Selection=d,d.__name__=\"Selection\",d.init_Selection()},\n",
" function _(e,t,s,n,i){n();const o=e(14),c=e(59),r=e(61),l=e(123);class p extends o.HasProps{constructor(e){super(e),this.inspectors=new Map}static init_SelectionManager(){this.internal((({AnyRef:e})=>({source:[e()]})))}select(e,t,s,n=\"replace\"){const i=[],o=[];for(const t of e)t instanceof r.GlyphRendererView?i.push(t):t instanceof l.GraphRendererView&&o.push(t);let c=!1;for(const e of o){const i=e.model.selection_policy.hit_test(t,e);c=c||e.model.selection_policy.do_selection(i,e.model,s,n)}if(i.length>0){const e=this.source.selection_policy.hit_test(t,i);c=c||this.source.selection_policy.do_selection(e,this.source,s,n)}return c}inspect(e,t){let s=!1;if(e instanceof r.GlyphRendererView){const n=e.hit_test(t);if(null!=n){s=!n.is_empty();const i=this.get_or_create_inspector(e.model);i.update(n,!0,\"replace\"),this.source.setv({inspected:i},{silent:!0}),this.source.inspect.emit([e.model,{geometry:t}])}}else if(e instanceof l.GraphRendererView){const n=e.model.inspection_policy.hit_test(t,e);s=s||e.model.inspection_policy.do_inspection(n,t,e,!1,\"replace\")}return s}clear(e){this.source.selected.clear(),null!=e&&this.get_or_create_inspector(e.model).clear()}get_or_create_inspector(e){let t=this.inspectors.get(e);return null==t&&(t=new c.Selection,this.inspectors.set(e,t)),t}}s.SelectionManager=p,p.__name__=\"SelectionManager\",p.init_SelectionManager()},\n",
" function _(e,t,i,s,l){s();const h=e(62),n=e(63),o=e(116),a=e(117),c=e(119),d=e(98),_=e(57),r=e(120),p=e(24),g=e(12),u=e(9),y=e(13),m=e(122),v=e(104),f={fill:{},line:{}},w={fill:{fill_alpha:.3,fill_color:\"grey\"},line:{line_alpha:.3,line_color:\"grey\"}},b={fill:{fill_alpha:.2},line:{}};class V extends h.DataRendererView{get glyph_view(){return this.glyph}async lazy_initialize(){var e,t;await super.lazy_initialize();const i=this.model.glyph;this.glyph=await this.build_glyph_view(i);const s=\"fill\"in this.glyph.visuals,l=\"line\"in this.glyph.visuals,h=Object.assign({},i.attributes);function n(e){const t=y.clone(h);return s&&y.extend(t,e.fill),l&&y.extend(t,e.line),new i.constructor(t)}delete h.id;let{selection_glyph:o}=this.model;null==o?o=n({fill:{},line:{}}):\"auto\"==o&&(o=n(f)),this.selection_glyph=await this.build_glyph_view(o);let{nonselection_glyph:a}=this.model;null==a?a=n({fill:{},line:{}}):\"auto\"==a&&(a=n(b)),this.nonselection_glyph=await this.build_glyph_view(a);const{hover_glyph:c}=this.model;null!=c&&(this.hover_glyph=await this.build_glyph_view(c));const{muted_glyph:d}=this.model;null!=d&&(this.muted_glyph=await this.build_glyph_view(d));const _=n(w);this.decimated_glyph=await this.build_glyph_view(_),this.selection_glyph.set_base(this.glyph),this.nonselection_glyph.set_base(this.glyph),null===(e=this.hover_glyph)||void 0===e||e.set_base(this.glyph),null===(t=this.muted_glyph)||void 0===t||t.set_base(this.glyph),this.decimated_glyph.set_base(this.glyph),this.set_data()}async build_glyph_view(e){return m.build_view(e,{parent:this})}remove(){var e,t;this.glyph.remove(),this.selection_glyph.remove(),this.nonselection_glyph.remove(),null===(e=this.hover_glyph)||void 0===e||e.remove(),null===(t=this.muted_glyph)||void 0===t||t.remove(),this.decimated_glyph.remove(),super.remove()}connect_signals(){super.connect_signals();const e=()=>this.request_render(),t=()=>this.update_data();this.connect(this.model.change,e),this.connect(this.glyph.model.change,t),this.connect(this.selection_glyph.model.change,t),this.connect(this.nonselection_glyph.model.change,t),null!=this.hover_glyph&&this.connect(this.hover_glyph.model.change,t),null!=this.muted_glyph&&this.connect(this.muted_glyph.model.change,t),this.connect(this.decimated_glyph.model.change,t),this.connect(this.model.data_source.change,t),this.connect(this.model.data_source.streaming,t),this.connect(this.model.data_source.patching,(e=>this.update_data(e))),this.connect(this.model.data_source.selected.change,e),this.connect(this.model.data_source._select,e),null!=this.hover_glyph&&this.connect(this.model.data_source.inspect,e),this.connect(this.model.properties.view.change,t),this.connect(this.model.view.properties.indices.change,t),this.connect(this.model.view.properties.masked.change,(()=>this.set_visuals())),this.connect(this.model.properties.visible.change,(()=>this.plot_view.invalidate_dataranges=!0));const{x_ranges:i,y_ranges:s}=this.plot_view.frame;for(const[,e]of i)e instanceof v.FactorRange&&this.connect(e.change,t);for(const[,e]of s)e instanceof v.FactorRange&&this.connect(e.change,t);const{transformchange:l,exprchange:h}=this.model.glyph;this.connect(l,t),this.connect(h,t)}_update_masked_indices(){const e=this.glyph.mask_data();return this.model.view.masked=e,e}update_data(e){this.set_data(e),this.request_render()}set_data(e){const t=this.model.data_source;this.all_indices=this.model.view.indices;const{all_indices:i}=this;this.glyph.set_data(t,i,e),this.set_visuals(),this._update_masked_indices();const{lod_factor:s}=this.plot_model,l=this.all_indices.count;this.decimated=new p.Indices(l);for(let e=0;e<l;e+=s)this.decimated.set(e);this.plot_view.invalidate_dataranges=!0}set_visuals(){var e,t,i,s;const l=this.model.data_source,{all_indices:h}=this;this.glyph.set_visuals(l,h),this.decimated_glyph.set_visuals(l,h),null===(e=this.selection_glyph)||void 0===e||e.set_visuals(l,h),null===(t=this.nonselection_glyph)||void 0===t||t.set_visuals(l,h),null===(i=this.hover_glyph)||void 0===i||i.set_visuals(l,h),null===(s=this.muted_glyph)||void 0===s||s.set_visuals(l,h)}get has_webgl(){return this.glyph.has_webgl}_render(){const e=this.has_webgl;this.glyph.map_data();const t=[...this.all_indices];let i=[...this._update_masked_indices()];const{ctx:s}=this.layer;s.save();const{selected:l}=this.model.data_source;let h;h=!l||l.is_empty()?[]:this.glyph instanceof n.LineView&&l.selected_glyph===this.glyph.model?this.model.view.convert_indices_from_subset(i):l.indices;const{inspected:d}=this.model.data_source,_=new Set((()=>!d||d.is_empty()?[]:d.selected_glyph?this.model.view.convert_indices_from_subset(i):d.indices.length>0?d.indices:Object.keys(d.multiline_indices).map((e=>parseInt(e))))()),r=g.filter(i,(e=>_.has(t[e]))),{lod_threshold:p}=this.plot_model;let y,m,v;if(null!=this.model.document&&this.model.document.interactive_duration()>0&&!e&&null!=p&&t.length>p?(i=[...this.decimated],y=this.decimated_glyph,m=this.decimated_glyph,v=this.selection_glyph):(y=this.model.muted&&null!=this.muted_glyph?this.muted_glyph:this.glyph,m=this.nonselection_glyph,v=this.selection_glyph),null!=this.hover_glyph&&r.length&&(i=u.difference(i,r)),h.length){const e={};for(const t of h)e[t]=!0;const l=new Array,o=new Array;if(this.glyph instanceof n.LineView)for(const i of t)null!=e[i]?l.push(i):o.push(i);else for(const s of i)null!=e[t[s]]?l.push(s):o.push(s);m.render(s,o),v.render(s,l),null!=this.hover_glyph&&(this.glyph instanceof n.LineView?this.hover_glyph.render(s,this.model.view.convert_indices_from_subset(r)):this.hover_glyph.render(s,r))}else if(this.glyph instanceof n.LineView)this.hover_glyph&&r.length?this.hover_glyph.render(s,this.model.view.convert_indices_from_subset(r)):y.render(s,t);else if(this.glyph instanceof o.PatchView||this.glyph instanceof a.HAreaView||this.glyph instanceof c.VAreaView)if(0==d.selected_glyphs.length||null==this.hover_glyph)y.render(s,t);else for(const e of d.selected_glyphs)e==this.glyph.model&&this.hover_glyph.render(s,t);else y.render(s,i),this.hover_glyph&&r.length&&this.hover_glyph.render(s,r);s.restore()}draw_legend(e,t,i,s,l,h,n,o){0!=this.glyph.data_size&&(null==o&&(o=this.model.get_reference_point(h,n)),this.glyph.draw_legend_for_index(e,{x0:t,x1:i,y0:s,y1:l},o))}hit_test(e){if(!this.model.visible)return null;const t=this.glyph.hit_test(e);return null==t?null:this.model.view.convert_selection_from_subset(t)}}i.GlyphRendererView=V,V.__name__=\"GlyphRendererView\";class G extends h.DataRenderer{constructor(e){super(e)}static init_GlyphRenderer(){this.prototype.default_view=V,this.define((({Boolean:e,Auto:t,Or:i,Ref:s,Null:l,Nullable:h})=>({data_source:[s(_.ColumnarDataSource)],view:[s(r.CDSView),e=>new r.CDSView({source:e.data_source})],glyph:[s(d.Glyph)],hover_glyph:[h(s(d.Glyph)),null],nonselection_glyph:[i(s(d.Glyph),t,l),\"auto\"],selection_glyph:[i(s(d.Glyph),t,l),\"auto\"],muted_glyph:[h(s(d.Glyph)),null],muted:[e,!1]})))}initialize(){super.initialize(),this.view.source!=this.data_source&&(this.view.source=this.data_source,this.view.compute_indices())}get_reference_point(e,t){if(null!=e){const i=this.data_source.get_column(e);if(null!=i)for(const[e,s]of Object.entries(this.view.indices_map))if(i[parseInt(e)]==t)return s}return 0}get_selection_manager(){return this.data_source.selection_manager}}i.GlyphRenderer=G,G.__name__=\"GlyphRenderer\",G.init_GlyphRenderer()},\n",
" function _(e,r,t,a,n){a();const s=e(41);class i extends s.RendererView{get xscale(){return this.coordinates.x_scale}get yscale(){return this.coordinates.y_scale}}t.DataRendererView=i,i.__name__=\"DataRendererView\";class _ extends s.Renderer{constructor(e){super(e)}static init_DataRenderer(){this.override({level:\"glyph\"})}get selection_manager(){return this.get_selection_manager()}}t.DataRenderer=_,_.__name__=\"DataRenderer\",_.init_DataRenderer()},\n",
" function _(e,i,t,s,n){s();const l=e(1),_=e(64),r=e(106),h=e(108),o=l.__importStar(e(48)),a=l.__importStar(e(107)),c=e(59);class d extends _.XYGlyphView{initialize(){super.initialize();const{webgl:e}=this.renderer.plot_view.canvas_view;null!=e&&(this.glglyph=new h.LineGL(e.gl,this))}_render(e,i,t){const{sx:s,sy:n}=null!=t?t:this;let l=!0;e.beginPath();for(const t of i){const i=s[t],_=n[t];isFinite(i+_)?l?(e.moveTo(i,_),l=!1):e.lineTo(i,_):l=!0}this.visuals.line.set_value(e),e.stroke()}_hit_point(e){const i=new c.Selection,t={x:e.sx,y:e.sy};let s=9999;const n=Math.max(2,this.line_width.value/2);for(let e=0,l=this.sx.length-1;e<l;e++){const l={x:this.sx[e],y:this.sy[e]},_={x:this.sx[e+1],y:this.sy[e+1]},r=a.dist_to_segment(t,l,_);r<n&&r<s&&(s=r,i.add_to_selected_glyphs(this.model),i.view=this,i.line_indices=[e])}return i}_hit_span(e){const{sx:i,sy:t}=e,s=new c.Selection;let n,l;\"v\"==e.direction?(n=this.renderer.yscale.invert(t),l=this._y):(n=this.renderer.xscale.invert(i),l=this._x);for(let e=0,i=l.length-1;e<i;e++)(l[e]<=n&&n<=l[e+1]||l[e+1]<=n&&n<=l[e])&&(s.add_to_selected_glyphs(this.model),s.view=this,s.line_indices.push(e));return s}get_interpolation_hit(e,i){const[t,s,n,l]=[this._x[e],this._y[e],this._x[e+1],this._y[e+1]];return r.line_interpolation(this.renderer,i,t,s,n,l)}draw_legend_for_index(e,i,t){r.generic_line_scalar_legend(this.visuals,e,i)}}t.LineView=d,d.__name__=\"LineView\";class x extends _.XYGlyph{constructor(e){super(e)}static init_Line(){this.prototype.default_view=d,this.mixins(o.LineScalar)}}t.Line=x,x.__name__=\"Line\",x.init_Line()},\n",
" function _(t,e,i,s,_){s();const n=t(1),a=t(65),p=n.__importStar(t(18)),y=t(98);class c extends y.GlyphView{_project_data(){a.inplace.project_xy(this._x,this._y)}_index_data(t){const{_x:e,_y:i,data_size:s}=this;for(let _=0;_<s;_++){const s=e[_],n=i[_];isNaN(s+n)||!isFinite(s+n)?t.add_empty():t.add(s,n,s,n)}}scenterxy(t){return[this.sx[t],this.sy[t]]}}i.XYGlyphView=c,c.__name__=\"XYGlyphView\";class d extends y.Glyph{constructor(t){super(t)}static init_XYGlyph(){this.define((({})=>({x:[p.XCoordinateSpec,{field:\"x\"}],y:[p.YCoordinateSpec,{field:\"y\"}]})))}}i.XYGlyph=d,d.__name__=\"XYGlyph\",d.init_XYGlyph()},\n",
" function _(n,t,e,o,r){o();const c=n(1),l=c.__importDefault(n(66)),i=c.__importDefault(n(67)),u=n(24),a=new i.default(\"GOOGLE\"),s=new i.default(\"WGS84\"),f=l.default(s,a);e.wgs84_mercator={compute:(n,t)=>isFinite(n)&&isFinite(t)?f.forward([n,t]):[NaN,NaN],invert:(n,t)=>isFinite(n)&&isFinite(t)?f.inverse([n,t]):[NaN,NaN]};const _={lon:[-20026376.39,20026376.39],lat:[-20048966.1,20048966.1]},p={lon:[-180,180],lat:[-85.06,85.06]},{min:g,max:h}=Math;function m(n,t){const o=g(n.length,t.length),r=u.infer_type(n,t),c=new r(o),l=new r(o);return e.inplace.project_xy(n,t,c,l),[c,l]}e.clip_mercator=function(n,t,e){const[o,r]=_[e];return[h(n,o),g(t,r)]},e.in_bounds=function(n,t){const[e,o]=p[t];return e<n&&n<o},function(n){function t(n,t,o,r){const c=g(n.length,t.length);o=null!=o?o:n,r=null!=r?r:t;for(let l=0;l<c;l++){const c=n[l],i=t[l],[u,a]=e.wgs84_mercator.compute(c,i);o[l]=u,r[l]=a}}n.project_xy=t,n.project_xsys=function(n,e,o,r){const c=g(n.length,e.length);o=null!=o?o:n,r=null!=r?r:e;for(let l=0;l<c;l++)t(n[l],e[l],o[l],r[l])}}(e.inplace||(e.inplace={})),e.project_xy=m,e.project_xsys=function(n,t){const e=g(n.length,t.length),o=new Array(e),r=new Array(e);for(let c=0;c<e;c++){const[e,l]=m(n[c],t[c]);o[c]=e,r[c]=l}return[o,r]}},\n",
" function _(e,n,t,r,o){r();const a=e(1),i=a.__importDefault(e(67)),c=a.__importDefault(e(92));var u=i.default(\"WGS84\");function f(e,n,t){var r,o,a;return Array.isArray(t)?(r=c.default(e,n,t)||{x:NaN,y:NaN},t.length>2?void 0!==e.name&&\"geocent\"===e.name||void 0!==n.name&&\"geocent\"===n.name?\"number\"==typeof r.z?[r.x,r.y,r.z].concat(t.splice(3)):[r.x,r.y,t[2]].concat(t.splice(3)):[r.x,r.y].concat(t.splice(2)):[r.x,r.y]):(o=c.default(e,n,t),2===(a=Object.keys(t)).length||a.forEach((function(r){if(void 0!==e.name&&\"geocent\"===e.name||void 0!==n.name&&\"geocent\"===n.name){if(\"x\"===r||\"y\"===r||\"z\"===r)return}else if(\"x\"===r||\"y\"===r)return;o[r]=t[r]})),o)}function l(e){return e instanceof i.default?e:e.oProj?e.oProj:i.default(e)}t.default=function(e,n,t){e=l(e);var r,o=!1;return void 0===n?(n=e,e=u,o=!0):(void 0!==n.x||Array.isArray(n))&&(t=n,n=e,e=u,o=!0),n=l(n),t?f(e,n,t):(r={forward:function(t){return f(e,n,t)},inverse:function(t){return f(n,e,t)}},o&&(r.oProj=n),r)}},\n",
" function _(t,e,a,s,i){s();const u=t(1),l=u.__importDefault(t(68)),o=u.__importDefault(t(79)),r=u.__importDefault(t(80)),f=t(88),p=u.__importDefault(t(90)),d=u.__importDefault(t(91)),m=u.__importDefault(t(75));function n(t,e){if(!(this instanceof n))return new n(t);e=e||function(t){if(t)throw t};var a=l.default(t);if(\"object\"==typeof a){var s=n.projections.get(a.projName);if(s){if(a.datumCode&&\"none\"!==a.datumCode){var i=m.default(p.default,a.datumCode);i&&(a.datum_params=i.towgs84?i.towgs84.split(\",\"):null,a.ellps=i.ellipse,a.datumName=i.datumName?i.datumName:a.datumCode)}a.k0=a.k0||1,a.axis=a.axis||\"enu\",a.ellps=a.ellps||\"wgs84\";var u=f.sphere(a.a,a.b,a.rf,a.ellps,a.sphere),r=f.eccentricity(u.a,u.b,u.rf,a.R_A),h=a.datum||d.default(a.datumCode,a.datum_params,u.a,u.b,r.es,r.ep2);o.default(this,a),o.default(this,s),this.a=u.a,this.b=u.b,this.rf=u.rf,this.sphere=u.sphere,this.es=r.es,this.e=r.e,this.ep2=r.ep2,this.datum=h,this.init(),e(null,this)}else e(t)}else e(t)}n.projections=r.default,n.projections.start(),a.default=n},\n",
" function _(t,r,n,u,e){u();const f=t(1),i=f.__importDefault(t(69)),a=f.__importDefault(t(76)),o=f.__importDefault(t(71)),l=f.__importDefault(t(75));var C=[\"PROJECTEDCRS\",\"PROJCRS\",\"GEOGCS\",\"GEOCCS\",\"PROJCS\",\"LOCAL_CS\",\"GEODCRS\",\"GEODETICCRS\",\"GEODETICDATUM\",\"ENGCRS\",\"ENGINEERINGCRS\"];var d=[\"3857\",\"900913\",\"3785\",\"102113\"];n.default=function(t){if(!function(t){return\"string\"==typeof t}(t))return t;if(function(t){return t in i.default}(t))return i.default[t];if(function(t){return C.some((function(r){return t.indexOf(r)>-1}))}(t)){var r=a.default(t);if(function(t){var r=l.default(t,\"authority\");if(r){var n=l.default(r,\"epsg\");return n&&d.indexOf(n)>-1}}(r))return i.default[\"EPSG:3857\"];var n=function(t){var r=l.default(t,\"extension\");if(r)return l.default(r,\"proj4\")}(r);return n?o.default(n):r}return function(t){return\"+\"===t[0]}(t)?o.default(t):void 0}},\n",
" function _(t,r,i,e,n){e();const f=t(1),a=f.__importDefault(t(70)),l=f.__importDefault(t(71)),u=f.__importDefault(t(76));function o(t){var r=this;if(2===arguments.length){var i=arguments[1];\"string\"==typeof i?\"+\"===i.charAt(0)?o[t]=l.default(arguments[1]):o[t]=u.default(arguments[1]):o[t]=i}else if(1===arguments.length){if(Array.isArray(t))return t.map((function(t){Array.isArray(t)?o.apply(r,t):o(t)}));if(\"string\"==typeof t){if(t in o)return o[t]}else\"EPSG\"in t?o[\"EPSG:\"+t.EPSG]=t:\"ESRI\"in t?o[\"ESRI:\"+t.ESRI]=t:\"IAU2000\"in t?o[\"IAU2000:\"+t.IAU2000]=t:console.log(t);return}}a.default(o),i.default=o},\n",
" function _(t,l,G,S,e){S(),G.default=function(t){t(\"EPSG:4326\",\"+title=WGS 84 (long/lat) +proj=longlat +ellps=WGS84 +datum=WGS84 +units=degrees\"),t(\"EPSG:4269\",\"+title=NAD83 (long/lat) +proj=longlat +a=6378137.0 +b=6356752.31414036 +ellps=GRS80 +datum=NAD83 +units=degrees\"),t(\"EPSG:3857\",\"+title=WGS 84 / Pseudo-Mercator +proj=merc +a=6378137 +b=6378137 +lat_ts=0.0 +lon_0=0.0 +x_0=0.0 +y_0=0 +k=1.0 +units=m +nadgrids=@null +no_defs\"),t.WGS84=t[\"EPSG:4326\"],t[\"EPSG:3785\"]=t[\"EPSG:3857\"],t.GOOGLE=t[\"EPSG:3857\"],t[\"EPSG:900913\"]=t[\"EPSG:3857\"],t[\"EPSG:102113\"]=t[\"EPSG:3857\"]}},\n",
" function _(t,n,o,a,u){a();const e=t(1),r=t(72),i=e.__importDefault(t(73)),f=e.__importDefault(t(74)),l=e.__importDefault(t(75));o.default=function(t){var n,o,a,u={},e=t.split(\"+\").map((function(t){return t.trim()})).filter((function(t){return t})).reduce((function(t,n){var o=n.split(\"=\");return o.push(!0),t[o[0].toLowerCase()]=o[1],t}),{}),c={proj:\"projName\",datum:\"datumCode\",rf:function(t){u.rf=parseFloat(t)},lat_0:function(t){u.lat0=t*r.D2R},lat_1:function(t){u.lat1=t*r.D2R},lat_2:function(t){u.lat2=t*r.D2R},lat_ts:function(t){u.lat_ts=t*r.D2R},lon_0:function(t){u.long0=t*r.D2R},lon_1:function(t){u.long1=t*r.D2R},lon_2:function(t){u.long2=t*r.D2R},alpha:function(t){u.alpha=parseFloat(t)*r.D2R},lonc:function(t){u.longc=t*r.D2R},x_0:function(t){u.x0=parseFloat(t)},y_0:function(t){u.y0=parseFloat(t)},k_0:function(t){u.k0=parseFloat(t)},k:function(t){u.k0=parseFloat(t)},a:function(t){u.a=parseFloat(t)},b:function(t){u.b=parseFloat(t)},r_a:function(){u.R_A=!0},zone:function(t){u.zone=parseInt(t,10)},south:function(){u.utmSouth=!0},towgs84:function(t){u.datum_params=t.split(\",\").map((function(t){return parseFloat(t)}))},to_meter:function(t){u.to_meter=parseFloat(t)},units:function(t){u.units=t;var n=l.default(f.default,t);n&&(u.to_meter=n.to_meter)},from_greenwich:function(t){u.from_greenwich=t*r.D2R},pm:function(t){var n=l.default(i.default,t);u.from_greenwich=(n||parseFloat(t))*r.D2R},nadgrids:function(t){\"@null\"===t?u.datumCode=\"none\":u.nadgrids=t},axis:function(t){var n=\"ewnsud\";3===t.length&&-1!==n.indexOf(t.substr(0,1))&&-1!==n.indexOf(t.substr(1,1))&&-1!==n.indexOf(t.substr(2,1))&&(u.axis=t)}};for(n in e)o=e[n],n in c?\"function\"==typeof(a=c[n])?a(o):u[a]=o:u[n]=o;return\"string\"==typeof u.datumCode&&\"WGS84\"!==u.datumCode&&(u.datumCode=u.datumCode.toLowerCase()),u}},\n",
" function _(P,A,_,D,I){D(),_.PJD_3PARAM=1,_.PJD_7PARAM=2,_.PJD_WGS84=4,_.PJD_NODATUM=5,_.SEC_TO_RAD=484813681109536e-20,_.HALF_PI=Math.PI/2,_.SIXTH=.16666666666666666,_.RA4=.04722222222222222,_.RA6=.022156084656084655,_.EPSLN=1e-10,_.D2R=.017453292519943295,_.R2D=57.29577951308232,_.FORTPI=Math.PI/4,_.TWO_PI=2*Math.PI,_.SPI=3.14159265359},\n",
" function _(o,r,a,e,s){e();var n={};a.default=n,n.greenwich=0,n.lisbon=-9.131906111111,n.paris=2.337229166667,n.bogota=-74.080916666667,n.madrid=-3.687938888889,n.rome=12.452333333333,n.bern=7.439583333333,n.jakarta=106.807719444444,n.ferro=-17.666666666667,n.brussels=4.367975,n.stockholm=18.058277777778,n.athens=23.7163375,n.oslo=10.722916666667},\n",
" function _(t,e,f,o,u){o(),f.default={ft:{to_meter:.3048},\"us-ft\":{to_meter:1200/3937}}},\n",
" function _(e,r,t,a,n){a();var o=/[\\s_\\-\\/\\(\\)]/g;t.default=function(e,r){if(e[r])return e[r];for(var t,a=Object.keys(e),n=r.toLowerCase().replace(o,\"\"),f=-1;++f<a.length;)if((t=a[f]).toLowerCase().replace(o,\"\")===n)return e[t]}},\n",
" function _(e,t,a,o,d){o();const r=e(1);const n=r.__importDefault(e(77)),l=e(78);function i(e){return.017453292519943295*e}a.default=function(e){var t=n.default(e),a=t.shift(),o=t.shift();t.unshift([\"name\",o]),t.unshift([\"type\",a]);var d={};return l.sExpr(t,d),function(e){if(\"GEOGCS\"===e.type?e.projName=\"longlat\":\"LOCAL_CS\"===e.type?(e.projName=\"identity\",e.local=!0):\"object\"==typeof e.PROJECTION?e.projName=Object.keys(e.PROJECTION)[0]:e.projName=e.PROJECTION,e.AXIS){for(var t=\"\",a=0,o=e.AXIS.length;a<o;++a){var d=e.AXIS[a][0].toLowerCase();-1!==d.indexOf(\"north\")?t+=\"n\":-1!==d.indexOf(\"south\")?t+=\"s\":-1!==d.indexOf(\"east\")?t+=\"e\":-1!==d.indexOf(\"west\")&&(t+=\"w\")}2===t.length&&(t+=\"u\"),3===t.length&&(e.axis=t)}e.UNIT&&(e.units=e.UNIT.name.toLowerCase(),\"metre\"===e.units&&(e.units=\"meter\"),e.UNIT.convert&&(\"GEOGCS\"===e.type?e.DATUM&&e.DATUM.SPHEROID&&(e.to_meter=e.UNIT.convert*e.DATUM.SPHEROID.a):e.to_meter=e.UNIT.convert));var r=e.GEOGCS;function n(t){return t*(e.to_meter||1)}\"GEOGCS\"===e.type&&(r=e),r&&(r.DATUM?e.datumCode=r.DATUM.name.toLowerCase():e.datumCode=r.name.toLowerCase(),\"d_\"===e.datumCode.slice(0,2)&&(e.datumCode=e.datumCode.slice(2)),\"new_zealand_geodetic_datum_1949\"!==e.datumCode&&\"new_zealand_1949\"!==e.datumCode||(e.datumCode=\"nzgd49\"),\"wgs_1984\"!==e.datumCode&&\"world_geodetic_system_1984\"!==e.datumCode||(\"Mercator_Auxiliary_Sphere\"===e.PROJECTION&&(e.sphere=!0),e.datumCode=\"wgs84\"),\"_ferro\"===e.datumCode.slice(-6)&&(e.datumCode=e.datumCode.slice(0,-6)),\"_jakarta\"===e.datumCode.slice(-8)&&(e.datumCode=e.datumCode.slice(0,-8)),~e.datumCode.indexOf(\"belge\")&&(e.datumCode=\"rnb72\"),r.DATUM&&r.DATUM.SPHEROID&&(e.ellps=r.DATUM.SPHEROID.name.replace(\"_19\",\"\").replace(/[Cc]larke\\_18/,\"clrk\"),\"international\"===e.ellps.toLowerCase().slice(0,13)&&(e.ellps=\"intl\"),e.a=r.DATUM.SPHEROID.a,e.rf=parseFloat(r.DATUM.SPHEROID.rf,10)),r.DATUM&&r.DATUM.TOWGS84&&(e.datum_params=r.DATUM.TOWGS84),~e.datumCode.indexOf(\"osgb_1936\")&&(e.datumCode=\"osgb36\"),~e.datumCode.indexOf(\"osni_1952\")&&(e.datumCode=\"osni52\"),(~e.datumCode.indexOf(\"tm65\")||~e.datumCode.indexOf(\"geodetic_datum_of_1965\"))&&(e.datumCode=\"ire65\"),\"ch1903+\"===e.datumCode&&(e.datumCode=\"ch1903\"),~e.datumCode.indexOf(\"israel\")&&(e.datumCode=\"isr93\")),e.b&&!isFinite(e.b)&&(e.b=e.a),[[\"standard_parallel_1\",\"Standard_Parallel_1\"],[\"standard_parallel_2\",\"Standard_Parallel_2\"],[\"false_easting\",\"False_Easting\"],[\"false_northing\",\"False_Northing\"],[\"central_meridian\",\"Central_Meridian\"],[\"latitude_of_origin\",\"Latitude_Of_Origin\"],[\"latitude_of_origin\",\"Central_Parallel\"],[\"scale_factor\",\"Scale_Factor\"],[\"k0\",\"scale_factor\"],[\"latitude_of_center\",\"Latitude_Of_Center\"],[\"latitude_of_center\",\"Latitude_of_center\"],[\"lat0\",\"latitude_of_center\",i],[\"longitude_of_center\",\"Longitude_Of_Center\"],[\"longitude_of_center\",\"Longitude_of_center\"],[\"longc\",\"longitude_of_center\",i],[\"x0\",\"false_easting\",n],[\"y0\",\"false_northing\",n],[\"long0\",\"central_meridian\",i],[\"lat0\",\"latitude_of_origin\",i],[\"lat0\",\"standard_parallel_1\",i],[\"lat1\",\"standard_parallel_1\",i],[\"lat2\",\"standard_parallel_2\",i],[\"azimuth\",\"Azimuth\"],[\"alpha\",\"azimuth\",i],[\"srsCode\",\"name\"]].forEach((function(t){return a=e,d=(o=t)[0],r=o[1],void(!(d in a)&&r in a&&(a[d]=a[r],3===o.length&&(a[d]=o[2](a[d]))));var a,o,d,r})),e.long0||!e.longc||\"Albers_Conic_Equal_Area\"!==e.projName&&\"Lambert_Azimuthal_Equal_Area\"!==e.projName||(e.long0=e.longc),e.lat_ts||!e.lat1||\"Stereographic_South_Pole\"!==e.projName&&\"Polar Stereographic (variant B)\"!==e.projName||(e.lat0=i(e.lat1>0?90:-90),e.lat_ts=e.lat1)}(d),d}},\n",
" function _(t,e,r,i,s){i(),r.default=function(t){return new d(t).output()};var h=/\\s/,o=/[A-Za-z]/,n=/[A-Za-z84]/,a=/[,\\]]/,u=/[\\d\\.E\\-\\+]/;function d(t){if(\"string\"!=typeof t)throw new Error(\"not a string\");this.text=t.trim(),this.level=0,this.place=0,this.root=null,this.stack=[],this.currentObject=null,this.state=1}d.prototype.readCharicter=function(){var t=this.text[this.place++];if(4!==this.state)for(;h.test(t);){if(this.place>=this.text.length)return;t=this.text[this.place++]}switch(this.state){case 1:return this.neutral(t);case 2:return this.keyword(t);case 4:return this.quoted(t);case 5:return this.afterquote(t);case 3:return this.number(t);case-1:return}},d.prototype.afterquote=function(t){if('\"'===t)return this.word+='\"',void(this.state=4);if(a.test(t))return this.word=this.word.trim(),void this.afterItem(t);throw new Error(\"havn't handled \\\"\"+t+'\" in afterquote yet, index '+this.place)},d.prototype.afterItem=function(t){return\",\"===t?(null!==this.word&&this.currentObject.push(this.word),this.word=null,void(this.state=1)):\"]\"===t?(this.level--,null!==this.word&&(this.currentObject.push(this.word),this.word=null),this.state=1,this.currentObject=this.stack.pop(),void(this.currentObject||(this.state=-1))):void 0},d.prototype.number=function(t){if(!u.test(t)){if(a.test(t))return this.word=parseFloat(this.word),void this.afterItem(t);throw new Error(\"havn't handled \\\"\"+t+'\" in number yet, index '+this.place)}this.word+=t},d.prototype.quoted=function(t){'\"'!==t?this.word+=t:this.state=5},d.prototype.keyword=function(t){if(n.test(t))this.word+=t;else{if(\"[\"===t){var e=[];return e.push(this.word),this.level++,null===this.root?this.root=e:this.currentObject.push(e),this.stack.push(this.currentObject),this.currentObject=e,void(this.state=1)}if(!a.test(t))throw new Error(\"havn't handled \\\"\"+t+'\" in keyword yet, index '+this.place);this.afterItem(t)}},d.prototype.neutral=function(t){if(o.test(t))return this.word=t,void(this.state=2);if('\"'===t)return this.word=\"\",void(this.state=4);if(u.test(t))return this.word=t,void(this.state=3);if(!a.test(t))throw new Error(\"havn't handled \\\"\"+t+'\" in neutral yet, index '+this.place);this.afterItem(t)},d.prototype.output=function(){for(;this.place<this.text.length;)this.readCharicter();if(-1===this.state)return this.root;throw new Error('unable to parse string \"'+this.text+'\". State is '+this.state)}},\n",
" function _(e,a,r,s,c){function n(e,a,r){Array.isArray(a)&&(r.unshift(a),a=null);var s=a?{}:e,c=r.reduce((function(e,a){return E(a,e),e}),s);a&&(e[a]=c)}function E(e,a){if(Array.isArray(e)){var r=e.shift();if(\"PARAMETER\"===r&&(r=e.shift()),1===e.length)return Array.isArray(e[0])?(a[r]={},void E(e[0],a[r])):void(a[r]=e[0]);if(e.length)if(\"TOWGS84\"!==r){if(\"AXIS\"===r)return r in a||(a[r]=[]),void a[r].push(e);var s;switch(Array.isArray(r)||(a[r]={}),r){case\"UNIT\":case\"PRIMEM\":case\"VERT_DATUM\":return a[r]={name:e[0].toLowerCase(),convert:e[1]},void(3===e.length&&E(e[2],a[r]));case\"SPHEROID\":case\"ELLIPSOID\":return a[r]={name:e[0],a:e[1],rf:e[2]},void(4===e.length&&E(e[3],a[r]));case\"PROJECTEDCRS\":case\"PROJCRS\":case\"GEOGCS\":case\"GEOCCS\":case\"PROJCS\":case\"LOCAL_CS\":case\"GEODCRS\":case\"GEODETICCRS\":case\"GEODETICDATUM\":case\"EDATUM\":case\"ENGINEERINGDATUM\":case\"VERT_CS\":case\"VERTCRS\":case\"VERTICALCRS\":case\"COMPD_CS\":case\"COMPOUNDCRS\":case\"ENGINEERINGCRS\":case\"ENGCRS\":case\"FITTED_CS\":case\"LOCAL_DATUM\":case\"DATUM\":return e[0]=[\"name\",e[0]],void n(a,r,e);default:for(s=-1;++s<e.length;)if(!Array.isArray(e[s]))return E(e,a[r]);return n(a,r,e)}}else a[r]=e;else a[r]=!0}else a[e]=!0}s(),r.sExpr=E},\n",
" function _(n,r,f,i,t){i(),f.default=function(n,r){var f,i;if(n=n||{},!r)return n;for(i in r)void 0!==(f=r[i])&&(n[i]=f);return n}},\n",
" function _(t,o,a,e,n){e();const r=t(1),f=r.__importDefault(t(81)),u=r.__importDefault(t(87));var i=[f.default,u.default],c={},d=[];function s(t,o){var a=d.length;return t.names?(d[a]=t,t.names.forEach((function(t){c[t.toLowerCase()]=a})),this):(console.log(o),!0)}function l(t){if(!t)return!1;var o=t.toLowerCase();return void 0!==c[o]&&d[c[o]]?d[c[o]]:void 0}function v(){i.forEach(s)}a.add=s,a.get=l,a.start=v,a.default={start:v,add:s,get:l}},\n",
" function _(t,i,s,h,a){h();const e=t(1),r=e.__importDefault(t(82)),n=e.__importDefault(t(83)),l=e.__importDefault(t(85)),u=e.__importDefault(t(86)),o=t(72);function f(){var t=this.b/this.a;this.es=1-t*t,\"x0\"in this||(this.x0=0),\"y0\"in this||(this.y0=0),this.e=Math.sqrt(this.es),this.lat_ts?this.sphere?this.k0=Math.cos(this.lat_ts):this.k0=r.default(this.e,Math.sin(this.lat_ts),Math.cos(this.lat_ts)):this.k0||(this.k?this.k0=this.k:this.k0=1)}function _(t){var i,s,h=t.x,a=t.y;if(a*o.R2D>90&&a*o.R2D<-90&&h*o.R2D>180&&h*o.R2D<-180)return null;if(Math.abs(Math.abs(a)-o.HALF_PI)<=o.EPSLN)return null;if(this.sphere)i=this.x0+this.a*this.k0*n.default(h-this.long0),s=this.y0+this.a*this.k0*Math.log(Math.tan(o.FORTPI+.5*a));else{var e=Math.sin(a),r=l.default(this.e,a,e);i=this.x0+this.a*this.k0*n.default(h-this.long0),s=this.y0-this.a*this.k0*Math.log(r)}return t.x=i,t.y=s,t}function M(t){var i,s,h=t.x-this.x0,a=t.y-this.y0;if(this.sphere)s=o.HALF_PI-2*Math.atan(Math.exp(-a/(this.a*this.k0)));else{var e=Math.exp(-a/(this.a*this.k0));if(-9999===(s=u.default(this.e,e)))return null}return i=n.default(this.long0+h/(this.a*this.k0)),t.x=i,t.y=s,t}s.init=f,s.forward=_,s.inverse=M,s.names=[\"Mercator\",\"Popular Visualisation Pseudo Mercator\",\"Mercator_1SP\",\"Mercator_Auxiliary_Sphere\",\"merc\"],s.default={init:f,forward:_,inverse:M,names:s.names}},\n",
" function _(t,n,r,u,a){u(),r.default=function(t,n,r){var u=t*n;return r/Math.sqrt(1-u*u)}},\n",
" function _(t,n,u,a,f){a();const e=t(1),o=t(72),_=e.__importDefault(t(84));u.default=function(t){return Math.abs(t)<=o.SPI?t:t-_.default(t)*o.TWO_PI}},\n",
" function _(n,t,u,f,c){f(),u.default=function(n){return n<0?-1:1}},\n",
" function _(t,n,a,o,u){o();const c=t(72);a.default=function(t,n,a){var o=t*a,u=.5*t;return o=Math.pow((1-o)/(1+o),u),Math.tan(.5*(c.HALF_PI-n))/o}},\n",
" function _(t,a,n,r,f){r();const h=t(72);n.default=function(t,a){for(var n,r,f=.5*t,o=h.HALF_PI-2*Math.atan(a),u=0;u<=15;u++)if(n=t*Math.sin(o),o+=r=h.HALF_PI-2*Math.atan(a*Math.pow((1-n)/(1+n),f))-o,Math.abs(r)<=1e-10)return o;return-9999}},\n",
" function _(n,i,e,t,r){function a(){}function f(n){return n}t(),e.init=a,e.forward=f,e.inverse=f,e.names=[\"longlat\",\"identity\"],e.default={init:a,forward:f,inverse:f,names:e.names}},\n",
" function _(t,r,e,a,n){a();const f=t(1),i=t(72),u=f.__importStar(t(89)),c=f.__importDefault(t(75));e.eccentricity=function(t,r,e,a){var n=t*t,f=r*r,u=(n-f)/n,c=0;return a?(n=(t*=1-u*(i.SIXTH+u*(i.RA4+u*i.RA6)))*t,u=0):c=Math.sqrt(u),{es:u,e:c,ep2:(n-f)/f}},e.sphere=function(t,r,e,a,n){if(!t){var f=c.default(u.default,a);f||(f=u.WGS84),t=f.a,r=f.b,e=f.rf}return e&&!r&&(r=(1-1/e)*t),(0===e||Math.abs(t-r)<i.EPSLN)&&(n=!0,r=t),{a:t,b:r,rf:e,sphere:n}}},\n",
" function _(e,a,l,s,r){s();var i={};l.default=i,i.MERIT={a:6378137,rf:298.257,ellipseName:\"MERIT 1983\"},i.SGS85={a:6378136,rf:298.257,ellipseName:\"Soviet Geodetic System 85\"},i.GRS80={a:6378137,rf:298.257222101,ellipseName:\"GRS 1980(IUGG, 1980)\"},i.IAU76={a:6378140,rf:298.257,ellipseName:\"IAU 1976\"},i.airy={a:6377563.396,b:6356256.91,ellipseName:\"Airy 1830\"},i.APL4={a:6378137,rf:298.25,ellipseName:\"Appl. Physics. 1965\"},i.NWL9D={a:6378145,rf:298.25,ellipseName:\"Naval Weapons Lab., 1965\"},i.mod_airy={a:6377340.189,b:6356034.446,ellipseName:\"Modified Airy\"},i.andrae={a:6377104.43,rf:300,ellipseName:\"Andrae 1876 (Den., Iclnd.)\"},i.aust_SA={a:6378160,rf:298.25,ellipseName:\"Australian Natl & S. Amer. 1969\"},i.GRS67={a:6378160,rf:298.247167427,ellipseName:\"GRS 67(IUGG 1967)\"},i.bessel={a:6377397.155,rf:299.1528128,ellipseName:\"Bessel 1841\"},i.bess_nam={a:6377483.865,rf:299.1528128,ellipseName:\"Bessel 1841 (Namibia)\"},i.clrk66={a:6378206.4,b:6356583.8,ellipseName:\"Clarke 1866\"},i.clrk80={a:6378249.145,rf:293.4663,ellipseName:\"Clarke 1880 mod.\"},i.clrk58={a:6378293.645208759,rf:294.2606763692654,ellipseName:\"Clarke 1858\"},i.CPM={a:6375738.7,rf:334.29,ellipseName:\"Comm. des Poids et Mesures 1799\"},i.delmbr={a:6376428,rf:311.5,ellipseName:\"Delambre 1810 (Belgium)\"},i.engelis={a:6378136.05,rf:298.2566,ellipseName:\"Engelis 1985\"},i.evrst30={a:6377276.345,rf:300.8017,ellipseName:\"Everest 1830\"},i.evrst48={a:6377304.063,rf:300.8017,ellipseName:\"Everest 1948\"},i.evrst56={a:6377301.243,rf:300.8017,ellipseName:\"Everest 1956\"},i.evrst69={a:6377295.664,rf:300.8017,ellipseName:\"Everest 1969\"},i.evrstSS={a:6377298.556,rf:300.8017,ellipseName:\"Everest (Sabah & Sarawak)\"},i.fschr60={a:6378166,rf:298.3,ellipseName:\"Fischer (Mercury Datum) 1960\"},i.fschr60m={a:6378155,rf:298.3,ellipseName:\"Fischer 1960\"},i.fschr68={a:6378150,rf:298.3,ellipseName:\"Fischer 1968\"},i.helmert={a:6378200,rf:298.3,ellipseName:\"Helmert 1906\"},i.hough={a:6378270,rf:297,ellipseName:\"Hough\"},i.intl={a:6378388,rf:297,ellipseName:\"International 1909 (Hayford)\"},i.kaula={a:6378163,rf:298.24,ellipseName:\"Kaula 1961\"},i.lerch={a:6378139,rf:298.257,ellipseName:\"Lerch 1979\"},i.mprts={a:6397300,rf:191,ellipseName:\"Maupertius 1738\"},i.new_intl={a:6378157.5,b:6356772.2,ellipseName:\"New International 1967\"},i.plessis={a:6376523,rf:6355863,ellipseName:\"Plessis 1817 (France)\"},i.krass={a:6378245,rf:298.3,ellipseName:\"Krassovsky, 1942\"},i.SEasia={a:6378155,b:6356773.3205,ellipseName:\"Southeast Asia\"},i.walbeck={a:6376896,b:6355834.8467,ellipseName:\"Walbeck\"},i.WGS60={a:6378165,rf:298.3,ellipseName:\"WGS 60\"},i.WGS66={a:6378145,rf:298.25,ellipseName:\"WGS 66\"},i.WGS7={a:6378135,rf:298.26,ellipseName:\"WGS 72\"},l.WGS84=i.WGS84={a:6378137,rf:298.257223563,ellipseName:\"WGS 84\"},i.sphere={a:6370997,b:6370997,ellipseName:\"Normal Sphere (r=6370997)\"}},\n",
" function _(e,a,s,t,l){t();var m={};s.default=m,m.wgs84={towgs84:\"0,0,0\",ellipse:\"WGS84\",datumName:\"WGS84\"},m.ch1903={towgs84:\"674.374,15.056,405.346\",ellipse:\"bessel\",datumName:\"swiss\"},m.ggrs87={towgs84:\"-199.87,74.79,246.62\",ellipse:\"GRS80\",datumName:\"Greek_Geodetic_Reference_System_1987\"},m.nad83={towgs84:\"0,0,0\",ellipse:\"GRS80\",datumName:\"North_American_Datum_1983\"},m.nad27={nadgrids:\"@conus,@alaska,@ntv2_0.gsb,@ntv1_can.dat\",ellipse:\"clrk66\",datumName:\"North_American_Datum_1927\"},m.potsdam={towgs84:\"606.0,23.0,413.0\",ellipse:\"bessel\",datumName:\"Potsdam Rauenberg 1950 DHDN\"},m.carthage={towgs84:\"-263.0,6.0,431.0\",ellipse:\"clark80\",datumName:\"Carthage 1934 Tunisia\"},m.hermannskogel={towgs84:\"653.0,-212.0,449.0\",ellipse:\"bessel\",datumName:\"Hermannskogel\"},m.osni52={towgs84:\"482.530,-130.596,564.557,-1.042,-0.214,-0.631,8.15\",ellipse:\"airy\",datumName:\"Irish National\"},m.ire65={towgs84:\"482.530,-130.596,564.557,-1.042,-0.214,-0.631,8.15\",ellipse:\"mod_airy\",datumName:\"Ireland 1965\"},m.rassadiran={towgs84:\"-133.63,-157.5,-158.62\",ellipse:\"intl\",datumName:\"Rassadiran\"},m.nzgd49={towgs84:\"59.47,-5.04,187.44,0.47,-0.1,1.024,-4.5993\",ellipse:\"intl\",datumName:\"New Zealand Geodetic Datum 1949\"},m.osgb36={towgs84:\"446.448,-125.157,542.060,0.1502,0.2470,0.8421,-20.4894\",ellipse:\"airy\",datumName:\"Airy 1830\"},m.s_jtsk={towgs84:\"589,76,480\",ellipse:\"bessel\",datumName:\"S-JTSK (Ferro)\"},m.beduaram={towgs84:\"-106,-87,188\",ellipse:\"clrk80\",datumName:\"Beduaram\"},m.gunung_segara={towgs84:\"-403,684,41\",ellipse:\"bessel\",datumName:\"Gunung Segara Jakarta\"},m.rnb72={towgs84:\"106.869,-52.2978,103.724,-0.33657,0.456955,-1.84218,1\",ellipse:\"intl\",datumName:\"Reseau National Belge 1972\"}},\n",
" function _(a,m,_,t,u){t();const p=a(72);_.default=function(a,m,_,t,u,d){var r={};return r.datum_type=void 0===a||\"none\"===a?p.PJD_NODATUM:p.PJD_WGS84,m&&(r.datum_params=m.map(parseFloat),0===r.datum_params[0]&&0===r.datum_params[1]&&0===r.datum_params[2]||(r.datum_type=p.PJD_3PARAM),r.datum_params.length>3&&(0===r.datum_params[3]&&0===r.datum_params[4]&&0===r.datum_params[5]&&0===r.datum_params[6]||(r.datum_type=p.PJD_7PARAM,r.datum_params[3]*=p.SEC_TO_RAD,r.datum_params[4]*=p.SEC_TO_RAD,r.datum_params[5]*=p.SEC_TO_RAD,r.datum_params[6]=r.datum_params[6]/1e6+1))),r.a=_,r.b=t,r.es=u,r.ep2=d,r}},\n",
" function _(t,e,a,r,u){r();const m=t(1),_=t(72),o=m.__importDefault(t(93)),d=m.__importDefault(t(95)),f=m.__importDefault(t(67)),n=m.__importDefault(t(96)),i=m.__importDefault(t(97));a.default=function t(e,a,r){var u;if(Array.isArray(r)&&(r=n.default(r)),i.default(r),e.datum&&a.datum&&function(t,e){return(t.datum.datum_type===_.PJD_3PARAM||t.datum.datum_type===_.PJD_7PARAM)&&\"WGS84\"!==e.datumCode||(e.datum.datum_type===_.PJD_3PARAM||e.datum.datum_type===_.PJD_7PARAM)&&\"WGS84\"!==t.datumCode}(e,a)&&(r=t(e,u=new f.default(\"WGS84\"),r),e=u),\"enu\"!==e.axis&&(r=d.default(e,!1,r)),\"longlat\"===e.projName)r={x:r.x*_.D2R,y:r.y*_.D2R,z:r.z||0};else if(e.to_meter&&(r={x:r.x*e.to_meter,y:r.y*e.to_meter,z:r.z||0}),!(r=e.inverse(r)))return;return e.from_greenwich&&(r.x+=e.from_greenwich),r=o.default(e.datum,a.datum,r),a.from_greenwich&&(r={x:r.x-a.from_greenwich,y:r.y,z:r.z||0}),\"longlat\"===a.projName?r={x:r.x*_.R2D,y:r.y*_.R2D,z:r.z||0}:(r=a.forward(r),a.to_meter&&(r={x:r.x/a.to_meter,y:r.y/a.to_meter,z:r.z||0})),\"enu\"!==a.axis?d.default(a,!0,r):r}},\n",
" function _(t,e,a,u,c){u();const m=t(72),o=t(94);function _(t){return t===m.PJD_3PARAM||t===m.PJD_7PARAM}a.default=function(t,e,a){return o.compareDatums(t,e)||t.datum_type===m.PJD_NODATUM||e.datum_type===m.PJD_NODATUM?a:t.es!==e.es||t.a!==e.a||_(t.datum_type)||_(e.datum_type)?(a=o.geodeticToGeocentric(a,t.es,t.a),_(t.datum_type)&&(a=o.geocentricToWgs84(a,t.datum_type,t.datum_params)),_(e.datum_type)&&(a=o.geocentricFromWgs84(a,e.datum_type,e.datum_params)),o.geocentricToGeodetic(a,e.es,e.a,e.b)):a}},\n",
" function _(a,t,r,m,s){m();const u=a(72);r.compareDatums=function(a,t){return a.datum_type===t.datum_type&&(!(a.a!==t.a||Math.abs(a.es-t.es)>5e-11)&&(a.datum_type===u.PJD_3PARAM?a.datum_params[0]===t.datum_params[0]&&a.datum_params[1]===t.datum_params[1]&&a.datum_params[2]===t.datum_params[2]:a.datum_type!==u.PJD_7PARAM||a.datum_params[0]===t.datum_params[0]&&a.datum_params[1]===t.datum_params[1]&&a.datum_params[2]===t.datum_params[2]&&a.datum_params[3]===t.datum_params[3]&&a.datum_params[4]===t.datum_params[4]&&a.datum_params[5]===t.datum_params[5]&&a.datum_params[6]===t.datum_params[6]))},r.geodeticToGeocentric=function(a,t,r){var m,s,_,e,n=a.x,d=a.y,i=a.z?a.z:0;if(d<-u.HALF_PI&&d>-1.001*u.HALF_PI)d=-u.HALF_PI;else if(d>u.HALF_PI&&d<1.001*u.HALF_PI)d=u.HALF_PI;else{if(d<-u.HALF_PI)return{x:-1/0,y:-1/0,z:a.z};if(d>u.HALF_PI)return{x:1/0,y:1/0,z:a.z}}return n>Math.PI&&(n-=2*Math.PI),s=Math.sin(d),e=Math.cos(d),_=s*s,{x:((m=r/Math.sqrt(1-t*_))+i)*e*Math.cos(n),y:(m+i)*e*Math.sin(n),z:(m*(1-t)+i)*s}},r.geocentricToGeodetic=function(a,t,r,m){var s,_,e,n,d,i,p,P,y,z,M,o,A,c,x,h=1e-12,f=a.x,I=a.y,F=a.z?a.z:0;if(s=Math.sqrt(f*f+I*I),_=Math.sqrt(f*f+I*I+F*F),s/r<h){if(c=0,_/r<h)return u.HALF_PI,x=-m,{x:a.x,y:a.y,z:a.z}}else c=Math.atan2(I,f);e=F/_,P=(n=s/_)*(1-t)*(d=1/Math.sqrt(1-t*(2-t)*n*n)),y=e*d,A=0;do{A++,i=t*(p=r/Math.sqrt(1-t*y*y))/(p+(x=s*P+F*y-p*(1-t*y*y))),o=(M=e*(d=1/Math.sqrt(1-i*(2-i)*n*n)))*P-(z=n*(1-i)*d)*y,P=z,y=M}while(o*o>1e-24&&A<30);return{x:c,y:Math.atan(M/Math.abs(z)),z:x}},r.geocentricToWgs84=function(a,t,r){if(t===u.PJD_3PARAM)return{x:a.x+r[0],y:a.y+r[1],z:a.z+r[2]};if(t===u.PJD_7PARAM){var m=r[0],s=r[1],_=r[2],e=r[3],n=r[4],d=r[5],i=r[6];return{x:i*(a.x-d*a.y+n*a.z)+m,y:i*(d*a.x+a.y-e*a.z)+s,z:i*(-n*a.x+e*a.y+a.z)+_}}},r.geocentricFromWgs84=function(a,t,r){if(t===u.PJD_3PARAM)return{x:a.x-r[0],y:a.y-r[1],z:a.z-r[2]};if(t===u.PJD_7PARAM){var m=r[0],s=r[1],_=r[2],e=r[3],n=r[4],d=r[5],i=r[6],p=(a.x-m)/i,P=(a.y-s)/i,y=(a.z-_)/i;return{x:p+d*P-n*y,y:-d*p+P+e*y,z:n*p-e*P+y}}}},\n",
" function _(e,a,i,r,s){r(),i.default=function(e,a,i){var r,s,n,c=i.x,d=i.y,f=i.z||0,u={};for(n=0;n<3;n++)if(!a||2!==n||void 0!==i.z)switch(0===n?(r=c,s=-1!==\"ew\".indexOf(e.axis[n])?\"x\":\"y\"):1===n?(r=d,s=-1!==\"ns\".indexOf(e.axis[n])?\"y\":\"x\"):(r=f,s=\"z\"),e.axis[n]){case\"e\":u[s]=r;break;case\"w\":u[s]=-r;break;case\"n\":u[s]=r;break;case\"s\":u[s]=-r;break;case\"u\":void 0!==i[s]&&(u.z=r);break;case\"d\":void 0!==i[s]&&(u.z=-r);break;default:return null}return u}},\n",
" function _(n,t,e,u,f){u(),e.default=function(n){var t={x:n[0],y:n[1]};return n.length>2&&(t.z=n[2]),n.length>3&&(t.m=n[3]),t}},\n",
" function _(e,i,n,t,r){function o(e){if(\"function\"==typeof Number.isFinite){if(Number.isFinite(e))return;throw new TypeError(\"coordinates must be finite numbers\")}if(\"number\"!=typeof e||e!=e||!isFinite(e))throw new TypeError(\"coordinates must be finite numbers\")}t(),n.default=function(e){o(e.x),o(e.y)}},\n",
" function _(e,t,s,i,n){i();const r=e(1),a=r.__importStar(e(18)),o=r.__importStar(e(99)),_=r.__importStar(e(45)),l=e(42),c=e(53),h=e(19),d=e(24),u=e(8),f=e(100),p=e(12),g=e(26),y=e(101),x=e(104),v=e(59),{abs:b,ceil:m}=Math;class w extends l.View{constructor(){super(...arguments),this._index=null,this._data_size=null,this._nohit_warned=new Set}get renderer(){return this.parent}get has_webgl(){return null!=this.glglyph}get index(){const{_index:e}=this;if(null!=e)return e;throw new Error(`${this}.index_data() wasn't called`)}get data_size(){const{_data_size:e}=this;if(null!=e)return e;throw new Error(`${this}.set_data() wasn't called`)}initialize(){super.initialize(),this.visuals=new _.Visuals(this)}request_render(){this.parent.request_render()}get canvas(){return this.renderer.parent.canvas_view}render(e,t,s){var i;null!=this.glglyph&&(this.renderer.needs_webgl_blit=this.glglyph.render(e,t,null!==(i=this.base)&&void 0!==i?i:this),this.renderer.needs_webgl_blit)||(e.beginPath(),this._render(e,t,null!=s?s:this.base))}has_finished(){return!0}notify_finished(){this.renderer.notify_finished()}_bounds(e){return e}bounds(){return this._bounds(this.index.bbox)}log_bounds(){const{x0:e,x1:t}=this.index.bounds(o.positive_x()),{y0:s,y1:i}=this.index.bounds(o.positive_y());return this._bounds({x0:e,y0:s,x1:t,y1:i})}get_anchor_point(e,t,[s,i]){switch(e){case\"center\":case\"center_center\":{const[e,n]=this.scenterxy(t,s,i);return{x:e,y:n}}default:return null}}scenterx(e,t,s){return this.scenterxy(e,t,s)[0]}scentery(e,t,s){return this.scenterxy(e,t,s)[1]}sdist(e,t,s,i=\"edge\",n=!1){const r=t.length,a=new d.ScreenArray(r),o=e.s_compute;if(\"center\"==i)for(let e=0;e<r;e++){const i=t[e],n=s.get(e)/2,r=o(i-n),_=o(i+n);a[e]=b(_-r)}else for(let e=0;e<r;e++){const i=t[e],n=o(i),r=o(i+s.get(e));a[e]=b(r-n)}return n&&p.inplace_map(a,(e=>m(e))),a}draw_legend_for_index(e,t,s){}hit_test(e){switch(e.type){case\"point\":if(null!=this._hit_point)return this._hit_point(e);break;case\"span\":if(null!=this._hit_span)return this._hit_span(e);break;case\"rect\":if(null!=this._hit_rect)return this._hit_rect(e);break;case\"poly\":if(null!=this._hit_poly)return this._hit_poly(e)}return this._nohit_warned.has(e.type)||(h.logger.debug(`'${e.type}' selection not available for ${this.model.type}`),this._nohit_warned.add(e.type)),null}_hit_rect_against_index(e){const{sx0:t,sx1:s,sy0:i,sy1:n}=e,[r,a]=this.renderer.coordinates.x_scale.r_invert(t,s),[o,_]=this.renderer.coordinates.y_scale.r_invert(i,n),l=[...this.index.indices({x0:r,x1:a,y0:o,y1:_})];return new v.Selection({indices:l})}_project_data(){}*_iter_visuals(){for(const e of this.visuals)for(const t of e)(t instanceof a.VectorSpec||t instanceof a.ScalarSpec)&&(yield t)}set_base(e){e!=this&&e instanceof this.constructor&&(this.base=e)}_configure(e,t){Object.defineProperty(this,u.isString(e)?e:e.attr,Object.assign({configurable:!0,enumerable:!0},t))}set_visuals(e,t){var s;for(const s of this._iter_visuals()){const{base:i}=this;if(null!=i){const e=i.model.properties[s.attr];if(null!=e&&g.is_equal(s.get_value(),e.get_value())){this._configure(s,{get:()=>i[`${s.attr}`]});continue}}const n=s.uniform(e).select(t);this._configure(s,{value:n})}for(const e of this.visuals)e.update();null===(s=this.glglyph)||void 0===s||s.set_visuals_changed()}set_data(e,t,s){var i;const{x_range:n,y_range:r}=this.renderer.coordinates,o=new Set(this._iter_visuals());this._data_size=t.count;for(const s of this.model)if((s instanceof a.VectorSpec||s instanceof a.ScalarSpec)&&!o.has(s))if(s instanceof a.BaseCoordinateSpec){const i=s.array(e);let o=t.select(i);const _=\"x\"==s.dimension?n:r;if(_ instanceof x.FactorRange)if(s instanceof a.CoordinateSpec)o=_.v_synthetic(o);else if(s instanceof a.CoordinateSeqSpec)for(let e=0;e<o.length;e++)o[e]=_.v_synthetic(o[e]);let l;l=s instanceof a.CoordinateSeqSpec?f.RaggedArray.from(o,Float64Array):o,this._configure(`_${s.attr}`,{value:l})}else{const i=s.uniform(e).select(t);if(this._configure(s,{value:i}),s instanceof a.DistanceSpec){const e=i.is_Scalar()?i.value:p.max(i.array);this._configure(`max_${s.attr}`,{value:e})}}this.renderer.plot_view.model.use_map&&this._project_data(),this._set_data(null!=s?s:null),null===(i=this.glglyph)||void 0===i||i.set_data_changed(),this.index_data()}_set_data(e){}get _index_size(){return this.data_size}index_data(){const e=new y.SpatialIndex(this._index_size);this._index_data(e),e.finish(),this._index=e}mask_data(){return null==this._mask_data?d.Indices.all_set(this.data_size):this._mask_data()}map_data(){var e;const t=this,{x_scale:s,y_scale:i}=this.renderer.coordinates;for(const e of this.model)if(e instanceof a.BaseCoordinateSpec){const n=\"x\"==e.dimension?s:i;let r=t[`_${e.attr}`];if(r instanceof f.RaggedArray){const e=n.v_compute(r.array);r=new f.RaggedArray(r.offsets,e)}else r=n.v_compute(r);this[`s${e.attr}`]=r}this._map_data(),null===(e=this.glglyph)||void 0===e||e.set_data_changed()}_map_data(){}}s.GlyphView=w,w.__name__=\"GlyphView\";class S extends c.Model{constructor(e){super(e)}}s.Glyph=S,S.__name__=\"Glyph\"},\n",
" function _(t,i,e,h,r){h();const s=t(24),n=t(26),{min:x,max:y}=Math;e.empty=function(){return{x0:1/0,y0:1/0,x1:-1/0,y1:-1/0}},e.positive_x=function(){return{x0:Number.MIN_VALUE,y0:-1/0,x1:1/0,y1:1/0}},e.positive_y=function(){return{x0:-1/0,y0:Number.MIN_VALUE,x1:1/0,y1:1/0}},e.union=function(t,i){return{x0:x(t.x0,i.x0),x1:y(t.x1,i.x1),y0:x(t.y0,i.y0),y1:y(t.y1,i.y1)}};class o{constructor(t){if(null==t)this.x0=0,this.y0=0,this.x1=0,this.y1=0;else if(\"x0\"in t){const{x0:i,y0:e,x1:h,y1:r}=t;if(!(i<=h&&e<=r))throw new Error(`invalid bbox {x0: ${i}, y0: ${e}, x1: ${h}, y1: ${r}}`);this.x0=i,this.y0=e,this.x1=h,this.y1=r}else if(\"x\"in t){const{x:i,y:e,width:h,height:r}=t;if(!(h>=0&&r>=0))throw new Error(`invalid bbox {x: ${i}, y: ${e}, width: ${h}, height: ${r}}`);this.x0=i,this.y0=e,this.x1=i+h,this.y1=e+r}else{let i,e,h,r;if(\"width\"in t)if(\"left\"in t)i=t.left,e=i+t.width;else if(\"right\"in t)e=t.right,i=e-t.width;else{const h=t.width/2;i=t.hcenter-h,e=t.hcenter+h}else i=t.left,e=t.right;if(\"height\"in t)if(\"top\"in t)h=t.top,r=h+t.height;else if(\"bottom\"in t)r=t.bottom,h=r-t.height;else{const i=t.height/2;h=t.vcenter-i,r=t.vcenter+i}else h=t.top,r=t.bottom;if(!(i<=e&&h<=r))throw new Error(`invalid bbox {left: ${i}, top: ${h}, right: ${e}, bottom: ${r}}`);this.x0=i,this.y0=h,this.x1=e,this.y1=r}}static from_rect({left:t,right:i,top:e,bottom:h}){return new o({x0:Math.min(t,i),y0:Math.min(e,h),x1:Math.max(t,i),y1:Math.max(e,h)})}equals(t){return this.x0==t.x0&&this.y0==t.y0&&this.x1==t.x1&&this.y1==t.y1}[n.equals](t,i){return i.eq(this.x0,t.x0)&&i.eq(this.y0,t.y0)&&i.eq(this.x1,t.x1)&&i.eq(this.y1,t.y1)}toString(){return`BBox({left: ${this.left}, top: ${this.top}, width: ${this.width}, height: ${this.height}})`}get left(){return this.x0}get top(){return this.y0}get right(){return this.x1}get bottom(){return this.y1}get p0(){return[this.x0,this.y0]}get p1(){return[this.x1,this.y1]}get x(){return this.x0}get y(){return this.y0}get width(){return this.x1-this.x0}get height(){return this.y1-this.y0}get size(){return{width:this.width,height:this.height}}get rect(){const{x0:t,y0:i,x1:e,y1:h}=this;return{p0:{x:t,y:i},p1:{x:e,y:i},p2:{x:e,y:h},p3:{x:t,y:h}}}get box(){const{x:t,y:i,width:e,height:h}=this;return{x:t,y:i,width:e,height:h}}get h_range(){return{start:this.x0,end:this.x1}}get v_range(){return{start:this.y0,end:this.y1}}get ranges(){return[this.h_range,this.v_range]}get aspect(){return this.width/this.height}get hcenter(){return(this.left+this.right)/2}get vcenter(){return(this.top+this.bottom)/2}get area(){return this.width*this.height}relative(){const{width:t,height:i}=this;return new o({x:0,y:0,width:t,height:i})}translate(t,i){const{x:e,y:h,width:r,height:s}=this;return new o({x:t+e,y:i+h,width:r,height:s})}relativize(t,i){return[t-this.x,i-this.y]}contains(t,i){return this.x0<=t&&t<=this.x1&&this.y0<=i&&i<=this.y1}clip(t,i){return t<this.x0?t=this.x0:t>this.x1&&(t=this.x1),i<this.y0?i=this.y0:i>this.y1&&(i=this.y1),[t,i]}grow_by(t){return new o({left:this.left-t,right:this.right+t,top:this.top-t,bottom:this.bottom+t})}shrink_by(t){return new o({left:this.left+t,right:this.right-t,top:this.top+t,bottom:this.bottom-t})}union(t){return new o({x0:x(this.x0,t.x0),y0:x(this.y0,t.y0),x1:y(this.x1,t.x1),y1:y(this.y1,t.y1)})}intersection(t){return this.intersects(t)?new o({x0:y(this.x0,t.x0),y0:y(this.y0,t.y0),x1:x(this.x1,t.x1),y1:x(this.y1,t.y1)}):null}intersects(t){return!(t.x1<this.x0||t.x0>this.x1||t.y1<this.y0||t.y0>this.y1)}get xview(){return{compute:t=>this.left+t,v_compute:t=>{const i=new s.ScreenArray(t.length),e=this.left;for(let h=0;h<t.length;h++)i[h]=e+t[h];return i}}}get yview(){return{compute:t=>this.bottom-t,v_compute:t=>{const i=new s.ScreenArray(t.length),e=this.bottom;for(let h=0;h<t.length;h++)i[h]=e-t[h];return i}}}}e.BBox=o,o.__name__=\"BBox\"},\n",
" function _(t,s,r,e,n){e();const a=t(26),o=t(11);class h{constructor(t,s){this.offsets=t,this.array=s}[a.equals](t,s){return s.arrays(this.offsets,t.offsets)&&s.arrays(this.array,t.array)}get length(){return this.offsets.length}clone(){return new h(this.offsets.slice(),this.array.slice())}static from(t,s){const r=t.length;let e=0;const n=(()=>{const s=new Uint32Array(r);for(let n=0;n<r;n++){const r=t[n].length;s[n]=e,e+=r}return e<256?new Uint8Array(s):e<65536?new Uint16Array(s):s})(),a=new s(e);for(let s=0;s<r;s++)a.set(t[s],n[s]);return new h(n,a)}*[Symbol.iterator](){const{offsets:t,length:s}=this;for(let r=0;r<s;r++)yield this.array.subarray(t[r],t[r+1])}_check_bounds(t){o.assert(0<=t&&t<this.length,`Out of bounds: 0 <= ${t} < ${this.length}`)}get(t){this._check_bounds(t);const{offsets:s}=this;return this.array.subarray(s[t],s[t+1])}set(t,s){this._check_bounds(t),this.array.set(s,this.offsets[t])}}r.RaggedArray=h,h.__name__=\"RaggedArray\",h[Symbol.toStringTag]=\"RaggedArray\"},\n",
" function _(n,i,t,e,s){e();const o=n(1).__importDefault(n(102)),d=n(24),x=n(99);function h(n,i){let t=0,e=i.length-1;for(;t<e;){const s=t+e>>1;i[s]>n?e=s:t=s+1}return i[t]}class r extends o.default{search_indices(n,i,t,e){if(this._pos!==this._boxes.length)throw new Error(\"Data not yet indexed - call index.finish().\");let s=this._boxes.length-4;const o=[],x=new d.Indices(this.numItems);for(;void 0!==s;){const d=Math.min(s+4*this.nodeSize,h(s,this._levelBounds));for(let h=s;h<d;h+=4){const d=0|this._indices[h>>2];t<this._boxes[h+0]||(e<this._boxes[h+1]||n>this._boxes[h+2]||i>this._boxes[h+3]||(s<4*this.numItems?x.set(d):o.push(d)))}s=o.pop()}return x}}r.__name__=\"_FlatBush\";class l{constructor(n){this.index=null,n>0&&(this.index=new r(n))}add(n,i,t,e){var s;null===(s=this.index)||void 0===s||s.add(n,i,t,e)}add_empty(){var n;null===(n=this.index)||void 0===n||n.add(1/0,1/0,-1/0,-1/0)}finish(){var n;null===(n=this.index)||void 0===n||n.finish()}_normalize(n){let{x0:i,y0:t,x1:e,y1:s}=n;return i>e&&([i,e]=[e,i]),t>s&&([t,s]=[s,t]),{x0:i,y0:t,x1:e,y1:s}}get bbox(){if(null==this.index)return x.empty();{const{minX:n,minY:i,maxX:t,maxY:e}=this.index;return{x0:n,y0:i,x1:t,y1:e}}}indices(n){if(null==this.index)return new d.Indices(0);{const{x0:i,y0:t,x1:e,y1:s}=this._normalize(n);return this.index.search_indices(i,t,e,s)}}bounds(n){const i=x.empty();for(const t of this.indices(n)){const n=this.index._boxes,e=n[4*t+0],s=n[4*t+1],o=n[4*t+2],d=n[4*t+3];o<i.x0&&(i.x0=o),e>i.x1&&(i.x1=e),d<i.y0&&(i.y0=d),s>i.y1&&(i.y1=s)}return i}}t.SpatialIndex=l,l.__name__=\"SpatialIndex\"},\n",
" function _(t,s,i,e,h){e();const n=t(1).__importDefault(t(103)),o=[Int8Array,Uint8Array,Uint8ClampedArray,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array];class r{static from(t){if(!(t instanceof ArrayBuffer))throw new Error(\"Data must be an instance of ArrayBuffer.\");const[s,i]=new Uint8Array(t,0,2);if(251!==s)throw new Error(\"Data does not appear to be in a Flatbush format.\");if(i>>4!=3)throw new Error(`Got v${i>>4} data when expected v3.`);const[e]=new Uint16Array(t,2,1),[h]=new Uint32Array(t,4,1);return new r(h,e,o[15&i],t)}constructor(t,s=16,i=Float64Array,e){if(void 0===t)throw new Error(\"Missing required argument: numItems.\");if(isNaN(t)||t<=0)throw new Error(`Unpexpected numItems value: ${t}.`);this.numItems=+t,this.nodeSize=Math.min(Math.max(+s,2),65535);let h=t,r=h;this._levelBounds=[4*h];do{h=Math.ceil(h/this.nodeSize),r+=h,this._levelBounds.push(4*r)}while(1!==h);this.ArrayType=i||Float64Array,this.IndexArrayType=r<16384?Uint16Array:Uint32Array;const a=o.indexOf(this.ArrayType),_=4*r*this.ArrayType.BYTES_PER_ELEMENT;if(a<0)throw new Error(`Unexpected typed array class: ${i}.`);e&&e instanceof ArrayBuffer?(this.data=e,this._boxes=new this.ArrayType(this.data,8,4*r),this._indices=new this.IndexArrayType(this.data,8+_,r),this._pos=4*r,this.minX=this._boxes[this._pos-4],this.minY=this._boxes[this._pos-3],this.maxX=this._boxes[this._pos-2],this.maxY=this._boxes[this._pos-1]):(this.data=new ArrayBuffer(8+_+r*this.IndexArrayType.BYTES_PER_ELEMENT),this._boxes=new this.ArrayType(this.data,8,4*r),this._indices=new this.IndexArrayType(this.data,8+_,r),this._pos=0,this.minX=1/0,this.minY=1/0,this.maxX=-1/0,this.maxY=-1/0,new Uint8Array(this.data,0,2).set([251,48+a]),new Uint16Array(this.data,2,1)[0]=s,new Uint32Array(this.data,4,1)[0]=t),this._queue=new n.default}add(t,s,i,e){const h=this._pos>>2;return this._indices[h]=h,this._boxes[this._pos++]=t,this._boxes[this._pos++]=s,this._boxes[this._pos++]=i,this._boxes[this._pos++]=e,t<this.minX&&(this.minX=t),s<this.minY&&(this.minY=s),i>this.maxX&&(this.maxX=i),e>this.maxY&&(this.maxY=e),h}finish(){if(this._pos>>2!==this.numItems)throw new Error(`Added ${this._pos>>2} items when expected ${this.numItems}.`);if(this.numItems<=this.nodeSize)return this._boxes[this._pos++]=this.minX,this._boxes[this._pos++]=this.minY,this._boxes[this._pos++]=this.maxX,void(this._boxes[this._pos++]=this.maxY);const t=this.maxX-this.minX,s=this.maxY-this.minY,i=new Uint32Array(this.numItems);for(let e=0;e<this.numItems;e++){let h=4*e;const n=this._boxes[h++],o=this._boxes[h++],r=this._boxes[h++],a=this._boxes[h++],_=Math.floor(65535*((n+r)/2-this.minX)/t),x=Math.floor(65535*((o+a)/2-this.minY)/s);i[e]=m(_,x)}x(i,this._boxes,this._indices,0,this.numItems-1,this.nodeSize);for(let t=0,s=0;t<this._levelBounds.length-1;t++){const i=this._levelBounds[t];for(;s<i;){const t=s;let e=1/0,h=1/0,n=-1/0,o=-1/0;for(let t=0;t<this.nodeSize&&s<i;t++)e=Math.min(e,this._boxes[s++]),h=Math.min(h,this._boxes[s++]),n=Math.max(n,this._boxes[s++]),o=Math.max(o,this._boxes[s++]);this._indices[this._pos>>2]=t,this._boxes[this._pos++]=e,this._boxes[this._pos++]=h,this._boxes[this._pos++]=n,this._boxes[this._pos++]=o}}}search(t,s,i,e,h){if(this._pos!==this._boxes.length)throw new Error(\"Data not yet indexed - call index.finish().\");let n=this._boxes.length-4;const o=[],r=[];for(;void 0!==n;){const a=Math.min(n+4*this.nodeSize,_(n,this._levelBounds));for(let _=n;_<a;_+=4){const a=0|this._indices[_>>2];i<this._boxes[_]||(e<this._boxes[_+1]||t>this._boxes[_+2]||s>this._boxes[_+3]||(n<4*this.numItems?(void 0===h||h(a))&&r.push(a):o.push(a)))}n=o.pop()}return r}neighbors(t,s,i=1/0,e=1/0,h){if(this._pos!==this._boxes.length)throw new Error(\"Data not yet indexed - call index.finish().\");let n=this._boxes.length-4;const o=this._queue,r=[],x=e*e;for(;void 0!==n;){const e=Math.min(n+4*this.nodeSize,_(n,this._levelBounds));for(let i=n;i<e;i+=4){const e=0|this._indices[i>>2],r=a(t,this._boxes[i],this._boxes[i+2]),_=a(s,this._boxes[i+1],this._boxes[i+3]),x=r*r+_*_;n<4*this.numItems?(void 0===h||h(e))&&o.push(-e-1,x):o.push(e,x)}for(;o.length&&o.peek()<0;){if(o.peekValue()>x)return o.clear(),r;if(r.push(-o.pop()-1),r.length===i)return o.clear(),r}n=o.pop()}return o.clear(),r}}function a(t,s,i){return t<s?s-t:t<=i?0:t-i}function _(t,s){let i=0,e=s.length-1;for(;i<e;){const h=i+e>>1;s[h]>t?e=h:i=h+1}return s[i]}function x(t,s,i,e,h,n){if(Math.floor(e/n)>=Math.floor(h/n))return;const o=t[e+h>>1];let r=e-1,a=h+1;for(;;){do{r++}while(t[r]<o);do{a--}while(t[a]>o);if(r>=a)break;d(t,s,i,r,a)}x(t,s,i,e,a,n),x(t,s,i,a+1,h,n)}function d(t,s,i,e,h){const n=t[e];t[e]=t[h],t[h]=n;const o=4*e,r=4*h,a=s[o],_=s[o+1],x=s[o+2],d=s[o+3];s[o]=s[r],s[o+1]=s[r+1],s[o+2]=s[r+2],s[o+3]=s[r+3],s[r]=a,s[r+1]=_,s[r+2]=x,s[r+3]=d;const m=i[e];i[e]=i[h],i[h]=m}function m(t,s){let i=t^s,e=65535^i,h=65535^(t|s),n=t&(65535^s),o=i|e>>1,r=i>>1^i,a=h>>1^e&n>>1^h,_=i&h>>1^n>>1^n;i=o,e=r,h=a,n=_,o=i&i>>2^e&e>>2,r=i&e>>2^e&(i^e)>>2,a^=i&h>>2^e&n>>2,_^=e&h>>2^(i^e)&n>>2,i=o,e=r,h=a,n=_,o=i&i>>4^e&e>>4,r=i&e>>4^e&(i^e)>>4,a^=i&h>>4^e&n>>4,_^=e&h>>4^(i^e)&n>>4,i=o,e=r,h=a,n=_,a^=i&h>>8^e&n>>8,_^=e&h>>8^(i^e)&n>>8,i=a^a>>1,e=_^_>>1;let x=t^s,d=e|65535^(x|i);return x=16711935&(x|x<<8),x=252645135&(x|x<<4),x=858993459&(x|x<<2),x=1431655765&(x|x<<1),d=16711935&(d|d<<8),d=252645135&(d|d<<4),d=858993459&(d|d<<2),d=1431655765&(d|d<<1),(d<<1|x)>>>0}i.default=r},\n",
" function _(s,t,i,h,e){h();i.default=class{constructor(){this.ids=[],this.values=[],this.length=0}clear(){this.length=0}push(s,t){let i=this.length++;for(this.ids[i]=s,this.values[i]=t;i>0;){const s=i-1>>1,h=this.values[s];if(t>=h)break;this.ids[i]=this.ids[s],this.values[i]=h,i=s}this.ids[i]=s,this.values[i]=t}pop(){if(0===this.length)return;const s=this.ids[0];if(this.length--,this.length>0){const s=this.ids[0]=this.ids[this.length],t=this.values[0]=this.values[this.length],i=this.length>>1;let h=0;for(;h<i;){let s=1+(h<<1);const i=s+1;let e=this.ids[s],l=this.values[s];const n=this.values[i];if(i<this.length&&n<l&&(s=i,e=this.ids[i],l=n),l>=t)break;this.ids[h]=e,this.values[h]=l,h=s}this.ids[h]=s,this.values[h]=t}return s}peek(){if(0!==this.length)return this.ids[0]}peekValue(){if(0!==this.length)return this.values[0]}}},\n",
" function _(t,n,e,i,s){i();const r=t(105),a=t(20),o=t(21),g=t(24),p=t(9),c=t(8),l=t(11);function u(t,n,e=0){const i=new Map;for(let s=0;s<t.length;s++){const r=t[s];if(i.has(r))throw new Error(`duplicate factor or subfactor: ${r}`);i.set(r,{value:.5+s*(1+n)+e})}return[i,(t.length-1)*n]}function h(t,n,e,i=0){var s;const r=new Map,a=new Map;for(const[n,e]of t){const t=null!==(s=a.get(n))&&void 0!==s?s:[];a.set(n,[...t,e])}let o=i,g=0;for(const[t,i]of a){const s=i.length,[a,c]=u(i,e,o);g+=c;const l=p.sum(i.map((t=>a.get(t).value)));r.set(t,{value:l/s,mapping:a}),o+=s+n+c}return[r,(a.size-1)*n+g]}function d(t,n,e,i,s=0){var r;const a=new Map,o=new Map;for(const[n,e,i]of t){const t=null!==(r=o.get(n))&&void 0!==r?r:[];o.set(n,[...t,[e,i]])}let g=s,c=0;for(const[t,s]of o){const r=s.length,[o,l]=h(s,e,i,g);c+=l;const u=p.sum(s.map((([t])=>o.get(t).value)));a.set(t,{value:u/r,mapping:o}),g+=r+n+l}return[a,(o.size-1)*n+c]}e.Factor=o.Or(o.String,o.Tuple(o.String,o.String),o.Tuple(o.String,o.String,o.String)),e.FactorSeq=o.Or(o.Array(o.String),o.Array(o.Tuple(o.String,o.String)),o.Array(o.Tuple(o.String,o.String,o.String))),e.map_one_level=u,e.map_two_levels=h,e.map_three_levels=d;class _ extends r.Range{constructor(t){super(t)}static init_FactorRange(){this.define((({Number:t})=>({factors:[e.FactorSeq,[]],factor_padding:[t,0],subgroup_padding:[t,.8],group_padding:[t,1.4],range_padding:[t,0],range_padding_units:[a.PaddingUnits,\"percent\"],start:[t],end:[t]}))),this.internal((({Number:t,String:n,Array:e,Tuple:i,Nullable:s})=>({levels:[t],mids:[s(e(i(n,n))),null],tops:[s(e(n)),null]})))}get min(){return this.start}get max(){return this.end}initialize(){super.initialize(),this._init(!0)}connect_signals(){super.connect_signals(),this.connect(this.properties.factors.change,(()=>this.reset())),this.connect(this.properties.factor_padding.change,(()=>this.reset())),this.connect(this.properties.group_padding.change,(()=>this.reset())),this.connect(this.properties.subgroup_padding.change,(()=>this.reset())),this.connect(this.properties.range_padding.change,(()=>this.reset())),this.connect(this.properties.range_padding_units.change,(()=>this.reset()))}reset(){this._init(!1),this.change.emit()}_lookup(t){switch(t.length){case 1:{const[n]=t,e=this._mapping.get(n);return null!=e?e.value:NaN}case 2:{const[n,e]=t,i=this._mapping.get(n);if(null!=i){const t=i.mapping.get(e);if(null!=t)return t.value}return NaN}case 3:{const[n,e,i]=t,s=this._mapping.get(n);if(null!=s){const t=s.mapping.get(e);if(null!=t){const n=t.mapping.get(i);if(null!=n)return n.value}}return NaN}default:l.unreachable()}}synthetic(t){if(c.isNumber(t))return t;if(c.isString(t))return this._lookup([t]);let n=0;const e=t[t.length-1];return c.isNumber(e)&&(n=e,t=t.slice(0,-1)),this._lookup(t)+n}v_synthetic(t){const n=t.length,e=new g.ScreenArray(n);for(let i=0;i<n;i++)e[i]=this.synthetic(t[i]);return e}_init(t){const{levels:n,mapping:e,tops:i,mids:s,inside_padding:r}=(()=>{if(p.every(this.factors,c.isString)){const t=this.factors,[n,e]=u(t,this.factor_padding);return{levels:1,mapping:n,tops:null,mids:null,inside_padding:e}}if(p.every(this.factors,(t=>c.isArray(t)&&2==t.length&&c.isString(t[0])&&c.isString(t[1])))){const t=this.factors,[n,e]=h(t,this.group_padding,this.factor_padding),i=[...n.keys()];return{levels:2,mapping:n,tops:i,mids:null,inside_padding:e}}if(p.every(this.factors,(t=>c.isArray(t)&&3==t.length&&c.isString(t[0])&&c.isString(t[1])&&c.isString(t[2])))){const t=this.factors,[n,e]=d(t,this.group_padding,this.subgroup_padding,this.factor_padding),i=[...n.keys()],s=[];for(const[t,e]of n)for(const n of e.mapping.keys())s.push([t,n]);return{levels:3,mapping:n,tops:i,mids:s,inside_padding:e}}l.unreachable()})();this._mapping=e,this.tops=i,this.mids=s;let a=0,o=this.factors.length+r;if(\"percent\"==this.range_padding_units){const t=(o-a)*this.range_padding/2;a-=t,o+=t}else a-=this.range_padding,o+=this.range_padding;this.setv({start:a,end:o,levels:n},{silent:t}),\"auto\"==this.bounds&&this.setv({bounds:[a,o]},{silent:!0})}}e.FactorRange=_,_.__name__=\"FactorRange\",_.init_FactorRange()},\n",
" function _(e,t,i,n,s){n();const a=e(53);class l extends a.Model{constructor(e){super(e),this.have_updated_interactively=!1}static init_Range(){this.define((({Number:e,Tuple:t,Or:i,Auto:n,Nullable:s})=>({bounds:[s(i(t(s(e),s(e)),n)),null],min_interval:[s(e),null],max_interval:[s(e),null]}))),this.internal((({Array:e,AnyRef:t})=>({plots:[e(t()),[]]})))}get is_reversed(){return this.start>this.end}get is_valid(){return isFinite(this.min)&&isFinite(this.max)}}i.Range=l,l.__name__=\"Range\",l.init_Range()},\n",
" function _(e,t,i,n,l){n();const o=e(1).__importStar(e(107));function a(e,t,{x0:i,x1:n,y0:l,y1:o},a){t.save(),t.beginPath(),t.moveTo(i,(l+o)/2),t.lineTo(n,(l+o)/2),e.line.doit&&(e.line.set_vectorize(t,a),t.stroke()),t.restore()}function r(e,t,{x0:i,x1:n,y0:l,y1:o},a){var r,c;const s=.1*Math.abs(n-i),_=.1*Math.abs(o-l),v=i+s,d=n-s,h=l+_,g=o-_;t.beginPath(),t.rect(v,h,d-v,g-h),e.fill.doit&&(e.fill.set_vectorize(t,a),t.fill()),(null===(r=e.hatch)||void 0===r?void 0:r.doit)&&(e.hatch.set_vectorize(t,a),t.fill()),(null===(c=e.line)||void 0===c?void 0:c.doit)&&(e.line.set_vectorize(t,a),t.stroke())}i.generic_line_scalar_legend=function(e,t,{x0:i,x1:n,y0:l,y1:o}){t.save(),t.beginPath(),t.moveTo(i,(l+o)/2),t.lineTo(n,(l+o)/2),e.line.doit&&(e.line.set_value(t),t.stroke()),t.restore()},i.generic_line_vector_legend=a,i.generic_line_legend=a,i.generic_area_scalar_legend=function(e,t,{x0:i,x1:n,y0:l,y1:o}){var a,r;const c=.1*Math.abs(n-i),s=.1*Math.abs(o-l),_=i+c,v=n-c,d=l+s,h=o-s;t.beginPath(),t.rect(_,d,v-_,h-d),e.fill.doit&&(e.fill.set_value(t),t.fill()),(null===(a=e.hatch)||void 0===a?void 0:a.doit)&&(e.hatch.set_value(t),t.fill()),(null===(r=e.line)||void 0===r?void 0:r.doit)&&(e.line.set_value(t),t.stroke())},i.generic_area_vector_legend=r,i.generic_area_legend=r,i.line_interpolation=function(e,t,i,n,l,a){const{sx:r,sy:c}=t;let s,_,v,d;\"point\"==t.type?([v,d]=e.yscale.r_invert(c-1,c+1),[s,_]=e.xscale.r_invert(r-1,r+1)):\"v\"==t.direction?([v,d]=e.yscale.r_invert(c,c),[s,_]=[Math.min(i-1,l-1),Math.max(i+1,l+1)]):([s,_]=e.xscale.r_invert(r,r),[v,d]=[Math.min(n-1,a-1),Math.max(n+1,a+1)]);const{x:h,y:g}=o.check_2_segments_intersect(s,v,_,d,i,n,l,a);return[h,g]}},\n",
" function _(t,n,e,i,r){function s(t,n){return(t.x-n.x)**2+(t.y-n.y)**2}function o(t,n,e){const i=s(n,e);if(0==i)return s(t,n);const r=((t.x-n.x)*(e.x-n.x)+(t.y-n.y)*(e.y-n.y))/i;if(r<0)return s(t,n);if(r>1)return s(t,e);return s(t,{x:n.x+r*(e.x-n.x),y:n.y+r*(e.y-n.y)})}i(),e.point_in_poly=function(t,n,e,i){let r=!1,s=e[e.length-1],o=i[i.length-1];for(let u=0;u<e.length;u++){const c=e[u],_=i[u];o<n!=_<n&&s+(n-o)/(_-o)*(c-s)<t&&(r=!r),s=c,o=_}return r},e.point_in_ellipse=function(t,n,e,i,r,s,o){return((Math.cos(e)/r)**2+(Math.sin(e)/i)**2)*(t-s)**2+2*Math.cos(e)*Math.sin(e)*((1/r)**2-(1/i)**2)*(t-s)*(n-o)+((Math.cos(e)/i)**2+(Math.sin(e)/r)**2)*(n-o)**2<=1},e.dist_2_pts=s,e.dist_to_segment_squared=o,e.dist_to_segment=function(t,n,e){return Math.sqrt(o(t,n,e))},e.check_2_segments_intersect=function(t,n,e,i,r,s,o,u){const c=(u-s)*(e-t)-(o-r)*(i-n);if(0==c)return{hit:!1,x:null,y:null};{let _=n-s,h=t-r;const l=(e-t)*_-(i-n)*h;_=((o-r)*_-(u-s)*h)/c,h=l/c;return{hit:_>0&&_<1&&h>0&&h<1,x:t+_*(e-t),y:n+_*(i-n)}}}},\n",
" function _(t,e,s,i,a){i();const o=t(1),n=t(109),_=t(113),r=o.__importDefault(t(114)),h=o.__importDefault(t(115)),l=t(22),g=t(46);class u{constructor(t){this._atlas=new Map,this._width=256,this._height=256,this.tex=new n.Texture2d(t),this.tex.set_wrapping(t.REPEAT,t.REPEAT),this.tex.set_interpolation(t.NEAREST,t.NEAREST),this.tex.set_size([this._width,this._height],t.RGBA),this.tex.set_data([0,0],[this._width,this._height],new Uint8Array(4*this._width*this._height)),this.get_atlas_data([1])}get_atlas_data(t){const e=t.join(\"-\");let s=this._atlas.get(e);if(null==s){const[i,a]=this.make_pattern(t),o=this._atlas.size;this.tex.set_data([0,o],[this._width,1],new Uint8Array(i.map((t=>t+10)))),s=[o/this._height,a],this._atlas.set(e,s)}return s}make_pattern(t){t.length>1&&t.length%2&&(t=t.concat(t));let e=0;for(const s of t)e+=s;const s=[];let i=0;for(let e=0,a=t.length+2;e<a;e+=2){const a=Math.max(1e-4,t[e%t.length]),o=Math.max(1e-4,t[(e+1)%t.length]);s.push(i,i+a),i+=a+o}const a=this._width,o=new Float32Array(4*a);for(let t=0,i=a;t<i;t++){let i,n,_;const r=e*t/(a-1);let h=0,l=1e16;for(let t=0,e=s.length;t<e;t++){const e=Math.abs(s[t]-r);e<l&&(h=t,l=e)}h%2==0?(_=r<=s[h]?1:0,n=s[h],i=s[h+1]):(_=r>s[h]?-1:0,n=s[h-1],i=s[h]),o[4*t+0]=s[h],o[4*t+1]=_,o[4*t+2]=n,o[4*t+3]=i}return[o,e]}}u.__name__=\"DashAtlas\";const f={miter:0,round:1,bevel:2},c={\"\":0,none:0,\".\":0,round:1,\")\":1,\"(\":1,o:1,\"triangle in\":2,\"<\":2,\"triangle out\":3,\">\":3,square:4,\"[\":4,\"]\":4,\"=\":4,butt:5,\"|\":5};class d extends _.BaseGLGlyph{constructor(t,e){super(t,e),this.glyph=e,this._scale_aspect=0;const s=r.default,i=h.default;this.prog=new n.Program(t),this.prog.set_shaders(s,i),this.index_buffer=new n.IndexBuffer(t),this.vbo_position=new n.VertexBuffer(t),this.vbo_tangents=new n.VertexBuffer(t),this.vbo_segment=new n.VertexBuffer(t),this.vbo_angles=new n.VertexBuffer(t),this.vbo_texcoord=new n.VertexBuffer(t),this.dash_atlas=new u(t)}draw(t,e,s){const i=e.glglyph;if(i.data_changed&&(i._set_data(),i.data_changed=!1),this.visuals_changed&&(this._set_visuals(),this.visuals_changed=!1),i._update_scale(1,1),this._scale_aspect=1,this.prog.set_attribute(\"a_position\",\"vec2\",i.vbo_position),this.prog.set_attribute(\"a_tangents\",\"vec4\",i.vbo_tangents),this.prog.set_attribute(\"a_segment\",\"vec2\",i.vbo_segment),this.prog.set_attribute(\"a_angles\",\"vec2\",i.vbo_angles),this.prog.set_attribute(\"a_texcoord\",\"vec2\",i.vbo_texcoord),this.prog.set_uniform(\"u_length\",\"float\",[i.cumsum]),this.prog.set_texture(\"u_dash_atlas\",this.dash_atlas.tex),this.prog.set_uniform(\"u_pixel_ratio\",\"float\",[s.pixel_ratio]),this.prog.set_uniform(\"u_canvas_size\",\"vec2\",[s.width,s.height]),this.prog.set_uniform(\"u_scale_aspect\",\"vec2\",[1,1]),this.prog.set_uniform(\"u_scale_length\",\"float\",[Math.sqrt(2)]),this.I_triangles=i.I_triangles,this.I_triangles.length<65535)this.index_buffer.set_size(2*this.I_triangles.length),this.index_buffer.set_data(0,new Uint16Array(this.I_triangles)),this.prog.draw(this.gl.TRIANGLES,this.index_buffer);else{t=Array.from(this.I_triangles);const e=this.I_triangles.length,s=64008,a=[];for(let t=0,i=Math.ceil(e/s);t<i;t++)a.push([]);for(let e=0,i=t.length;e<i;e++){const i=t[e]%s;a[Math.floor(t[e]/s)].push(i)}for(let t=0,e=a.length;t<e;t++){const e=new Uint16Array(a[t]),o=t*s*4;0!==e.length&&(this.prog.set_attribute(\"a_position\",\"vec2\",i.vbo_position,0,2*o),this.prog.set_attribute(\"a_tangents\",\"vec4\",i.vbo_tangents,0,4*o),this.prog.set_attribute(\"a_segment\",\"vec2\",i.vbo_segment,0,2*o),this.prog.set_attribute(\"a_angles\",\"vec2\",i.vbo_angles,0,2*o),this.prog.set_attribute(\"a_texcoord\",\"vec2\",i.vbo_texcoord,0,2*o),this.index_buffer.set_size(2*e.length),this.index_buffer.set_data(0,e),this.prog.draw(this.gl.TRIANGLES,this.index_buffer))}}}_set_data(){this._bake(),this.vbo_position.set_size(4*this.V_position.length),this.vbo_position.set_data(0,this.V_position),this.vbo_tangents.set_size(4*this.V_tangents.length),this.vbo_tangents.set_data(0,this.V_tangents),this.vbo_angles.set_size(4*this.V_angles.length),this.vbo_angles.set_data(0,this.V_angles),this.vbo_texcoord.set_size(4*this.V_texcoord.length),this.vbo_texcoord.set_data(0,this.V_texcoord)}_set_visuals(){const{line_color:t,line_alpha:e,line_width:s,line_cap:i,line_join:a,line_dash:o,line_dash_offset:n}=this.glyph.visuals.line,[_,r,h,u]=l.color2rgba(t.value,e.value),d=s.value,p=c[i.value],v=f[a.value];this.prog.set_uniform(\"u_color\",\"vec4\",[_/255,r/255,h/255,u/255]),this.prog.set_uniform(\"u_linewidth\",\"float\",[d]),this.prog.set_uniform(\"u_antialias\",\"float\",[.9]),this.prog.set_uniform(\"u_linecaps\",\"vec2\",[p,p]),this.prog.set_uniform(\"u_linejoin\",\"float\",[v]),this.prog.set_uniform(\"u_miter_limit\",\"float\",[10]);const b=g.resolve_line_dash(o.value);let m=0,w=1;b.length&&([m,w]=this.dash_atlas.get_atlas_data(b)),this.prog.set_uniform(\"u_dash_index\",\"float\",[m]),this.prog.set_uniform(\"u_dash_phase\",\"float\",[n.value]),this.prog.set_uniform(\"u_dash_period\",\"float\",[w]),this.prog.set_uniform(\"u_dash_caps\",\"vec2\",[p,p]),this.prog.set_uniform(\"u_closed\",\"float\",[0])}_bake(){let t,e,s,i,a,o,n,_;const r=this.nvertices,h=this.glyph.sx,l=this.glyph.sy,g=n=new Float32Array(2*r),u=new Float32Array(2*r),f=_=new Float32Array(4*r);for(let t=0,e=r;t<e;t++)g[2*t+0]=isFinite(h[t])?h[t]:0,g[2*t+1]=isFinite(l[t])?l[t]:0;this.tangents=e=new Float32Array(2*r-2);for(let t=0,s=r-1;t<s;t++)e[2*t+0]=n[2*(t+1)+0]-n[2*t+0],e[2*t+1]=n[2*(t+1)+1]-n[2*t+1];for(let t=0,s=r-1;t<s;t++)f[4*(t+1)+0]=e[2*t+0],f[4*(t+1)+1]=e[2*t+1],f[4*t+2]=e[2*t+0],f[4*t+3]=e[2*t+1];f[0]=e[0],f[1]=e[1],f[4*(r-1)+2]=e[2*(r-2)+0],f[4*(r-1)+3]=e[2*(r-2)+1];const c=new Float32Array(r);for(let t=0,e=r;t<e;t++)c[t]=Math.atan2(_[4*t+0]*_[4*t+3]-_[4*t+1]*_[4*t+2],_[4*t+0]*_[4*t+2]+_[4*t+1]*_[4*t+3]);for(let t=0,e=r-1;t<e;t++)u[2*t+0]=c[t],u[2*t+1]=c[t+1];for(let t=0,e=r;t<e;t++)isFinite(h[t])||(g[2*t+0]=h[t]),isFinite(l[t])||(g[2*t+1]=l[t]);const d=4*r-4;this.V_position=i=new Float32Array(2*d),this.V_angles=s=new Float32Array(2*d),this.V_tangents=a=new Float32Array(4*d),this.V_texcoord=o=new Float32Array(2*d);for(let t=0,e=r;t<e;t++)for(let e=0;e<4;e++){for(let a=0;a<2;a++)i[2*(4*t+e-2)+a]=g[2*t+a],s[2*(4*t+e)+a]=u[2*t+a];for(let s=0;s<4;s++)a[4*(4*t+e-2)+s]=f[4*t+s]}for(let t=0,e=r;t<e;t++)o[2*(4*t+0)+0]=-1,o[2*(4*t+1)+0]=-1,o[2*(4*t+2)+0]=1,o[2*(4*t+3)+0]=1,o[2*(4*t+0)+1]=-1,o[2*(4*t+1)+1]=1,o[2*(4*t+2)+1]=-1,o[2*(4*t+3)+1]=1;const p=6*(r-1);this.I_triangles=t=new Uint32Array(p);for(let e=0,s=r;e<s;e++)t[6*e+0]=0+4*e,t[6*e+1]=1+4*e,t[6*e+2]=3+4*e,t[6*e+3]=2+4*e,t[6*e+4]=0+4*e,t[6*e+5]=3+4*e}_update_scale(t,e){let s;const i=this.nvertices,a=4*i-4,o=this.tangents,n=new Float32Array(i-1),_=new Float32Array(2*i);this.V_segment=s=new Float32Array(2*a);for(let s=0,a=i-1;s<a;s++)n[s]=Math.sqrt((o[2*s+0]*t)**2+(o[2*s+1]*e)**2);let r=0;for(let t=0,e=i-1;t<e;t++)r+=n[t],_[2*(t+1)+0]=r,_[2*t+1]=r;for(let t=0,e=i;t<e;t++)for(let e=0;e<4;e++)for(let i=0;i<2;i++)s[2*(4*t+e)+i]=_[2*t+i];this.cumsum=r,this.vbo_segment.set_size(4*this.V_segment.length),this.vbo_segment.set_data(0,this.V_segment)}}s.LineGL=d,d.__name__=\"LineGL\"},\n",
" function _(e,r,f,u,x){u(),x(\"Program\",e(110).Program),x(\"Texture2d\",e(112).Texture2d);var t=e(111);x(\"IndexBuffer\",t.IndexBuffer),x(\"VertexBuffer\",t.VertexBuffer)},\n",
" function _(t,e,i,s,a){s();const r=t(111);class n{constructor(t){this.gl=t,this.UTYPEMAP={float:\"uniform1fv\",vec2:\"uniform2fv\",vec3:\"uniform3fv\",vec4:\"uniform4fv\",int:\"uniform1iv\",ivec2:\"uniform2iv\",ivec3:\"uniform3iv\",ivec4:\"uniform4iv\",bool:\"uniform1iv\",bvec2:\"uniform2iv\",bvec3:\"uniform3iv\",bvec4:\"uniform4iv\",mat2:\"uniformMatrix2fv\",mat3:\"uniformMatrix3fv\",mat4:\"uniformMatrix4fv\",sampler1D:\"uniform1i\",sampler2D:\"uniform1i\",sampler3D:\"uniform1i\"},this.ATYPEMAP={float:\"vertexAttrib1f\",vec2:\"vertexAttrib2f\",vec3:\"vertexAttrib3f\",vec4:\"vertexAttrib4f\"},this.ATYPEINFO={float:[1,5126],vec2:[2,5126],vec3:[3,5126],vec4:[4,5126],vec4_uint8:[4,5121]},this._linked=!1,this._validated=!1,this._unset_variables=new Set,this._known_invalid=new Set,this._locations=new Map,this._samplers=new Map,this._attributes=new Map,this.handle=this.gl.createProgram()}delete(){this.gl.deleteProgram(this.handle)}activate(){this.gl.useProgram(this.handle)}deactivate(){this.gl.useProgram(0)}set_shaders(t,e){const i=this.gl;this._linked=!1;const s=i.createShader(i.VERTEX_SHADER),a=i.createShader(i.FRAGMENT_SHADER),r=[[t,s,\"vertex\"],[e,a,\"fragment\"]];for(const[t,e,s]of r){i.shaderSource(e,t),i.compileShader(e);if(!i.getShaderParameter(e,i.COMPILE_STATUS)){const t=i.getShaderInfoLog(e);throw new Error(`errors in ${s} shader:\\n${t}`)}}if(i.attachShader(this.handle,s),i.attachShader(this.handle,a),i.linkProgram(this.handle),!i.getProgramParameter(this.handle,i.LINK_STATUS)){const t=i.getProgramInfoLog(this.handle);throw new Error(`Program link error:\\n${t}`)}this._unset_variables=this._get_active_attributes_and_uniforms(),i.detachShader(this.handle,s),i.detachShader(this.handle,a),i.deleteShader(s),i.deleteShader(a),this._known_invalid.clear(),this._linked=!0}_get_active_attributes_and_uniforms(){const t=this.gl;this._locations.clear();const e=new RegExp(\"(\\\\w+)\\\\s*(\\\\[(\\\\d+)\\\\])\\\\s*\"),i=t.getProgramParameter(this.handle,t.ACTIVE_UNIFORMS),s=[],a=[],r=[[s,t.getProgramParameter(this.handle,t.ACTIVE_ATTRIBUTES),t.getActiveAttrib,t.getAttribLocation],[a,i,t.getActiveUniform,t.getUniformLocation]];for(const[i,s,a,n]of r)for(let r=0;r<s;r+=1){const s=a.call(t,this.handle,r),o=s.name,h=o.match(e);if(null!=h){const t=h[1];for(let e=0;e<s.size;e+=1)i.push([`${t}[${e}]`,s.type])}else i.push([o,s.type]);this._locations.set(o,n.call(t,this.handle,o))}const n=new Set;for(const[t]of s)n.add(t);for(const[t]of a)n.add(t);return n}set_texture(t,e){var i;if(!this._linked)throw new Error(\"Cannot set uniform when program has no code\");const s=null!==(i=this._locations.get(t))&&void 0!==i?i:-1;if(s<0)this._known_invalid.has(t)||(this._known_invalid.add(t),console.log(`\"Variable ${t} is not an active texture`));else{this._unset_variables.has(t)&&this._unset_variables.delete(t),this.activate();{let i=this._samplers.size;this._samplers.has(t)&&(i=this._samplers.get(t)[2]),this._samplers.set(t,[e._target,e.handle,i]),this.gl.uniform1i(s,i)}}}set_uniform(t,e,i){var s;if(!this._linked)throw new Error(\"Cannot set uniform when program has no code\");const a=null!==(s=this._locations.get(t))&&void 0!==s?s:-1;if(a<0)return void(this._known_invalid.has(t)||(this._known_invalid.add(t),console.log(`Variable ${t} is not an active uniform`)));this._unset_variables.has(t)&&this._unset_variables.delete(t);let r=1;if(!e.startsWith(\"mat\")){const t=\"int\"==e||\"bool\"==e?\"float\":e.replace(/^ib/,\"\");r=Math.floor(i.length/this.ATYPEINFO[t][0])}if(r>1)for(let e=0;e<r;e+=1)if(this._unset_variables.has(`${t}[${e}]`)){const i=`${t}[${e}]`;this._unset_variables.has(i)&&this._unset_variables.delete(i)}const n=this.UTYPEMAP[e];this.activate(),e.startsWith(\"mat\")?this.gl[n](a,!1,i):this.gl[n](a,i)}set_attribute(t,e,i,s=0,a=0,n=!1){var o;if(!this._linked)throw new Error(\"Cannot set attribute when program has no code\");const h=null!==(o=this._locations.get(t))&&void 0!==o?o:-1;if(h<0)this._known_invalid.has(t)||(this._known_invalid.add(t),i instanceof r.VertexBuffer&&a>0||console.log(`Variable ${t} is not an active attribute`));else if(this._unset_variables.has(t)&&this._unset_variables.delete(t),this.activate(),i instanceof r.VertexBuffer){const[r,o]=this.ATYPEINFO[e],l=\"vertexAttribPointer\",_=[r,o,n,s,a];this._attributes.set(t,[i.handle,h,l,_])}else{const s=this.ATYPEMAP[e];this._attributes.set(t,[null,h,s,i])}}_pre_draw(){this.activate();for(const[t,e,i]of this._samplers.values())this.gl.activeTexture(this.gl.TEXTURE0+i),this.gl.bindTexture(t,e);for(const[t,e,i,s]of this._attributes.values())null!=t?(this.gl.bindBuffer(this.gl.ARRAY_BUFFER,t),this.gl.enableVertexAttribArray(e),this.gl[i].apply(this.gl,[e,...s])):(this.gl.bindBuffer(this.gl.ARRAY_BUFFER,null),this.gl.disableVertexAttribArray(e),this.gl[i].apply(this.gl,[e,...s]));this._validated||(this._validated=!0,this._validate())}_validate(){if(this._unset_variables.size&&console.log(`Program has unset variables: ${this._unset_variables}`),this.gl.validateProgram(this.handle),!this.gl.getProgramParameter(this.handle,this.gl.VALIDATE_STATUS))throw console.log(this.gl.getProgramInfoLog(this.handle)),new Error(\"Program validation error\")}draw(t,e){if(!this._linked)throw new Error(\"Cannot draw program if code has not been set\");if(e instanceof r.IndexBuffer){this._pre_draw(),e.activate();const i=e.buffer_size/2,s=this.gl.UNSIGNED_SHORT;this.gl.drawElements(t,i,s,0),e.deactivate()}else{const[i,s]=e;0!=s&&(this._pre_draw(),this.gl.drawArrays(t,i,s))}}}i.Program=n,n.__name__=\"Program\"},\n",
" function _(t,e,s,i,a){i();class r{constructor(t){this.gl=t,this._usage=35048,this.buffer_size=0,this.handle=this.gl.createBuffer()}delete(){this.gl.deleteBuffer(this.handle)}activate(){this.gl.bindBuffer(this._target,this.handle)}deactivate(){this.gl.bindBuffer(this._target,null)}set_size(t){t!=this.buffer_size&&(this.activate(),this.gl.bufferData(this._target,t,this._usage),this.buffer_size=t)}set_data(t,e){this.activate(),this.gl.bufferSubData(this._target,t,e)}}s.Buffer=r,r.__name__=\"Buffer\";class f extends r{constructor(){super(...arguments),this._target=34962}}s.VertexBuffer=f,f.__name__=\"VertexBuffer\";class h extends r{constructor(){super(...arguments),this._target=34963}}s.IndexBuffer=h,h.__name__=\"IndexBuffer\"},\n",
" function _(t,e,i,a,r){a();const s=t(11);class h{constructor(t){this.gl=t,this._target=3553,this._types={Int8Array:5120,Uint8Array:5121,Int16Array:5122,Uint16Array:5123,Int32Array:5124,Uint32Array:5125,Float32Array:5126},this.handle=this.gl.createTexture()}delete(){this.gl.deleteTexture(this.handle)}activate(){this.gl.bindTexture(this._target,this.handle)}deactivate(){this.gl.bindTexture(this._target,0)}_get_alignment(t){const e=[4,8,2,1];for(const i of e)if(t%i==0)return i;s.unreachable()}set_wrapping(t,e){this.activate(),this.gl.texParameterf(this._target,this.gl.TEXTURE_WRAP_S,t),this.gl.texParameterf(this._target,this.gl.TEXTURE_WRAP_T,e)}set_interpolation(t,e){this.activate(),this.gl.texParameterf(this._target,this.gl.TEXTURE_MIN_FILTER,t),this.gl.texParameterf(this._target,this.gl.TEXTURE_MAG_FILTER,e)}set_size([t,e],i){var a,r,s;t==(null===(a=this._shape_format)||void 0===a?void 0:a.width)&&e==(null===(r=this._shape_format)||void 0===r?void 0:r.height)&&i==(null===(s=this._shape_format)||void 0===s?void 0:s.format)||(this._shape_format={width:t,height:e,format:i},this.activate(),this.gl.texImage2D(this._target,0,i,t,e,0,i,this.gl.UNSIGNED_BYTE,null))}set_data(t,[e,i],a){this.activate();const{format:r}=this._shape_format,[s,h]=t,l=this._types[a.constructor.name];if(null==l)throw new Error(`Type ${a.constructor.name} not allowed for texture`);const _=this._get_alignment(e);4!=_&&this.gl.pixelStorei(this.gl.UNPACK_ALIGNMENT,_),this.gl.texSubImage2D(this._target,0,s,h,e,i,r,l,a),4!=_&&this.gl.pixelStorei(this.gl.UNPACK_ALIGNMENT,4)}}i.Texture2d=h,h.__name__=\"Texture2d\"},\n",
" function _(e,t,s,i,h){i();class a{constructor(e,t){this.gl=e,this.glyph=t,this.nvertices=0,this.size_changed=!1,this.data_changed=!1,this.visuals_changed=!1}set_data_changed(){const{data_size:e}=this.glyph;e!=this.nvertices&&(this.nvertices=e,this.size_changed=!0),this.data_changed=!0}set_visuals_changed(){this.visuals_changed=!0}render(e,t,s){if(0==t.length)return!0;const{width:i,height:h}=this.glyph.renderer.plot_view.canvas_view.webgl.canvas,a={pixel_ratio:this.glyph.renderer.plot_view.canvas_view.pixel_ratio,width:i,height:h};return this.draw(t,s,a),!0}}s.BaseGLGlyph=a,a.__name__=\"BaseGLGlyph\"},\n",
" function _(n,e,t,a,i){a();t.default=\"\\nprecision mediump float;\\n\\nconst float PI = 3.14159265358979323846264;\\nconst float THETA = 15.0 * 3.14159265358979323846264/180.0;\\n\\nuniform float u_pixel_ratio;\\nuniform vec2 u_canvas_size, u_offset;\\nuniform vec2 u_scale_aspect;\\nuniform float u_scale_length;\\n\\nuniform vec4 u_color;\\nuniform float u_antialias;\\nuniform float u_length;\\nuniform float u_linewidth;\\nuniform float u_dash_index;\\nuniform float u_closed;\\n\\nattribute vec2 a_position;\\nattribute vec4 a_tangents;\\nattribute vec2 a_segment;\\nattribute vec2 a_angles;\\nattribute vec2 a_texcoord;\\n\\nvarying vec4 v_color;\\nvarying vec2 v_segment;\\nvarying vec2 v_angles;\\nvarying vec2 v_texcoord;\\nvarying vec2 v_miter;\\nvarying float v_length;\\nvarying float v_linewidth;\\n\\nfloat cross(in vec2 v1, in vec2 v2)\\n{\\n return v1.x*v2.y - v1.y*v2.x;\\n}\\n\\nfloat signed_distance(in vec2 v1, in vec2 v2, in vec2 v3)\\n{\\n return cross(v2-v1,v1-v3) / length(v2-v1);\\n}\\n\\nvoid rotate( in vec2 v, in float alpha, out vec2 result )\\n{\\n float c = cos(alpha);\\n float s = sin(alpha);\\n result = vec2( c*v.x - s*v.y,\\n s*v.x + c*v.y );\\n}\\n\\nvoid main()\\n{\\n bool closed = (u_closed > 0.0);\\n\\n // Attributes and uniforms to varyings\\n v_color = u_color;\\n v_linewidth = u_linewidth;\\n v_segment = a_segment * u_scale_length;\\n v_length = u_length * u_scale_length;\\n\\n // Scale to map to pixel coordinates. The original algorithm from the paper\\n // assumed isotropic scale. We obviously do not have this.\\n vec2 abs_scale_aspect = abs(u_scale_aspect);\\n vec2 abs_scale = u_scale_length * abs_scale_aspect;\\n\\n // Correct angles for aspect ratio\\n vec2 av;\\n av = vec2(1.0, tan(a_angles.x)) / abs_scale_aspect;\\n v_angles.x = atan(av.y, av.x);\\n av = vec2(1.0, tan(a_angles.y)) / abs_scale_aspect;\\n v_angles.y = atan(av.y, av.x);\\n\\n // Thickness below 1 pixel are represented using a 1 pixel thickness\\n // and a modified alpha\\n v_color.a = min(v_linewidth, v_color.a);\\n v_linewidth = max(v_linewidth, 1.0);\\n\\n // If color is fully transparent we just will discard the fragment anyway\\n if( v_color.a <= 0.0 ) {\\n gl_Position = vec4(0.0,0.0,0.0,1.0);\\n return;\\n }\\n\\n // This is the actual half width of the line\\n float w = ceil(u_antialias+v_linewidth)/2.0;\\n\\n vec2 position = a_position;\\n\\n vec2 t1 = normalize(a_tangents.xy * abs_scale_aspect); // note the scaling for aspect ratio here\\n vec2 t2 = normalize(a_tangents.zw * abs_scale_aspect);\\n float u = a_texcoord.x;\\n float v = a_texcoord.y;\\n vec2 o1 = vec2( +t1.y, -t1.x);\\n vec2 o2 = vec2( +t2.y, -t2.x);\\n\\n // This is a join\\n // ----------------------------------------------------------------\\n if( t1 != t2 ) {\\n float angle = atan (t1.x*t2.y-t1.y*t2.x, t1.x*t2.x+t1.y*t2.y); // Angle needs recalculation for some reason\\n vec2 t = normalize(t1+t2);\\n vec2 o = vec2( + t.y, - t.x);\\n\\n if ( u_dash_index > 0.0 )\\n {\\n // Broken angle\\n // ----------------------------------------------------------------\\n if( (abs(angle) > THETA) ) {\\n position += v * w * o / cos(angle/2.0);\\n float s = sign(angle);\\n if( angle < 0.0 ) {\\n if( u == +1.0 ) {\\n u = v_segment.y + v * w * tan(angle/2.0);\\n if( v == 1.0 ) {\\n position -= 2.0 * w * t1 / sin(angle);\\n u -= 2.0 * w / sin(angle);\\n }\\n } else {\\n u = v_segment.x - v * w * tan(angle/2.0);\\n if( v == 1.0 ) {\\n position += 2.0 * w * t2 / sin(angle);\\n u += 2.0*w / sin(angle);\\n }\\n }\\n } else {\\n if( u == +1.0 ) {\\n u = v_segment.y + v * w * tan(angle/2.0);\\n if( v == -1.0 ) {\\n position += 2.0 * w * t1 / sin(angle);\\n u += 2.0 * w / sin(angle);\\n }\\n } else {\\n u = v_segment.x - v * w * tan(angle/2.0);\\n if( v == -1.0 ) {\\n position -= 2.0 * w * t2 / sin(angle);\\n u -= 2.0*w / sin(angle);\\n }\\n }\\n }\\n // Continuous angle\\n // ------------------------------------------------------------\\n } else {\\n position += v * w * o / cos(angle/2.0);\\n if( u == +1.0 ) u = v_segment.y;\\n else u = v_segment.x;\\n }\\n }\\n\\n // Solid line\\n // --------------------------------------------------------------------\\n else\\n {\\n position.xy += v * w * o / cos(angle/2.0);\\n if( angle < 0.0 ) {\\n if( u == +1.0 ) {\\n u = v_segment.y + v * w * tan(angle/2.0);\\n } else {\\n u = v_segment.x - v * w * tan(angle/2.0);\\n }\\n } else {\\n if( u == +1.0 ) {\\n u = v_segment.y + v * w * tan(angle/2.0);\\n } else {\\n u = v_segment.x - v * w * tan(angle/2.0);\\n }\\n }\\n }\\n\\n // This is a line start or end (t1 == t2)\\n // ------------------------------------------------------------------------\\n } else {\\n position += v * w * o1;\\n if( u == -1.0 ) {\\n u = v_segment.x - w;\\n position -= w * t1;\\n } else {\\n u = v_segment.y + w;\\n position += w * t2;\\n }\\n }\\n\\n // Miter distance\\n // ------------------------------------------------------------------------\\n vec2 t;\\n vec2 curr = a_position * abs_scale;\\n if( a_texcoord.x < 0.0 ) {\\n vec2 next = curr + t2*(v_segment.y-v_segment.x);\\n\\n rotate( t1, +v_angles.x/2.0, t);\\n v_miter.x = signed_distance(curr, curr+t, position);\\n\\n rotate( t2, +v_angles.y/2.0, t);\\n v_miter.y = signed_distance(next, next+t, position);\\n } else {\\n vec2 prev = curr - t1*(v_segment.y-v_segment.x);\\n\\n rotate( t1, -v_angles.x/2.0,t);\\n v_miter.x = signed_distance(prev, prev+t, position);\\n\\n rotate( t2, -v_angles.y/2.0,t);\\n v_miter.y = signed_distance(curr, curr+t, position);\\n }\\n\\n if (!closed && v_segment.x <= 0.0) {\\n v_miter.x = 1e10;\\n }\\n if (!closed && v_segment.y >= v_length)\\n {\\n v_miter.y = 1e10;\\n }\\n\\n v_texcoord = vec2( u, v*w );\\n\\n // Calculate position in device coordinates. Note that we\\n // already scaled with abs scale above.\\n vec2 normpos = position * sign(u_scale_aspect);\\n normpos += 0.5; // make up for Bokeh's offset\\n normpos /= u_canvas_size / u_pixel_ratio; // in 0..1\\n gl_Position = vec4(normpos*2.0-1.0, 0.0, 1.0);\\n gl_Position.y *= -1.0;\\n}\\n\"},\n",
" function _(n,t,e,s,a){s();e.default=\"\\nprecision mediump float;\\n\\nconst float PI = 3.14159265358979323846264;\\nconst float THETA = 15.0 * 3.14159265358979323846264/180.0;\\n\\nuniform sampler2D u_dash_atlas;\\n\\nuniform vec2 u_linecaps;\\nuniform float u_miter_limit;\\nuniform float u_linejoin;\\nuniform float u_antialias;\\nuniform float u_dash_phase;\\nuniform float u_dash_period;\\nuniform float u_dash_index;\\nuniform vec2 u_dash_caps;\\nuniform float u_closed;\\n\\nvarying vec4 v_color;\\nvarying vec2 v_segment;\\nvarying vec2 v_angles;\\nvarying vec2 v_texcoord;\\nvarying vec2 v_miter;\\nvarying float v_length;\\nvarying float v_linewidth;\\n\\n// Compute distance to cap ----------------------------------------------------\\nfloat cap( int type, float dx, float dy, float t, float linewidth )\\n{\\n float d = 0.0;\\n dx = abs(dx);\\n dy = abs(dy);\\n if (type == 0) discard; // None\\n else if (type == 1) d = sqrt(dx*dx+dy*dy); // Round\\n else if (type == 3) d = (dx+abs(dy)); // Triangle in\\n else if (type == 2) d = max(abs(dy),(t+dx-abs(dy))); // Triangle out\\n else if (type == 4) d = max(dx,dy); // Square\\n else if (type == 5) d = max(dx+t,dy); // Butt\\n return d;\\n}\\n\\n// Compute distance to join -------------------------------------------------\\nfloat join( in int type, in float d, in vec2 segment, in vec2 texcoord, in vec2 miter,\\n in float linewidth )\\n{\\n // texcoord.x is distance from start\\n // texcoord.y is distance from centerline\\n // segment.x and y indicate the limits (as for texcoord.x) for this segment\\n\\n float dx = texcoord.x;\\n\\n // Round join\\n if( type == 1 ) {\\n if (dx < segment.x) {\\n d = max(d,length( texcoord - vec2(segment.x,0.0)));\\n //d = length( texcoord - vec2(segment.x,0.0));\\n } else if (dx > segment.y) {\\n d = max(d,length( texcoord - vec2(segment.y,0.0)));\\n //d = length( texcoord - vec2(segment.y,0.0));\\n }\\n }\\n // Bevel join\\n else if ( type == 2 ) {\\n if (dx < segment.x) {\\n vec2 x = texcoord - vec2(segment.x,0.0);\\n d = max(d, max(abs(x.x), abs(x.y)));\\n\\n } else if (dx > segment.y) {\\n vec2 x = texcoord - vec2(segment.y,0.0);\\n d = max(d, max(abs(x.x), abs(x.y)));\\n }\\n /* Original code for bevel which does not work for us\\n if( (dx < segment.x) || (dx > segment.y) )\\n d = max(d, min(abs(x.x),abs(x.y)));\\n */\\n }\\n\\n return d;\\n}\\n\\nvoid main()\\n{\\n // If color is fully transparent we just discard the fragment\\n if( v_color.a <= 0.0 ) {\\n discard;\\n }\\n\\n // Test if dash pattern is the solid one (0)\\n bool solid = (u_dash_index == 0.0);\\n\\n // Test if path is closed\\n bool closed = (u_closed > 0.0);\\n\\n vec4 color = v_color;\\n float dx = v_texcoord.x;\\n float dy = v_texcoord.y;\\n float t = v_linewidth/2.0-u_antialias;\\n float width = 1.0; //v_linewidth; original code had dashes scale with line width, we do not\\n float d = 0.0;\\n\\n vec2 linecaps = u_linecaps;\\n vec2 dash_caps = u_dash_caps;\\n float line_start = 0.0;\\n float line_stop = v_length;\\n\\n // Apply miter limit; fragments too far into the miter are simply discarded\\n if( (dx < v_segment.x) || (dx > v_segment.y) ) {\\n float into_miter = max(v_segment.x - dx, dx - v_segment.y);\\n if (into_miter > u_miter_limit*v_linewidth/2.0)\\n discard;\\n }\\n\\n // Solid line --------------------------------------------------------------\\n if( solid ) {\\n d = abs(dy);\\n if( (!closed) && (dx < line_start) ) {\\n d = cap( int(u_linecaps.x), abs(dx), abs(dy), t, v_linewidth );\\n }\\n else if( (!closed) && (dx > line_stop) ) {\\n d = cap( int(u_linecaps.y), abs(dx)-line_stop, abs(dy), t, v_linewidth );\\n }\\n else {\\n d = join( int(u_linejoin), abs(dy), v_segment, v_texcoord, v_miter, v_linewidth );\\n }\\n\\n // Dash line --------------------------------------------------------------\\n } else {\\n float segment_start = v_segment.x;\\n float segment_stop = v_segment.y;\\n float segment_center= (segment_start+segment_stop)/2.0;\\n float freq = u_dash_period*width;\\n float u = mod( dx + u_dash_phase*width, freq);\\n vec4 tex = texture2D(u_dash_atlas, vec2(u/freq, u_dash_index)) * 255.0 -10.0; // conversion to int-like\\n float dash_center= tex.x * width;\\n float dash_type = tex.y;\\n float _start = tex.z * width;\\n float _stop = tex.a * width;\\n float dash_start = dx - u + _start;\\n float dash_stop = dx - u + _stop;\\n\\n // Compute extents of the first dash (the one relative to v_segment.x)\\n // Note: this could be computed in the vertex shader\\n if( (dash_stop < segment_start) && (dash_caps.x != 5.0) ) {\\n float u = mod(segment_start + u_dash_phase*width, freq);\\n vec4 tex = texture2D(u_dash_atlas, vec2(u/freq, u_dash_index)) * 255.0 -10.0; // conversion to int-like\\n dash_center= tex.x * width;\\n //dash_type = tex.y;\\n float _start = tex.z * width;\\n float _stop = tex.a * width;\\n dash_start = segment_start - u + _start;\\n dash_stop = segment_start - u + _stop;\\n }\\n\\n // Compute extents of the last dash (the one relatives to v_segment.y)\\n // Note: This could be computed in the vertex shader\\n else if( (dash_start > segment_stop) && (dash_caps.y != 5.0) ) {\\n float u = mod(segment_stop + u_dash_phase*width, freq);\\n vec4 tex = texture2D(u_dash_atlas, vec2(u/freq, u_dash_index)) * 255.0 -10.0; // conversion to int-like\\n dash_center= tex.x * width;\\n //dash_type = tex.y;\\n float _start = tex.z * width;\\n float _stop = tex.a * width;\\n dash_start = segment_stop - u + _start;\\n dash_stop = segment_stop - u + _stop;\\n }\\n\\n // This test if the we are dealing with a discontinuous angle\\n bool discontinuous = ((dx < segment_center) && abs(v_angles.x) > THETA) ||\\n ((dx >= segment_center) && abs(v_angles.y) > THETA);\\n //if( dx < line_start) discontinuous = false;\\n //if( dx > line_stop) discontinuous = false;\\n\\n float d_join = join( int(u_linejoin), abs(dy),\\n v_segment, v_texcoord, v_miter, v_linewidth );\\n\\n // When path is closed, we do not have room for linecaps, so we make room\\n // by shortening the total length\\n if (closed) {\\n line_start += v_linewidth/2.0;\\n line_stop -= v_linewidth/2.0;\\n }\\n\\n // We also need to take antialias area into account\\n //line_start += u_antialias;\\n //line_stop -= u_antialias;\\n\\n // Check is dash stop is before line start\\n if( dash_stop <= line_start ) {\\n discard;\\n }\\n // Check is dash start is beyond line stop\\n if( dash_start >= line_stop ) {\\n discard;\\n }\\n\\n // Check if current dash start is beyond segment stop\\n if( discontinuous ) {\\n // Dash start is beyond segment, we discard\\n if( (dash_start > segment_stop) ) {\\n discard;\\n //gl_FragColor = vec4(1.0,0.0,0.0,.25); return;\\n }\\n\\n // Dash stop is before segment, we discard\\n if( (dash_stop < segment_start) ) {\\n discard; //gl_FragColor = vec4(0.0,1.0,0.0,.25); return;\\n }\\n\\n // Special case for round caps (nicer with this)\\n if( dash_caps.x == 1.0 ) {\\n if( (u > _stop) && (dash_stop > segment_stop ) && (abs(v_angles.y) < PI/2.0)) {\\n discard;\\n }\\n }\\n\\n // Special case for round caps (nicer with this)\\n if( dash_caps.y == 1.0 ) {\\n if( (u < _start) && (dash_start < segment_start ) && (abs(v_angles.x) < PI/2.0)) {\\n discard;\\n }\\n }\\n\\n // Special case for triangle caps (in & out) and square\\n // We make sure the cap stop at crossing frontier\\n if( (dash_caps.x != 1.0) && (dash_caps.x != 5.0) ) {\\n if( (dash_start < segment_start ) && (abs(v_angles.x) < PI/2.0) ) {\\n float a = v_angles.x/2.0;\\n float x = (segment_start-dx)*cos(a) - dy*sin(a);\\n float y = (segment_start-dx)*sin(a) + dy*cos(a);\\n if( x > 0.0 ) discard;\\n // We transform the cap into square to avoid holes\\n dash_caps.x = 4.0;\\n }\\n }\\n\\n // Special case for triangle caps (in & out) and square\\n // We make sure the cap stop at crossing frontier\\n if( (dash_caps.y != 1.0) && (dash_caps.y != 5.0) ) {\\n if( (dash_stop > segment_stop ) && (abs(v_angles.y) < PI/2.0) ) {\\n float a = v_angles.y/2.0;\\n float x = (dx-segment_stop)*cos(a) - dy*sin(a);\\n float y = (dx-segment_stop)*sin(a) + dy*cos(a);\\n if( x > 0.0 ) discard;\\n // We transform the caps into square to avoid holes\\n dash_caps.y = 4.0;\\n }\\n }\\n }\\n\\n // Line cap at start\\n if( (dx < line_start) && (dash_start < line_start) && (dash_stop > line_start) ) {\\n d = cap( int(linecaps.x), dx-line_start, dy, t, v_linewidth);\\n }\\n // Line cap at stop\\n else if( (dx > line_stop) && (dash_stop > line_stop) && (dash_start < line_stop) ) {\\n d = cap( int(linecaps.y), dx-line_stop, dy, t, v_linewidth);\\n }\\n // Dash cap left - dash_type = -1, 0 or 1, but there may be roundoff errors\\n else if( dash_type < -0.5 ) {\\n d = cap( int(dash_caps.y), abs(u-dash_center), dy, t, v_linewidth);\\n if( (dx > line_start) && (dx < line_stop) )\\n d = max(d,d_join);\\n }\\n // Dash cap right\\n else if( dash_type > 0.5 ) {\\n d = cap( int(dash_caps.x), abs(dash_center-u), dy, t, v_linewidth);\\n if( (dx > line_start) && (dx < line_stop) )\\n d = max(d,d_join);\\n }\\n // Dash body (plain)\\n else {// if( dash_type > -0.5 && dash_type < 0.5) {\\n d = abs(dy);\\n }\\n\\n // Line join\\n if( (dx > line_start) && (dx < line_stop)) {\\n if( (dx <= segment_start) && (dash_start <= segment_start)\\n && (dash_stop >= segment_start) ) {\\n d = d_join;\\n // Antialias at outer border\\n float angle = PI/2.+v_angles.x;\\n float f = abs( (segment_start - dx)*cos(angle) - dy*sin(angle));\\n d = max(f,d);\\n }\\n else if( (dx > segment_stop) && (dash_start <= segment_stop)\\n && (dash_stop >= segment_stop) ) {\\n d = d_join;\\n // Antialias at outer border\\n float angle = PI/2.+v_angles.y;\\n float f = abs((dx - segment_stop)*cos(angle) - dy*sin(angle));\\n d = max(f,d);\\n }\\n else if( dx < (segment_start - v_linewidth/2.)) {\\n discard;\\n }\\n else if( dx > (segment_stop + v_linewidth/2.)) {\\n discard;\\n }\\n }\\n else if( dx < (segment_start - v_linewidth/2.)) {\\n discard;\\n }\\n else if( dx > (segment_stop + v_linewidth/2.)) {\\n discard;\\n }\\n }\\n\\n // Distance to border ------------------------------------------------------\\n d = d - t;\\n if( d < 0.0 ) {\\n gl_FragColor = color;\\n } else {\\n d /= u_antialias;\\n gl_FragColor = vec4(color.rgb, exp(-d*d)*color.a);\\n }\\n}\\n\"},\n",
" function _(i,t,s,e,l){e();const a=i(1),n=i(64),_=i(106),o=a.__importStar(i(107)),h=a.__importStar(i(48)),c=i(59);class r extends n.XYGlyphView{_inner_loop(i,t,s,e,l){for(const a of t){const t=s[a],n=e[a];0!=a?isNaN(t+n)?(i.closePath(),l.apply(i),i.beginPath()):i.lineTo(t,n):(i.beginPath(),i.moveTo(t,n))}i.closePath(),l.call(i)}_render(i,t,s){const{sx:e,sy:l}=null!=s?s:this;this.visuals.fill.doit&&(this.visuals.fill.set_value(i),this._inner_loop(i,t,e,l,i.fill)),this.visuals.hatch.doit&&(this.visuals.hatch.set_value(i),this._inner_loop(i,t,e,l,i.fill)),this.visuals.line.doit&&(this.visuals.line.set_value(i),this._inner_loop(i,t,e,l,i.stroke))}draw_legend_for_index(i,t,s){_.generic_area_scalar_legend(this.visuals,i,t)}_hit_point(i){const t=new c.Selection;return o.point_in_poly(i.sx,i.sy,this.sx,this.sy)&&(t.add_to_selected_glyphs(this.model),t.view=this),t}}s.PatchView=r,r.__name__=\"PatchView\";class p extends n.XYGlyph{constructor(i){super(i)}static init_Patch(){this.prototype.default_view=r,this.mixins([h.LineScalar,h.FillScalar,h.HatchScalar])}}s.Patch=p,p.__name__=\"Patch\",p.init_Patch()},\n",
" function _(t,e,s,i,n){i();const a=t(1),r=t(24),h=t(118),_=a.__importStar(t(107)),l=a.__importStar(t(18)),o=t(59);class c extends h.AreaView{_index_data(t){const{min:e,max:s}=Math,{data_size:i}=this;for(let n=0;n<i;n++){const i=this._x1[n],a=this._x2[n],r=this._y[n];isNaN(i+a+r)||!isFinite(i+a+r)?t.add_empty():t.add(e(i,a),r,s(i,a),r)}}_inner(t,e,s,i,n){t.beginPath();for(let s=0,n=e.length;s<n;s++)t.lineTo(e[s],i[s]);for(let e=s.length-1;e>=0;e--)t.lineTo(s[e],i[e]);t.closePath(),n.call(t)}_render(t,e,s){const{sx1:i,sx2:n,sy:a}=null!=s?s:this;this.visuals.fill.doit&&(this.visuals.fill.set_value(t),this._inner(t,i,n,a,t.fill)),this.visuals.hatch.doit&&(this.visuals.hatch.set_value(t),this._inner(t,i,n,a,t.fill))}_hit_point(t){const e=this.sy.length,s=new r.ScreenArray(2*e),i=new r.ScreenArray(2*e);for(let t=0,n=e;t<n;t++)s[t]=this.sx1[t],i[t]=this.sy[t],s[e+t]=this.sx2[e-t-1],i[e+t]=this.sy[e-t-1];const n=new o.Selection;return _.point_in_poly(t.sx,t.sy,s,i)&&(n.add_to_selected_glyphs(this.model),n.view=this),n}scenterxy(t){return[(this.sx1[t]+this.sx2[t])/2,this.sy[t]]}_map_data(){this.sx1=this.renderer.xscale.v_compute(this._x1),this.sx2=this.renderer.xscale.v_compute(this._x2),this.sy=this.renderer.yscale.v_compute(this._y)}}s.HAreaView=c,c.__name__=\"HAreaView\";class d extends h.Area{constructor(t){super(t)}static init_HArea(){this.prototype.default_view=c,this.define((({})=>({x1:[l.XCoordinateSpec,{field:\"x1\"}],x2:[l.XCoordinateSpec,{field:\"x2\"}],y:[l.YCoordinateSpec,{field:\"y\"}]})))}}s.HArea=d,d.__name__=\"HArea\",d.init_HArea()},\n",
" function _(e,a,_,i,r){i();const s=e(1),n=e(98),t=e(106),c=s.__importStar(e(48));class l extends n.GlyphView{draw_legend_for_index(e,a,_){t.generic_area_scalar_legend(this.visuals,e,a)}}_.AreaView=l,l.__name__=\"AreaView\";class d extends n.Glyph{constructor(e){super(e)}static init_Area(){this.mixins([c.FillScalar,c.HatchScalar])}}_.Area=d,d.__name__=\"Area\",d.init_Area()},\n",
" function _(t,e,s,i,n){i();const a=t(1),r=t(24),h=t(118),_=a.__importStar(t(107)),l=a.__importStar(t(18)),o=t(59);class c extends h.AreaView{_index_data(t){const{min:e,max:s}=Math,{data_size:i}=this;for(let n=0;n<i;n++){const i=this._x[n],a=this._y1[n],r=this._y2[n];isNaN(i+a+r)||!isFinite(i+a+r)?t.add_empty():t.add(i,e(a,r),i,s(a,r))}}_inner(t,e,s,i,n){t.beginPath();for(let i=0,n=s.length;i<n;i++)t.lineTo(e[i],s[i]);for(let s=i.length-1;s>=0;s--)t.lineTo(e[s],i[s]);t.closePath(),n.call(t)}_render(t,e,s){const{sx:i,sy1:n,sy2:a}=null!=s?s:this;this.visuals.fill.doit&&(this.visuals.fill.set_value(t),this._inner(t,i,n,a,t.fill)),this.visuals.hatch.doit&&(this.visuals.hatch.set_value(t),this._inner(t,i,n,a,t.fill))}scenterxy(t){return[this.sx[t],(this.sy1[t]+this.sy2[t])/2]}_hit_point(t){const e=this.sx.length,s=new r.ScreenArray(2*e),i=new r.ScreenArray(2*e);for(let t=0,n=e;t<n;t++)s[t]=this.sx[t],i[t]=this.sy1[t],s[e+t]=this.sx[e-t-1],i[e+t]=this.sy2[e-t-1];const n=new o.Selection;return _.point_in_poly(t.sx,t.sy,s,i)&&(n.add_to_selected_glyphs(this.model),n.view=this),n}_map_data(){this.sx=this.renderer.xscale.v_compute(this._x),this.sy1=this.renderer.yscale.v_compute(this._y1),this.sy2=this.renderer.yscale.v_compute(this._y2)}}s.VAreaView=c,c.__name__=\"VAreaView\";class d extends h.Area{constructor(t){super(t)}static init_VArea(){this.prototype.default_view=c,this.define((({})=>({x:[l.XCoordinateSpec,{field:\"x\"}],y1:[l.YCoordinateSpec,{field:\"y1\"}],y2:[l.YCoordinateSpec,{field:\"y2\"}]})))}}s.VArea=d,d.__name__=\"VArea\",d.init_VArea()},\n",
" function _(i,e,s,t,n){t();const c=i(53),o=i(59),r=i(24),a=i(121),u=i(57);class _ extends c.Model{constructor(i){super(i)}static init_CDSView(){this.define((({Array:i,Ref:e})=>({filters:[i(e(a.Filter)),[]],source:[e(u.ColumnarDataSource)]}))),this.internal((({Int:i,Dict:e,Ref:s,Nullable:t})=>({indices:[s(r.Indices)],indices_map:[e(i),{}],masked:[t(s(r.Indices)),null]})))}initialize(){super.initialize(),this.compute_indices()}connect_signals(){super.connect_signals(),this.connect(this.properties.filters.change,(()=>this.compute_indices()));const i=()=>{const i=()=>this.compute_indices();null!=this.source&&(this.connect(this.source.change,i),this.source instanceof u.ColumnarDataSource&&(this.connect(this.source.streaming,i),this.connect(this.source.patching,i)))};let e=null!=this.source;e?i():this.connect(this.properties.source.change,(()=>{e||(i(),e=!0)}))}compute_indices(){var i;const{source:e}=this;if(null==e)return;const s=null!==(i=e.get_length())&&void 0!==i?i:1,t=r.Indices.all_set(s);for(const i of this.filters)t.intersect(i.compute_indices(e));this.indices=t,this._indices=[...t],this.indices_map_to_subset()}indices_map_to_subset(){this.indices_map={};for(let i=0;i<this._indices.length;i++)this.indices_map[this._indices[i]]=i}convert_selection_from_subset(i){const e=i.indices.map((i=>this._indices[i]));return new o.Selection(Object.assign(Object.assign({},i.attributes),{indices:e}))}convert_selection_to_subset(i){const e=i.indices.map((i=>this.indices_map[i]));return new o.Selection(Object.assign(Object.assign({},i.attributes),{indices:e}))}convert_indices_from_subset(i){return i.map((i=>this._indices[i]))}}s.CDSView=_,_.__name__=\"CDSView\",_.init_CDSView()},\n",
" function _(e,t,n,s,c){s();const o=e(53);class r extends o.Model{constructor(e){super(e)}}n.Filter=r,r.__name__=\"Filter\"},\n",
" function _(n,e,t,i,o){i();const s=n(9);async function c(n,e,t){const i=new n(Object.assign(Object.assign({},t),{model:e}));return i.initialize(),await i.lazy_initialize(),i}t.build_view=async function(n,e={parent:null},t=(n=>n.default_view)){const i=await c(t(n),n,e);return i.connect_signals(),i},t.build_views=async function(n,e,t={parent:null},i=(n=>n.default_view)){const o=s.difference([...n.keys()],e);for(const e of o)n.get(e).remove(),n.delete(e);const a=[],f=e.filter((e=>!n.has(e)));for(const e of f){const o=await c(i(e),e,t);n.set(e,o),a.push(o)}for(const n of a)n.connect_signals();return a},t.remove_views=function(n){for(const[e,t]of n)t.remove(),n.delete(e)}},\n",
" function _(e,r,n,t,i){t();const s=e(62),o=e(61),l=e(124),d=e(125),a=e(126),p=e(122),_=e(64),h=e(127),c=e(128),u=e(11);class y extends s.DataRendererView{get glyph_view(){return this.node_view.glyph}async lazy_initialize(){await super.lazy_initialize();const e=this.model;let r=null,n=null;const t=new class extends l.Expression{_v_compute(n){u.assert(null==r);const[t]=r=e.layout_provider.get_edge_coordinates(n);return t}},i=new class extends l.Expression{_v_compute(e){u.assert(null!=r);const[,n]=r;return r=null,n}},s=new class extends l.Expression{_v_compute(r){u.assert(null==n);const[t]=n=e.layout_provider.get_node_coordinates(r);return t}},o=new class extends l.Expression{_v_compute(e){u.assert(null!=n);const[,r]=n;return n=null,r}},{edge_renderer:d,node_renderer:a}=this.model;if(!(d.glyph instanceof h.MultiLine||d.glyph instanceof c.Patches))throw new Error(`${this}.edge_renderer.glyph must be a MultiLine glyph`);if(!(a.glyph instanceof _.XYGlyph))throw new Error(`${this}.node_renderer.glyph must be a XYGlyph glyph`);d.glyph.properties.xs.internal=!0,d.glyph.properties.ys.internal=!0,a.glyph.properties.x.internal=!0,a.glyph.properties.y.internal=!0,d.glyph.xs={expr:t},d.glyph.ys={expr:i},a.glyph.x={expr:s},a.glyph.y={expr:o};const{parent:y}=this;this.edge_view=await p.build_view(d,{parent:y}),this.node_view=await p.build_view(a,{parent:y})}connect_signals(){super.connect_signals(),this.connect(this.model.layout_provider.change,(()=>{this.edge_view.set_data(),this.node_view.set_data(),this.request_render()}))}remove(){this.edge_view.remove(),this.node_view.remove(),super.remove()}_render(){this.edge_view.render(),this.node_view.render()}renderer_view(e){if(e instanceof o.GlyphRenderer){if(e==this.edge_view.model)return this.edge_view;if(e==this.node_view.model)return this.node_view}return super.renderer_view(e)}}n.GraphRendererView=y,y.__name__=\"GraphRendererView\";class g extends s.DataRenderer{constructor(e){super(e)}static init_GraphRenderer(){this.prototype.default_view=y,this.define((({Ref:e})=>({layout_provider:[e(d.LayoutProvider)],node_renderer:[e(o.GlyphRenderer)],edge_renderer:[e(o.GlyphRenderer)],selection_policy:[e(a.GraphHitTestPolicy),()=>new a.NodesOnly],inspection_policy:[e(a.GraphHitTestPolicy),()=>new a.NodesOnly]})))}get_selection_manager(){return this.node_renderer.data_source.selection_manager}}n.GraphRenderer=g,g.__name__=\"GraphRenderer\",g.init_GraphRenderer()},\n",
" function _(e,t,s,n,i){n();const c=e(53);class l extends c.Model{constructor(e){super(e)}initialize(){super.initialize(),this._connected=new Set,this._result=new Map}v_compute(e){this._connected.has(e)||(this.connect(e.change,(()=>this._result.delete(e))),this.connect(e.patching,(()=>this._result.delete(e))),this.connect(e.streaming,(()=>this._result.delete(e))),this._connected.add(e));let t=this._result.get(e);return null==t&&(t=this._v_compute(e),this._result.set(e,t)),t}}s.Expression=l,l.__name__=\"Expression\";class h extends c.Model{constructor(e){super(e)}initialize(){super.initialize(),this._connected=new Set,this._result=new Map}compute(e){this._connected.has(e)||(this.connect(e.change,(()=>this._result.delete(e))),this.connect(e.patching,(()=>this._result.delete(e))),this.connect(e.streaming,(()=>this._result.delete(e))),this._connected.add(e));let t=this._result.get(e);return null==t&&(t=this._compute(e),this._result.set(e,t)),t}}s.ScalarExpression=h,h.__name__=\"ScalarExpression\"},\n",
" function _(o,e,r,t,n){t();const s=o(53);class c extends s.Model{constructor(o){super(o)}}r.LayoutProvider=c,c.__name__=\"LayoutProvider\"},\n",
" function _(e,t,d,n,s){n();const o=e(53),r=e(12),_=e(9),i=e(59);class c extends o.Model{constructor(e){super(e)}_hit_test(e,t,d){if(!t.model.visible)return null;const n=d.glyph.hit_test(e);return null==n?null:d.model.view.convert_selection_from_subset(n)}}d.GraphHitTestPolicy=c,c.__name__=\"GraphHitTestPolicy\";class a extends c{constructor(e){super(e)}hit_test(e,t){return this._hit_test(e,t,t.edge_view)}do_selection(e,t,d,n){if(null==e)return!1;const s=t.edge_renderer.data_source.selected;return s.update(e,d,n),t.edge_renderer.data_source._select.emit(),!s.is_empty()}do_inspection(e,t,d,n,s){if(null==e)return!1;const{edge_renderer:o}=d.model,r=o.get_selection_manager().get_or_create_inspector(d.edge_view.model);return r.update(e,n,s),d.edge_view.model.data_source.setv({inspected:r},{silent:!0}),d.edge_view.model.data_source.inspect.emit([d.edge_view.model,{geometry:t}]),!r.is_empty()}}d.EdgesOnly=a,a.__name__=\"EdgesOnly\";class l extends c{constructor(e){super(e)}hit_test(e,t){return this._hit_test(e,t,t.node_view)}do_selection(e,t,d,n){if(null==e)return!1;const s=t.node_renderer.data_source.selected;return s.update(e,d,n),t.node_renderer.data_source._select.emit(),!s.is_empty()}do_inspection(e,t,d,n,s){if(null==e)return!1;const{node_renderer:o}=d.model,r=o.get_selection_manager().get_or_create_inspector(d.node_view.model);return r.update(e,n,s),d.node_view.model.data_source.setv({inspected:r},{silent:!0}),d.node_view.model.data_source.inspect.emit([d.node_view.model,{geometry:t}]),!r.is_empty()}}d.NodesOnly=l,l.__name__=\"NodesOnly\";class u extends c{constructor(e){super(e)}hit_test(e,t){return this._hit_test(e,t,t.node_view)}get_linked_edges(e,t,d){let n=[];\"selection\"==d?n=e.selected.indices.map((t=>e.data.index[t])):\"inspection\"==d&&(n=e.inspected.indices.map((t=>e.data.index[t])));const s=[];for(let e=0;e<t.data.start.length;e++)(_.contains(n,t.data.start[e])||_.contains(n,t.data.end[e]))&&s.push(e);const o=new i.Selection;for(const e of s)o.multiline_indices[e]=[0];return o.indices=s,o}do_selection(e,t,d,n){if(null==e)return!1;const s=t.node_renderer.data_source.selected;s.update(e,d,n);const o=t.edge_renderer.data_source.selected,r=this.get_linked_edges(t.node_renderer.data_source,t.edge_renderer.data_source,\"selection\");return o.update(r,d,n),t.node_renderer.data_source._select.emit(),!s.is_empty()}do_inspection(e,t,d,n,s){if(null==e)return!1;const o=d.node_view.model.data_source.selection_manager.get_or_create_inspector(d.node_view.model);o.update(e,n,s),d.node_view.model.data_source.setv({inspected:o},{silent:!0});const r=d.edge_view.model.data_source.selection_manager.get_or_create_inspector(d.edge_view.model),_=this.get_linked_edges(d.node_view.model.data_source,d.edge_view.model.data_source,\"inspection\");return r.update(_,n,s),d.edge_view.model.data_source.setv({inspected:r},{silent:!0}),d.node_view.model.data_source.inspect.emit([d.node_view.model,{geometry:t}]),!o.is_empty()}}d.NodesAndLinkedEdges=u,u.__name__=\"NodesAndLinkedEdges\";class m extends c{constructor(e){super(e)}hit_test(e,t){return this._hit_test(e,t,t.edge_view)}get_linked_nodes(e,t,d){let n=[];\"selection\"==d?n=t.selected.indices:\"inspection\"==d&&(n=t.inspected.indices);const s=[];for(const e of n)s.push(t.data.start[e]),s.push(t.data.end[e]);const o=_.uniq(s).map((t=>r.indexOf(e.data.index,t)));return new i.Selection({indices:o})}do_selection(e,t,d,n){if(null==e)return!1;const s=t.edge_renderer.data_source.selected;s.update(e,d,n);const o=t.node_renderer.data_source.selected,r=this.get_linked_nodes(t.node_renderer.data_source,t.edge_renderer.data_source,\"selection\");return o.update(r,d,n),t.edge_renderer.data_source._select.emit(),!s.is_empty()}do_inspection(e,t,d,n,s){if(null==e)return!1;const o=d.edge_view.model.data_source.selection_manager.get_or_create_inspector(d.edge_view.model);o.update(e,n,s),d.edge_view.model.data_source.setv({inspected:o},{silent:!0});const r=d.node_view.model.data_source.selection_manager.get_or_create_inspector(d.node_view.model),_=this.get_linked_nodes(d.node_view.model.data_source,d.edge_view.model.data_source,\"inspection\");return r.update(_,n,s),d.node_view.model.data_source.setv({inspected:r},{silent:!0}),d.edge_view.model.data_source.inspect.emit([d.edge_view.model,{geometry:t}]),!o.is_empty()}}d.EdgesAndLinkedNodes=m,m.__name__=\"EdgesAndLinkedNodes\"},\n",
" function _(t,e,i,n,s){n();const o=t(1),l=t(65),r=t(48),_=o.__importStar(t(107)),c=o.__importStar(t(18)),h=t(12),a=t(13),d=t(98),x=t(106),y=t(59);class g extends d.GlyphView{_project_data(){l.inplace.project_xy(this._xs.array,this._ys.array)}_index_data(t){const{data_size:e}=this;for(let i=0;i<e;i++){const e=this._xs.get(i);if(0==e.length){t.add_empty();continue}const n=this._ys.get(i);if(0==n.length){t.add_empty();continue}const[s,o]=h.minmax(e),[l,r]=h.minmax(n);t.add(s,l,o,r)}}_render(t,e,i){const{sxs:n,sys:s}=null!=i?i:this;for(const i of e){const e=n.get(i),o=s.get(i),l=Math.min(e.length,o.length);let r=!0;t.beginPath();for(let i=0;i<l;i++){const n=e[i],s=o[i];isFinite(n+s)?r?(t.moveTo(n,s),r=!1):t.lineTo(n,s):r=!0}this.visuals.line.set_vectorize(t,i),t.stroke()}}_hit_point(t){const e={x:t.sx,y:t.sy};let i=9999;const n=new Map;for(let t=0,s=this.sxs.length;t<s;t++){const s=Math.max(2,this.line_width.get(t)/2),o=this.sxs.get(t),l=this.sys.get(t);let r=null;for(let t=0,n=o.length-1;t<n;t++){const n={x:o[t],y:l[t]},c={x:o[t+1],y:l[t+1]},h=_.dist_to_segment(e,n,c);h<s&&h<i&&(i=h,r=[t])}null!=r&&n.set(t,r)}return new y.Selection({indices:[...n.keys()],multiline_indices:a.to_object(n)})}_hit_span(t){const{sx:e,sy:i}=t;let n,s;\"v\"==t.direction?(n=this.renderer.yscale.invert(i),s=this._ys):(n=this.renderer.xscale.invert(e),s=this._xs);const o=new Map;for(let t=0,e=s.length;t<e;t++){const e=s.get(t),i=[];for(let t=0,s=e.length-1;t<s;t++)e[t]<=n&&n<=e[t+1]&&i.push(t);i.length>0&&o.set(t,i)}return new y.Selection({indices:[...o.keys()],multiline_indices:a.to_object(o)})}get_interpolation_hit(t,e,i){const n=this._xs.get(t),s=this._ys.get(t),o=n[e],l=s[e],r=n[e+1],_=s[e+1];return x.line_interpolation(this.renderer,i,o,l,r,_)}draw_legend_for_index(t,e,i){x.generic_line_vector_legend(this.visuals,t,e,i)}scenterxy(){throw new Error(`${this}.scenterxy() is not implemented`)}}i.MultiLineView=g,g.__name__=\"MultiLineView\";class u extends d.Glyph{constructor(t){super(t)}static init_MultiLine(){this.prototype.default_view=g,this.define((({})=>({xs:[c.XCoordinateSeqSpec,{field:\"xs\"}],ys:[c.YCoordinateSeqSpec,{field:\"ys\"}]}))),this.mixins(r.LineVector)}}i.MultiLine=u,u.__name__=\"MultiLine\",u.init_MultiLine()},\n",
" function _(e,t,s,i,n){i();const r=e(1),o=e(98),a=e(106),_=e(12),c=e(48),l=r.__importStar(e(107)),h=r.__importStar(e(18)),d=e(59),y=e(11),p=e(65);class x extends o.GlyphView{_project_data(){p.inplace.project_xy(this._xs.array,this._ys.array)}_index_data(e){const{data_size:t}=this;for(let s=0;s<t;s++){const t=this._xs.get(s),i=this._ys.get(s);if(0==t.length)e.add_empty();else{const[s,n]=_.minmax(t),[r,o]=_.minmax(i);e.add(s,r,n,o)}}}_mask_data(){const{x_range:e,y_range:t}=this.renderer.plot_view.frame;return this.index.indices({x0:e.min,x1:e.max,y0:t.min,y1:t.max})}_inner_loop(e,t,s,i){for(let n=0,r=t.length;n<r;n++)0!=n?isNaN(t[n]+s[n])?(e.closePath(),i.apply(e),e.beginPath()):e.lineTo(t[n],s[n]):(e.beginPath(),e.moveTo(t[n],s[n]));e.closePath(),i.call(e)}_render(e,t,s){const{sxs:i,sys:n}=null!=s?s:this;for(const s of t){const t=i.get(s),r=n.get(s);this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(e,s),this._inner_loop(e,t,r,e.fill)),this.visuals.hatch.doit&&(this.visuals.hatch.set_vectorize(e,s),this._inner_loop(e,t,r,e.fill)),this.visuals.line.doit&&(this.visuals.line.set_vectorize(e,s),this._inner_loop(e,t,r,e.stroke))}}_hit_rect(e){const{sx0:t,sx1:s,sy0:i,sy1:n}=e,r=[t,s,s,t],o=[i,i,n,n],[a,_]=this.renderer.xscale.r_invert(t,s),[c,h]=this.renderer.yscale.r_invert(i,n),y=this.index.indices({x0:a,x1:_,y0:c,y1:h}),p=[];for(const e of y){const t=this.sxs.get(e),s=this.sys.get(e);let i=!0;for(let e=0,n=t.length;e<n;e++){const n=t[e],a=s[e];if(!l.point_in_poly(n,a,r,o)){i=!1;break}}i&&p.push(e)}return new d.Selection({indices:p})}_hit_point(e){const{sx:t,sy:s}=e,i=this.renderer.xscale.invert(t),n=this.renderer.yscale.invert(s),r=this.index.indices({x0:i,y0:n,x1:i,y1:n}),o=[];for(const e of r){const i=this.sxs.get(e),n=this.sys.get(e),r=i.length;for(let a=0,_=0;;_++){if(isNaN(i[_])||_==r){const r=i.subarray(a,_),c=n.subarray(a,_);if(l.point_in_poly(t,s,r,c)){o.push(e);break}a=_+1}if(_==r)break}}return new d.Selection({indices:o})}_get_snap_coord(e){return _.sum(e)/e.length}scenterxy(e,t,s){const i=this.sxs.get(e),n=this.sys.get(e),r=i.length;let o=!1;for(let e=0,a=0;;a++){const _=isNaN(i[a]);if(o=o||_,a==r&&!o){return[this._get_snap_coord(i),this._get_snap_coord(n)]}if(_||a==r){const r=i.subarray(e,a),o=n.subarray(e,a);if(l.point_in_poly(t,s,r,o)){return[this._get_snap_coord(r),this._get_snap_coord(o)]}e=a+1}if(a==r)break}y.unreachable()}draw_legend_for_index(e,t,s){a.generic_area_vector_legend(this.visuals,e,t,s)}}s.PatchesView=x,x.__name__=\"PatchesView\";class f extends o.Glyph{constructor(e){super(e)}static init_Patches(){this.prototype.default_view=x,this.define((({})=>({xs:[h.XCoordinateSeqSpec,{field:\"xs\"}],ys:[h.YCoordinateSeqSpec,{field:\"ys\"}]}))),this.mixins([c.LineVector,c.FillVector,c.HatchVector])}}s.Patches=f,f.__name__=\"Patches\",f.init_Patches()},\n",
" function _(e,t,n,s,o){s();const r=e(53);class c extends r.Model{do_selection(e,t,n,s){return null!=e&&(t.selected.update(e,n,s),t._select.emit(),!t.selected.is_empty())}}n.SelectionPolicy=c,c.__name__=\"SelectionPolicy\";class l extends c{hit_test(e,t){const n=[];for(const s of t){const t=s.hit_test(e);null!=t&&n.push(t)}if(n.length>0){const e=n[0];for(const t of n)e.update_through_intersection(t);return e}return null}}n.IntersectRenderers=l,l.__name__=\"IntersectRenderers\";class _ extends c{hit_test(e,t){const n=[];for(const s of t){const t=s.hit_test(e);null!=t&&n.push(t)}if(n.length>0){const e=n[0];for(const t of n)e.update_through_union(t);return e}return null}}n.UnionRenderers=_,_.__name__=\"UnionRenderers\"},\n",
" function _(t,n,e,s,o){s();const r=t(1),i=t(57),l=t(8),c=t(13),a=r.__importStar(t(131)),u=t(132),h=t(35);function d(t,n,e){if(l.isArray(t)){const s=t.concat(n);return null!=e&&s.length>e?s.slice(-e):s}if(l.isTypedArray(t)){const s=t.length+n.length;if(null!=e&&s>e){const o=s-e,r=t.length;let i;t.length<e?(i=new t.constructor(e),i.set(t,0)):i=t;for(let t=o,n=r;t<n;t++)i[t-o]=i[t];for(let t=0,e=n.length;t<e;t++)i[t+(r-o)]=n[t];return i}{const e=new t.constructor(n);return a.concat(t,e)}}throw new Error(\"unsupported array types\")}function f(t,n){let e,s,o;return l.isNumber(t)?(e=t,o=t+1,s=1):(e=null!=t.start?t.start:0,o=null!=t.stop?t.stop:n,s=null!=t.step?t.step:1),[e,o,s]}function m(t,n){const e=new Set;let s=!1;for(const[o,r]of n){let n,i,c,a;if(l.isArray(o)){const[s]=o;e.add(s),n=t[s].shape,i=t[s],a=r,2===o.length?(n=[1,n[0]],c=[o[0],0,o[1]]):c=o}else l.isNumber(o)?(a=[r],e.add(o)):(a=r,s=!0),c=[0,0,o],n=[1,t.length],i=t;let u=0;const[h,d,m]=f(c[1],n[0]),[_,p,g]=f(c[2],n[1]);for(let t=h;t<d;t+=m)for(let o=_;o<p;o+=g)s&&e.add(o),i[t*n[1]+o]=a[u],u++}return e}e.stream_to_column=d,e.slice=f,e.patch_to_column=m;class _ extends i.ColumnarDataSource{constructor(t){super(t)}static init_ColumnDataSource(){this.define((({Dict:t,Any:n})=>({data:[t(n),{}]})))}stream(t,n,e){const{data:s}=this;for(const[e,o]of c.entries(t))s[e]=d(s[e],o,n);if(this.setv({data:s},{silent:!0}),this.streaming.emit(),null!=this.document){const s=new h.ColumnsStreamedEvent(this.document,this.ref(),t,n);this.document._notify_change(this,\"data\",null,null,{setter_id:e,hint:s})}}patch(t,n){const{data:e}=this;let s=new Set;for(const[n,o]of c.entries(t))s=u.union(s,m(e[n],o));if(this.setv({data:e},{silent:!0}),this.patching.emit([...s]),null!=this.document){const e=new h.ColumnsPatchedEvent(this.document,this.ref(),t);this.document._notify_change(this,\"data\",null,null,{setter_id:n,hint:e})}}}e.ColumnDataSource=_,_.__name__=\"ColumnDataSource\",_.init_ColumnDataSource()},\n",
" function _(t,n,o,e,c){e(),o.concat=function(t,...n){let o=t.length;for(const t of n)o+=t.length;const e=new t.constructor(o);e.set(t,0);let c=t.length;for(const t of n)e.set(t,c),c+=t.length;return e}},\n",
" function _(n,o,t,e,f){function c(...n){const o=new Set;for(const t of n)for(const n of t)o.add(n);return o}e(),t.union=c,t.intersection=function(n,...o){const t=new Set;n:for(const e of n){for(const n of o)if(!n.has(e))continue n;t.add(e)}return t},t.difference=function(n,...o){const t=new Set(n);for(const n of c(...o))t.delete(n);return t}},\n",
" function _(e,i,t,s,o){s();const n=e(1),a=e(53),l=e(42),r=n.__importStar(e(45)),_=e(48),c=n.__importStar(e(18));class d extends l.View{initialize(){super.initialize(),this.visuals=new r.Visuals(this)}request_render(){this.parent.request_render()}get canvas(){return this.parent.canvas}set_data(e){const i=this;for(const t of this.model){if(!(t instanceof c.VectorSpec||t instanceof c.ScalarSpec))continue;const s=t.uniform(e);i[`${t.attr}`]=s}}}t.ArrowHeadView=d,d.__name__=\"ArrowHeadView\";class h extends a.Model{constructor(e){super(e)}static init_ArrowHead(){this.define((()=>({size:[c.NumberSpec,25]})))}}t.ArrowHead=h,h.__name__=\"ArrowHead\",h.init_ArrowHead();class v extends d{clip(e,i){this.visuals.line.set_vectorize(e,i);const t=this.size.get(i);e.moveTo(.5*t,t),e.lineTo(.5*t,-2),e.lineTo(-.5*t,-2),e.lineTo(-.5*t,t),e.lineTo(0,0),e.lineTo(.5*t,t)}render(e,i){if(this.visuals.line.doit){this.visuals.line.set_vectorize(e,i);const t=this.size.get(i);e.beginPath(),e.moveTo(.5*t,t),e.lineTo(0,0),e.lineTo(-.5*t,t),e.stroke()}}}t.OpenHeadView=v,v.__name__=\"OpenHeadView\";class u extends h{constructor(e){super(e)}static init_OpenHead(){this.prototype.default_view=v,this.mixins(_.LineVector)}}t.OpenHead=u,u.__name__=\"OpenHead\",u.init_OpenHead();class m extends d{clip(e,i){this.visuals.line.set_vectorize(e,i);const t=this.size.get(i);e.moveTo(.5*t,t),e.lineTo(.5*t,-2),e.lineTo(-.5*t,-2),e.lineTo(-.5*t,t),e.lineTo(.5*t,t)}render(e,i){this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(e,i),this._normal(e,i),e.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(e,i),this._normal(e,i),e.stroke())}_normal(e,i){const t=this.size.get(i);e.beginPath(),e.moveTo(.5*t,t),e.lineTo(0,0),e.lineTo(-.5*t,t),e.closePath()}}t.NormalHeadView=m,m.__name__=\"NormalHeadView\";class T extends h{constructor(e){super(e)}static init_NormalHead(){this.prototype.default_view=m,this.mixins([_.LineVector,_.FillVector]),this.override({fill_color:\"black\"})}}t.NormalHead=T,T.__name__=\"NormalHead\",T.init_NormalHead();class p extends d{clip(e,i){this.visuals.line.set_vectorize(e,i);const t=this.size.get(i);e.moveTo(.5*t,t),e.lineTo(.5*t,-2),e.lineTo(-.5*t,-2),e.lineTo(-.5*t,t),e.lineTo(0,.5*t),e.lineTo(.5*t,t)}render(e,i){this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(e,i),this._vee(e,i),e.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(e,i),this._vee(e,i),e.stroke())}_vee(e,i){const t=this.size.get(i);e.beginPath(),e.moveTo(.5*t,t),e.lineTo(0,0),e.lineTo(-.5*t,t),e.lineTo(0,.5*t),e.closePath()}}t.VeeHeadView=p,p.__name__=\"VeeHeadView\";class H extends h{constructor(e){super(e)}static init_VeeHead(){this.prototype.default_view=p,this.mixins([_.LineVector,_.FillVector]),this.override({fill_color:\"black\"})}}t.VeeHead=H,H.__name__=\"VeeHead\",H.init_VeeHead();class V extends d{render(e,i){if(this.visuals.line.doit){this.visuals.line.set_vectorize(e,i);const t=this.size.get(i);e.beginPath(),e.moveTo(.5*t,0),e.lineTo(-.5*t,0),e.stroke()}}clip(e,i){}}t.TeeHeadView=V,V.__name__=\"TeeHeadView\";class f extends h{constructor(e){super(e)}static init_TeeHead(){this.prototype.default_view=V,this.mixins(_.LineVector)}}t.TeeHead=f,f.__name__=\"TeeHead\",f.init_TeeHead()},\n",
" function _(s,e,i,t,l){t();const _=s(1),o=s(135),r=_.__importStar(s(48));class h extends o.UpperLowerView{paint(s){s.beginPath(),s.moveTo(this._lower_sx[0],this._lower_sy[0]);for(let e=0,i=this._lower_sx.length;e<i;e++)s.lineTo(this._lower_sx[e],this._lower_sy[e]);for(let e=this._upper_sx.length-1;e>=0;e--)s.lineTo(this._upper_sx[e],this._upper_sy[e]);s.closePath(),this.visuals.fill.doit&&(this.visuals.fill.set_value(s),s.fill()),s.beginPath(),s.moveTo(this._lower_sx[0],this._lower_sy[0]);for(let e=0,i=this._lower_sx.length;e<i;e++)s.lineTo(this._lower_sx[e],this._lower_sy[e]);this.visuals.line.doit&&(this.visuals.line.set_value(s),s.stroke()),s.beginPath(),s.moveTo(this._upper_sx[0],this._upper_sy[0]);for(let e=0,i=this._upper_sx.length;e<i;e++)s.lineTo(this._upper_sx[e],this._upper_sy[e]);this.visuals.line.doit&&(this.visuals.line.set_value(s),s.stroke())}}i.BandView=h,h.__name__=\"BandView\";class n extends o.UpperLower{constructor(s){super(s)}static init_Band(){this.prototype.default_view=h,this.mixins([r.Line,r.Fill]),this.override({fill_color:\"#fff9ba\",fill_alpha:.4,line_color:\"#cccccc\",line_alpha:.3})}}i.Band=n,n.__name__=\"Band\",n.init_Band()},\n",
" function _(e,t,i,s,o){s();const r=e(1),p=e(56),n=e(20),_=r.__importStar(e(18));class a extends p.DataAnnotationView{map_data(){const{frame:e}=this.plot_view,t=this.model.dimension,i=this.coordinates.x_scale,s=this.coordinates.y_scale,o=\"height\"==t?s:i,r=\"height\"==t?i:s,p=\"height\"==t?e.bbox.yview:e.bbox.xview,n=\"height\"==t?e.bbox.xview:e.bbox.yview;let _,a,h;_=\"data\"==this.model.properties.lower.units?o.v_compute(this._lower):p.v_compute(this._lower),a=\"data\"==this.model.properties.upper.units?o.v_compute(this._upper):p.v_compute(this._upper),h=\"data\"==this.model.properties.base.units?r.v_compute(this._base):n.v_compute(this._base);const[d,c]=\"height\"==t?[1,0]:[0,1],u=[_,h],l=[a,h];this._lower_sx=u[d],this._lower_sy=u[c],this._upper_sx=l[d],this._upper_sy=l[c]}}i.UpperLowerView=a,a.__name__=\"UpperLowerView\";class h extends _.CoordinateSpec{get dimension(){return\"width\"==this.obj.dimension?\"x\":\"y\"}get units(){var e;return null!==(e=this.spec.units)&&void 0!==e?e:\"data\"}}i.XOrYCoordinateSpec=h,h.__name__=\"XOrYCoordinateSpec\";class d extends p.DataAnnotation{constructor(e){super(e)}static init_UpperLower(){this.define((()=>({dimension:[n.Dimension,\"height\"],lower:[h,{field:\"lower\"}],upper:[h,{field:\"upper\"}],base:[h,{field:\"base\"}]})))}}i.UpperLower=d,d.__name__=\"UpperLower\",d.init_UpperLower()},\n",
" function _(t,i,o,n,e){n();const s=t(1),l=t(40),a=s.__importStar(t(48)),r=t(20),h=t(99);o.EDGE_TOLERANCE=2.5;class c extends l.AnnotationView{constructor(){super(...arguments),this.bbox=new h.BBox}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.request_render()))}_render(){const{left:t,right:i,top:o,bottom:n}=this.model;if(null==t&&null==i&&null==o&&null==n)return;const{frame:e}=this.plot_view,s=this.coordinates.x_scale,l=this.coordinates.y_scale,a=(t,i,o,n,e)=>{let s;return s=null!=t?this.model.screen?t:\"data\"==i?o.compute(t):n.compute(t):e,s};this.bbox=h.BBox.from_rect({left:a(t,this.model.left_units,s,e.bbox.xview,e.bbox.left),right:a(i,this.model.right_units,s,e.bbox.xview,e.bbox.right),top:a(o,this.model.top_units,l,e.bbox.yview,e.bbox.top),bottom:a(n,this.model.bottom_units,l,e.bbox.yview,e.bbox.bottom)}),this._paint_box()}_paint_box(){const{ctx:t}=this.layer;t.save();const{left:i,top:o,width:n,height:e}=this.bbox;t.beginPath(),t.rect(i,o,n,e),this.visuals.fill.doit&&(this.visuals.fill.set_value(t),t.fill()),this.visuals.hatch.doit&&(this.visuals.hatch.set_value(t),t.fill()),this.visuals.line.doit&&(this.visuals.line.set_value(t),t.stroke()),t.restore()}interactive_bbox(){const t=this.model.line_width+o.EDGE_TOLERANCE;return this.bbox.grow_by(t)}interactive_hit(t,i){if(null==this.model.in_cursor)return!1;return this.interactive_bbox().contains(t,i)}cursor(t,i){const{left:o,right:n,bottom:e,top:s}=this.bbox;return Math.abs(t-o)<3||Math.abs(t-n)<3?this.model.ew_cursor:Math.abs(i-e)<3||Math.abs(i-s)<3?this.model.ns_cursor:this.bbox.contains(t,i)?this.model.in_cursor:null}}o.BoxAnnotationView=c,c.__name__=\"BoxAnnotationView\";class u extends l.Annotation{constructor(t){super(t)}static init_BoxAnnotation(){this.prototype.default_view=c,this.mixins([a.Line,a.Fill,a.Hatch]),this.define((({Number:t,Nullable:i})=>({top:[i(t),null],top_units:[r.SpatialUnits,\"data\"],bottom:[i(t),null],bottom_units:[r.SpatialUnits,\"data\"],left:[i(t),null],left_units:[r.SpatialUnits,\"data\"],right:[i(t),null],right_units:[r.SpatialUnits,\"data\"],render_mode:[r.RenderMode,\"canvas\"]}))),this.internal((({Boolean:t,String:i,Nullable:o})=>({screen:[t,!1],ew_cursor:[o(i),null],ns_cursor:[o(i),null],in_cursor:[o(i),null]}))),this.override({fill_color:\"#fff9ba\",fill_alpha:.4,line_color:\"#cccccc\",line_alpha:.3})}update({left:t,right:i,top:o,bottom:n}){this.setv({left:t,right:i,top:o,bottom:n,screen:!0})}}o.BoxAnnotation=u,u.__name__=\"BoxAnnotation\",u.init_BoxAnnotation()},\n",
" function _(t,e,i,a,n){a();const o=t(1),r=t(40),s=t(138),l=t(144),_=t(162),c=t(165),h=t(198),u=t(166),p=t(205),m=t(169),g=t(203),d=t(202),f=t(209),w=t(217),b=t(220),v=t(20),y=o.__importStar(t(48)),k=t(9),x=t(221),C=t(222),j=t(225),z=t(140),L=t(11),S=t(122),M=t(8);class T extends r.AnnotationView{get orientation(){return this._orientation}initialize(){super.initialize();const{ticker:t,formatter:e,color_mapper:i}=this.model;this._ticker=\"auto\"!=t?t:(()=>{switch(!0){case i instanceof f.LogColorMapper:return new h.LogTicker;case i instanceof f.ScanningColorMapper:return new h.BinnedTicker({mapper:i});case i instanceof f.CategoricalColorMapper:return new h.CategoricalTicker;default:return new h.BasicTicker}})(),this._formatter=\"auto\"!=e?e:(()=>{switch(!0){case this._ticker instanceof h.LogTicker:return new p.LogTickFormatter;case i instanceof f.CategoricalColorMapper:return new p.CategoricalTickFormatter;default:return new p.BasicTickFormatter}})(),this._major_range=(()=>{if(i instanceof f.CategoricalColorMapper){const{factors:t}=i;return new b.FactorRange({factors:t})}if(i instanceof d.ContinuousColorMapper){const{min:t,max:e}=i.metrics;return new b.Range1d({start:t,end:e})}L.unreachable()})(),this._major_scale=(()=>{if(i instanceof f.LinearColorMapper)return new w.LinearScale;if(i instanceof f.LogColorMapper)return new w.LogScale;if(i instanceof f.ScanningColorMapper){const{binning:t}=i.metrics;return new w.LinearInterpolationScale({binning:t})}if(i instanceof f.CategoricalColorMapper)return new w.CategoricalScale;L.unreachable()})(),this._minor_range=new b.Range1d({start:0,end:1}),this._minor_scale=new w.LinearScale;const a=y.attrs_of(this.model,\"major_label_\",y.Text,!0),n=y.attrs_of(this.model,\"major_tick_\",y.Line,!0),o=y.attrs_of(this.model,\"minor_tick_\",y.Line,!0),r=y.attrs_of(this.model,\"title_\",y.Text),l=i instanceof f.CategoricalColorMapper?_.CategoricalAxis:i instanceof f.LogColorMapper?_.LogAxis:_.LinearAxis;this._axis=new l(Object.assign(Object.assign(Object.assign({ticker:this._ticker,formatter:this._formatter,major_tick_in:this.model.major_tick_in,major_tick_out:this.model.major_tick_out,minor_tick_in:this.model.minor_tick_in,minor_tick_out:this.model.minor_tick_out,major_label_standoff:this.model.label_standoff,major_label_overrides:this.model.major_label_overrides,major_label_policy:this.model.major_label_policy,axis_line_color:null},a),n),o));const{title:c}=this.model;c&&(this._title=new s.Title(Object.assign({text:c,standoff:this.model.title_standoff},r)))}async lazy_initialize(){await super.lazy_initialize();const t=this,e={get parent(){return t.parent},get root(){return t.root},get frame(){return t._frame},get canvas_view(){return t.parent.canvas_view},request_layout(){t.parent.request_layout()}};this._axis_view=await S.build_view(this._axis,{parent:e}),null!=this._title&&(this._title_view=await S.build_view(this._title,{parent:e}))}remove(){var t;null===(t=this._title_view)||void 0===t||t.remove(),this._axis_view.remove(),super.remove()}connect_signals(){super.connect_signals(),this.connect(this._ticker.change,(()=>this.request_render())),this.connect(this._formatter.change,(()=>this.request_render())),this.connect(this.model.color_mapper.metrics_change,(()=>{const t=this._major_range,e=this._major_scale,{color_mapper:i}=this.model;if(i instanceof d.ContinuousColorMapper&&t instanceof b.Range1d){const{min:e,max:a}=i.metrics;t.setv({start:e,end:a})}if(i instanceof f.ScanningColorMapper&&e instanceof w.LinearInterpolationScale){const{binning:t}=i.metrics;e.binning=t}this._set_canvas_image(),this.plot_view.request_layout()}))}_set_canvas_image(){const{orientation:t}=this,e=(()=>{const{palette:e}=this.model.color_mapper;return\"vertical\"==t?k.reversed(e):e})(),[i,a]=\"vertical\"==t?[1,e.length]:[e.length,1],n=this._image=document.createElement(\"canvas\");n.width=i,n.height=a;const o=n.getContext(\"2d\"),r=o.getImageData(0,0,i,a),s=new f.LinearColorMapper({palette:e}).rgba_mapper.v_compute(k.range(0,e.length));r.data.set(s),o.putImageData(r,0,0)}update_layout(){const{location:t,width:e,height:i,padding:a,margin:n}=this.model,[o,r]=(()=>{if(!M.isString(t))return[\"end\",\"start\"];switch(t){case\"top_left\":return[\"start\",\"start\"];case\"top\":case\"top_center\":return[\"start\",\"center\"];case\"top_right\":return[\"start\",\"end\"];case\"bottom_left\":return[\"end\",\"start\"];case\"bottom\":case\"bottom_center\":return[\"end\",\"center\"];case\"bottom_right\":return[\"end\",\"end\"];case\"left\":case\"center_left\":return[\"center\",\"start\"];case\"center\":case\"center_center\":return[\"center\",\"center\"];case\"right\":case\"center_right\":return[\"center\",\"end\"]}})(),s=this._orientation=(()=>{const{orientation:t}=this.model;return\"auto\"==t?null!=this.panel?this.panel.is_horizontal?\"horizontal\":\"vertical\":\"start\"==r||\"end\"==r||\"center\"==r&&\"center\"==o?\"vertical\":\"horizontal\":t})(),_=new C.NodeLayout,c=new C.VStack,h=new C.VStack,u=new C.HStack,p=new C.HStack;_.absolute=!0,c.absolute=!0,h.absolute=!0,u.absolute=!0,p.absolute=!0;const[m,g,d,f]=(()=>\"horizontal\"==s?[this._major_scale,this._minor_scale,this._major_range,this._minor_range]:[this._minor_scale,this._major_scale,this._minor_range,this._major_range])();this._frame=new l.CartesianFrame(m,g,d,f),_.on_resize((t=>this._frame.set_geometry(t)));const w=new j.BorderLayout;this._inner_layout=w,w.absolute=!0,w.center_panel=_,w.top_panel=c,w.bottom_panel=h,w.left_panel=u,w.right_panel=p;const b={left:a,right:a,top:a,bottom:a},v=(()=>{if(null==this.panel){if(M.isString(t))return{left:n,right:n,top:n,bottom:n};{const[e,i]=t;return{left:e,right:n,top:n,bottom:i}}}if(!M.isString(t)){const[e,i]=t;return{left:e,right:0,top:0,bottom:i}}})();let y,k,L,S;if(w.padding=b,null!=this.panel?(y=\"max\",k=void 0,L=void 0,S=void 0):\"auto\"==(\"horizontal\"==s?e:i)?(y=\"fixed\",k=25*this.model.color_mapper.palette.length,L={percent:.3},S={percent:.8}):(y=\"fit\",k=void 0),\"horizontal\"==s){const t=\"auto\"==e?void 0:e,a=\"auto\"==i?25:i;w.set_sizing({width_policy:y,height_policy:\"min\",width:k,min_width:L,max_width:S,halign:r,valign:o,margin:v}),w.center_panel.set_sizing({width_policy:\"auto\"==e?\"fit\":\"fixed\",height_policy:\"fixed\",width:t,height:a})}else{const t=\"auto\"==e?25:e,a=\"auto\"==i?void 0:i;w.set_sizing({width_policy:\"min\",height_policy:y,height:k,min_height:L,max_height:S,halign:r,valign:o,margin:v}),w.center_panel.set_sizing({width_policy:\"fixed\",height_policy:\"auto\"==i?\"fit\":\"fixed\",width:t,height:a})}c.set_sizing({width_policy:\"fit\",height_policy:\"min\"}),h.set_sizing({width_policy:\"fit\",height_policy:\"min\"}),u.set_sizing({width_policy:\"min\",height_policy:\"fit\"}),p.set_sizing({width_policy:\"min\",height_policy:\"fit\"});const{_title_view:T}=this;null!=T&&(\"horizontal\"==s?(T.panel=new z.Panel(\"above\"),T.update_layout(),c.children.push(T.layout)):(T.panel=new z.Panel(\"left\"),T.update_layout(),u.children.push(T.layout)));const{panel:B}=this,A=null!=B&&s==B.orientation?B.side:\"horizontal\"==s?\"below\":\"right\",O=(()=>{switch(A){case\"above\":return c;case\"below\":return h;case\"left\":return u;case\"right\":return p}})(),{_axis_view:R}=this;if(R.panel=new z.Panel(A),R.update_layout(),O.children.push(R.layout),null!=this.panel){const t=new x.Grid([{layout:w,row:0,col:0}]);t.absolute=!0,\"horizontal\"==s?t.set_sizing({width_policy:\"max\",height_policy:\"min\"}):t.set_sizing({width_policy:\"min\",height_policy:\"max\"}),this.layout=t}else this.layout=this._inner_layout;const{visible:F}=this.model;this.layout.sizing.visible=F,this._set_canvas_image()}_render(){var t;const{ctx:e}=this.layer;e.save(),this._paint_bbox(e,this._inner_layout.bbox),this._paint_image(e,this._inner_layout.center_panel.bbox),null===(t=this._title_view)||void 0===t||t.render(),this._axis_view.render(),e.restore()}_paint_bbox(t,e){const{x:i,y:a}=e;let{width:n,height:o}=e;i+n>=this.parent.canvas_view.bbox.width&&(n-=1),a+o>=this.parent.canvas_view.bbox.height&&(o-=1),t.save(),this.visuals.background_fill.doit&&(this.visuals.background_fill.set_value(t),t.fillRect(i,a,n,o)),this.visuals.border_line.doit&&(this.visuals.border_line.set_value(t),t.strokeRect(i,a,n,o)),t.restore()}_paint_image(t,e){const{x:i,y:a,width:n,height:o}=e;t.save(),t.setImageSmoothingEnabled(!1),t.globalAlpha=this.model.scale_alpha,t.drawImage(this._image,i,a,n,o),this.visuals.bar_line.doit&&(this.visuals.bar_line.set_value(t),t.strokeRect(i,a,n,o)),t.restore()}serializable_state(){const t=super.serializable_state(),{children:e=[]}=t,i=o.__rest(t,[\"children\"]);return null!=this._title_view&&e.push(this._title_view.serializable_state()),e.push(this._axis_view.serializable_state()),Object.assign(Object.assign({},i),{children:e})}}i.ColorBarView=T,T.__name__=\"ColorBarView\";class B extends r.Annotation{constructor(t){super(t)}static init_ColorBar(){this.prototype.default_view=T,this.mixins([[\"major_label_\",y.Text],[\"title_\",y.Text],[\"major_tick_\",y.Line],[\"minor_tick_\",y.Line],[\"border_\",y.Line],[\"bar_\",y.Line],[\"background_\",y.Fill]]),this.define((({Alpha:t,Number:e,String:i,Tuple:a,Dict:n,Or:o,Ref:r,Auto:s,Nullable:l})=>({location:[o(v.Anchor,a(e,e)),\"top_right\"],orientation:[o(v.Orientation,s),\"auto\"],title:[l(i),null],title_standoff:[e,2],width:[o(e,s),\"auto\"],height:[o(e,s),\"auto\"],scale_alpha:[t,1],ticker:[o(r(c.Ticker),s),\"auto\"],formatter:[o(r(u.TickFormatter),s),\"auto\"],major_label_overrides:[n(i),{}],major_label_policy:[r(m.LabelingPolicy),()=>new m.NoOverlap],color_mapper:[r(g.ColorMapper)],label_standoff:[e,5],margin:[e,30],padding:[e,10],major_tick_in:[e,5],major_tick_out:[e,0],minor_tick_in:[e,0],minor_tick_out:[e,0]}))),this.override({background_fill_color:\"#ffffff\",background_fill_alpha:.95,bar_line_color:null,border_line_color:null,major_label_text_font_size:\"11px\",major_tick_line_color:\"#ffffff\",minor_tick_line_color:null,title_text_font_size:\"13px\",title_text_font_style:\"italic\"})}}i.ColorBar=B,B.__name__=\"ColorBar\",B.init_ColorBar()},\n",
" function _(t,e,i,s,l){s();const o=t(1),a=t(139),n=t(20),r=t(143),c=o.__importStar(t(48));class h extends a.TextAnnotationView{_get_location(){const t=this.model.offset,e=this.model.standoff/2;let i,s;const{bbox:l}=this.layout;switch(this.panel.side){case\"above\":case\"below\":switch(this.model.vertical_align){case\"top\":s=l.top+e;break;case\"middle\":s=l.vcenter;break;case\"bottom\":s=l.bottom-e}switch(this.model.align){case\"left\":i=l.left+t;break;case\"center\":i=l.hcenter;break;case\"right\":i=l.right-t}break;case\"left\":switch(this.model.vertical_align){case\"top\":i=l.left+e;break;case\"middle\":i=l.hcenter;break;case\"bottom\":i=l.right-e}switch(this.model.align){case\"left\":s=l.bottom-t;break;case\"center\":s=l.vcenter;break;case\"right\":s=l.top+t}break;case\"right\":switch(this.model.vertical_align){case\"top\":i=l.right-e;break;case\"middle\":i=l.hcenter;break;case\"bottom\":i=l.left+e}switch(this.model.align){case\"left\":s=l.top+t;break;case\"center\":s=l.vcenter;break;case\"right\":s=l.bottom-t}}return[i,s]}_render(){const{text:t}=this.model;if(null==t||0==t.length)return;this.model.text_baseline=this.model.vertical_align,this.model.text_align=this.model.align;const[e,i]=this._get_location(),s=this.panel.get_label_angle_heuristic(\"parallel\");(\"canvas\"==this.model.render_mode?this._canvas_text.bind(this):this._css_text.bind(this))(this.layer.ctx,t,e,i,s)}_get_size(){const{text:t}=this.model;if(null==t||0==t.length)return{width:0,height:0};{const{ctx:e}=this.layer;this.visuals.text.set_value(e);const{width:i}=this.layer.ctx.measureText(t),{height:s}=r.font_metrics(e.font);return{width:i,height:2+s*this.model.text_line_height+this.model.standoff}}}}i.TitleView=h,h.__name__=\"TitleView\";class _ extends a.TextAnnotation{constructor(t){super(t)}static init_Title(){this.prototype.default_view=h,this.mixins([c.Text,[\"border_\",c.Line],[\"background_\",c.Fill]]),this.define((({Number:t,String:e})=>({text:[e,\"\"],vertical_align:[n.VerticalAlign,\"bottom\"],align:[n.TextAlign,\"left\"],offset:[t,0],standoff:[t,10]}))),this.prototype._props.text_align.options.internal=!0,this.prototype._props.text_baseline.options.internal=!0,this.override({text_font_size:\"13px\",text_font_style:\"bold\",text_line_height:1,background_fill_color:null,border_line_color:null})}}i.Title=_,_.__name__=\"Title\",_.init_Title()},\n",
" function _(e,t,s,i,n){i();const l=e(40),a=e(43),o=e(20),r=e(140),d=e(143),c=e(11);class _ extends l.AnnotationView{update_layout(){const{panel:e}=this;this.layout=null!=e?new r.SideLayout(e,(()=>this.get_size()),!0):void 0}initialize(){super.initialize(),\"css\"==this.model.render_mode&&(this.el=a.div(),this.plot_view.canvas_view.add_overlay(this.el))}remove(){null!=this.el&&a.remove(this.el),super.remove()}connect_signals(){super.connect_signals(),\"css\"==this.model.render_mode?this.connect(this.model.change,(()=>this.render())):this.connect(this.model.change,(()=>this.request_render()))}render(){this.model.visible||\"css\"!=this.model.render_mode||a.undisplay(this.el),super.render()}_calculate_text_dimensions(e,t){const{width:s}=e.measureText(t),{height:i}=d.font_metrics(this.visuals.text.font_value());return[s,i]}_calculate_bounding_box_dimensions(e,t){const[s,i]=this._calculate_text_dimensions(e,t);let n,l;switch(e.textAlign){case\"left\":n=0;break;case\"center\":n=-s/2;break;case\"right\":n=-s;break;default:c.unreachable()}switch(e.textBaseline){case\"top\":l=0;break;case\"middle\":l=-.5*i;break;case\"bottom\":l=-1*i;break;case\"alphabetic\":l=-.8*i;break;case\"hanging\":l=-.17*i;break;case\"ideographic\":l=-.83*i;break;default:c.unreachable()}return[n,l,s,i]}_canvas_text(e,t,s,i,n){this.visuals.text.set_value(e);const l=this._calculate_bounding_box_dimensions(e,t);e.save(),e.beginPath(),e.translate(s,i),n&&e.rotate(n),e.rect(l[0],l[1],l[2],l[3]),this.visuals.background_fill.doit&&(this.visuals.background_fill.set_value(e),e.fill()),this.visuals.border_line.doit&&(this.visuals.border_line.set_value(e),e.stroke()),this.visuals.text.doit&&(this.visuals.text.set_value(e),e.fillText(t,0,0)),e.restore()}_css_text(e,t,s,i,n){const{el:l}=this;c.assert(null!=l),a.undisplay(l),this.visuals.text.set_value(e);const[o,r]=this._calculate_bounding_box_dimensions(e,t);l.style.position=\"absolute\",l.style.left=`${s+o}px`,l.style.top=`${i+r}px`,l.style.color=e.fillStyle,l.style.font=e.font,l.style.lineHeight=\"normal\",n&&(l.style.transform=`rotate(${n}rad)`),this.visuals.background_fill.doit&&(this.visuals.background_fill.set_value(e),l.style.backgroundColor=e.fillStyle),this.visuals.border_line.doit&&(this.visuals.border_line.set_value(e),l.style.borderStyle=e.lineDash.length<2?\"solid\":\"dashed\",l.style.borderWidth=`${e.lineWidth}px`,l.style.borderColor=e.strokeStyle),l.textContent=t,a.display(l)}}s.TextAnnotationView=_,_.__name__=\"TextAnnotationView\";class u extends l.Annotation{constructor(e){super(e)}static init_TextAnnotation(){this.define((()=>({render_mode:[o.RenderMode,\"canvas\"]})))}}s.TextAnnotation=u,u.__name__=\"TextAnnotation\",u.init_TextAnnotation()},\n",
" function _(t,e,i,l,r){l();const a=t(141),o=t(142),n=t(8),h=Math.PI/2,s={above:{parallel:0,normal:-h,horizontal:0,vertical:-h},below:{parallel:0,normal:h,horizontal:0,vertical:h},left:{parallel:-h,normal:0,horizontal:0,vertical:-h},right:{parallel:h,normal:0,horizontal:0,vertical:h}},c={above:{parallel:\"bottom\",normal:\"center\",horizontal:\"bottom\",vertical:\"center\"},below:{parallel:\"top\",normal:\"center\",horizontal:\"top\",vertical:\"center\"},left:{parallel:\"bottom\",normal:\"center\",horizontal:\"center\",vertical:\"bottom\"},right:{parallel:\"bottom\",normal:\"center\",horizontal:\"center\",vertical:\"bottom\"}},g={above:{parallel:\"center\",normal:\"left\",horizontal:\"center\",vertical:\"left\"},below:{parallel:\"center\",normal:\"left\",horizontal:\"center\",vertical:\"left\"},left:{parallel:\"center\",normal:\"right\",horizontal:\"right\",vertical:\"center\"},right:{parallel:\"center\",normal:\"left\",horizontal:\"left\",vertical:\"center\"}},_={above:\"right\",below:\"left\",left:\"right\",right:\"left\"},b={above:\"left\",below:\"right\",left:\"right\",right:\"left\"};class z{constructor(t){this.side=t}get dimension(){return\"above\"==this.side||\"below\"==this.side?0:1}get normals(){switch(this.side){case\"above\":return[0,-1];case\"below\":return[0,1];case\"left\":return[-1,0];case\"right\":return[1,0]}}get orientation(){return this.is_horizontal?\"horizontal\":\"vertical\"}get is_horizontal(){return 0==this.dimension}get is_vertical(){return 1==this.dimension}get_label_text_heuristics(t){const{side:e}=this;return n.isString(t)?{vertical_align:c[e][t],align:g[e][t]}:{vertical_align:\"center\",align:(t<0?_:b)[e]}}get_label_angle_heuristic(t){return n.isString(t)?s[this.side][t]:-t}}i.Panel=z,z.__name__=\"Panel\";class m extends o.ContentLayoutable{constructor(t,e,i=!1){super(),this.panel=t,this.get_size=e,this.rotate=i,this.panel.is_horizontal?this.set_sizing({width_policy:\"max\",height_policy:\"fixed\"}):this.set_sizing({width_policy:\"fixed\",height_policy:\"max\"})}_content_size(){const{width:t,height:e}=this.get_size();return!this.rotate||this.panel.is_horizontal?new a.Sizeable({width:t,height:e}):new a.Sizeable({width:e,height:t})}has_size_changed(){const{width:t,height:e}=this._content_size();return this.panel.is_horizontal?this.bbox.height!=e:this.bbox.width!=t}}i.SideLayout=m,m.__name__=\"SideLayout\"},\n",
" function _(h,t,i,e,w){e();const n=h(21),{min:d,max:s}=Math;class g{constructor(h={}){this.width=null!=h.width?h.width:0,this.height=null!=h.height?h.height:0}bounded_to({width:h,height:t}){return new g({width:this.width==1/0&&null!=h?h:this.width,height:this.height==1/0&&null!=t?t:this.height})}expanded_to({width:h,height:t}){return new g({width:h!=1/0?s(this.width,h):this.width,height:t!=1/0?s(this.height,t):this.height})}expand_to({width:h,height:t}){this.width=s(this.width,h),this.height=s(this.height,t)}narrowed_to({width:h,height:t}){return new g({width:d(this.width,h),height:d(this.height,t)})}narrow_to({width:h,height:t}){this.width=d(this.width,h),this.height=d(this.height,t)}grow_by({left:h,right:t,top:i,bottom:e}){const w=this.width+h+t,n=this.height+i+e;return new g({width:w,height:n})}shrink_by({left:h,right:t,top:i,bottom:e}){const w=s(this.width-h-t,0),n=s(this.height-i-e,0);return new g({width:w,height:n})}map(h,t){return new g({width:h(this.width),height:(null!=t?t:h)(this.height)})}}i.Sizeable=g,g.__name__=\"Sizeable\",i.SizingPolicy=n.Enum(\"fixed\",\"fit\",\"min\",\"max\")},\n",
" function _(i,t,h,e,n){e();const s=i(141),r=i(99),g=i(8),{min:l,max:a,round:_}=Math;class o{constructor(){this.absolute=!1,this._bbox=new r.BBox,this._inner_bbox=new r.BBox,this._dirty=!1,this._handlers=[]}*[Symbol.iterator](){}get bbox(){return this._bbox}get inner_bbox(){return this._inner_bbox}get sizing(){return this._sizing}set visible(i){this._sizing.visible=i,this._dirty=!0}set_sizing(i){var t,h,e,n,s;const r=null!==(t=i.width_policy)&&void 0!==t?t:\"fit\",g=i.width,l=i.min_width,a=i.max_width,_=null!==(h=i.height_policy)&&void 0!==h?h:\"fit\",o=i.height,d=i.min_height,u=i.max_height,c=i.aspect,w=null!==(e=i.margin)&&void 0!==e?e:{top:0,right:0,bottom:0,left:0},m=!1!==i.visible,x=null!==(n=i.halign)&&void 0!==n?n:\"start\",b=null!==(s=i.valign)&&void 0!==s?s:\"start\";this._sizing={width_policy:r,min_width:l,width:g,max_width:a,height_policy:_,min_height:d,height:o,max_height:u,aspect:c,margin:w,visible:m,halign:x,valign:b,size:{width:g,height:o}},this._init()}_init(){}_set_geometry(i,t){this._bbox=i,this._inner_bbox=t}set_geometry(i,t){this._set_geometry(i,null!=t?t:i);for(const i of this._handlers)i(this._bbox,this._inner_bbox)}on_resize(i){this._handlers.push(i)}is_width_expanding(){return\"max\"==this.sizing.width_policy}is_height_expanding(){return\"max\"==this.sizing.height_policy}apply_aspect(i,{width:t,height:h}){const{aspect:e}=this.sizing;if(null!=e){const{width_policy:n,height_policy:s}=this.sizing,r=(i,t)=>{const h={max:4,fit:3,min:2,fixed:1};return h[i]>h[t]};if(\"fixed\"!=n&&\"fixed\"!=s)if(n==s){const n=t,s=_(t/e),r=_(h*e),g=h;Math.abs(i.width-n)+Math.abs(i.height-s)<=Math.abs(i.width-r)+Math.abs(i.height-g)?(t=n,h=s):(t=r,h=g)}else r(n,s)?h=_(t/e):t=_(h*e);else\"fixed\"==n?h=_(t/e):\"fixed\"==s&&(t=_(h*e))}return{width:t,height:h}}measure(i){if(!this.sizing.visible)return{width:0,height:0};const t=new s.Sizeable(i).shrink_by(this.sizing.margin).map((i=>i==1/0&&\"fixed\"==this.sizing.width_policy&&null!=this.sizing.width?this.sizing.width:i),(i=>i==1/0&&\"fixed\"==this.sizing.height_policy&&null!=this.sizing.height?this.sizing.height:i)),h=this._measure(t),e=this.clip_size(h,t),n=this.apply_aspect(t,e);return Object.assign(Object.assign({},h),n)}compute(i={}){const t={width:null!=i.width&&this.is_width_expanding()?i.width:1/0,height:null!=i.height&&this.is_height_expanding()?i.height:1/0},h=this.measure(t),{width:e,height:n}=h,s=new r.BBox({left:0,top:0,width:e,height:n});let g;if(null!=h.inner){const{left:i,top:t,right:s,bottom:l}=h.inner;g=new r.BBox({left:i,top:t,right:e-s,bottom:n-l})}this.set_geometry(s,g)}get xview(){return this.bbox.xview}get yview(){return this.bbox.yview}clip_size(i,t){function h(i,t,h,e){return null==h?h=0:g.isNumber(h)||(h=Math.round(h.percent*t)),null==e?e=1/0:g.isNumber(e)||(e=Math.round(e.percent*t)),a(h,l(i,e))}return{width:h(i.width,t.width,this.sizing.min_width,this.sizing.max_width),height:h(i.height,t.height,this.sizing.min_height,this.sizing.max_height)}}has_size_changed(){const{_dirty:i}=this;return this._dirty=!1,i}}h.Layoutable=o,o.__name__=\"Layoutable\";class d extends o{_measure(i){const{width_policy:t,height_policy:h}=this.sizing;return{width:(()=>{const{width:h}=this.sizing;if(i.width==1/0)return null!=h?h:0;switch(t){case\"fixed\":return null!=h?h:0;case\"min\":return null!=h?l(i.width,h):0;case\"fit\":return null!=h?l(i.width,h):i.width;case\"max\":return null!=h?a(i.width,h):i.width}})(),height:(()=>{const{height:t}=this.sizing;if(i.height==1/0)return null!=t?t:0;switch(h){case\"fixed\":return null!=t?t:0;case\"min\":return null!=t?l(i.height,t):0;case\"fit\":return null!=t?l(i.height,t):i.height;case\"max\":return null!=t?a(i.height,t):i.height}})()}}}h.LayoutItem=d,d.__name__=\"LayoutItem\";class u extends o{_measure(i){const t=this._content_size(),h=i.bounded_to(this.sizing.size).bounded_to(t);return{width:(()=>{switch(this.sizing.width_policy){case\"fixed\":return null!=this.sizing.width?this.sizing.width:t.width;case\"min\":return t.width;case\"fit\":return h.width;case\"max\":return Math.max(t.width,h.width)}})(),height:(()=>{switch(this.sizing.height_policy){case\"fixed\":return null!=this.sizing.height?this.sizing.height:t.height;case\"min\":return t.height;case\"fit\":return h.height;case\"max\":return Math.max(t.height,h.height)}})()}}}h.ContentLayoutable=u,u.__name__=\"ContentLayoutable\"},\n",
" function _(t,e,n,r,a){r();const l=t(11),c=(()=>{try{return\"undefined\"!=typeof OffscreenCanvas&&null!=new OffscreenCanvas(0,0).getContext(\"2d\")}catch(t){return!1}})()?(t,e)=>new OffscreenCanvas(t,e):(t,e)=>{const n=document.createElement(\"canvas\");return n.width=t,n.height=e,n},o=(()=>{const t=c(0,0).getContext(\"2d\");return e=>{t.font=e;const n=t.measureText(\"M\"),r=t.measureText(\"x\"),a=t.measureText(\"ÅŚg|\"),c=a.fontBoundingBoxAscent,o=a.fontBoundingBoxDescent;if(null!=c&&null!=o)return{height:c+o,ascent:c,descent:o,cap_height:n.actualBoundingBoxAscent,x_height:r.actualBoundingBoxAscent};const s=a.actualBoundingBoxAscent,u=a.actualBoundingBoxDescent;if(null!=s&&null!=u)return{height:s+u,ascent:s,descent:u,cap_height:n.actualBoundingBoxAscent,x_height:r.actualBoundingBoxAscent};l.unreachable()}})(),s=(()=>{const t=c(0,0).getContext(\"2d\");return(e,n)=>{t.font=n;const r=t.measureText(e),a=r.actualBoundingBoxAscent,c=r.actualBoundingBoxDescent;if(null!=a&&null!=c)return{width:r.width,height:a+c,ascent:a,descent:c};l.unreachable()}})(),u=(()=>{const t=document.createElement(\"canvas\"),e=t.getContext(\"2d\");let n=-1,r=-1;return(a,l=1)=>{e.font=a;const{width:c}=e.measureText(\"M\"),o=c*l,s=Math.ceil(o),u=Math.ceil(2*o),i=Math.ceil(1.5*o);n<s&&(n=s,t.width=s),r<u&&(r=u,t.height=u),e.save(),e.scale(l,l),e.fillStyle=\"#f00\",e.fillRect(0,0,s,u);const f=t=>{let e=0;for(let n=0;n<=i;n++)for(let r=0;r<s;r++,e+=4)if(255!=t[e])return i-n;return 0};e.font=a,e.fillStyle=\"#000\";for(const t of\"xa\")e.fillText(t,0,i/l);const{data:h}=e.getImageData(0,0,s,u),g=f(h)/l;for(const t of\"ASQ\")e.fillText(t,0,i/l);const{data:d}=e.getImageData(0,0,s,u),x=f(d)/l;for(const t of\"ÅŚgy\")e.fillText(t,0,i/l);const{data:m}=e.getImageData(0,0,s,u),B=f(m)/l,w=(t=>{let e=t.length-4;for(let n=u;n>=i;n--)for(let r=0;r<s;r++,e-=4)if(255!=t[e])return n-i;return 0})(m)/l;return e.restore(),{height:B+w,ascent:B,cap_height:x,x_height:g,descent:w}}})(),i=(()=>{const t=document.createElement(\"canvas\"),e=t.getContext(\"2d\");let n=-1,r=-1;return(a,l,c=1)=>{e.font=l;const{width:o}=e.measureText(\"M\"),s=o*c,u=Math.ceil(s),i=Math.ceil(2*s),f=Math.ceil(1.5*s);(n<u||r<i)&&(n=u,t.width=u,r=i,t.height=i),e.save(),e.scale(c,c),e.fillStyle=\"#f00\",e.fillRect(0,0,u,i);e.font=l,e.fillStyle=\"#000\",e.fillText(a,0,f/c);const h=e.measureText(a),{data:g}=e.getImageData(0,0,u,i),d=(t=>{let e=0;for(let n=0;n<=f;n++)for(let r=0;r<u;r++,e+=4)if(255!=t[e])return f-n;return 0})(g)/c,x=(t=>{let e=t.length-4;for(let n=i;n>=f;n--)for(let r=0;r<u;r++,e-=4)if(255!=t[e])return n-f;return 0})(g)/c;return e.restore(),{width:h.width,height:d+x,ascent:d,descent:x}}})(),f=(()=>{try{return o(\"normal 10px sans-serif\"),o}catch(t){return u}})(),h=(()=>{try{return s(\"A\",\"normal 10px sans-serif\"),s}catch(t){return i}})(),g=new Map;function d(t){let e=g.get(t);return null==e&&(e={font:f(t),glyphs:new Map},g.set(t,e)),e.font}n.font_metrics=d,n.glyph_metrics=function(t,e){let n=g.get(e);null==n&&(d(e),n=g.get(e));let r=n.glyphs.get(t);return null==r&&(r=h(t,e),n.glyphs.set(t,r)),r}},\n",
" function _(e,t,s,_,a){_();const r=e(145),n=e(157),g=e(156),i=e(159),c=e(104),h=e(99),o=e(13),l=e(11);class x{constructor(e,t,s,_,a={},r={}){this.in_x_scale=e,this.in_y_scale=t,this.x_range=s,this.y_range=_,this.extra_x_ranges=a,this.extra_y_ranges=r,this._bbox=new h.BBox,l.assert(null==e.source_range&&null==e.target_range),l.assert(null==t.source_range&&null==t.target_range),this._configure_scales()}get bbox(){return this._bbox}_get_ranges(e,t){return new Map(o.entries(Object.assign(Object.assign({},t),{default:e})))}_get_scales(e,t,s){const _=new Map;for(const[a,g]of t){if(g instanceof c.FactorRange!=e instanceof r.CategoricalScale)throw new Error(`Range ${g.type} is incompatible is Scale ${e.type}`);e instanceof n.LogScale&&g instanceof i.DataRange1d&&(g.scale_hint=\"log\");const t=e.clone();t.setv({source_range:g,target_range:s}),_.set(a,t)}return _}_configure_frame_ranges(){const{bbox:e}=this;this._x_target=new g.Range1d({start:e.left,end:e.right}),this._y_target=new g.Range1d({start:e.bottom,end:e.top})}_configure_scales(){this._configure_frame_ranges(),this._x_ranges=this._get_ranges(this.x_range,this.extra_x_ranges),this._y_ranges=this._get_ranges(this.y_range,this.extra_y_ranges),this._x_scales=this._get_scales(this.in_x_scale,this._x_ranges,this._x_target),this._y_scales=this._get_scales(this.in_y_scale,this._y_ranges,this._y_target)}_update_scales(){this._configure_frame_ranges();for(const[,e]of this._x_scales)e.target_range=this._x_target;for(const[,e]of this._y_scales)e.target_range=this._y_target}set_geometry(e){this._bbox=e,this._update_scales()}get x_target(){return this._x_target}get y_target(){return this._y_target}get x_ranges(){return this._x_ranges}get y_ranges(){return this._y_ranges}get x_scales(){return this._x_scales}get y_scales(){return this._y_scales}get x_scale(){return this._x_scales.get(\"default\")}get y_scale(){return this._y_scales.get(\"default\")}get xscales(){return o.to_object(this.x_scales)}get yscales(){return o.to_object(this.y_scales)}}s.CartesianFrame=x,x.__name__=\"CartesianFrame\"},\n",
" function _(e,t,r,n,_){n();const c=e(146);class s extends c.Scale{constructor(e){super(e)}get s_compute(){const[e,t]=this._linear_compute_state(),r=this.source_range;return n=>e*r.synthetic(n)+t}compute(e){return super._linear_compute(this.source_range.synthetic(e))}v_compute(e){return super._linear_v_compute(this.source_range.v_synthetic(e))}invert(e){return this._linear_invert(e)}v_invert(e){return this._linear_v_invert(e)}}r.CategoricalScale=s,s.__name__=\"CategoricalScale\"},\n",
" function _(t,e,r,n,s){n();const i=t(147),_=t(105),a=t(156),c=t(24);class o extends i.Transform{constructor(t){super(t)}static init_Scale(){this.internal((({Ref:t})=>({source_range:[t(_.Range)],target_range:[t(a.Range1d)]})))}r_compute(t,e){return this.target_range.is_reversed?[this.compute(e),this.compute(t)]:[this.compute(t),this.compute(e)]}r_invert(t,e){return this.target_range.is_reversed?[this.invert(e),this.invert(t)]:[this.invert(t),this.invert(e)]}_linear_compute(t){const[e,r]=this._linear_compute_state();return e*t+r}_linear_v_compute(t){const[e,r]=this._linear_compute_state(),n=new c.ScreenArray(t.length);for(let s=0;s<t.length;s++)n[s]=e*t[s]+r;return n}_linear_invert(t){const[e,r]=this._linear_compute_state();return(t-r)/e}_linear_v_invert(t){const[e,r]=this._linear_compute_state(),n=new Float64Array(t.length);for(let s=0;s<t.length;s++)n[s]=(t[s]-r)/e;return n}_linear_compute_state(){const t=this.source_range.start,e=this.source_range.end,r=this.target_range.start,n=(this.target_range.end-r)/(e-t);return[n,-n*t+r]}}r.Scale=o,o.__name__=\"Scale\",o.init_Scale()},\n",
" function _(r,o,t,e,n){e(),n(\"CustomJSTransform\",r(148).CustomJSTransform),n(\"Dodge\",r(150).Dodge),n(\"Interpolator\",r(152).Interpolator),n(\"Jitter\",r(153).Jitter),n(\"LinearInterpolator\",r(154).LinearInterpolator),n(\"StepInterpolator\",r(155).StepInterpolator),n(\"Transform\",r(149).Transform)},\n",
" function _(t,r,s,n,e){n();const a=t(149),o=t(13),u=t(34);class m extends a.Transform{constructor(t){super(t)}static init_CustomJSTransform(){this.define((({Unknown:t,String:r,Dict:s})=>({args:[s(t),{}],func:[r,\"\"],v_func:[r,\"\"]})))}get names(){return o.keys(this.args)}get values(){return o.values(this.args)}_make_transform(t,r){return new Function(...this.names,t,u.use_strict(r))}get scalar_transform(){return this._make_transform(\"x\",this.func)}get vector_transform(){return this._make_transform(\"xs\",this.v_func)}compute(t){return this.scalar_transform(...this.values,t)}v_compute(t){return this.vector_transform(...this.values,t)}}s.CustomJSTransform=m,m.__name__=\"CustomJSTransform\",m.init_CustomJSTransform()},\n",
" function _(n,s,o,r,c){r();const e=n(53);class t extends e.Model{constructor(n){super(n)}}o.Transform=t,t.__name__=\"Transform\"},\n",
" function _(e,t,n,o,s){o();const i=e(151);class r extends i.RangeTransform{constructor(e){super(e)}static init_Dodge(){this.define((({Number:e})=>({value:[e,0]})))}_compute(e){return e+this.value}}n.Dodge=r,r.__name__=\"Dodge\",r.init_Dodge()},\n",
" function _(e,n,t,r,s){r();const a=e(149),i=e(105),o=e(104),c=e(24),f=e(8);class u extends a.Transform{constructor(e){super(e)}static init_RangeTransform(){this.define((({Ref:e,Nullable:n})=>({range:[n(e(i.Range)),null]})))}v_compute(e){let n;if(this.range instanceof o.FactorRange)n=this.range.v_synthetic(e);else{if(!f.isArrayableOf(e,f.isNumber))throw new Error(\"unexpected\");n=e}const t=new(c.infer_type(n))(n.length);for(let e=0;e<n.length;e++){const r=n[e];t[e]=this._compute(r)}return t}compute(e){if(this.range instanceof o.FactorRange)return this._compute(this.range.synthetic(e));if(f.isNumber(e))return this._compute(e);throw new Error(\"unexpected\")}}t.RangeTransform=u,u.__name__=\"RangeTransform\",u.init_RangeTransform()},\n",
" function _(t,e,r,n,o){n();const s=t(149),i=t(57),a=t(24),h=t(9),l=t(8);class d extends s.Transform{constructor(t){super(t),this._sorted_dirty=!0}static init_Interpolator(){this.define((({Boolean:t,Number:e,String:r,Ref:n,Array:o,Or:s,Nullable:a})=>({x:[s(r,o(e))],y:[s(r,o(e))],data:[a(n(i.ColumnarDataSource)),null],clip:[t,!0]})))}connect_signals(){super.connect_signals(),this.connect(this.change,(()=>this._sorted_dirty=!0))}v_compute(t){const e=new(a.infer_type(t))(t.length);for(let r=0;r<t.length;r++){const n=t[r];e[r]=this.compute(n)}return e}sort(t=!1){if(!this._sorted_dirty)return;let e,r;if(l.isString(this.x)&&l.isString(this.y)&&null!=this.data){const t=this.data.columns();if(!h.includes(t,this.x))throw new Error(\"The x parameter does not correspond to a valid column name defined in the data parameter\");if(!h.includes(t,this.y))throw new Error(\"The y parameter does not correspond to a valid column name defined in the data parameter\");e=this.data.get_column(this.x),r=this.data.get_column(this.y)}else{if(!l.isArray(this.x)||!l.isArray(this.y))throw new Error(\"parameters 'x' and 'y' must be both either string fields or arrays\");e=this.x,r=this.y}if(e.length!==r.length)throw new Error(\"The length for x and y do not match\");if(e.length<2)throw new Error(\"x and y must have at least two elements to support interpolation\");const n=e.length,o=new Uint32Array(n);for(let t=0;t<n;t++)o[t]=t;const s=t?-1:1;o.sort(((t,r)=>s*(e[t]-e[r]))),this._x_sorted=new(a.infer_type(e))(n),this._y_sorted=new(a.infer_type(r))(n);for(let t=0;t<n;t++)this._x_sorted[t]=e[o[t]],this._y_sorted[t]=r[o[t]];this._sorted_dirty=!1}}r.Interpolator=d,d.__name__=\"Interpolator\",d.init_Interpolator()},\n",
" function _(t,i,e,s,r){s();const n=t(1),u=t(151),o=t(20),a=n.__importStar(t(10));class h extends u.RangeTransform{constructor(t){super(t)}static init_Jitter(){this.define((({Number:t})=>({mean:[t,0],width:[t,1],distribution:[o.Distribution,\"uniform\"]})))}v_compute(t){return null!=this.previous_values&&this.previous_values.length==t.length||(this.previous_values=super.v_compute(t)),this.previous_values}_compute(t){switch(this.distribution){case\"uniform\":return t+this.mean+(a.random()-.5)*this.width;case\"normal\":return t+a.rnorm(this.mean,this.width)}}}e.Jitter=h,h.__name__=\"Jitter\",h.init_Jitter()},\n",
" function _(t,s,_,r,e){r();const i=t(9),o=t(152);class n extends o.Interpolator{constructor(t){super(t)}compute(t){if(this.sort(!1),this.clip){if(t<this._x_sorted[0]||t>this._x_sorted[this._x_sorted.length-1])return NaN}else{if(t<this._x_sorted[0])return this._y_sorted[0];if(t>this._x_sorted[this._x_sorted.length-1])return this._y_sorted[this._y_sorted.length-1]}if(t==this._x_sorted[0])return this._y_sorted[0];const s=i.find_last_index(this._x_sorted,(s=>s<t)),_=this._x_sorted[s],r=this._x_sorted[s+1],e=this._y_sorted[s],o=this._y_sorted[s+1];return e+(t-_)/(r-_)*(o-e)}}_.LinearInterpolator=n,n.__name__=\"LinearInterpolator\"},\n",
" function _(t,e,s,r,o){r();const i=t(152),_=t(20),n=t(9);class d extends i.Interpolator{constructor(t){super(t)}static init_StepInterpolator(){this.define((()=>({mode:[_.StepMode,\"after\"]})))}compute(t){if(this.sort(!1),this.clip){if(t<this._x_sorted[0]||t>this._x_sorted[this._x_sorted.length-1])return NaN}else{if(t<this._x_sorted[0])return this._y_sorted[0];if(t>this._x_sorted[this._x_sorted.length-1])return this._y_sorted[this._y_sorted.length-1]}let e;switch(this.mode){case\"after\":e=n.find_last_index(this._x_sorted,(e=>t>=e));break;case\"before\":e=n.find_index(this._x_sorted,(e=>t<=e));break;case\"center\":{const s=n.map(this._x_sorted,(e=>Math.abs(e-t))),r=n.min(s);e=n.find_index(s,(t=>r===t));break}default:throw new Error(`unknown mode: ${this.mode}`)}return-1!=e?this._y_sorted[e]:NaN}}s.StepInterpolator=d,d.__name__=\"StepInterpolator\",d.init_StepInterpolator()},\n",
" function _(t,e,s,n,i){n();const a=t(105);class r extends a.Range{constructor(t){super(t)}static init_Range1d(){this.define((({Number:t,Nullable:e})=>({start:[t,0],end:[t,1],reset_start:[e(t),null,{on_update(t,e){e._reset_start=null!=t?t:e.start}}],reset_end:[e(t),null,{on_update(t,e){e._reset_end=null!=t?t:e.end}}]})))}_set_auto_bounds(){if(\"auto\"==this.bounds){const t=Math.min(this._reset_start,this._reset_end),e=Math.max(this._reset_start,this._reset_end);this.setv({bounds:[t,e]},{silent:!0})}}initialize(){super.initialize(),this._set_auto_bounds()}get min(){return Math.min(this.start,this.end)}get max(){return Math.max(this.start,this.end)}reset(){this._set_auto_bounds();const{_reset_start:t,_reset_end:e}=this;this.start!=t||this.end!=e?this.setv({start:t,end:e}):this.change.emit()}map(t){return new r({start:t(this.start),end:t(this.end)})}widen(t){let{start:e,end:s}=this;return this.is_reversed?(e+=t,s-=t):(e-=t,s+=t),new r({start:e,end:s})}}s.Range1d=r,r.__name__=\"Range1d\",r.init_Range1d()},\n",
" function _(t,e,o,n,s){n();const a=t(158),r=t(24);class c extends a.ContinuousScale{constructor(t){super(t)}get s_compute(){const[t,e,o,n]=this._compute_state();return s=>{if(0==o)return 0;{const a=(Math.log(s)-n)/o;return isFinite(a)?a*t+e:NaN}}}compute(t){const[e,o,n,s]=this._compute_state();let a;if(0==n)a=0;else{const r=(Math.log(t)-s)/n;a=isFinite(r)?r*e+o:NaN}return a}v_compute(t){const[e,o,n,s]=this._compute_state(),a=new r.ScreenArray(t.length);if(0==n)for(let e=0;e<t.length;e++)a[e]=0;else for(let r=0;r<t.length;r++){const c=(Math.log(t[r])-s)/n;let l;l=isFinite(c)?c*e+o:NaN,a[r]=l}return a}invert(t){const[e,o,n,s]=this._compute_state(),a=(t-o)/e;return Math.exp(n*a+s)}v_invert(t){const[e,o,n,s]=this._compute_state(),a=new Float64Array(t.length);for(let r=0;r<t.length;r++){const c=(t[r]-o)/e;a[r]=Math.exp(n*c+s)}return a}_get_safe_factor(t,e){let o=t<0?0:t,n=e<0?0:e;if(o==n)if(0==o)[o,n]=[1,10];else{const t=Math.log(o)/Math.log(10);o=10**Math.floor(t),n=Math.ceil(t)!=Math.floor(t)?10**Math.ceil(t):10**(Math.ceil(t)+1)}return[o,n]}_compute_state(){const t=this.source_range.start,e=this.source_range.end,o=this.target_range.start,n=this.target_range.end-o,[s,a]=this._get_safe_factor(t,e);let r,c;0==s?(r=Math.log(a),c=0):(r=Math.log(a)-Math.log(s),c=Math.log(s));return[n,o,r,c]}}o.LogScale=c,c.__name__=\"LogScale\"},\n",
" function _(n,c,o,s,e){s();const t=n(146);class u extends t.Scale{constructor(n){super(n)}}o.ContinuousScale=u,u.__name__=\"ContinuousScale\"},\n",
" function _(t,i,n,a,e){a();const s=t(1),l=t(160),_=t(20),o=t(9),h=t(19),r=s.__importStar(t(99)),d=t(161);class u extends l.DataRange{constructor(t){super(t),this.have_updated_interactively=!1}static init_DataRange1d(){this.define((({Boolean:t,Number:i,Nullable:n})=>({start:[i],end:[i],range_padding:[i,.1],range_padding_units:[_.PaddingUnits,\"percent\"],flipped:[t,!1],follow:[n(_.StartEnd),null],follow_interval:[n(i),null],default_span:[i,2],only_visible:[t,!1]}))),this.internal((({Enum:t})=>({scale_hint:[t(\"log\",\"auto\"),\"auto\"]})))}initialize(){super.initialize(),this._initial_start=this.start,this._initial_end=this.end,this._initial_range_padding=this.range_padding,this._initial_range_padding_units=this.range_padding_units,this._initial_follow=this.follow,this._initial_follow_interval=this.follow_interval,this._initial_default_span=this.default_span,this._plot_bounds=new Map}get min(){return Math.min(this.start,this.end)}get max(){return Math.max(this.start,this.end)}computed_renderers(){const{renderers:t,names:i}=this,n=o.concat(this.plots.map((t=>t.data_renderers)));return d.compute_renderers(0==t.length?\"auto\":t,n,i)}_compute_plot_bounds(t,i){let n=r.empty();for(const a of t){const t=i.get(a);null==t||!a.visible&&this.only_visible||(n=r.union(n,t))}return n}adjust_bounds_for_aspect(t,i){const n=r.empty();let a=t.x1-t.x0;a<=0&&(a=1);let e=t.y1-t.y0;e<=0&&(e=1);const s=.5*(t.x1+t.x0),l=.5*(t.y1+t.y0);return a<i*e?a=i*e:e=a/i,n.x1=s+.5*a,n.x0=s-.5*a,n.y1=l+.5*e,n.y0=l-.5*e,n}_compute_min_max(t,i){let n,a,e=r.empty();for(const i of t)e=r.union(e,i);return[n,a]=0==i?[e.x0,e.x1]:[e.y0,e.y1],[n,a]}_compute_range(t,i){const n=this.range_padding;let a,e;if(null!=this._initial_start&&(t=this._initial_start),null!=this._initial_end&&(i=this._initial_end),\"log\"==this.scale_hint){let s,l;if((isNaN(t)||!isFinite(t)||t<=0)&&(t=isNaN(i)||!isFinite(i)||i<=0?.1:i/100,h.logger.warn(`could not determine minimum data value for log axis, DataRange1d using value ${t}`)),(isNaN(i)||!isFinite(i)||i<=0)&&(i=isNaN(t)||!isFinite(t)||t<=0?10:100*t,h.logger.warn(`could not determine maximum data value for log axis, DataRange1d using value ${i}`)),i==t)l=this.default_span+.001,s=Math.log(t)/Math.log(10);else{let a,e;\"percent\"==this.range_padding_units?(a=Math.log(t)/Math.log(10),e=Math.log(i)/Math.log(10),l=(e-a)*(1+n)):(a=Math.log(t-n)/Math.log(10),e=Math.log(i+n)/Math.log(10),l=e-a),s=(a+e)/2}a=10**(s-l/2),e=10**(s+l/2)}else{let s;s=i==t?this.default_span:\"percent\"==this.range_padding_units?(i-t)*(1+n):i-t+2*n;const l=(i+t)/2;a=l-s/2,e=l+s/2}let s=1;this.flipped&&([a,e]=[e,a],s=-1);const l=this.follow_interval;return null!=l&&Math.abs(a-e)>l&&(\"start\"==this.follow?e=a+s*l:\"end\"==this.follow&&(a=e-s*l)),[a,e]}update(t,i,n,a){if(this.have_updated_interactively)return;const e=this.computed_renderers();let s=this._compute_plot_bounds(e,t);null!=a&&(s=this.adjust_bounds_for_aspect(s,a)),this._plot_bounds.set(n,s);const[l,_]=this._compute_min_max(this._plot_bounds.values(),i);let[o,h]=this._compute_range(l,_);null!=this._initial_start&&(\"log\"==this.scale_hint?this._initial_start>0&&(o=this._initial_start):o=this._initial_start),null!=this._initial_end&&(\"log\"==this.scale_hint?this._initial_end>0&&(h=this._initial_end):h=this._initial_end);let r=!1;\"auto\"==this.bounds&&(this.setv({bounds:[o,h]},{silent:!0}),r=!0);const[d,u]=[this.start,this.end];if(o!=d||h!=u){const t={};o!=d&&(t.start=o),h!=u&&(t.end=h),this.setv(t),r=!1}r&&this.change.emit()}reset(){this.have_updated_interactively=!1,this.setv({range_padding:this._initial_range_padding,range_padding_units:this._initial_range_padding_units,follow:this._initial_follow,follow_interval:this._initial_follow_interval,default_span:this._initial_default_span},{silent:!0}),this.change.emit()}}n.DataRange1d=u,u.__name__=\"DataRange1d\",u.init_DataRange1d()},\n",
" function _(a,e,n,t,r){t();const s=a(105),i=a(62);class R extends s.Range{constructor(a){super(a)}static init_DataRange(){this.define((({String:a,Array:e,Ref:n})=>({names:[e(a),[]],renderers:[e(n(i.DataRenderer)),[]]})))}}n.DataRange=R,R.__name__=\"DataRange\",R.init_DataRange()},\n",
" function _(n,e,t,r,u){r();const l=n(9);t.compute_renderers=function(n,e,t){if(null==n)return[];let r=\"auto\"==n?e:n;return t.length>0&&(r=r.filter((n=>l.includes(t,n.name)))),r}},\n",
" function _(i,s,x,A,o){A(),o(\"Axis\",i(163).Axis),o(\"CategoricalAxis\",i(170).CategoricalAxis),o(\"ContinuousAxis\",i(173).ContinuousAxis),o(\"DatetimeAxis\",i(174).DatetimeAxis),o(\"LinearAxis\",i(175).LinearAxis),o(\"LogAxis\",i(192).LogAxis),o(\"MercatorAxis\",i(195).MercatorAxis)},\n",
" function _(t,e,i,s,o){s();const n=t(1),a=t(164),l=t(165),r=t(166),_=t(169),c=n.__importStar(t(48)),h=t(20),b=t(24),m=t(140),d=t(9),u=t(8),x=t(167),g=t(104),{abs:f}=Math;class p extends a.GuideRendererView{update_layout(){this.layout=new m.SideLayout(this.panel,(()=>this.get_size()),!0)}get_size(){const{visible:t,fixed_location:e}=this.model;if(t&&null==e&&this.is_renderable){const{extents:t}=this;return{width:0,height:Math.round(t.tick+t.tick_label+t.axis_label)}}return{width:0,height:0}}get is_renderable(){const[t,e]=this.ranges;return t.is_valid&&e.is_valid}_render(){var t;if(!this.is_renderable)return;const{tick_coords:e,extents:i}=this,s=this.layer.ctx;s.save(),this._draw_rule(s,i),this._draw_major_ticks(s,i,e),this._draw_minor_ticks(s,i,e),this._draw_major_labels(s,i,e),this._draw_axis_label(s,i,e),null===(t=this._paint)||void 0===t||t.call(this,s,i,e),s.restore()}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.plot_view.request_layout()))}get needs_clip(){return null!=this.model.fixed_location}_draw_rule(t,e){if(!this.visuals.axis_line.doit)return;const[i,s]=this.rule_coords,[o,n]=this.coordinates.map_to_screen(i,s),[a,l]=this.normals,[r,_]=this.offsets;this.visuals.axis_line.set_value(t),t.beginPath();for(let e=0;e<o.length;e++){const i=Math.round(o[e]+a*r),s=Math.round(n[e]+l*_);t.lineTo(i,s)}t.stroke()}_draw_major_ticks(t,e,i){const s=this.model.major_tick_in,o=this.model.major_tick_out,n=this.visuals.major_tick_line;this._draw_ticks(t,i.major,s,o,n)}_draw_minor_ticks(t,e,i){const s=this.model.minor_tick_in,o=this.model.minor_tick_out,n=this.visuals.minor_tick_line;this._draw_ticks(t,i.minor,s,o,n)}_draw_major_labels(t,e,i){const s=i.major,o=this.compute_labels(s[this.dimension]),n=this.model.major_label_orientation,a=e.tick+this.model.major_label_standoff,l=this.visuals.major_label_text;this._draw_oriented_labels(t,o,s,n,this.panel.side,a,l)}_axis_label_extent(){const t=this.model.axis_label;if(!t)return 0;const e=new x.TextBox({text:t});e.angle=this.panel.get_label_angle_heuristic(\"parallel\"),e.visuals=this.visuals.axis_label_text;const i=e.size(),s=0==this.dimension?i.height:i.width,o=this.model.axis_label_standoff;return s>0?o+s+3:0}_draw_axis_label(t,e,i){const s=this.model.axis_label;if(!s||null!=this.model.fixed_location)return;const o=new x.TextBox({text:s});o.angle=this.panel.get_label_angle_heuristic(\"parallel\"),o.visuals=this.visuals.axis_label_text;const[n,a]=(()=>{const{bbox:t}=this.layout;switch(this.panel.side){case\"above\":return[t.hcenter,t.bottom];case\"below\":return[t.hcenter,t.top];case\"left\":return[t.right,t.vcenter];case\"right\":return[t.left,t.vcenter]}})(),[l,r]=this.normals,_=e.tick+e.tick_label+this.model.axis_label_standoff,{vertical_align:c,align:h}=this.panel.get_label_text_heuristics(\"parallel\");o.position={sx:n+l*_,sy:a+r*_,x_anchor:h,y_anchor:c},o.align=h,o.paint(t)}_draw_ticks(t,e,i,s,o){if(!o.doit)return;const[n,a]=e,[l,r]=this.coordinates.map_to_screen(n,a),[_,c]=this.normals,[h,b]=this.offsets,[m,d]=[_*(h-i),c*(b-i)],[u,x]=[_*(h+s),c*(b+s)];o.set_value(t),t.beginPath();for(let e=0;e<l.length;e++){const i=Math.round(l[e]+u),s=Math.round(r[e]+x),o=Math.round(l[e]+m),n=Math.round(r[e]+d);t.moveTo(i,s),t.lineTo(o,n)}t.stroke()}_draw_oriented_labels(t,e,i,s,o,n,a){if(!a.doit||0==e.length)return;const[l,r]=i,[_,c]=this.coordinates.map_to_screen(l,r),[h,m]=this.offsets,[d,u]=this.normals,g=d*(h+n),f=u*(m+n),{vertical_align:p,align:k}=this.panel.get_label_text_heuristics(s),w=this.panel.get_label_angle_heuristic(s);e.visuals=a,e.angle=w;for(let t=0;t<e.length;t++){const i=e.items[t];i.position={sx:_[t]+g,sy:c[t]+f,x_anchor:k,y_anchor:p},i instanceof x.TextBox&&(i.align=k)}const j=e.length,v=b.Indices.all_set(j),{items:y}=e,T=y.map((t=>t.bbox())),O=(()=>{const[t]=this.ranges;return t.is_reversed?0==this.dimension?(t,e)=>T[t].left-T[e].right:(t,e)=>T[e].top-T[t].bottom:0==this.dimension?(t,e)=>T[e].left-T[t].right:(t,e)=>T[t].top-T[e].bottom})(),{major_label_policy:A}=this.model,M=A.filter(v,T,O),z=[...M.ones()];if(0!=z.length){const t=this.parent.canvas_view.bbox,e=e=>{const i=T[e];if(i.left<0){const t=-i.left,{position:s}=y[e];y[e].position=Object.assign(Object.assign({},s),{sx:s.sx+t})}else if(i.right>t.width){const s=i.right-t.width,{position:o}=y[e];y[e].position=Object.assign(Object.assign({},o),{sx:o.sx-s})}},i=e=>{const i=T[e];if(i.top<0){const t=-i.top,{position:s}=y[e];y[e].position=Object.assign(Object.assign({},s),{sy:s.sy+t})}else if(i.bottom>t.height){const s=i.bottom-t.height,{position:o}=y[e];y[e].position=Object.assign(Object.assign({},o),{sy:o.sy-s})}},s=z[0],o=z[z.length-1];0==this.dimension?(e(s),e(o)):(i(s),i(o))}for(const e of M){y[e].paint(t)}}_tick_extent(){return this.model.major_tick_out}_tick_label_extents(){const t=this.tick_coords.major,e=this.compute_labels(t[this.dimension]),i=this.model.major_label_orientation,s=this.model.major_label_standoff,o=this.visuals.major_label_text;return[this._oriented_labels_extent(e,i,s,o)]}get extents(){const t=this._tick_label_extents();return{tick:this._tick_extent(),tick_labels:t,tick_label:d.sum(t),axis_label:this._axis_label_extent()}}_oriented_labels_extent(t,e,i,s){if(0==t.length)return 0;const o=this.panel.get_label_angle_heuristic(e);t.visuals=s,t.angle=o;const n=t.max_size(),a=0==this.dimension?n.height:n.width;return a>0?i+a+3:0}get normals(){return this.panel.normals}get dimension(){return this.panel.dimension}compute_labels(t){const e=this.model.formatter.format_graphics(t,this),{major_label_overrides:i}=this.model;for(let s=0;s<t.length;s++){const o=i[t[s]];null!=o&&(e[s]=new x.TextBox({text:o}))}return new x.GraphicsBoxes(e)}get offsets(){if(null!=this.model.fixed_location)return[0,0];const{frame:t}=this.plot_view;let[e,i]=[0,0];switch(this.panel.side){case\"below\":i=f(this.layout.bbox.top-t.bbox.bottom);break;case\"above\":i=f(this.layout.bbox.bottom-t.bbox.top);break;case\"right\":e=f(this.layout.bbox.left-t.bbox.right);break;case\"left\":e=f(this.layout.bbox.right-t.bbox.left)}return[e,i]}get ranges(){const t=this.dimension,e=(t+1)%2,{ranges:i}=this.coordinates;return[i[t],i[e]]}get computed_bounds(){const[t]=this.ranges,e=this.model.bounds,i=[t.min,t.max];if(\"auto\"==e)return[t.min,t.max];{let t,s;const[o,n]=e,[a,l]=i,{min:r,max:_}=Math;return f(o-n)>f(a-l)?(t=_(r(o,n),a),s=r(_(o,n),l)):(t=r(o,n),s=_(o,n)),[t,s]}}get rule_coords(){const t=this.dimension,e=(t+1)%2,[i]=this.ranges,[s,o]=this.computed_bounds,n=[new Array(2),new Array(2)];return n[t][0]=Math.max(s,i.min),n[t][1]=Math.min(o,i.max),n[t][0]>n[t][1]&&(n[t][0]=n[t][1]=NaN),n[e][0]=this.loc,n[e][1]=this.loc,n}get tick_coords(){const t=this.dimension,e=(t+1)%2,[i]=this.ranges,[s,o]=this.computed_bounds,n=this.model.ticker.get_ticks(s,o,i,this.loc),a=n.major,l=n.minor,r=[[],[]],_=[[],[]],[c,h]=[i.min,i.max];for(let i=0;i<a.length;i++)a[i]<c||a[i]>h||(r[t].push(a[i]),r[e].push(this.loc));for(let i=0;i<l.length;i++)l[i]<c||l[i]>h||(_[t].push(l[i]),_[e].push(this.loc));return{major:r,minor:_}}get loc(){const{fixed_location:t}=this.model;if(null!=t){if(u.isNumber(t))return t;const[,e]=this.ranges;if(e instanceof g.FactorRange)return e.synthetic(t);throw new Error(\"unexpected\")}const[,e]=this.ranges;switch(this.panel.side){case\"left\":case\"below\":return e.start;case\"right\":case\"above\":return e.end}}serializable_state(){return Object.assign(Object.assign({},super.serializable_state()),{bbox:this.layout.bbox.box})}}i.AxisView=p,p.__name__=\"AxisView\";class k extends a.GuideRenderer{constructor(t){super(t)}static init_Axis(){this.prototype.default_view=p,this.mixins([[\"axis_\",c.Line],[\"major_tick_\",c.Line],[\"minor_tick_\",c.Line],[\"major_label_\",c.Text],[\"axis_label_\",c.Text]]),this.define((({Any:t,Int:e,Number:i,String:s,Ref:o,Dict:n,Tuple:a,Or:c,Nullable:b,Auto:m})=>({bounds:[c(a(i,i),m),\"auto\"],ticker:[o(l.Ticker)],formatter:[o(r.TickFormatter)],axis_label:[b(s),\"\"],axis_label_standoff:[e,5],major_label_standoff:[e,5],major_label_orientation:[c(h.TickLabelOrientation,i),\"horizontal\"],major_label_overrides:[n(s),{}],major_label_policy:[o(_.LabelingPolicy),()=>new _.AllLabels],major_tick_in:[i,2],major_tick_out:[i,6],minor_tick_in:[i,0],minor_tick_out:[i,4],fixed_location:[b(c(i,t)),null]}))),this.override({axis_line_color:\"black\",major_tick_line_color:\"black\",minor_tick_line_color:\"black\",major_label_text_font_size:\"11px\",major_label_text_align:\"center\",major_label_text_baseline:\"alphabetic\",axis_label_text_font_size:\"13px\",axis_label_text_font_style:\"italic\"})}}i.Axis=k,k.__name__=\"Axis\",k.init_Axis()},\n",
" function _(e,r,d,i,n){i();const s=e(41);class t extends s.RendererView{}d.GuideRendererView=t,t.__name__=\"GuideRendererView\";class _ extends s.Renderer{constructor(e){super(e)}static init_GuideRenderer(){this.override({level:\"guide\"})}}d.GuideRenderer=_,_.__name__=\"GuideRenderer\",_.init_GuideRenderer()},\n",
" function _(c,e,n,s,o){s();const r=c(53);class t extends r.Model{constructor(c){super(c)}}n.Ticker=t,t.__name__=\"Ticker\"},\n",
" function _(t,o,r,e,c){e();const n=t(53),a=t(167);class m extends n.Model{constructor(t){super(t)}format_graphics(t,o){return this.doFormat(t,o).map((t=>new a.TextBox({text:t})))}compute(t,o){return this.doFormat([t],null!=o?o:{loc:0})[0]}v_compute(t,o){return this.doFormat(t,null!=o?o:{loc:0})}}r.TickFormatter=m,m.__name__=\"TickFormatter\"},\n",
" function _(t,e,s,i,n){i();const h=t(99),o=t(143),r=t(9),a=t(8),c=t(168),_=t(22);s.text_width=(()=>{const t=document.createElement(\"canvas\").getContext(\"2d\");let e=\"\";return(s,i)=>(i!=e&&(e=i,t.font=i),t.measureText(s).width)})();class l{constructor(){this._position={sx:0,sy:0},this.font_size_scale=1}set position(t){this._position=t}get position(){return this._position}infer_text_height(){return\"ascent_descent\"}bbox(){const{p0:t,p1:e,p2:s,p3:i}=this.rect(),n=Math.min(t.x,e.x,s.x,i.x),o=Math.min(t.y,e.y,s.y,i.y),r=Math.max(t.x,e.x,s.x,i.x),a=Math.max(t.y,e.y,s.y,i.y);return new h.BBox({left:n,right:r,top:o,bottom:a})}size(){const{width:t,height:e}=this._size(),{angle:s}=this;if(s){const i=Math.cos(Math.abs(s)),n=Math.sin(Math.abs(s));return{width:Math.abs(t*i+e*n),height:Math.abs(t*n+e*i)}}return{width:t,height:e}}rect(){const t=this._rect(),{angle:e}=this;if(e){const{sx:s,sy:i}=this.position,n=new c.AffineTransform;return n.translate(s,i),n.rotate(e),n.translate(-s,-i),n.apply_rect(t)}return t}paint_rect(t){const{p0:e,p1:s,p2:i,p3:n}=this.rect();t.save(),t.strokeStyle=\"red\",t.lineWidth=1,t.beginPath();const{round:h}=Math;t.moveTo(h(e.x),h(e.y)),t.lineTo(h(s.x),h(s.y)),t.lineTo(h(i.x),h(i.y)),t.lineTo(h(n.x),h(n.y)),t.closePath(),t.stroke(),t.restore()}paint_bbox(t){const{x:e,y:s,width:i,height:n}=this.bbox();t.save(),t.strokeStyle=\"blue\",t.lineWidth=1,t.beginPath();const{round:h}=Math;t.moveTo(h(e),h(s)),t.lineTo(h(e),h(s+n)),t.lineTo(h(e+i),h(s+n)),t.lineTo(h(e+i),h(s)),t.closePath(),t.stroke(),t.restore()}}s.GraphicsBox=l,l.__name__=\"GraphicsBox\";class x extends l{constructor({text:t}){super(),this.align=\"left\",this.text=t}set visuals(t){const e=t.text_color.get_value(),s=t.text_alpha.get_value(),i=t.text_font_style.get_value();let n=t.text_font_size.get_value();const h=t.text_font.get_value(),{font_size_scale:o}=this;if(1!=o){const t=n.match(/^\\s*(\\d+(\\.\\d+)?)(\\w+)\\s*$/);if(null!=t){const[,e,,s]=t,i=Number(e);isNaN(i)||(n=`${i*o}${s}`)}}const r=`${i} ${n} ${h}`;this.font=r,this.color=_.color2css(e,s),this.line_height=t.text_line_height.get_value()}infer_text_height(){if(this.text.includes(\"\\n\"))return\"ascent_descent\";return function(t){for(const e of new Set(t))if(!(\"0\"<=e&&e<=\"9\"))switch(e){case\",\":case\".\":case\"+\":case\"-\":case\"−\":case\"e\":continue;default:return!1}return!0}(this.text)?\"cap\":\"ascent_descent\"}_text_line(t){var e;const s=null!==(e=this.text_height_metric)&&void 0!==e?e:this.infer_text_height(),i=(()=>{switch(s){case\"x\":case\"x_descent\":return t.x_height;case\"cap\":case\"cap_descent\":return t.cap_height;case\"ascent\":case\"ascent_descent\":return t.ascent}})(),n=(()=>{switch(s){case\"x\":case\"cap\":case\"ascent\":return 0;case\"x_descent\":case\"cap_descent\":case\"ascent_descent\":return t.descent}})();return{height:i+n,ascent:i,descent:n}}get nlines(){return this.text.split(\"\\n\").length}_size(){var t,e;const{font:i}=this,n=o.font_metrics(i),h=(this.line_height-1)*n.height,a=\"\"==this.text,c=this.text.split(\"\\n\"),_=c.length,l=c.map((t=>s.text_width(t,i))),x=this._text_line(n).height*_,u=\"%\"==(null===(t=this.width)||void 0===t?void 0:t.unit)?this.width.value:1,p=\"%\"==(null===(e=this.height)||void 0===e?void 0:e.unit)?this.height.value:1;return{width:r.max(l)*u,height:a?0:(x+h*(_-1))*p,metrics:n}}_computed_position(t,e,s){const{width:i,height:n}=t,{sx:h,sy:o,x_anchor:r=\"left\",y_anchor:c=\"center\"}=this.position;return{x:h-(()=>{if(a.isNumber(r))return r*i;switch(r){case\"left\":return 0;case\"center\":return.5*i;case\"right\":return i}})(),y:o-(()=>{var t;if(a.isNumber(c))return c*n;switch(c){case\"top\":return 0;case\"center\":return.5*n;case\"bottom\":return n;case\"baseline\":if(1!=s)return.5*n;switch(null!==(t=this.text_height_metric)&&void 0!==t?t:this.infer_text_height()){case\"x\":case\"x_descent\":return e.x_height;case\"cap\":case\"cap_descent\":return e.cap_height;case\"ascent\":case\"ascent_descent\":return e.ascent}}})()}}_rect(){const{width:t,height:e,metrics:s}=this._size(),i=this.text.split(\"\\n\").length,{x:n,y:o}=this._computed_position({width:t,height:e},s,i);return new h.BBox({x:n,y:o,width:t,height:e}).rect}paint(t){var e,i;const{font:n}=this,h=o.font_metrics(n),a=(this.line_height-1)*h.height,c=this.text.split(\"\\n\"),_=c.length,l=c.map((t=>s.text_width(t,n))),x=this._text_line(h),u=x.height*_,p=\"%\"==(null===(e=this.width)||void 0===e?void 0:e.unit)?this.width.value:1,g=\"%\"==(null===(i=this.height)||void 0===i?void 0:i.unit)?this.height.value:1,f=r.max(l)*p,d=(u+a*(_-1))*g;t.save(),t.fillStyle=this.color,t.font=this.font,t.textAlign=\"left\",t.textBaseline=\"alphabetic\";const{sx:m,sy:b}=this.position,{align:y}=this,{angle:w}=this;w&&(t.translate(m,b),t.rotate(w),t.translate(-m,-b));let{x:v,y:z}=this._computed_position({width:f,height:d},h,_);if(\"justify\"==y)for(let e=0;e<_;e++){let i=v;const h=c[e].split(\" \"),o=h.length,_=h.map((t=>s.text_width(t,n))),l=(f-r.sum(_))/(o-1);for(let e=0;e<o;e++)t.fillText(h[e],i,z),i+=_[e]+l;z+=x.height+a}else for(let e=0;e<_;e++){const s=v+(()=>{switch(y){case\"left\":return 0;case\"center\":return.5*(f-l[e]);case\"right\":return f-l[e]}})();t.fillStyle=this.color,t.fillText(c[e],s,z+x.ascent),z+=x.height+a}t.restore()}}s.TextBox=x,x.__name__=\"TextBox\";class u extends l{constructor(t,e){super(),this.base=t,this.expo=e}get children(){return[this.base,this.expo]}set position(t){this._position=t;const e=this.base.size(),s=this.expo.size(),i=this._shift_scale()*e.height,n=Math.max(e.height,i+s.height);this.base.position={sx:0,x_anchor:\"left\",sy:n,y_anchor:\"bottom\"},this.expo.position={sx:e.width,x_anchor:\"left\",sy:i,y_anchor:\"bottom\"}}get position(){return this._position}set visuals(t){this.expo.font_size_scale=.7,this.base.visuals=t,this.expo.visuals=t}_shift_scale(){if(this.base instanceof x&&1==this.base.nlines){const{x_height:t,cap_height:e}=o.font_metrics(this.base.font);return t/e}return 2/3}infer_text_height(){return this.base.infer_text_height()}_rect(){const t=this.base.bbox(),e=this.expo.bbox(),s=t.union(e),{x:i,y:n}=this._computed_position();return s.translate(i,n).rect}_size(){const t=this.base.size(),e=this.expo.size();return{width:t.width+e.width,height:Math.max(t.height,this._shift_scale()*t.height+e.height)}}paint(t){t.save();const{angle:e}=this;if(e){const{sx:s,sy:i}=this.position;t.translate(s,i),t.rotate(e),t.translate(-s,-i)}const{x:s,y:i}=this._computed_position();t.translate(s,i),this.base.paint(t),this.expo.paint(t),t.restore()}paint_bbox(t){super.paint_bbox(t);const{x:e,y:s}=this._computed_position();t.save(),t.translate(e,s);for(const e of this.children)e.paint_bbox(t);t.restore()}_computed_position(){const{width:t,height:e}=this._size(),{sx:s,sy:i,x_anchor:n=\"left\",y_anchor:h=\"center\"}=this.position;return{x:s-(()=>{if(a.isNumber(n))return n*t;switch(n){case\"left\":return 0;case\"center\":return.5*t;case\"right\":return t}})(),y:i-(()=>{if(a.isNumber(h))return h*e;switch(h){case\"top\":return 0;case\"center\":return.5*e;case\"bottom\":return e;case\"baseline\":return.5*e}})()}}}s.BaseExpo=u,u.__name__=\"BaseExpo\";class p{constructor(t){this.items=t}get length(){return this.items.length}set visuals(t){for(const e of this.items)e.visuals=t;const e={x:0,cap:1,ascent:2,x_descent:3,cap_descent:4,ascent_descent:5},s=r.max_by(this.items.map((t=>t.infer_text_height())),(t=>e[t]));for(const t of this.items)t.text_height_metric=s}set angle(t){for(const e of this.items)e.angle=t}max_size(){let t=0,e=0;for(const s of this.items){const i=s.size();t=Math.max(t,i.width),e=Math.max(e,i.height)}return{width:t,height:e}}}s.GraphicsBoxes=p,p.__name__=\"GraphicsBoxes\"},\n",
" function _(t,s,r,n,i){n();const{sin:e,cos:a}=Math;class h{constructor(t=1,s=0,r=0,n=1,i=0,e=0){this.a=t,this.b=s,this.c=r,this.d=n,this.e=i,this.f=e}toString(){const{a:t,b:s,c:r,d:n,e:i,f:e}=this;return`matrix(${t}, ${s}, ${r}, ${n}, ${i}, ${e})`}clone(){const{a:t,b:s,c:r,d:n,e:i,f:e}=this;return new h(t,s,r,n,i,e)}get is_identity(){const{a:t,b:s,c:r,d:n,e:i,f:e}=this;return 1==t&&0==s&&0==r&&1==n&&0==i&&0==e}apply_point(t){const[s,r]=this.apply(t.x,t.y);return{x:s,y:r}}apply_rect(t){return{p0:this.apply_point(t.p0),p1:this.apply_point(t.p1),p2:this.apply_point(t.p2),p3:this.apply_point(t.p3)}}apply(t,s){const{a:r,b:n,c:i,d:e,e:a,f:h}=this;return[r*t+i*s+a,n*t+e*s+h]}iv_apply(t,s){const{a:r,b:n,c:i,d:e,e:a,f:h}=this,p=t.length;for(let o=0;o<p;o++){const p=t[o],c=s[o];t[o]=r*p+i*c+a,s[o]=n*p+e*c+h}}transform(t,s,r,n,i,e){const{a,b:h,c:p,d:o,e:c,f:l}=this;return this.a=a*t+p*s,this.c=a*r+p*n,this.e=a*i+p*e+c,this.b=h*t+o*s,this.d=h*r+o*n,this.f=h*i+o*e+l,this}translate(t,s){return this.transform(1,0,0,1,t,s)}scale(t,s){return this.transform(t,0,0,s,0,0)}skew(t,s){return this.transform(1,s,t,1,0,0)}rotate(t){const s=e(t),r=a(t);return this.transform(r,s,-s,r,0,0)}rotate_ccw(t){return this.rotate(-t)}translate_x(t){return this.translate(t,0)}translate_y(t){return this.translate(0,t)}flip(){return this.scale(-1,-1)}flip_x(){return this.scale(1,-1)}flip_y(){return this.scale(-1,1)}}r.AffineTransform=h,h.__name__=\"AffineTransform\"},\n",
" function _(e,n,s,t,i){t();const l=e(53),c=e(13),o=e(34),r=e(8),a=e(24);class u extends l.Model{constructor(e){super(e)}}s.LabelingPolicy=u,u.__name__=\"LabelingPolicy\";class _ extends u{constructor(e){super(e)}filter(e,n,s){return e}}s.AllLabels=_,_.__name__=\"AllLabels\";class d extends u{constructor(e){super(e)}static init_NoOverlap(){this.define((({Number:e})=>({min_distance:[e,5]})))}filter(e,n,s){const{min_distance:t}=this;let i=null;for(const n of e)null!=i&&s(i,n)<t?e.unset(n):i=n;return e}}s.NoOverlap=d,d.__name__=\"NoOverlap\",d.init_NoOverlap();class m extends u{constructor(e){super(e)}static init_CustomLabelingPolicy(){this.define((({Unknown:e,String:n,Dict:s})=>({args:[s(e),{}],code:[n,\"\"]})))}get names(){return c.keys(this.args)}get values(){return c.values(this.args)}get func(){const e=o.use_strict(this.code);return new a.GeneratorFunction(\"indices\",\"bboxes\",\"distance\",...this.names,e)}filter(e,n,s){const t=Object.create(null),i=this.func.call(t,e,n,s,...this.values);let l=i.next();if(l.done&&void 0!==l.value){const{value:n}=l;return n instanceof a.Indices?n:void 0===n?e:r.isIterable(n)?a.Indices.from_indices(e.size,n):a.Indices.all_unset(e.size)}{const n=[];do{n.push(l.value),l=i.next()}while(!l.done);return a.Indices.from_indices(e.size,n)}}}s.CustomLabelingPolicy=m,m.__name__=\"CustomLabelingPolicy\",m.init_CustomLabelingPolicy()},\n",
" function _(t,s,e,o,i){o();const a=t(1),r=t(163),l=t(171),_=t(172),n=a.__importStar(t(48)),c=t(20),p=t(167),h=t(8);class m extends r.AxisView{_paint(t,s,e){this._draw_group_separators(t,s,e)}_draw_group_separators(t,s,e){const[o]=this.ranges,[i,a]=this.computed_bounds;if(!o.tops||o.tops.length<2||!this.visuals.separator_line.doit)return;const r=this.dimension,l=(r+1)%2,_=[[],[]];let n=0;for(let t=0;t<o.tops.length-1;t++){let s,e;for(let i=n;i<o.factors.length;i++)if(o.factors[i][0]==o.tops[t+1]){[s,e]=[o.factors[i-1],o.factors[i]],n=i;break}const c=(o.synthetic(s)+o.synthetic(e))/2;c>i&&c<a&&(_[r].push(c),_[l].push(this.loc))}const c=this.extents.tick_label;this._draw_ticks(t,_,-3,c-6,this.visuals.separator_line)}_draw_major_labels(t,s,e){const o=this._get_factor_info();let i=s.tick+this.model.major_label_standoff;for(let e=0;e<o.length;e++){const[a,r,l,_]=o[e];this._draw_oriented_labels(t,a,r,l,this.panel.side,i,_),i+=s.tick_labels[e]}}_tick_label_extents(){const t=this._get_factor_info(),s=[];for(const[e,,o,i]of t){const t=this._oriented_labels_extent(e,o,this.model.major_label_standoff,i);s.push(t)}return s}_get_factor_info(){const[t]=this.ranges,[s,e]=this.computed_bounds,o=this.loc,i=this.model.ticker.get_ticks(s,e,t,o),a=this.tick_coords,r=[],l=t=>new p.GraphicsBoxes(t.map((t=>h.isString(t)?new p.TextBox({text:t}):t))),_=t=>l(this.model.formatter.doFormat(t,this));if(1==t.levels){const t=_(i.major);r.push([t,a.major,this.model.major_label_orientation,this.visuals.major_label_text])}else if(2==t.levels){const t=_(i.major.map((t=>t[1])));r.push([t,a.major,this.model.major_label_orientation,this.visuals.major_label_text]),r.push([l(i.tops),a.tops,this.model.group_label_orientation,this.visuals.group_text])}else if(3==t.levels){const t=_(i.major.map((t=>t[2]))),s=i.mids.map((t=>t[1]));r.push([t,a.major,this.model.major_label_orientation,this.visuals.major_label_text]),r.push([l(s),a.mids,this.model.subgroup_label_orientation,this.visuals.subgroup_text]),r.push([l(i.tops),a.tops,this.model.group_label_orientation,this.visuals.group_text])}return r}get tick_coords(){const t=this.dimension,s=(t+1)%2,[e]=this.ranges,[o,i]=this.computed_bounds,a=this.model.ticker.get_ticks(o,i,e,this.loc),r={major:[[],[]],mids:[[],[]],tops:[[],[]],minor:[[],[]]};return r.major[t]=a.major,r.major[s]=a.major.map((()=>this.loc)),3==e.levels&&(r.mids[t]=a.mids,r.mids[s]=a.mids.map((()=>this.loc))),e.levels>1&&(r.tops[t]=a.tops,r.tops[s]=a.tops.map((()=>this.loc))),r}}e.CategoricalAxisView=m,m.__name__=\"CategoricalAxisView\";class u extends r.Axis{constructor(t){super(t)}static init_CategoricalAxis(){this.prototype.default_view=m,this.mixins([[\"separator_\",n.Line],[\"group_\",n.Text],[\"subgroup_\",n.Text]]),this.define((({Number:t,Or:s})=>({group_label_orientation:[s(c.TickLabelOrientation,t),\"parallel\"],subgroup_label_orientation:[s(c.TickLabelOrientation,t),\"parallel\"]}))),this.override({ticker:()=>new l.CategoricalTicker,formatter:()=>new _.CategoricalTickFormatter,separator_line_color:\"lightgrey\",separator_line_width:2,group_text_font_style:\"bold\",group_text_font_size:\"11px\",group_text_color:\"grey\",subgroup_text_font_style:\"bold\",subgroup_text_font_size:\"11px\"})}}e.CategoricalAxis=u,u.__name__=\"CategoricalAxis\",u.init_CategoricalAxis()},\n",
" function _(t,c,o,s,e){s();const r=t(165);class i extends r.Ticker{constructor(t){super(t)}get_ticks(t,c,o,s){var e,r;return{major:this._collect(o.factors,o,t,c),minor:[],tops:this._collect(null!==(e=o.tops)&&void 0!==e?e:[],o,t,c),mids:this._collect(null!==(r=o.mids)&&void 0!==r?r:[],o,t,c)}}_collect(t,c,o,s){const e=[];for(const r of t){const t=c.synthetic(r);t>o&&t<s&&e.push(r)}return e}}o.CategoricalTicker=i,i.__name__=\"CategoricalTicker\"},\n",
" function _(t,r,o,c,a){c();const e=t(166),n=t(9);class i extends e.TickFormatter{constructor(t){super(t)}doFormat(t,r){return n.copy(t)}}o.CategoricalTickFormatter=i,i.__name__=\"CategoricalTickFormatter\"},\n",
" function _(s,n,i,o,u){o();const e=s(163);class t extends e.AxisView{}i.ContinuousAxisView=t,t.__name__=\"ContinuousAxisView\";class _ extends e.Axis{constructor(s){super(s)}}i.ContinuousAxis=_,_.__name__=\"ContinuousAxis\"},\n",
" function _(e,t,i,s,a){s();const n=e(175),r=e(180),m=e(185);class _ extends n.LinearAxisView{}i.DatetimeAxisView=_,_.__name__=\"DatetimeAxisView\";class c extends n.LinearAxis{constructor(e){super(e)}static init_DatetimeAxis(){this.prototype.default_view=_,this.override({ticker:()=>new m.DatetimeTicker,formatter:()=>new r.DatetimeTickFormatter})}}i.DatetimeAxis=c,c.__name__=\"DatetimeAxis\",c.init_DatetimeAxis()},\n",
" function _(i,e,s,n,t){n();const r=i(173),a=i(176),o=i(177);class c extends r.ContinuousAxisView{}s.LinearAxisView=c,c.__name__=\"LinearAxisView\";class _ extends r.ContinuousAxis{constructor(i){super(i)}static init_LinearAxis(){this.prototype.default_view=c,this.override({ticker:()=>new o.BasicTicker,formatter:()=>new a.BasicTickFormatter})}}s.LinearAxis=_,_.__name__=\"LinearAxis\",_.init_LinearAxis()},\n",
" function _(i,t,e,n,o){n();const s=i(166),r=i(34);function c(i){let t=\"\";for(const e of i)t+=\"-\"==e?\"−\":e;return t}e.unicode_replace=c;class _ extends s.TickFormatter{constructor(i){super(i),this.last_precision=3}static init_BasicTickFormatter(){this.define((({Boolean:i,Int:t,Auto:e,Or:n})=>({precision:[n(t,e),\"auto\"],use_scientific:[i,!0],power_limit_high:[t,5],power_limit_low:[t,-3]})))}get scientific_limit_low(){return 10**this.power_limit_low}get scientific_limit_high(){return 10**this.power_limit_high}_need_sci(i){if(!this.use_scientific)return!1;const{scientific_limit_high:t}=this,{scientific_limit_low:e}=this,n=i.length<2?0:Math.abs(i[1]-i[0])/1e4;for(const o of i){const i=Math.abs(o);if(!(i<=n)&&(i>=t||i<=e))return!0}return!1}_format_with_precision(i,t,e){return t?i.map((i=>c(i.toExponential(e)))):i.map((i=>c(r.to_fixed(i,e))))}_auto_precision(i,t){const e=new Array(i.length),n=this.last_precision<=15;i:for(let o=this.last_precision;n?o<=15:o>=1;n?o++:o--){if(t){e[0]=i[0].toExponential(o);for(let t=1;t<i.length;t++)if(e[t]==e[t-1])continue i;this.last_precision=o;break}e[0]=r.to_fixed(i[0],o);for(let t=1;t<i.length;t++)if(e[t]=r.to_fixed(i[t],o),e[t]==e[t-1])continue i;this.last_precision=o;break}return this.last_precision}doFormat(i,t){if(0==i.length)return[];const e=this._need_sci(i),n=\"auto\"==this.precision?this._auto_precision(i,e):this.precision;return this._format_with_precision(i,e,n)}}e.BasicTickFormatter=_,_.__name__=\"BasicTickFormatter\",_.init_BasicTickFormatter()},\n",
" function _(c,e,s,i,n){i();const r=c(178);class t extends r.AdaptiveTicker{constructor(c){super(c)}}s.BasicTicker=t,t.__name__=\"BasicTicker\"},\n",
" function _(t,i,a,e,s){e();const n=t(179),r=t(9),_=t(10);class l extends n.ContinuousTicker{constructor(t){super(t)}static init_AdaptiveTicker(){this.define((({Number:t,Array:i,Nullable:a})=>({base:[t,10],mantissas:[i(t),[1,2,5]],min_interval:[t,0],max_interval:[a(t),null]})))}get_min_interval(){return this.min_interval}get_max_interval(){var t;return null!==(t=this.max_interval)&&void 0!==t?t:1/0}initialize(){super.initialize();const t=r.nth(this.mantissas,-1)/this.base,i=r.nth(this.mantissas,0)*this.base;this.extended_mantissas=[t,...this.mantissas,i],this.base_factor=0===this.get_min_interval()?1:this.get_min_interval()}get_interval(t,i,a){const e=i-t,s=this.get_ideal_interval(t,i,a),n=Math.floor(_.log(s/this.base_factor,this.base)),l=this.base**n*this.base_factor,h=this.extended_mantissas,m=h.map((t=>Math.abs(a-e/(t*l)))),v=h[r.argmin(m)]*l;return _.clamp(v,this.get_min_interval(),this.get_max_interval())}}a.AdaptiveTicker=l,l.__name__=\"AdaptiveTicker\",l.init_AdaptiveTicker()},\n",
" function _(t,i,n,s,e){s();const o=t(165),r=t(9);class c extends o.Ticker{constructor(t){super(t)}static init_ContinuousTicker(){this.define((({Int:t})=>({num_minor_ticks:[t,5],desired_num_ticks:[t,6]})))}get_ticks(t,i,n,s){return this.get_ticks_no_defaults(t,i,s,this.desired_num_ticks)}get_ticks_no_defaults(t,i,n,s){const e=this.get_interval(t,i,s),o=Math.floor(t/e),c=Math.ceil(i/e);let _;_=isFinite(o)&&isFinite(c)?r.range(o,c+1):[];const u=_.map((t=>t*e)).filter((n=>t<=n&&n<=i)),a=this.num_minor_ticks,f=[];if(a>0&&u.length>0){const n=e/a,s=r.range(0,a).map((t=>t*n));for(const n of s.slice(1)){const s=u[0]-n;t<=s&&s<=i&&f.push(s)}for(const n of u)for(const e of s){const s=n+e;t<=s&&s<=i&&f.push(s)}}return{major:u,minor:f}}get_ideal_interval(t,i,n){return(i-t)/n}}n.ContinuousTicker=c,c.__name__=\"ContinuousTicker\",c.init_ContinuousTicker()},\n",
" function _(t,s,e,i,n){i();const r=t(1).__importDefault(t(181)),o=t(166),a=t(19),c=t(182),m=t(9),u=t(8);function h(t){return r.default(t,\"%Y %m %d %H %M %S\").split(/\\s+/).map((t=>parseInt(t,10)))}function d(t,s){if(u.isFunction(s))return s(t);{const e=c.sprintf(\"$1%06d\",function(t){return Math.round(t/1e3%1*1e6)}(t));return-1==(s=s.replace(/((^|[^%])(%%)*)%f/,e)).indexOf(\"%\")?s:r.default(t,s)}}const l=[\"microseconds\",\"milliseconds\",\"seconds\",\"minsec\",\"minutes\",\"hourmin\",\"hours\",\"days\",\"months\",\"years\"];class f extends o.TickFormatter{constructor(t){super(t),this.strip_leading_zeros=!0}static init_DatetimeTickFormatter(){this.define((({String:t,Array:s})=>({microseconds:[s(t),[\"%fus\"]],milliseconds:[s(t),[\"%3Nms\",\"%S.%3Ns\"]],seconds:[s(t),[\"%Ss\"]],minsec:[s(t),[\":%M:%S\"]],minutes:[s(t),[\":%M\",\"%Mm\"]],hourmin:[s(t),[\"%H:%M\"]],hours:[s(t),[\"%Hh\",\"%H:%M\"]],days:[s(t),[\"%m/%d\",\"%a%d\"]],months:[s(t),[\"%m/%Y\",\"%b %Y\"]],years:[s(t),[\"%Y\"]]})))}initialize(){super.initialize(),this._update_width_formats()}_update_width_formats(){const t=+r.default(new Date),s=function(s){const e=s.map((s=>d(t,s).length)),i=m.sort_by(m.zip(e,s),(([t])=>t));return m.unzip(i)};this._width_formats={microseconds:s(this.microseconds),milliseconds:s(this.milliseconds),seconds:s(this.seconds),minsec:s(this.minsec),minutes:s(this.minutes),hourmin:s(this.hourmin),hours:s(this.hours),days:s(this.days),months:s(this.months),years:s(this.years)}}_get_resolution_str(t,s){const e=1.1*t;switch(!1){case!(e<.001):return\"microseconds\";case!(e<1):return\"milliseconds\";case!(e<60):return s>=60?\"minsec\":\"seconds\";case!(e<3600):return s>=3600?\"hourmin\":\"minutes\";case!(e<86400):return\"hours\";case!(e<2678400):return\"days\";case!(e<31536e3):return\"months\";default:return\"years\"}}doFormat(t,s){if(0==t.length)return[];const e=Math.abs(t[t.length-1]-t[0])/1e3,i=e/(t.length-1),n=this._get_resolution_str(i,e),[,[r]]=this._width_formats[n],o=[],c=l.indexOf(n),m={};for(const t of l)m[t]=0;m.seconds=5,m.minsec=4,m.minutes=4,m.hourmin=3,m.hours=3;for(const s of t){let t,e;try{e=h(s),t=d(s,r)}catch(t){a.logger.warn(`unable to format tick for timestamp value ${s}`),a.logger.warn(` - ${t}`),o.push(\"ERR\");continue}let i=!1,u=c;for(;0==e[m[l[u]]];){let r;if(u+=1,u==l.length)break;if((\"minsec\"==n||\"hourmin\"==n)&&!i){if(\"minsec\"==n&&0==e[4]&&0!=e[5]||\"hourmin\"==n&&0==e[3]&&0!=e[4]){r=this._width_formats[l[c-1]][1][0],t=d(s,r);break}i=!0}r=this._width_formats[l[u]][1][0],t=d(s,r)}if(this.strip_leading_zeros){let s=t.replace(/^0+/g,\"\");s!=t&&isNaN(parseInt(s))&&(s=`0${s}`),o.push(s)}else o.push(t)}return o}}e.DatetimeTickFormatter=f,f.__name__=\"DatetimeTickFormatter\",f.init_DatetimeTickFormatter()},\n",
" function _(e,t,n,r,o){!function(e){\"object\"==typeof t&&t.exports?t.exports=e():\"function\"==typeof define?define(e):this.tz=e()}((function(){function e(e,t,n){var r,o=t.day[1];do{r=new Date(Date.UTC(n,t.month,Math.abs(o++)))}while(t.day[0]<7&&r.getUTCDay()!=t.day[0]);return(r={clock:t.clock,sort:r.getTime(),rule:t,save:6e4*t.save,offset:e.offset})[r.clock]=r.sort+6e4*t.time,r.posix?r.wallclock=r[r.clock]+(e.offset+t.saved):r.posix=r[r.clock]-(e.offset+t.saved),r}function t(t,n,r){var o,a,u,i,l,s,c,f=t[t.zone],h=[],T=new Date(r).getUTCFullYear(),g=1;for(o=1,a=f.length;o<a&&!(f[o][n]<=r);o++);if((u=f[o]).rules){for(s=t[u.rules],c=T+1;c>=T-g;--c)for(o=0,a=s.length;o<a;o++)s[o].from<=c&&c<=s[o].to?h.push(e(u,s[o],c)):s[o].to<c&&1==g&&(g=c-s[o].to);for(h.sort((function(e,t){return e.sort-t.sort})),o=0,a=h.length;o<a;o++)r>=h[o][n]&&h[o][h[o].clock]>u[h[o].clock]&&(i=h[o])}return i&&((l=/^(.*)\\/(.*)$/.exec(u.format))?i.abbrev=l[i.save?2:1]:i.abbrev=u.format.replace(/%s/,i.rule.letter)),i||u}function n(e,n){return\"UTC\"==e.zone?n:(e.entry=t(e,\"posix\",n),n+e.entry.offset+e.entry.save)}function r(e,n){return\"UTC\"==e.zone?n:(e.entry=r=t(e,\"wallclock\",n),0<(o=n-r.wallclock)&&o<r.save?null:n-r.offset-r.save);var r,o}function o(e,t,o){var a,i=+(o[1]+1),s=o[2]*i,c=u.indexOf(o[3].toLowerCase());if(c>9)t+=s*l[c-10];else{if(a=new Date(n(e,t)),c<7)for(;s;)a.setUTCDate(a.getUTCDate()+i),a.getUTCDay()==c&&(s-=i);else 7==c?a.setUTCFullYear(a.getUTCFullYear()+s):8==c?a.setUTCMonth(a.getUTCMonth()+s):a.setUTCDate(a.getUTCDate()+s);null==(t=r(e,a.getTime()))&&(t=r(e,a.getTime()+864e5*i)-864e5*i)}return t}var a={clock:function(){return+new Date},zone:\"UTC\",entry:{abbrev:\"UTC\",offset:0,save:0},UTC:1,z:function(e,t,n,r){var o,a,u=this.entry.offset+this.entry.save,i=Math.abs(u/1e3),l=[],s=3600;for(o=0;o<3;o++)l.push((\"0\"+Math.floor(i/s)).slice(-2)),i%=s,s/=60;return\"^\"!=n||u?(\"^\"==n&&(r=3),3==r?(a=(a=l.join(\":\")).replace(/:00$/,\"\"),\"^\"!=n&&(a=a.replace(/:00$/,\"\"))):r?(a=l.slice(0,r+1).join(\":\"),\"^\"==n&&(a=a.replace(/:00$/,\"\"))):a=l.slice(0,2).join(\"\"),a=(a=(u<0?\"-\":\"+\")+a).replace(/([-+])(0)/,{_:\" $1\",\"-\":\"$1\"}[n]||\"$1$2\")):\"Z\"},\"%\":function(e){return\"%\"},n:function(e){return\"\\n\"},t:function(e){return\"\\t\"},U:function(e){return s(e,0)},W:function(e){return s(e,1)},V:function(e){return c(e)[0]},G:function(e){return c(e)[1]},g:function(e){return c(e)[1]%100},j:function(e){return Math.floor((e.getTime()-Date.UTC(e.getUTCFullYear(),0))/864e5)+1},s:function(e){return Math.floor(e.getTime()/1e3)},C:function(e){return Math.floor(e.getUTCFullYear()/100)},N:function(e){return e.getTime()%1e3*1e6},m:function(e){return e.getUTCMonth()+1},Y:function(e){return e.getUTCFullYear()},y:function(e){return e.getUTCFullYear()%100},H:function(e){return e.getUTCHours()},M:function(e){return e.getUTCMinutes()},S:function(e){return e.getUTCSeconds()},e:function(e){return e.getUTCDate()},d:function(e){return e.getUTCDate()},u:function(e){return e.getUTCDay()||7},w:function(e){return e.getUTCDay()},l:function(e){return e.getUTCHours()%12||12},I:function(e){return e.getUTCHours()%12||12},k:function(e){return e.getUTCHours()},Z:function(e){return this.entry.abbrev},a:function(e){return this[this.locale].day.abbrev[e.getUTCDay()]},A:function(e){return this[this.locale].day.full[e.getUTCDay()]},h:function(e){return this[this.locale].month.abbrev[e.getUTCMonth()]},b:function(e){return this[this.locale].month.abbrev[e.getUTCMonth()]},B:function(e){return this[this.locale].month.full[e.getUTCMonth()]},P:function(e){return this[this.locale].meridiem[Math.floor(e.getUTCHours()/12)].toLowerCase()},p:function(e){return this[this.locale].meridiem[Math.floor(e.getUTCHours()/12)]},R:function(e,t){return this.convert([t,\"%H:%M\"])},T:function(e,t){return this.convert([t,\"%H:%M:%S\"])},D:function(e,t){return this.convert([t,\"%m/%d/%y\"])},F:function(e,t){return this.convert([t,\"%Y-%m-%d\"])},x:function(e,t){return this.convert([t,this[this.locale].date])},r:function(e,t){return this.convert([t,this[this.locale].time12||\"%I:%M:%S\"])},X:function(e,t){return this.convert([t,this[this.locale].time24])},c:function(e,t){return this.convert([t,this[this.locale].dateTime])},convert:function(e){if(!e.length)return\"1.0.23\";var t,a,u,l,s,c=Object.create(this),f=[];for(t=0;t<e.length;t++)if(l=e[t],Array.isArray(l))t||isNaN(l[1])?l.splice.apply(e,[t--,1].concat(l)):s=l;else if(isNaN(l)){if(\"string\"==(u=typeof l))~l.indexOf(\"%\")?c.format=l:t||\"*\"!=l?!t&&(u=/^(\\d{4})-(\\d{2})-(\\d{2})(?:[T\\s](\\d{2}):(\\d{2})(?::(\\d{2})(?:\\.(\\d+))?)?(Z|(([+-])(\\d{2}(:\\d{2}){0,2})))?)?$/.exec(l))?((s=[]).push.apply(s,u.slice(1,8)),u[9]?(s.push(u[10]+1),s.push.apply(s,u[11].split(/:/))):u[8]&&s.push(1)):/^\\w{2,3}_\\w{2}$/.test(l)?c.locale=l:(u=i.exec(l))?f.push(u):c.zone=l:s=l;else if(\"function\"==u){if(u=l.call(c))return u}else if(/^\\w{2,3}_\\w{2}$/.test(l.name))c[l.name]=l;else if(l.zones){for(u in l.zones)c[u]=l.zones[u];for(u in l.rules)c[u]=l.rules[u]}}else t||(s=l);if(c[c.locale]||delete c.locale,c[c.zone]||delete c.zone,null!=s){if(\"*\"==s)s=c.clock();else if(Array.isArray(s)){for(u=[],a=!s[7],t=0;t<11;t++)u[t]=+(s[t]||0);--u[1],s=Date.UTC.apply(Date.UTC,u)+-u[7]*(36e5*u[8]+6e4*u[9]+1e3*u[10])}else s=Math.floor(s);if(!isNaN(s)){if(a&&(s=r(c,s)),null==s)return s;for(t=0,a=f.length;t<a;t++)s=o(c,s,f[t]);return c.format?(u=new Date(n(c,s)),c.format.replace(/%([-0_^]?)(:{0,3})(\\d*)(.)/g,(function(e,t,n,r,o){var a,i,l=\"0\";if(a=c[o]){for(e=String(a.call(c,u,s,t,n.length)),\"_\"==(t||a.style)&&(l=\" \"),i=\"-\"==t?0:a.pad||0;e.length<i;)e=l+e;for(i=\"-\"==t?0:r||a.pad;e.length<i;)e=l+e;\"N\"==o&&i<e.length&&(e=e.slice(0,i)),\"^\"==t&&(e=e.toUpperCase())}return e}))):s}}return function(){return c.convert(arguments)}},locale:\"en_US\",en_US:{date:\"%m/%d/%Y\",time24:\"%I:%M:%S %p\",time12:\"%I:%M:%S %p\",dateTime:\"%a %d %b %Y %I:%M:%S %p %Z\",meridiem:[\"AM\",\"PM\"],month:{abbrev:\"Jan|Feb|Mar|Apr|May|Jun|Jul|Aug|Sep|Oct|Nov|Dec\".split(\"|\"),full:\"January|February|March|April|May|June|July|August|September|October|November|December\".split(\"|\")},day:{abbrev:\"Sun|Mon|Tue|Wed|Thu|Fri|Sat\".split(\"|\"),full:\"Sunday|Monday|Tuesday|Wednesday|Thursday|Friday|Saturday\".split(\"|\")}}},u=\"Sunday|Monday|Tuesday|Wednesday|Thursday|Friday|Saturday|year|month|day|hour|minute|second|millisecond\",i=new RegExp(\"^\\\\s*([+-])(\\\\d+)\\\\s+(\"+u+\")s?\\\\s*$\",\"i\"),l=[36e5,6e4,1e3,1];function s(e,t){var n,r,o;return r=new Date(Date.UTC(e.getUTCFullYear(),0)),n=Math.floor((e.getTime()-r.getTime())/864e5),r.getUTCDay()==t?o=0:8==(o=7-r.getUTCDay()+t)&&(o=1),n>=o?Math.floor((n-o)/7)+1:0}function c(e){var t,n,r;return n=e.getUTCFullYear(),t=new Date(Date.UTC(n,0)).getUTCDay(),(r=s(e,1)+(t>1&&t<=4?1:0))?53!=r||4==t||3==t&&29==new Date(n,1,29).getDate()?[r,e.getUTCFullYear()]:[1,e.getUTCFullYear()+1]:(n=e.getUTCFullYear()-1,[r=4==(t=new Date(Date.UTC(n,0)).getUTCDay())||3==t&&29==new Date(n,1,29).getDate()?53:52,e.getUTCFullYear()-1])}return u=u.toLowerCase().split(\"|\"),\"delmHMSUWVgCIky\".replace(/./g,(function(e){a[e].pad=2})),a.N.pad=9,a.j.pad=3,a.k.style=\"_\",a.l.style=\"_\",a.e.style=\"_\",function(){return a.convert(arguments)}}))},\n",
" function _(r,t,n,e,i){e();const u=r(1),a=u.__importStar(r(183)),f=r(184),o=u.__importDefault(r(181)),l=r(21),s=r(8);function c(r,...t){return f.sprintf(r,...t)}function m(r,t,n){if(s.isNumber(r)){return c((()=>{switch(!1){case Math.floor(r)!=r:return\"%d\";case!(Math.abs(r)>.1&&Math.abs(r)<1e3):return\"%0.3f\";default:return\"%0.3e\"}})(),r)}return`${r}`}function p(r,t,e){if(null==t)return m;if(null!=e&&r in e){const t=e[r];if(s.isString(t)){if(t in n.DEFAULT_FORMATTERS)return n.DEFAULT_FORMATTERS[t];throw new Error(`Unknown tooltip field formatter type '${t}'`)}return function(r,n,e){return t.format(r,n,e)}}return n.DEFAULT_FORMATTERS.numeral}function d(r,t,n,e){if(\"$\"==r[0]){return function(r,t){if(r in t)return t[r];throw new Error(`Unknown special variable '$${r}'`)}(r.substring(1),e)}return function(r,t,n){const e=t.get_column(r);if(null==e)return null;if(s.isNumber(n))return e[n];const i=e[n.index];if(s.isTypedArray(i)||s.isArray(i))return s.isArray(i[0])?i[n.dim2][n.dim1]:i[n.flat_index];return i}(r.substring(1).replace(/[{}]/g,\"\"),t,n)}n.FormatterType=l.Enum(\"numeral\",\"printf\",\"datetime\"),n.DEFAULT_FORMATTERS={numeral:(r,t,n)=>a.format(r,t),datetime:(r,t,n)=>o.default(r,t),printf:(r,t,n)=>c(t,r)},n.sprintf=c,n.basic_formatter=m,n.get_formatter=p,n.get_value=d,n.replace_placeholders=function(r,t,n,e,i={},u){let a,f;if(s.isString(r)?(a=r,f=!1):(a=r.html,f=!0),a=a.replace(/@\\$name/g,(r=>`@{${i.name}}`)),a=a.replace(/((?:\\$\\w+)|(?:@\\w+)|(?:@{(?:[^{}]+)}))(?:{([^{}]+)})?/g,((r,a,o)=>{const l=d(a,t,n,i);if(null==l)return u?u(\"???\"):\"???\";if(\"safe\"==o)return f=!0,`${l}`;const s=`${p(a,o,e)(l,o,i)}`;return u?u(s):s})),f){return[...(new DOMParser).parseFromString(a,\"text/html\").body.childNodes]}return a}},\n",
" function _(e,n,t,r,i){\n",
" /*!\n",
" * numbro.js\n",
" * version : 1.6.2\n",
" * author : Företagsplatsen AB\n",
" * license : MIT\n",
" * http://www.foretagsplatsen.se\n",
" */\n",
" var a,o={},l=o,u=\"en-US\",c=null,s=\"0,0\";void 0!==n&&n.exports;function f(e){this._value=e}function d(e){var n,t=\"\";for(n=0;n<e;n++)t+=\"0\";return t}function h(e,n,t,r){var i,a,o=Math.pow(10,n);return a=e.toFixed(0).search(\"e\")>-1?function(e,n){var t,r,i,a;return t=(a=e.toString()).split(\"e\")[0],i=a.split(\"e\")[1],a=t.split(\".\")[0]+(r=t.split(\".\")[1]||\"\")+d(i-r.length),n>0&&(a+=\".\"+d(n)),a}(e,n):(t(e*o)/o).toFixed(n),r&&(i=new RegExp(\"0{1,\"+r+\"}$\"),a=a.replace(i,\"\")),a}function p(e,n,t){return n.indexOf(\"$\")>-1?function(e,n,t){var r,i,a=n,l=a.indexOf(\"$\"),c=a.indexOf(\"(\"),s=a.indexOf(\"+\"),f=a.indexOf(\"-\"),d=\"\",h=\"\";-1===a.indexOf(\"$\")?\"infix\"===o[u].currency.position?(h=o[u].currency.symbol,o[u].currency.spaceSeparated&&(h=\" \"+h+\" \")):o[u].currency.spaceSeparated&&(d=\" \"):a.indexOf(\" $\")>-1?(d=\" \",a=a.replace(\" $\",\"\")):a.indexOf(\"$ \")>-1?(d=\" \",a=a.replace(\"$ \",\"\")):a=a.replace(\"$\",\"\");if(i=m(e,a,t,h),-1===n.indexOf(\"$\"))switch(o[u].currency.position){case\"postfix\":i.indexOf(\")\")>-1?((i=i.split(\"\")).splice(-1,0,d+o[u].currency.symbol),i=i.join(\"\")):i=i+d+o[u].currency.symbol;break;case\"infix\":break;case\"prefix\":i.indexOf(\"(\")>-1||i.indexOf(\"-\")>-1?(i=i.split(\"\"),r=Math.max(c,f)+1,i.splice(r,0,o[u].currency.symbol+d),i=i.join(\"\")):i=o[u].currency.symbol+d+i;break;default:throw Error('Currency position should be among [\"prefix\", \"infix\", \"postfix\"]')}else l<=1?i.indexOf(\"(\")>-1||i.indexOf(\"+\")>-1||i.indexOf(\"-\")>-1?(r=1,(l<c||l<s||l<f)&&(r=0),(i=i.split(\"\")).splice(r,0,o[u].currency.symbol+d),i=i.join(\"\")):i=o[u].currency.symbol+d+i:i.indexOf(\")\")>-1?((i=i.split(\"\")).splice(-1,0,d+o[u].currency.symbol),i=i.join(\"\")):i=i+d+o[u].currency.symbol;return i}(e,n,t):n.indexOf(\"%\")>-1?function(e,n,t){var r,i=\"\";e*=100,n.indexOf(\" %\")>-1?(i=\" \",n=n.replace(\" %\",\"\")):n=n.replace(\"%\",\"\");(r=m(e,n,t)).indexOf(\")\")>-1?((r=r.split(\"\")).splice(-1,0,i+\"%\"),r=r.join(\"\")):r=r+i+\"%\";return r}(e,n,t):n.indexOf(\":\")>-1?function(e){var n=Math.floor(e/60/60),t=Math.floor((e-60*n*60)/60),r=Math.round(e-60*n*60-60*t);return n+\":\"+(t<10?\"0\"+t:t)+\":\"+(r<10?\"0\"+r:r)}(e):m(e,n,t)}function m(e,n,t,r){var i,a,l,s,f,d,p,m,x,g,O,b,w,y,M,v,$,B=!1,E=!1,F=!1,k=\"\",U=!1,N=!1,S=!1,j=!1,D=!1,C=\"\",L=\"\",T=Math.abs(e),K=[\"B\",\"KiB\",\"MiB\",\"GiB\",\"TiB\",\"PiB\",\"EiB\",\"ZiB\",\"YiB\"],G=[\"B\",\"KB\",\"MB\",\"GB\",\"TB\",\"PB\",\"EB\",\"ZB\",\"YB\"],I=\"\",P=!1,R=!1;if(0===e&&null!==c)return c;if(!isFinite(e))return\"\"+e;if(0===n.indexOf(\"{\")){var W=n.indexOf(\"}\");if(-1===W)throw Error('Format should also contain a \"}\"');b=n.slice(1,W),n=n.slice(W+1)}else b=\"\";if(n.indexOf(\"}\")===n.length-1){var Y=n.indexOf(\"{\");if(-1===Y)throw Error('Format should also contain a \"{\"');w=n.slice(Y+1,-1),n=n.slice(0,Y+1)}else w=\"\";if(v=null===($=-1===n.indexOf(\".\")?n.match(/([0-9]+).*/):n.match(/([0-9]+)\\..*/))?-1:$[1].length,-1!==n.indexOf(\"-\")&&(P=!0),n.indexOf(\"(\")>-1?(B=!0,n=n.slice(1,-1)):n.indexOf(\"+\")>-1&&(E=!0,n=n.replace(/\\+/g,\"\")),n.indexOf(\"a\")>-1){if(g=n.split(\".\")[0].match(/[0-9]+/g)||[\"0\"],g=parseInt(g[0],10),U=n.indexOf(\"aK\")>=0,N=n.indexOf(\"aM\")>=0,S=n.indexOf(\"aB\")>=0,j=n.indexOf(\"aT\")>=0,D=U||N||S||j,n.indexOf(\" a\")>-1?(k=\" \",n=n.replace(\" a\",\"\")):n=n.replace(\"a\",\"\"),p=0===(p=(f=Math.floor(Math.log(T)/Math.LN10)+1)%3)?3:p,g&&0!==T&&(d=Math.floor(Math.log(T)/Math.LN10)+1-g,m=3*~~((Math.min(g,f)-p)/3),T/=Math.pow(10,m),-1===n.indexOf(\".\")&&g>3))for(n+=\"[.]\",M=(M=0===d?0:3*~~(d/3)-d)<0?M+3:M,i=0;i<M;i++)n+=\"0\";Math.floor(Math.log(Math.abs(e))/Math.LN10)+1!==g&&(T>=Math.pow(10,12)&&!D||j?(k+=o[u].abbreviations.trillion,e/=Math.pow(10,12)):T<Math.pow(10,12)&&T>=Math.pow(10,9)&&!D||S?(k+=o[u].abbreviations.billion,e/=Math.pow(10,9)):T<Math.pow(10,9)&&T>=Math.pow(10,6)&&!D||N?(k+=o[u].abbreviations.million,e/=Math.pow(10,6)):(T<Math.pow(10,6)&&T>=Math.pow(10,3)&&!D||U)&&(k+=o[u].abbreviations.thousand,e/=Math.pow(10,3)))}if(n.indexOf(\"b\")>-1)for(n.indexOf(\" b\")>-1?(C=\" \",n=n.replace(\" b\",\"\")):n=n.replace(\"b\",\"\"),s=0;s<=K.length;s++)if(a=Math.pow(1024,s),l=Math.pow(1024,s+1),e>=a&&e<l){C+=K[s],a>0&&(e/=a);break}if(n.indexOf(\"d\")>-1)for(n.indexOf(\" d\")>-1?(C=\" \",n=n.replace(\" d\",\"\")):n=n.replace(\"d\",\"\"),s=0;s<=G.length;s++)if(a=Math.pow(1e3,s),l=Math.pow(1e3,s+1),e>=a&&e<l){C+=G[s],a>0&&(e/=a);break}if(n.indexOf(\"o\")>-1&&(n.indexOf(\" o\")>-1?(L=\" \",n=n.replace(\" o\",\"\")):n=n.replace(\"o\",\"\"),o[u].ordinal&&(L+=o[u].ordinal(e))),n.indexOf(\"[.]\")>-1&&(F=!0,n=n.replace(\"[.]\",\".\")),x=e.toString().split(\".\")[0],O=n.split(\".\")[1],y=n.indexOf(\",\"),O){if(x=(I=-1!==O.indexOf(\"*\")?h(e,e.toString().split(\".\")[1].length,t):O.indexOf(\"[\")>-1?h(e,(O=(O=O.replace(\"]\",\"\")).split(\"[\"))[0].length+O[1].length,t,O[1].length):h(e,O.length,t)).split(\".\")[0],I.split(\".\")[1].length)I=(r?k+r:o[u].delimiters.decimal)+I.split(\".\")[1];else I=\"\";F&&0===Number(I.slice(1))&&(I=\"\")}else x=h(e,null,t);return x.indexOf(\"-\")>-1&&(x=x.slice(1),R=!0),x.length<v&&(x=new Array(v-x.length+1).join(\"0\")+x),y>-1&&(x=x.toString().replace(/(\\d)(?=(\\d{3})+(?!\\d))/g,\"$1\"+o[u].delimiters.thousands)),0===n.indexOf(\".\")&&(x=\"\"),b+(n.indexOf(\"(\")<n.indexOf(\"-\")?(B&&R?\"(\":\"\")+(P&&R||!B&&R?\"-\":\"\"):(P&&R||!B&&R?\"-\":\"\")+(B&&R?\"(\":\"\"))+(!R&&E&&0!==e?\"+\":\"\")+x+I+(L||\"\")+(k&&!r?k:\"\")+(C||\"\")+(B&&R?\")\":\"\")+w}function x(e,n){o[e]=n}function g(e){u=e;var n=o[e].defaults;n&&n.format&&a.defaultFormat(n.format),n&&n.currencyFormat&&a.defaultCurrencyFormat(n.currencyFormat)}(a=function(e){return a.isNumbro(e)?e=e.value():0===e||void 0===e?e=0:Number(e)||(e=a.fn.unformat(e)),new f(Number(e))}).version=\"1.6.2\",a.isNumbro=function(e){return e instanceof f},a.setLanguage=function(e,n){console.warn(\"`setLanguage` is deprecated since version 1.6.0. Use `setCulture` instead\");var t=e,r=e.split(\"-\")[0],i=null;l[t]||(Object.keys(l).forEach((function(e){i||e.split(\"-\")[0]!==r||(i=e)})),t=i||n||\"en-US\"),g(t)},a.setCulture=function(e,n){var t=e,r=e.split(\"-\")[1],i=null;o[t]||(r&&Object.keys(o).forEach((function(e){i||e.split(\"-\")[1]!==r||(i=e)})),t=i||n||\"en-US\"),g(t)},a.language=function(e,n){if(console.warn(\"`language` is deprecated since version 1.6.0. Use `culture` instead\"),!e)return u;if(e&&!n){if(!l[e])throw new Error(\"Unknown language : \"+e);g(e)}return!n&&l[e]||x(e,n),a},a.culture=function(e,n){if(!e)return u;if(e&&!n){if(!o[e])throw new Error(\"Unknown culture : \"+e);g(e)}return!n&&o[e]||x(e,n),a},a.languageData=function(e){if(console.warn(\"`languageData` is deprecated since version 1.6.0. Use `cultureData` instead\"),!e)return l[u];if(!l[e])throw new Error(\"Unknown language : \"+e);return l[e]},a.cultureData=function(e){if(!e)return o[u];if(!o[e])throw new Error(\"Unknown culture : \"+e);return o[e]},a.culture(\"en-US\",{delimiters:{thousands:\",\",decimal:\".\"},abbreviations:{thousand:\"k\",million:\"m\",billion:\"b\",trillion:\"t\"},ordinal:function(e){var n=e%10;return 1==~~(e%100/10)?\"th\":1===n?\"st\":2===n?\"nd\":3===n?\"rd\":\"th\"},currency:{symbol:\"$\",position:\"prefix\"},defaults:{currencyFormat:\",0000 a\"},formats:{fourDigits:\"0000 a\",fullWithTwoDecimals:\"$ ,0.00\",fullWithTwoDecimalsNoCurrency:\",0.00\"}}),a.languages=function(){return console.warn(\"`languages` is deprecated since version 1.6.0. Use `cultures` instead\"),l},a.cultures=function(){return o},a.zeroFormat=function(e){c=\"string\"==typeof e?e:null},a.defaultFormat=function(e){s=\"string\"==typeof e?e:\"0.0\"},a.defaultCurrencyFormat=function(e){\"string\"==typeof e?e:\"0$\"},a.validate=function(e,n){var t,r,i,o,l,u,c,s;if(\"string\"!=typeof e&&(e+=\"\",console.warn&&console.warn(\"Numbro.js: Value is not string. It has been co-erced to: \",e)),(e=e.trim()).match(/^\\d+$/))return!0;if(\"\"===e)return!1;try{c=a.cultureData(n)}catch(e){c=a.cultureData(a.culture())}return i=c.currency.symbol,l=c.abbreviations,t=c.delimiters.decimal,r=\".\"===c.delimiters.thousands?\"\\\\.\":c.delimiters.thousands,(null===(s=e.match(/^[^\\d]+/))||(e=e.substr(1),s[0]===i))&&((null===(s=e.match(/[^\\d]+$/))||(e=e.slice(0,-1),s[0]===l.thousand||s[0]===l.million||s[0]===l.billion||s[0]===l.trillion))&&(u=new RegExp(r+\"{2}\"),!e.match(/[^\\d.,]/g)&&(!((o=e.split(t)).length>2)&&(o.length<2?!!o[0].match(/^\\d+.*\\d$/)&&!o[0].match(u):1===o[0].length?!!o[0].match(/^\\d+$/)&&!o[0].match(u)&&!!o[1].match(/^\\d+$/):!!o[0].match(/^\\d+.*\\d$/)&&!o[0].match(u)&&!!o[1].match(/^\\d+$/)))))},n.exports={format:function(e,n,t,r){return null!=t&&t!==a.culture()&&a.setCulture(t),p(Number(e),null!=n?n:s,null==r?Math.round:r)}}},\n",
" function _(e,n,t,r,i){!function(){\"use strict\";var e={not_string:/[^s]/,not_bool:/[^t]/,not_type:/[^T]/,not_primitive:/[^v]/,number:/[diefg]/,numeric_arg:/[bcdiefguxX]/,json:/[j]/,not_json:/[^j]/,text:/^[^\\x25]+/,modulo:/^\\x25{2}/,placeholder:/^\\x25(?:([1-9]\\d*)\\$|\\(([^)]+)\\))?(\\+)?(0|'[^$])?(-)?(\\d+)?(?:\\.(\\d+))?([b-gijostTuvxX])/,key:/^([a-z_][a-z_\\d]*)/i,key_access:/^\\.([a-z_][a-z_\\d]*)/i,index_access:/^\\[(\\d+)\\]/,sign:/^[+-]/};function n(e){return i(a(e),arguments)}function r(e,t){return n.apply(null,[e].concat(t||[]))}function i(t,r){var i,s,a,o,p,c,l,u,f,d=1,g=t.length,y=\"\";for(s=0;s<g;s++)if(\"string\"==typeof t[s])y+=t[s];else if(\"object\"==typeof t[s]){if((o=t[s]).keys)for(i=r[d],a=0;a<o.keys.length;a++){if(null==i)throw new Error(n('[sprintf] Cannot access property \"%s\" of undefined value \"%s\"',o.keys[a],o.keys[a-1]));i=i[o.keys[a]]}else i=o.param_no?r[o.param_no]:r[d++];if(e.not_type.test(o.type)&&e.not_primitive.test(o.type)&&i instanceof Function&&(i=i()),e.numeric_arg.test(o.type)&&\"number\"!=typeof i&&isNaN(i))throw new TypeError(n(\"[sprintf] expecting number but found %T\",i));switch(e.number.test(o.type)&&(u=i>=0),o.type){case\"b\":i=parseInt(i,10).toString(2);break;case\"c\":i=String.fromCharCode(parseInt(i,10));break;case\"d\":case\"i\":i=parseInt(i,10);break;case\"j\":i=JSON.stringify(i,null,o.width?parseInt(o.width):0);break;case\"e\":i=o.precision?parseFloat(i).toExponential(o.precision):parseFloat(i).toExponential();break;case\"f\":i=o.precision?parseFloat(i).toFixed(o.precision):parseFloat(i);break;case\"g\":i=o.precision?String(Number(i.toPrecision(o.precision))):parseFloat(i);break;case\"o\":i=(parseInt(i,10)>>>0).toString(8);break;case\"s\":i=String(i),i=o.precision?i.substring(0,o.precision):i;break;case\"t\":i=String(!!i),i=o.precision?i.substring(0,o.precision):i;break;case\"T\":i=Object.prototype.toString.call(i).slice(8,-1).toLowerCase(),i=o.precision?i.substring(0,o.precision):i;break;case\"u\":i=parseInt(i,10)>>>0;break;case\"v\":i=i.valueOf(),i=o.precision?i.substring(0,o.precision):i;break;case\"x\":i=(parseInt(i,10)>>>0).toString(16);break;case\"X\":i=(parseInt(i,10)>>>0).toString(16).toUpperCase()}e.json.test(o.type)?y+=i:(!e.number.test(o.type)||u&&!o.sign?f=\"\":(f=u?\"+\":\"-\",i=i.toString().replace(e.sign,\"\")),c=o.pad_char?\"0\"===o.pad_char?\"0\":o.pad_char.charAt(1):\" \",l=o.width-(f+i).length,p=o.width&&l>0?c.repeat(l):\"\",y+=o.align?f+i+p:\"0\"===c?f+p+i:p+f+i)}return y}var s=Object.create(null);function a(n){if(s[n])return s[n];for(var t,r=n,i=[],a=0;r;){if(null!==(t=e.text.exec(r)))i.push(t[0]);else if(null!==(t=e.modulo.exec(r)))i.push(\"%\");else{if(null===(t=e.placeholder.exec(r)))throw new SyntaxError(\"[sprintf] unexpected placeholder\");if(t[2]){a|=1;var o=[],p=t[2],c=[];if(null===(c=e.key.exec(p)))throw new SyntaxError(\"[sprintf] failed to parse named argument key\");for(o.push(c[1]);\"\"!==(p=p.substring(c[0].length));)if(null!==(c=e.key_access.exec(p)))o.push(c[1]);else{if(null===(c=e.index_access.exec(p)))throw new SyntaxError(\"[sprintf] failed to parse named argument key\");o.push(c[1])}t[2]=o}else a|=2;if(3===a)throw new Error(\"[sprintf] mixing positional and named placeholders is not (yet) supported\");i.push({placeholder:t[0],param_no:t[1],keys:t[2],sign:t[3],pad_char:t[4],align:t[5],width:t[6],precision:t[7],type:t[8]})}r=r.substring(t[0].length)}return s[n]=i}void 0!==t&&(t.sprintf=n,t.vsprintf=r),\"undefined\"!=typeof window&&(window.sprintf=n,window.vsprintf=r,\"function\"==typeof define&&define.amd&&define((function(){return{sprintf:n,vsprintf:r}})))}()},\n",
" function _(e,i,n,t,a){t();const s=e(9),r=e(178),c=e(186),m=e(187),_=e(190),k=e(191),o=e(189);class T extends c.CompositeTicker{constructor(e){super(e)}static init_DatetimeTicker(){this.override({num_minor_ticks:0,tickers:()=>[new r.AdaptiveTicker({mantissas:[1,2,5],base:10,min_interval:0,max_interval:500*o.ONE_MILLI,num_minor_ticks:0}),new r.AdaptiveTicker({mantissas:[1,2,5,10,15,20,30],base:60,min_interval:o.ONE_SECOND,max_interval:30*o.ONE_MINUTE,num_minor_ticks:0}),new r.AdaptiveTicker({mantissas:[1,2,4,6,8,12],base:24,min_interval:o.ONE_HOUR,max_interval:12*o.ONE_HOUR,num_minor_ticks:0}),new m.DaysTicker({days:s.range(1,32)}),new m.DaysTicker({days:s.range(1,31,3)}),new m.DaysTicker({days:[1,8,15,22]}),new m.DaysTicker({days:[1,15]}),new _.MonthsTicker({months:s.range(0,12,1)}),new _.MonthsTicker({months:s.range(0,12,2)}),new _.MonthsTicker({months:s.range(0,12,4)}),new _.MonthsTicker({months:s.range(0,12,6)}),new k.YearsTicker({})]})}}n.DatetimeTicker=T,T.__name__=\"DatetimeTicker\",T.init_DatetimeTicker()},\n",
" function _(t,e,i,s,r){s();const n=t(179),_=t(9);class a extends n.ContinuousTicker{constructor(t){super(t)}static init_CompositeTicker(){this.define((({Array:t,Ref:e})=>({tickers:[t(e(n.ContinuousTicker)),[]]})))}get min_intervals(){return this.tickers.map((t=>t.get_min_interval()))}get max_intervals(){return this.tickers.map((t=>t.get_max_interval()))}get_min_interval(){return this.min_intervals[0]}get_max_interval(){return this.max_intervals[0]}get_best_ticker(t,e,i){const s=e-t,r=this.get_ideal_interval(t,e,i),n=[_.sorted_index(this.min_intervals,r)-1,_.sorted_index(this.max_intervals,r)],a=[this.min_intervals[n[0]],this.max_intervals[n[1]]].map((t=>Math.abs(i-s/t)));let c;if(_.is_empty(a.filter((t=>!isNaN(t)))))c=this.tickers[0];else{const t=n[_.argmin(a)];c=this.tickers[t]}return c}get_interval(t,e,i){return this.get_best_ticker(t,e,i).get_interval(t,e,i)}get_ticks_no_defaults(t,e,i,s){return this.get_best_ticker(t,e,s).get_ticks_no_defaults(t,e,i,s)}}i.CompositeTicker=a,a.__name__=\"CompositeTicker\",a.init_CompositeTicker()},\n",
" function _(t,e,n,i,s){i();const a=t(188),o=t(189),r=t(9);class c extends a.SingleIntervalTicker{constructor(t){super(t)}static init_DaysTicker(){this.define((({Int:t,Array:e})=>({days:[e(t),[]]}))),this.override({num_minor_ticks:0})}initialize(){super.initialize();const t=this.days;t.length>1?this.interval=(t[1]-t[0])*o.ONE_DAY:this.interval=31*o.ONE_DAY}get_ticks_no_defaults(t,e,n,i){const s=function(t,e){const n=o.last_month_no_later_than(new Date(t)),i=o.last_month_no_later_than(new Date(e));i.setUTCMonth(i.getUTCMonth()+1);const s=[],a=n;for(;s.push(o.copy_date(a)),a.setUTCMonth(a.getUTCMonth()+1),!(a>i););return s}(t,e),a=this.days,c=this.interval;return{major:r.concat(s.map((t=>((t,e)=>{const n=t.getUTCMonth(),i=[];for(const s of a){const a=o.copy_date(t);a.setUTCDate(s),new Date(a.getTime()+e/2).getUTCMonth()==n&&i.push(a)}return i})(t,c)))).map((t=>t.getTime())).filter((n=>t<=n&&n<=e)),minor:[]}}}n.DaysTicker=c,c.__name__=\"DaysTicker\",c.init_DaysTicker()},\n",
" function _(e,t,n,i,r){i();const l=e(179);class a extends l.ContinuousTicker{constructor(e){super(e)}static init_SingleIntervalTicker(){this.define((({Number:e})=>({interval:[e]})))}get_interval(e,t,n){return this.interval}get_min_interval(){return this.interval}get_max_interval(){return this.interval}}n.SingleIntervalTicker=a,a.__name__=\"SingleIntervalTicker\",a.init_SingleIntervalTicker()},\n",
" function _(t,n,e,_,E){function N(t){return new Date(t.getTime())}function O(t){const n=N(t);return n.setUTCDate(1),n.setUTCHours(0),n.setUTCMinutes(0),n.setUTCSeconds(0),n.setUTCMilliseconds(0),n}_(),e.ONE_MILLI=1,e.ONE_SECOND=1e3,e.ONE_MINUTE=60*e.ONE_SECOND,e.ONE_HOUR=60*e.ONE_MINUTE,e.ONE_DAY=24*e.ONE_HOUR,e.ONE_MONTH=30*e.ONE_DAY,e.ONE_YEAR=365*e.ONE_DAY,e.copy_date=N,e.last_month_no_later_than=O,e.last_year_no_later_than=function(t){const n=O(t);return n.setUTCMonth(0),n}},\n",
" function _(t,e,n,i,s){i();const r=t(188),a=t(189),o=t(9);class c extends r.SingleIntervalTicker{constructor(t){super(t)}static init_MonthsTicker(){this.define((({Int:t,Array:e})=>({months:[e(t),[]]})))}initialize(){super.initialize();const t=this.months;t.length>1?this.interval=(t[1]-t[0])*a.ONE_MONTH:this.interval=12*a.ONE_MONTH}get_ticks_no_defaults(t,e,n,i){const s=function(t,e){const n=a.last_year_no_later_than(new Date(t)),i=a.last_year_no_later_than(new Date(e));i.setUTCFullYear(i.getUTCFullYear()+1);const s=[],r=n;for(;s.push(a.copy_date(r)),r.setUTCFullYear(r.getUTCFullYear()+1),!(r>i););return s}(t,e),r=this.months;return{major:o.concat(s.map((t=>r.map((e=>{const n=a.copy_date(t);return n.setUTCMonth(e),n}))))).map((t=>t.getTime())).filter((n=>t<=n&&n<=e)),minor:[]}}}n.MonthsTicker=c,c.__name__=\"MonthsTicker\",c.init_MonthsTicker()},\n",
" function _(e,t,a,i,r){i();const n=e(177),_=e(188),s=e(189);class c extends _.SingleIntervalTicker{constructor(e){super(e)}initialize(){super.initialize(),this.interval=s.ONE_YEAR,this.basic_ticker=new n.BasicTicker({num_minor_ticks:0})}get_ticks_no_defaults(e,t,a,i){const r=s.last_year_no_later_than(new Date(e)).getUTCFullYear(),n=s.last_year_no_later_than(new Date(t)).getUTCFullYear();return{major:this.basic_ticker.get_ticks_no_defaults(r,n,a,i).major.map((e=>Date.UTC(e,0,1))).filter((a=>e<=a&&a<=t)),minor:[]}}}a.YearsTicker=c,c.__name__=\"YearsTicker\"},\n",
" function _(i,s,t,e,o){e();const n=i(173),r=i(193),_=i(194);class c extends n.ContinuousAxisView{}t.LogAxisView=c,c.__name__=\"LogAxisView\";class x extends n.ContinuousAxis{constructor(i){super(i)}static init_LogAxis(){this.prototype.default_view=c,this.override({ticker:()=>new _.LogTicker,formatter:()=>new r.LogTickFormatter})}}t.LogAxis=x,x.__name__=\"LogAxis\",x.init_LogAxis()},\n",
" function _(t,e,r,i,n){i();const o=t(166),a=t(176),s=t(194),c=t(167),{log:l,round:u}=Math;class _ extends o.TickFormatter{constructor(t){super(t)}static init_LogTickFormatter(){this.define((({Ref:t,Nullable:e})=>({ticker:[e(t(s.LogTicker)),null]})))}initialize(){super.initialize(),this.basic_formatter=new a.BasicTickFormatter}format_graphics(t,e){var r,i;if(0==t.length)return[];const n=null!==(i=null===(r=this.ticker)||void 0===r?void 0:r.base)&&void 0!==i?i:10,o=this._exponents(t,n);return null==o?this.basic_formatter.format_graphics(t,e):o.map((t=>{const e=new c.TextBox({text:a.unicode_replace(`${n}`)}),r=new c.TextBox({text:a.unicode_replace(`${t}`)});return new c.BaseExpo(e,r)}))}_exponents(t,e){let r=null;const i=[];for(const n of t){const t=u(l(n)/l(e));if(r==t)return null;r=t,i.push(t)}return i}doFormat(t,e){var r,i;if(0==t.length)return[];const n=null!==(i=null===(r=this.ticker)||void 0===r?void 0:r.base)&&void 0!==i?i:10,o=this._exponents(t,n);return null==o?this.basic_formatter.doFormat(t,e):o.map((t=>a.unicode_replace(`${n}^${t}`)))}}r.LogTickFormatter=_,_.__name__=\"LogTickFormatter\",_.init_LogTickFormatter()},\n",
" function _(t,o,e,i,s){i();const n=t(178),r=t(9);class c extends n.AdaptiveTicker{constructor(t){super(t)}static init_LogTicker(){this.override({mantissas:[1,5]})}get_ticks_no_defaults(t,o,e,i){const s=this.num_minor_ticks,n=[],c=this.base,a=Math.log(t)/Math.log(c),f=Math.log(o)/Math.log(c),l=f-a;let h;if(isFinite(l))if(l<2){const e=this.get_interval(t,o,i),c=Math.floor(t/e),a=Math.ceil(o/e);if(h=r.range(c,a+1).filter((t=>0!=t)).map((t=>t*e)).filter((e=>t<=e&&e<=o)),s>0&&h.length>0){const t=e/s,o=r.range(0,s).map((o=>o*t));for(const t of o.slice(1))n.push(h[0]-t);for(const t of h)for(const e of o)n.push(t+e)}}else{const t=Math.ceil(.999999*a),o=Math.floor(1.000001*f),e=Math.ceil((o-t)/9);if(h=r.range(t-1,o+1,e).map((t=>c**t)),s>0&&h.length>0){const t=c**e/s,o=r.range(1,s+1).map((o=>o*t));for(const t of o)n.push(h[0]/t);n.push(h[0]);for(const t of h)for(const e of o)n.push(t*e)}}else h=[];return{major:h.filter((e=>t<=e&&e<=o)),minor:n.filter((e=>t<=e&&e<=o))}}}e.LogTicker=c,c.__name__=\"LogTicker\",c.init_LogTicker()},\n",
" function _(e,t,i,r,s){r();const a=e(163),o=e(175),c=e(196),n=e(197);class _ extends a.AxisView{}i.MercatorAxisView=_,_.__name__=\"MercatorAxisView\";class x extends o.LinearAxis{constructor(e){super(e)}static init_MercatorAxis(){this.prototype.default_view=_,this.override({ticker:()=>new n.MercatorTicker({dimension:\"lat\"}),formatter:()=>new c.MercatorTickFormatter({dimension:\"lat\"})})}}i.MercatorAxis=x,x.__name__=\"MercatorAxis\",x.init_MercatorAxis()},\n",
" function _(r,t,e,o,n){o();const i=r(176),c=r(20),a=r(65);class s extends i.BasicTickFormatter{constructor(r){super(r)}static init_MercatorTickFormatter(){this.define((({Nullable:r})=>({dimension:[r(c.LatLon),null]})))}doFormat(r,t){if(null==this.dimension)throw new Error(\"MercatorTickFormatter.dimension not configured\");if(0==r.length)return[];const e=r.length,o=new Array(e);if(\"lon\"==this.dimension)for(let n=0;n<e;n++){const[e]=a.wgs84_mercator.invert(r[n],t.loc);o[n]=e}else for(let n=0;n<e;n++){const[,e]=a.wgs84_mercator.invert(t.loc,r[n]);o[n]=e}return super.doFormat(o,t)}}e.MercatorTickFormatter=s,s.__name__=\"MercatorTickFormatter\",s.init_MercatorTickFormatter()},\n",
" function _(t,o,n,r,s){r();const i=t(177),e=t(20),c=t(65);class _ extends i.BasicTicker{constructor(t){super(t)}static init_MercatorTicker(){this.define((({Nullable:t})=>({dimension:[t(e.LatLon),null]})))}get_ticks_no_defaults(t,o,n,r){if(null==this.dimension)throw new Error(`${this}.dimension wasn't configured`);return[t,o]=c.clip_mercator(t,o,this.dimension),\"lon\"==this.dimension?this._get_ticks_lon(t,o,n,r):this._get_ticks_lat(t,o,n,r)}_get_ticks_lon(t,o,n,r){const[s]=c.wgs84_mercator.invert(t,n),[i,e]=c.wgs84_mercator.invert(o,n),_=super.get_ticks_no_defaults(s,i,n,r),a=[];for(const t of _.major)if(c.in_bounds(t,\"lon\")){const[o]=c.wgs84_mercator.compute(t,e);a.push(o)}const m=[];for(const t of _.minor)if(c.in_bounds(t,\"lon\")){const[o]=c.wgs84_mercator.compute(t,e);m.push(o)}return{major:a,minor:m}}_get_ticks_lat(t,o,n,r){const[,s]=c.wgs84_mercator.invert(n,t),[i,e]=c.wgs84_mercator.invert(n,o),_=super.get_ticks_no_defaults(s,e,n,r),a=[];for(const t of _.major)if(c.in_bounds(t,\"lat\")){const[,o]=c.wgs84_mercator.compute(i,t);a.push(o)}const m=[];for(const t of _.minor)if(c.in_bounds(t,\"lat\")){const[,o]=c.wgs84_mercator.compute(i,t);m.push(o)}return{major:a,minor:m}}}n.MercatorTicker=_,_.__name__=\"MercatorTicker\",_.init_MercatorTicker()},\n",
" function _(e,i,r,c,k){c(),k(\"AdaptiveTicker\",e(178).AdaptiveTicker),k(\"BasicTicker\",e(177).BasicTicker),k(\"CategoricalTicker\",e(171).CategoricalTicker),k(\"CompositeTicker\",e(186).CompositeTicker),k(\"ContinuousTicker\",e(179).ContinuousTicker),k(\"DatetimeTicker\",e(185).DatetimeTicker),k(\"DaysTicker\",e(187).DaysTicker),k(\"FixedTicker\",e(199).FixedTicker),k(\"LogTicker\",e(194).LogTicker),k(\"MercatorTicker\",e(197).MercatorTicker),k(\"MonthsTicker\",e(190).MonthsTicker),k(\"SingleIntervalTicker\",e(188).SingleIntervalTicker),k(\"Ticker\",e(165).Ticker),k(\"YearsTicker\",e(191).YearsTicker),k(\"BinnedTicker\",e(200).BinnedTicker)},\n",
" function _(i,t,e,r,n){r();const s=i(179);class _ extends s.ContinuousTicker{constructor(i){super(i)}static init_FixedTicker(){this.define((({Number:i,Array:t})=>({ticks:[t(i),[]],minor_ticks:[t(i),[]]})))}get_ticks_no_defaults(i,t,e,r){return{major:this.ticks,minor:this.minor_ticks}}get_interval(i,t,e){return 0}get_min_interval(){return 0}get_max_interval(){return 0}}e.FixedTicker=_,_.__name__=\"FixedTicker\",_.init_FixedTicker()},\n",
" function _(e,n,t,i,r){i();const c=e(165),o=e(201),s=e(12);class a extends c.Ticker{constructor(e){super(e)}static init_BinnedTicker(){this.define((({Number:e,Ref:n,Or:t,Auto:i})=>({mapper:[n(o.ScanningColorMapper)],num_major_ticks:[t(e,i),8]})))}get_ticks(e,n,t,i){const{binning:r}=this.mapper.metrics,c=Math.max(0,s.left_edge_index(e,r)),o=Math.min(s.left_edge_index(n,r)+1,r.length-1),a=[];for(let e=c;e<=o;e++)a.push(r[e]);const{num_major_ticks:_}=this,m=[],h=\"auto\"==_?a.length:_,l=Math.max(1,Math.floor(a.length/h));for(let e=0;e<a.length;e+=l)m.push(a[e]);return{major:m,minor:[]}}}t.BinnedTicker=a,a.__name__=\"BinnedTicker\",a.init_BinnedTicker()},\n",
" function _(n,e,i,r,o){r();const t=n(202),a=n(12);class c extends t.ContinuousColorMapper{constructor(n){super(n)}cmap(n,e,i,r,o){if(n<o.binning[0])return i;if(n>o.binning[o.binning.length-1])return r;return e[a.left_edge_index(n,o.binning)]}}i.ScanningColorMapper=c,c.__name__=\"ScanningColorMapper\"},\n",
" function _(t,o,e,n,s){n();const l=t(203),i=t(61),c=t(9),a=t(8);class r extends l.ColorMapper{constructor(t){super(t),this._scan_data=null}static init_ContinuousColorMapper(){this.define((({Number:t,String:o,Ref:e,Color:n,Or:s,Tuple:l,Array:c,Nullable:a})=>({high:[a(t),null],low:[a(t),null],high_color:[a(n),null],low_color:[a(n),null],domain:[c(l(e(i.GlyphRenderer),s(o,c(o)))),[]]})))}connect_signals(){super.connect_signals();const t=()=>{for(const[t]of this.domain)this.connect(t.view.change,(()=>this.update_data())),this.connect(t.data_source.selected.change,(()=>this.update_data()))};this.connect(this.properties.domain.change,(()=>t())),t()}update_data(){const{domain:t,palette:o}=this,e=[...this._collect(t)];this._scan_data=this.scan(e,o.length),this.metrics_change.emit(),this.change.emit()}get metrics(){return null==this._scan_data&&this.update_data(),this._scan_data}*_collect(t){for(const[o,e]of t)for(const t of a.isArray(e)?e:[e]){let e=o.data_source.get_column(t);e=o.view.indices.select(e);const n=o.view.masked,s=o.data_source.selected.indices;let l;if(null!=n&&s.length>0?l=c.intersection([...n],s):null!=n?l=[...n]:s.length>0&&(l=s),null!=l&&(e=c.map(l,(t=>e[t]))),e.length>0&&!a.isNumber(e[0]))for(const t of e)yield*t;else yield*e}}_v_compute(t,o,e,n){const{nan_color:s}=n;let{low_color:l,high_color:i}=n;null==l&&(l=e[0]),null==i&&(i=e[e.length-1]);const{domain:a}=this,r=c.is_empty(a)?t:[...this._collect(a)];this._scan_data=this.scan(r,e.length),this.metrics_change.emit();for(let n=0,c=t.length;n<c;n++){const c=t[n];isNaN(c)?o[n]=s:o[n]=this.cmap(c,e,l,i,this._scan_data)}}_colors(t){return Object.assign(Object.assign({},super._colors(t)),{low_color:null!=this.low_color?t(this.low_color):void 0,high_color:null!=this.high_color?t(this.high_color):void 0})}}e.ContinuousColorMapper=r,r.__name__=\"ContinuousColorMapper\",r.init_ContinuousColorMapper()},\n",
" function _(t,r,e,n,o){n();const i=t(204),a=t(15),c=t(24),_=t(22),l=t(27);function s(t){return _.encode_rgba(_.color2rgba(t))}function p(t){const r=new Uint32Array(t.length);for(let e=0,n=t.length;e<n;e++)r[e]=s(t[e]);return r}e._convert_color=s,e._convert_palette=p;class u extends i.Mapper{constructor(t){super(t)}initialize(){super.initialize(),this.metrics_change=new a.Signal0(this,\"metrics_change\")}static init_ColorMapper(){this.define((({Color:t,Array:r})=>({palette:[r(t)],nan_color:[t,\"gray\"]})))}v_compute(t){const r=new Array(t.length);return this._v_compute(t,r,this.palette,this._colors((t=>t))),r}get rgba_mapper(){const t=this,r=p(this.palette),e=this._colors(s);return{v_compute(n){const o=new c.ColorArray(n.length);return t._v_compute(n,o,r,e),new Uint8ClampedArray(l.to_big_endian(o).buffer)}}}_colors(t){return{nan_color:t(this.nan_color)}}}e.ColorMapper=u,u.__name__=\"ColorMapper\",u.init_ColorMapper()},\n",
" function _(r,e,n,s,o){s();const p=r(149);class t extends p.Transform{constructor(r){super(r)}compute(r){throw new Error(\"mapping single values is not supported\")}}n.Mapper=t,t.__name__=\"Mapper\"},\n",
" function _(t,r,a,e,c){e(),c(\"BasicTickFormatter\",t(176).BasicTickFormatter),c(\"CategoricalTickFormatter\",t(172).CategoricalTickFormatter),c(\"DatetimeTickFormatter\",t(180).DatetimeTickFormatter),c(\"FuncTickFormatter\",t(206).FuncTickFormatter),c(\"LogTickFormatter\",t(193).LogTickFormatter),c(\"MercatorTickFormatter\",t(196).MercatorTickFormatter),c(\"NumeralTickFormatter\",t(207).NumeralTickFormatter),c(\"PrintfTickFormatter\",t(208).PrintfTickFormatter),c(\"TickFormatter\",t(166).TickFormatter)},\n",
" function _(t,n,e,s,i){s();const r=t(166),c=t(13),a=t(34);class u extends r.TickFormatter{constructor(t){super(t)}static init_FuncTickFormatter(){this.define((({Unknown:t,String:n,Dict:e})=>({args:[e(t),{}],code:[n,\"\"]})))}get names(){return c.keys(this.args)}get values(){return c.values(this.args)}_make_func(){const t=a.use_strict(this.code);return new Function(\"tick\",\"index\",\"ticks\",...this.names,t)}doFormat(t,n){const e=this._make_func().bind({});return t.map(((t,n,s)=>`${e(t,n,s,...this.values)}`))}}e.FuncTickFormatter=u,u.__name__=\"FuncTickFormatter\",u.init_FuncTickFormatter()},\n",
" function _(r,t,n,e,a){e();const o=r(1).__importStar(r(183)),i=r(166),u=r(20);class c extends i.TickFormatter{constructor(r){super(r)}static init_NumeralTickFormatter(){this.define((({String:r})=>({format:[r,\"0,0\"],language:[r,\"en\"],rounding:[u.RoundingFunction,\"round\"]})))}get _rounding_fn(){switch(this.rounding){case\"round\":case\"nearest\":return Math.round;case\"floor\":case\"rounddown\":return Math.floor;case\"ceil\":case\"roundup\":return Math.ceil}}doFormat(r,t){const{format:n,language:e,_rounding_fn:a}=this;return r.map((r=>o.format(r,n,e,a)))}}n.NumeralTickFormatter=c,c.__name__=\"NumeralTickFormatter\",c.init_NumeralTickFormatter()},\n",
" function _(t,r,i,n,o){n();const a=t(166),e=t(182);class c extends a.TickFormatter{constructor(t){super(t)}static init_PrintfTickFormatter(){this.define((({String:t})=>({format:[t,\"%s\"]})))}doFormat(t,r){return t.map((t=>e.sprintf(this.format,t)))}}i.PrintfTickFormatter=c,c.__name__=\"PrintfTickFormatter\",c.init_PrintfTickFormatter()},\n",
" function _(r,o,a,p,e){p(),e(\"CategoricalColorMapper\",r(210).CategoricalColorMapper),e(\"CategoricalMarkerMapper\",r(212).CategoricalMarkerMapper),e(\"CategoricalPatternMapper\",r(213).CategoricalPatternMapper),e(\"ContinuousColorMapper\",r(202).ContinuousColorMapper),e(\"ColorMapper\",r(203).ColorMapper),e(\"LinearColorMapper\",r(214).LinearColorMapper),e(\"LogColorMapper\",r(215).LogColorMapper),e(\"ScanningColorMapper\",r(201).ScanningColorMapper),e(\"EqHistColorMapper\",r(216).EqHistColorMapper)},\n",
" function _(t,o,a,r,e){r();const c=t(211),l=t(203),i=t(104);class s extends l.ColorMapper{constructor(t){super(t)}static init_CategoricalColorMapper(){this.define((({Number:t,Nullable:o})=>({factors:[i.FactorSeq],start:[t,0],end:[o(t),null]})))}_v_compute(t,o,a,{nan_color:r}){c.cat_v_compute(t,this.factors,a,o,this.start,this.end,r)}}a.CategoricalColorMapper=s,s.__name__=\"CategoricalColorMapper\",s.init_CategoricalColorMapper()},\n",
" function _(n,t,e,l,i){l();const c=n(12),u=n(8);function f(n,t){if(n.length!=t.length)return!1;for(let e=0,l=n.length;e<l;e++)if(n[e]!==t[e])return!1;return!0}e._cat_equals=f,e.cat_v_compute=function(n,t,e,l,i,o,r){const _=n.length;for(let g=0;g<_;g++){let _,s,h=n[g];u.isString(h)?_=c.index_of(t,h):(null!=i?h=null!=o?h.slice(i,o):h.slice(i):null!=o&&(h=h.slice(0,o)),_=1==h.length?c.index_of(t,h[0]):c.find_index(t,(n=>f(n,h)))),s=_<0||_>=e.length?r:e[_],l[g]=s}}},\n",
" function _(r,e,a,t,s){t();const c=r(211),i=r(104),l=r(204),n=r(20);class p extends l.Mapper{constructor(r){super(r)}static init_CategoricalMarkerMapper(){this.define((({Number:r,Array:e,Nullable:a})=>({factors:[i.FactorSeq],markers:[e(n.MarkerType)],start:[r,0],end:[a(r),null],default_value:[n.MarkerType,\"circle\"]})))}v_compute(r){const e=new Array(r.length);return c.cat_v_compute(r,this.factors,this.markers,e,this.start,this.end,this.default_value),e}}a.CategoricalMarkerMapper=p,p.__name__=\"CategoricalMarkerMapper\",p.init_CategoricalMarkerMapper()},\n",
" function _(t,a,e,r,n){r();const s=t(211),c=t(104),i=t(204),p=t(20);class l extends i.Mapper{constructor(t){super(t)}static init_CategoricalPatternMapper(){this.define((({Number:t,Array:a,Nullable:e})=>({factors:[c.FactorSeq],patterns:[a(p.HatchPatternType)],start:[t,0],end:[e(t),null],default_value:[p.HatchPatternType,\" \"]})))}v_compute(t){const a=new Array(t.length);return s.cat_v_compute(t,this.factors,this.patterns,a,this.start,this.end,this.default_value),a}}e.CategoricalPatternMapper=l,l.__name__=\"CategoricalPatternMapper\",l.init_CategoricalPatternMapper()},\n",
" function _(n,r,o,t,a){t();const e=n(202),i=n(12);class s extends e.ContinuousColorMapper{constructor(n){super(n)}scan(n,r){const o=null!=this.low?this.low:i.min(n),t=null!=this.high?this.high:i.max(n);return{max:t,min:o,norm_factor:1/(t-o),normed_interval:1/r}}cmap(n,r,o,t,a){const e=r.length-1;if(n==a.max)return r[e];const i=(n-a.min)*a.norm_factor,s=Math.floor(i/a.normed_interval);return s<0?o:s>e?t:r[s]}}o.LinearColorMapper=s,s.__name__=\"LinearColorMapper\"},\n",
" function _(o,t,n,r,l){r();const a=o(202),s=o(12);class e extends a.ContinuousColorMapper{constructor(o){super(o)}scan(o,t){const n=null!=this.low?this.low:s.min(o),r=null!=this.high?this.high:s.max(o);return{max:r,min:n,scale:t/(Math.log(r)-Math.log(n))}}cmap(o,t,n,r,l){const a=t.length-1;if(o>l.max)return r;if(o==l.max)return t[a];if(o<l.min)return n;const s=Math.log(o)-Math.log(l.min);let e=Math.floor(s*l.scale);return e>a&&(e=a),t[e]}}n.LogColorMapper=e,e.__name__=\"LogColorMapper\"},\n",
" function _(n,t,i,e,o){e();const s=n(201),r=n(12),a=n(9),l=n(19);class c extends s.ScanningColorMapper{constructor(n){super(n)}static init_EqHistColorMapper(){this.define((({Int:n})=>({bins:[n,65536]})))}scan(n,t){const i=null!=this.low?this.low:r.min(n),e=null!=this.high?this.high:r.max(n),o=this.bins,s=a.linspace(i,e,o+1),c=r.bin_counts(n,s),h=new Array(o);for(let n=0,t=s.length;n<t-1;n++){const t=s[n],i=s[n+1];h[n]=(t+i)/2}const p=a.cumsum(c),g=p[p.length-1],u=r.map(p,(n=>n/g));let m=t-1,M=[],_=0,f=2*t;for(;m!=t&&_<4&&0!=m;){const n=f/m;if(n>1e3)break;f=Math.round(Math.max(t*n,t));const i=a.range(0,f),e=r.map(u,(n=>n*(f-1)));M=r.interpolate(i,e,h);m=a.uniq(M).length-1,_++}if(0==m){M=[i,e];for(let n=0;n<t-1;n++)M.push(e)}else M=M.slice(M.length-t-1),m!=t&&l.logger.warn(\"EqHistColorMapper warning: Histogram equalization did not converge.\");return M[0]=i,M[M.length-1]=e,{min:i,max:e,binning:M}}}i.EqHistColorMapper=c,c.__name__=\"EqHistColorMapper\",c.init_EqHistColorMapper()},\n",
" function _(a,e,l,c,n){c(),n(\"CategoricalScale\",a(145).CategoricalScale),n(\"ContinuousScale\",a(158).ContinuousScale),n(\"LinearScale\",a(218).LinearScale),n(\"LinearInterpolationScale\",a(219).LinearInterpolationScale),n(\"LogScale\",a(157).LogScale),n(\"Scale\",a(146).Scale)},\n",
" function _(e,t,n,r,_){r();const i=e(158);class u extends i.ContinuousScale{constructor(e){super(e)}get s_compute(){const[e,t]=this._linear_compute_state();return n=>e*n+t}compute(e){return this._linear_compute(e)}v_compute(e){return this._linear_v_compute(e)}invert(e){return this._linear_invert(e)}v_invert(e){return this._linear_v_invert(e)}}n.LinearScale=u,u.__name__=\"LinearScale\"},\n",
" function _(n,e,t,r,i){r();const a=n(146),o=n(12);class c extends a.Scale{constructor(n){super(n)}static init_LinearInterpolationScale(){this.internal((({Arrayable:n})=>({binning:[n]})))}get s_compute(){throw new Error(\"not implemented\")}compute(n){return n}v_compute(n){const{binning:e}=this,{start:t,end:r}=this.source_range,i=t,a=r,c=e.length,l=(r-t)/(c-1),s=new Float64Array(c);for(let n=0;n<c;n++)s[n]=t+n*l;const _=o.map(n,(n=>{if(n<i)return i;if(n>a)return a;const t=o.left_edge_index(n,e),r=e[t],c=(n-r)/(e[t+1]-r),l=s[t];return l+c*(s[t+1]-l)}));return this._linear_v_compute(_)}invert(n){return n}v_invert(n){return new Float64Array(n)}}t.LinearInterpolationScale=c,c.__name__=\"LinearInterpolationScale\",c.init_LinearInterpolationScale()},\n",
" function _(a,n,e,g,R){g(),R(\"DataRange\",a(160).DataRange),R(\"DataRange1d\",a(159).DataRange1d),R(\"FactorRange\",a(104).FactorRange),R(\"Range\",a(105).Range),R(\"Range1d\",a(156).Range1d)},\n",
" function _(a,o,i,t,e){t();var n=a(141);e(\"Sizeable\",n.Sizeable),e(\"SizingPolicy\",n.SizingPolicy);var c=a(142);e(\"Layoutable\",c.Layoutable),e(\"LayoutItem\",c.LayoutItem);var r=a(222);e(\"HStack\",r.HStack),e(\"VStack\",r.VStack);var l=a(223);e(\"Grid\",l.Grid),e(\"Row\",l.Row),e(\"Column\",l.Column);var S=a(224);e(\"ContentBox\",S.ContentBox),e(\"VariadicBox\",S.VariadicBox)},\n",
" function _(t,e,h,i,r){i();const n=t(142),o=t(99);class s extends n.Layoutable{constructor(){super(...arguments),this.children=[]}*[Symbol.iterator](){yield*this.children}}h.Stack=s,s.__name__=\"Stack\";class c extends s{_measure(t){let e=0,h=0;for(const t of this.children){const i=t.measure({width:0,height:0});e+=i.width,h=Math.max(h,i.height)}return{width:e,height:h}}_set_geometry(t,e){super._set_geometry(t,e);const h=this.absolute?t.top:0;let i=this.absolute?t.left:0;const{height:r}=t;for(const t of this.children){const{width:e}=t.measure({width:0,height:0});t.set_geometry(new o.BBox({left:i,width:e,top:h,height:r})),i+=e}}}h.HStack=c,c.__name__=\"HStack\";class a extends s{_measure(t){let e=0,h=0;for(const t of this.children){const i=t.measure({width:0,height:0});e=Math.max(e,i.width),h+=i.height}return{width:e,height:h}}_set_geometry(t,e){super._set_geometry(t,e);const h=this.absolute?t.left:0;let i=this.absolute?t.top:0;const{width:r}=t;for(const t of this.children){const{height:e}=t.measure({width:0,height:0});t.set_geometry(new o.BBox({top:i,height:e,left:h,width:r})),i+=e}}}h.VStack=a,a.__name__=\"VStack\";class l extends n.Layoutable{constructor(){super(...arguments),this.children=[]}*[Symbol.iterator](){yield*this.children}_measure(t){const{width_policy:e,height_policy:h}=this.sizing,{min:i,max:r}=Math;let n=0,o=0;for(const e of this.children){const{width:h,height:i}=e.measure(t);n=r(n,h),o=r(o,i)}return{width:(()=>{const{width:h}=this.sizing;if(t.width==1/0)return\"fixed\"==e&&null!=h?h:n;switch(e){case\"fixed\":return null!=h?h:n;case\"min\":return n;case\"fit\":return null!=h?i(t.width,h):t.width;case\"max\":return null!=h?r(t.width,h):t.width}})(),height:(()=>{const{height:e}=this.sizing;if(t.height==1/0)return\"fixed\"==h&&null!=e?e:o;switch(h){case\"fixed\":return null!=e?e:o;case\"min\":return o;case\"fit\":return null!=e?i(t.height,e):t.height;case\"max\":return null!=e?r(t.height,e):t.height}})()}}_set_geometry(t,e){super._set_geometry(t,e);const h=this.absolute?t:t.relative(),{left:i,right:r,top:n,bottom:s}=h,c=Math.round(h.vcenter),a=Math.round(h.hcenter);for(const e of this.children){const{margin:h,halign:l,valign:d}=e.sizing,{width:u,height:g,inner:_}=e.measure(t),w=(()=>{switch(`${d}_${l}`){case\"start_start\":return new o.BBox({left:i+h.left,top:n+h.top,width:u,height:g});case\"start_center\":return new o.BBox({hcenter:a,top:n+h.top,width:u,height:g});case\"start_end\":return new o.BBox({right:r-h.right,top:n+h.top,width:u,height:g});case\"center_start\":return new o.BBox({left:i+h.left,vcenter:c,width:u,height:g});case\"center_center\":return new o.BBox({hcenter:a,vcenter:c,width:u,height:g});case\"center_end\":return new o.BBox({right:r-h.right,vcenter:c,width:u,height:g});case\"end_start\":return new o.BBox({left:i+h.left,bottom:s-h.bottom,width:u,height:g});case\"end_center\":return new o.BBox({hcenter:a,bottom:s-h.bottom,width:u,height:g});case\"end_end\":return new o.BBox({right:r-h.right,bottom:s-h.bottom,width:u,height:g})}})(),m=null==_?w:new o.BBox({left:w.left+_.left,top:w.top+_.top,right:w.right-_.right,bottom:w.bottom-_.bottom});e.set_geometry(w,m)}}}h.NodeLayout=l,l.__name__=\"NodeLayout\"},\n",
" function _(t,i,s,e,o){e();const n=t(141),l=t(142),r=t(8),h=t(99),c=t(9),{max:a,round:g}=Math;class p{constructor(t){this.def=t,this._map=new Map}get(t){let i=this._map.get(t);return void 0===i&&(i=this.def(),this._map.set(t,i)),i}apply(t,i){const s=this.get(t);this._map.set(t,i(s))}}p.__name__=\"DefaultMap\";class f{constructor(){this._items=[],this._nrows=0,this._ncols=0}get nrows(){return this._nrows}get ncols(){return this._ncols}add(t,i){const{r1:s,c1:e}=t;this._nrows=a(this._nrows,s+1),this._ncols=a(this._ncols,e+1),this._items.push({span:t,data:i})}at(t,i){return this._items.filter((({span:s})=>s.r0<=t&&t<=s.r1&&s.c0<=i&&i<=s.c1)).map((({data:t})=>t))}row(t){return this._items.filter((({span:i})=>i.r0<=t&&t<=i.r1)).map((({data:t})=>t))}col(t){return this._items.filter((({span:i})=>i.c0<=t&&t<=i.c1)).map((({data:t})=>t))}foreach(t){for(const{span:i,data:s}of this._items)t(i,s)}map(t){const i=new f;for(const{span:s,data:e}of this._items)i.add(s,t(s,e));return i}}f.__name__=\"Container\";class _ extends l.Layoutable{constructor(t=[]){super(),this.items=t,this.rows=\"auto\",this.cols=\"auto\",this.spacing=0}*[Symbol.iterator](){for(const{layout:t}of this.items)yield t}is_width_expanding(){if(super.is_width_expanding())return!0;if(\"fixed\"==this.sizing.width_policy)return!1;const{cols:t}=this._state;return c.some(t,(t=>\"max\"==t.policy))}is_height_expanding(){if(super.is_height_expanding())return!0;if(\"fixed\"==this.sizing.height_policy)return!1;const{rows:t}=this._state;return c.some(t,(t=>\"max\"==t.policy))}_init(){var t,i,s,e;super._init();const o=new f;for(const{layout:t,row:i,col:s,row_span:e,col_span:n}of this.items)if(t.sizing.visible){const l=i,r=s,h=i+(null!=e?e:1)-1,c=s+(null!=n?n:1)-1;o.add({r0:l,c0:r,r1:h,c1:c},t)}const{nrows:n,ncols:l}=o,h=new Array(n);for(let s=0;s<n;s++){const e=(()=>{var t;const i=r.isPlainObject(this.rows)?null!==(t=this.rows[s])&&void 0!==t?t:this.rows[\"*\"]:this.rows;return null==i?{policy:\"auto\"}:r.isNumber(i)?{policy:\"fixed\",height:i}:r.isString(i)?{policy:i}:i})(),n=null!==(t=e.align)&&void 0!==t?t:\"auto\";if(\"fixed\"==e.policy)h[s]={policy:\"fixed\",height:e.height,align:n};else if(\"min\"==e.policy)h[s]={policy:\"min\",align:n};else if(\"fit\"==e.policy||\"max\"==e.policy)h[s]={policy:e.policy,flex:null!==(i=e.flex)&&void 0!==i?i:1,align:n};else{if(\"auto\"!=e.policy)throw new Error(\"unrechable\");c.some(o.row(s),(t=>t.is_height_expanding()))?h[s]={policy:\"max\",flex:1,align:n}:h[s]={policy:\"min\",align:n}}}const a=new Array(l);for(let t=0;t<l;t++){const i=(()=>{var i;const s=r.isPlainObject(this.cols)?null!==(i=this.cols[t])&&void 0!==i?i:this.cols[\"*\"]:this.cols;return null==s?{policy:\"auto\"}:r.isNumber(s)?{policy:\"fixed\",width:s}:r.isString(s)?{policy:s}:s})(),n=null!==(s=i.align)&&void 0!==s?s:\"auto\";if(\"fixed\"==i.policy)a[t]={policy:\"fixed\",width:i.width,align:n};else if(\"min\"==i.policy)a[t]={policy:\"min\",align:n};else if(\"fit\"==i.policy||\"max\"==i.policy)a[t]={policy:i.policy,flex:null!==(e=i.flex)&&void 0!==e?e:1,align:n};else{if(\"auto\"!=i.policy)throw new Error(\"unrechable\");c.some(o.col(t),(t=>t.is_width_expanding()))?a[t]={policy:\"max\",flex:1,align:n}:a[t]={policy:\"min\",align:n}}}const[g,p]=r.isNumber(this.spacing)?[this.spacing,this.spacing]:this.spacing;this._state={items:o,nrows:n,ncols:l,rows:h,cols:a,rspacing:g,cspacing:p}}_measure_totals(t,i){const{nrows:s,ncols:e,rspacing:o,cspacing:n}=this._state;return{height:c.sum(t)+(s-1)*o,width:c.sum(i)+(e-1)*n}}_measure_cells(t){const{items:i,nrows:s,ncols:e,rows:o,cols:l,rspacing:r,cspacing:h}=this._state,c=new Array(s);for(let t=0;t<s;t++){const i=o[t];c[t]=\"fixed\"==i.policy?i.height:0}const p=new Array(e);for(let t=0;t<e;t++){const i=l[t];p[t]=\"fixed\"==i.policy?i.width:0}const _=new f;i.foreach(((i,s)=>{const{r0:e,c0:f,r1:d,c1:u}=i,w=(d-e)*r,m=(u-f)*h;let y=0;for(let i=e;i<=d;i++)y+=t(i,f).height;y+=w;let x=0;for(let i=f;i<=u;i++)x+=t(e,i).width;x+=m;const b=s.measure({width:x,height:y});_.add(i,{layout:s,size_hint:b});const z=new n.Sizeable(b).grow_by(s.sizing.margin);z.height-=w,z.width-=m;const v=[];for(let t=e;t<=d;t++){const i=o[t];\"fixed\"==i.policy?z.height-=i.height:v.push(t)}if(z.height>0){const t=g(z.height/v.length);for(const i of v)c[i]=a(c[i],t)}const j=[];for(let t=f;t<=u;t++){const i=l[t];\"fixed\"==i.policy?z.width-=i.width:j.push(t)}if(z.width>0){const t=g(z.width/j.length);for(const i of j)p[i]=a(p[i],t)}}));return{size:this._measure_totals(c,p),row_heights:c,col_widths:p,size_hints:_}}_measure_grid(t){const{nrows:i,ncols:s,rows:e,cols:o,rspacing:n,cspacing:l}=this._state,r=s=>{let o;o=\"fixed\"==this.sizing.height_policy&&null!=this.sizing.height?this.sizing.height:t.height!=1/0&&this.is_height_expanding()?Math.max(t.height,s.size.height):s.size.height;let l=0;for(let t=0;t<i;t++){const i=e[t];\"max\"==i.policy?l+=i.flex:o-=s.row_heights[t]}if(o-=(i-1)*n,0!=l&&o>0)for(let t=0;t<i;t++){const i=e[t];if(\"max\"==i.policy){const e=g(o*(i.flex/l));o-=e,s.row_heights[t]=e,l-=i.flex}}else if(o<0){let t=0;for(let s=0;s<i;s++){\"fixed\"!=e[s].policy&&t++}let n=-o;for(let o=0;o<i;o++){if(\"fixed\"!=e[o].policy){const i=s.row_heights[o],e=g(n/t);s.row_heights[o]=a(i-e,0),n-=e>i?i:e,t--}}}},h=i=>{let e;e=\"fixed\"==this.sizing.width_policy&&null!=this.sizing.width?this.sizing.width:t.width!=1/0&&this.is_width_expanding()?t.width:i.size.width;let n=0;for(let t=0;t<s;t++){const s=o[t];\"fit\"==s.policy||\"max\"==s.policy?n+=s.flex:e-=i.col_widths[t]}if(e-=(s-1)*l,0!=n&&e>0)for(let t=0;t<s;t++){const s=o[t];if(\"fit\"==s.policy||\"max\"==s.policy){const o=g(e*(s.flex/n));e-=o,i.col_widths[t]=o,n-=s.flex}}else if(e<0){let t=0;for(let i=0;i<s;i++){\"fixed\"!=o[i].policy&&t++}let n=-e;for(let e=0;e<s;e++){if(\"fixed\"!=o[e].policy){const s=i.col_widths[e],o=g(n/t);i.col_widths[e]=a(s-o,0),n-=o>s?s:o,t--}}}},c=this._measure_cells(((t,i)=>{const s=e[t],n=o[i];return{width:\"fixed\"==n.policy?n.width:1/0,height:\"fixed\"==s.policy?s.height:1/0}}));r(c),h(c);const p=this._measure_cells(((t,i)=>({width:c.col_widths[i],height:c.row_heights[t]})));r(p),h(p);const{row_heights:f,col_widths:_}=p;return{size:this._measure_totals(f,_),row_heights:f,col_widths:_}}_measure(t){const{size:i}=this._measure_grid(t);return i}_set_geometry(t,i){super._set_geometry(t,i);const{nrows:s,ncols:e,rspacing:o,cspacing:n}=this._state,{row_heights:l,col_widths:r}=this._measure_grid(t),{size_hints:c}=this._measure_cells(((t,i)=>({width:r[i],height:l[t]}))),f=this._state.rows.map(((t,i)=>Object.assign(Object.assign({},t),{top:0,height:l[i],get bottom(){return this.top+this.height}}))),_=this._state.cols.map(((t,i)=>Object.assign(Object.assign({},t),{left:0,width:r[i],get right(){return this.left+this.width}}))),d=c.map(((t,i)=>Object.assign(Object.assign({},i),{outer:new h.BBox,inner:new h.BBox})));for(let i=0,e=this.absolute?t.top:0;i<s;i++){const t=f[i];t.top=e,e+=t.height+o}for(let i=0,s=this.absolute?t.left:0;i<e;i++){const t=_[i];t.left=s,s+=t.width+n}d.foreach((({r0:t,c0:i,r1:s,c1:e},l)=>{const{layout:r,size_hint:c}=l,{sizing:a}=r,{width:p,height:d}=c,u=function(t,i){let s=(i-t)*n;for(let e=t;e<=i;e++)s+=_[e].width;return s}(i,e),w=function(t,i){let s=(i-t)*o;for(let e=t;e<=i;e++)s+=f[e].height;return s}(t,s),m=i==e&&\"auto\"!=_[i].align?_[i].align:a.halign,y=t==s&&\"auto\"!=f[t].align?f[t].align:a.valign;let x=_[i].left;\"start\"==m?x+=a.margin.left:\"center\"==m?x+=g((u-p)/2):\"end\"==m&&(x+=u-a.margin.right-p);let b=f[t].top;\"start\"==y?b+=a.margin.top:\"center\"==y?b+=g((w-d)/2):\"end\"==y&&(b+=w-a.margin.bottom-d),l.outer=new h.BBox({left:x,top:b,width:p,height:d})}));const u=f.map((()=>({start:new p((()=>0)),end:new p((()=>0))}))),w=_.map((()=>({start:new p((()=>0)),end:new p((()=>0))})));d.foreach((({r0:t,c0:i,r1:s,c1:e},{size_hint:o,outer:n})=>{const{inner:l}=o;null!=l&&(u[t].start.apply(n.top,(t=>a(t,l.top))),u[s].end.apply(f[s].bottom-n.bottom,(t=>a(t,l.bottom))),w[i].start.apply(n.left,(t=>a(t,l.left))),w[e].end.apply(_[e].right-n.right,(t=>a(t,l.right))))})),d.foreach((({r0:t,c0:i,r1:s,c1:e},o)=>{const{size_hint:n,outer:l}=o,r=t=>{const i=this.absolute?l:l.relative(),s=i.left+t.left,e=i.top+t.top,o=i.right-t.right,n=i.bottom-t.bottom;return new h.BBox({left:s,top:e,right:o,bottom:n})};if(null!=n.inner){let h=r(n.inner);if(!1!==n.align){const o=u[t].start.get(l.top),n=u[s].end.get(f[s].bottom-l.bottom),c=w[i].start.get(l.left),a=w[e].end.get(_[e].right-l.right);try{h=r({top:o,bottom:n,left:c,right:a})}catch(t){}}o.inner=h}else o.inner=l})),d.foreach(((t,{layout:i,outer:s,inner:e})=>{i.set_geometry(s,e)}))}}s.Grid=_,_.__name__=\"Grid\";class d extends _{constructor(t){super(),this.items=t.map(((t,i)=>({layout:t,row:0,col:i}))),this.rows=\"fit\"}}s.Row=d,d.__name__=\"Row\";class u extends _{constructor(t){super(),this.items=t.map(((t,i)=>({layout:t,row:i,col:0}))),this.cols=\"fit\"}}s.Column=u,u.__name__=\"Column\"},\n",
" function _(e,t,s,n,i){n();const a=e(142),c=e(141),o=e(43);class r extends a.ContentLayoutable{constructor(e){super(),this.content_size=o.unsized(e,(()=>new c.Sizeable(o.size(e))))}_content_size(){return this.content_size}}s.ContentBox=r,r.__name__=\"ContentBox\";class _ extends a.Layoutable{constructor(e){super(),this.el=e}_measure(e){const t=new c.Sizeable(e).bounded_to(this.sizing.size);return o.sized(this.el,t,(()=>{const e=new c.Sizeable(o.content_size(this.el)),{border:t,padding:s}=o.extents(this.el);return e.grow_by(t).grow_by(s).map(Math.ceil)}))}}s.VariadicBox=_,_.__name__=\"VariadicBox\";class h extends _{constructor(e){super(e),this._cache=new Map}_measure(e){const{width:t,height:s}=e,n=`${t},${s}`;let i=this._cache.get(n);return null==i&&(i=super._measure(e),this._cache.set(n,i)),i}invalidate_cache(){this._cache.clear()}}s.CachedVariadicBox=h,h.__name__=\"CachedVariadicBox\"},\n",
" function _(t,e,i,h,o){h();const s=t(141),r=t(142),n=t(99);class g extends r.Layoutable{constructor(){super(...arguments),this.min_border={left:0,top:0,right:0,bottom:0},this.padding={left:0,top:0,right:0,bottom:0}}*[Symbol.iterator](){yield this.top_panel,yield this.bottom_panel,yield this.left_panel,yield this.right_panel,yield this.center_panel}_measure(t){t=new s.Sizeable({width:\"fixed\"==this.sizing.width_policy||t.width==1/0?this.sizing.width:t.width,height:\"fixed\"==this.sizing.height_policy||t.height==1/0?this.sizing.height:t.height});const e=this.left_panel.measure({width:0,height:t.height}),i=Math.max(e.width,this.min_border.left)+this.padding.left,h=this.right_panel.measure({width:0,height:t.height}),o=Math.max(h.width,this.min_border.right)+this.padding.right,r=this.top_panel.measure({width:t.width,height:0}),n=Math.max(r.height,this.min_border.top)+this.padding.top,g=this.bottom_panel.measure({width:t.width,height:0}),a=Math.max(g.height,this.min_border.bottom)+this.padding.bottom,d=new s.Sizeable(t).shrink_by({left:i,right:o,top:n,bottom:a}),l=this.center_panel.measure(d);return{width:i+l.width+o,height:n+l.height+a,inner:{left:i,right:o,top:n,bottom:a},align:(()=>{const{width_policy:t,height_policy:e}=this.center_panel.sizing;return\"fixed\"!=t&&\"fixed\"!=e})()}}_set_geometry(t,e){super._set_geometry(t,e),this.center_panel.set_geometry(e);const i=this.left_panel.measure({width:0,height:t.height}),h=this.right_panel.measure({width:0,height:t.height}),o=this.top_panel.measure({width:t.width,height:0}),s=this.bottom_panel.measure({width:t.width,height:0}),{left:r,top:g,right:a,bottom:d}=e;this.top_panel.set_geometry(new n.BBox({left:r,right:a,bottom:g,height:o.height})),this.bottom_panel.set_geometry(new n.BBox({left:r,right:a,top:d,height:s.height})),this.left_panel.set_geometry(new n.BBox({top:g,bottom:d,right:r,width:i.width})),this.right_panel.set_geometry(new n.BBox({top:g,bottom:d,left:a,width:h.width}))}}i.BorderLayout=g,g.__name__=\"BorderLayout\"},\n",
" function _(t,e,i,s,n){s();const o=t(1),l=t(139),a=t(10),_=t(143),d=t(20),h=o.__importStar(t(48));class r extends l.TextAnnotationView{_get_size(){const{ctx:t}=this.layer;this.visuals.text.set_value(t);const{width:e}=t.measureText(this.model.text),{height:i}=_.font_metrics(t.font);return{width:e,height:i}}_render(){const{angle:t,angle_units:e}=this.model,i=a.resolve_angle(t,e),s=null!=this.layout?this.layout:this.plot_view.frame,n=this.coordinates.x_scale,o=this.coordinates.y_scale;let l=\"data\"==this.model.x_units?n.compute(this.model.x):s.bbox.xview.compute(this.model.x),_=\"data\"==this.model.y_units?o.compute(this.model.y):s.bbox.yview.compute(this.model.y);l+=this.model.x_offset,_-=this.model.y_offset;(\"canvas\"==this.model.render_mode?this._canvas_text.bind(this):this._css_text.bind(this))(this.layer.ctx,this.model.text,l,_,i)}}i.LabelView=r,r.__name__=\"LabelView\";class c extends l.TextAnnotation{constructor(t){super(t)}static init_Label(){this.prototype.default_view=r,this.mixins([h.Text,[\"border_\",h.Line],[\"background_\",h.Fill]]),this.define((({Number:t,String:e,Angle:i})=>({x:[t],x_units:[d.SpatialUnits,\"data\"],y:[t],y_units:[d.SpatialUnits,\"data\"],text:[e,\"\"],angle:[i,0],angle_units:[d.AngleUnits,\"rad\"],x_offset:[t,0],y_offset:[t,0]}))),this.override({background_fill_color:null,border_line_color:null})}}i.Label=c,c.__name__=\"Label\",c.init_Label()},\n",
" function _(t,e,s,i,o){i();const l=t(1),n=t(139),a=t(56),r=t(130),_=l.__importStar(t(48)),c=t(20),h=t(43),d=l.__importStar(t(18)),u=t(143);class x extends n.TextAnnotationView{set_data(t){a.DataAnnotationView.prototype.set_data.call(this,t)}initialize(){if(super.initialize(),this.set_data(this.model.source),\"css\"==this.model.render_mode)for(let t=0,e=this.text.length;t<e;t++){const t=h.div({style:{display:\"none\"}});this.el.appendChild(t)}}connect_signals(){super.connect_signals();const t=()=>{this.set_data(this.model.source),\"css\"==this.model.render_mode?this.render():this.request_render()};this.connect(this.model.change,t),this.connect(this.model.source.streaming,t),this.connect(this.model.source.patching,t),this.connect(this.model.source.change,t)}_calculate_text_dimensions(t,e){const{width:s}=t.measureText(e),{height:i}=u.font_metrics(this.visuals.text.font_value(0));return[s,i]}_map_data(){const t=this.coordinates.x_scale,e=this.coordinates.y_scale,s=null!=this.layout?this.layout:this.plot_view.frame;return[\"data\"==this.model.x_units?t.v_compute(this._x):s.bbox.xview.v_compute(this._x),\"data\"==this.model.y_units?e.v_compute(this._y):s.bbox.yview.v_compute(this._y)]}_render(){const t=\"canvas\"==this.model.render_mode?this._v_canvas_text.bind(this):this._v_css_text.bind(this),{ctx:e}=this.layer,[s,i]=this._map_data();for(let o=0,l=this.text.length;o<l;o++)t(e,o,this.text.get(o),s[o]+this.x_offset.get(o),i[o]-this.y_offset.get(o),this.angle.get(o))}_get_size(){const{ctx:t}=this.layer;this.visuals.text.set_vectorize(t,0);const{width:e}=t.measureText(this.text.get(0)),{height:s}=u.font_metrics(t.font);return{width:e,height:s}}_v_canvas_text(t,e,s,i,o,l){this.visuals.text.set_vectorize(t,e);const n=this._calculate_bounding_box_dimensions(t,s);t.save(),t.beginPath(),t.translate(i,o),t.rotate(l),t.rect(n[0],n[1],n[2],n[3]),this.visuals.background_fill.doit&&(this.visuals.background_fill.set_vectorize(t,e),t.fill()),this.visuals.border_line.doit&&(this.visuals.border_line.set_vectorize(t,e),t.stroke()),this.visuals.text.doit&&(this.visuals.text.set_vectorize(t,e),t.fillText(s,0,0)),t.restore()}_v_css_text(t,e,s,i,o,l){const n=this.el.children[e];n.textContent=s,this.visuals.text.set_vectorize(t,e);const[a,r]=this._calculate_bounding_box_dimensions(t,s);n.style.position=\"absolute\",n.style.left=`${i+a}px`,n.style.top=`${o+r}px`,n.style.color=t.fillStyle,n.style.font=t.font,n.style.lineHeight=\"normal\",l&&(n.style.transform=`rotate(${l}rad)`),this.visuals.background_fill.doit&&(this.visuals.background_fill.set_vectorize(t,e),n.style.backgroundColor=t.fillStyle),this.visuals.border_line.doit&&(this.visuals.border_line.set_vectorize(t,e),n.style.borderStyle=t.lineDash.length<2?\"solid\":\"dashed\",n.style.borderWidth=`${t.lineWidth}px`,n.style.borderColor=t.strokeStyle),h.display(n)}}s.LabelSetView=x,x.__name__=\"LabelSetView\";class v extends n.TextAnnotation{constructor(t){super(t)}static init_LabelSet(){this.prototype.default_view=x,this.mixins([_.TextVector,[\"border_\",_.LineVector],[\"background_\",_.FillVector]]),this.define((({Ref:t})=>({x:[d.XCoordinateSpec,{field:\"x\"}],y:[d.YCoordinateSpec,{field:\"y\"}],x_units:[c.SpatialUnits,\"data\"],y_units:[c.SpatialUnits,\"data\"],text:[d.StringSpec,{field:\"text\"}],angle:[d.AngleSpec,0],x_offset:[d.NumberSpec,{value:0}],y_offset:[d.NumberSpec,{value:0}],source:[t(r.ColumnDataSource),()=>new r.ColumnDataSource]}))),this.override({background_fill_color:null,border_line_color:null})}}s.LabelSet=v,v.__name__=\"LabelSet\",v.init_LabelSet()},\n",
" function _(t,e,i,s,l){s();const n=t(1),h=t(40),o=t(229),a=t(20),_=n.__importStar(t(48)),r=t(15),d=t(140),c=t(143),g=t(99),m=t(9),b=t(8),f=t(11);class u extends h.AnnotationView{update_layout(){const{panel:t}=this;this.layout=null!=t?new d.SideLayout(t,(()=>this.get_size())):void 0}cursor(t,e){return\"none\"==this.model.click_policy?null:\"pointer\"}get legend_padding(){return null!=this.model.border_line_color?this.model.padding:0}connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.request_render())),this.connect(this.model.item_change,(()=>this.request_render()))}compute_legend_bbox(){const t=this.model.get_legend_names(),{glyph_height:e,glyph_width:i}=this.model,{label_height:s,label_width:l}=this.model;this.max_label_height=m.max([c.font_metrics(this.visuals.label_text.font_value()).height,s,e]);const{ctx:n}=this.layer;n.save(),this.visuals.label_text.set_value(n),this.text_widths=new Map;for(const e of t)this.text_widths.set(e,m.max([n.measureText(e).width,l]));this.visuals.title_text.set_value(n),this.title_height=this.model.title?c.font_metrics(this.visuals.title_text.font_value()).height+this.model.title_standoff:0,this.title_width=this.model.title?n.measureText(this.model.title).width:0,n.restore();const h=Math.max(m.max([...this.text_widths.values()]),0),o=this.model.margin,{legend_padding:a}=this,_=this.model.spacing,{label_standoff:r}=this.model;let d,u;if(\"vertical\"==this.model.orientation)d=t.length*this.max_label_height+Math.max(t.length-1,0)*_+2*a+this.title_height,u=m.max([h+i+r+2*a,this.title_width+2*a]);else{let e=2*a+Math.max(t.length-1,0)*_;for(const[,t]of this.text_widths)e+=m.max([t,l])+i+r;u=m.max([this.title_width+2*a,e]),d=this.max_label_height+this.title_height+2*a}const x=null!=this.layout?this.layout:this.plot_view.frame,[p,w]=x.bbox.ranges,{location:v}=this.model;let y,k;if(b.isString(v))switch(v){case\"top_left\":y=p.start+o,k=w.start+o;break;case\"top\":case\"top_center\":y=(p.end+p.start)/2-u/2,k=w.start+o;break;case\"top_right\":y=p.end-o-u,k=w.start+o;break;case\"bottom_right\":y=p.end-o-u,k=w.end-o-d;break;case\"bottom\":case\"bottom_center\":y=(p.end+p.start)/2-u/2,k=w.end-o-d;break;case\"bottom_left\":y=p.start+o,k=w.end-o-d;break;case\"left\":case\"center_left\":y=p.start+o,k=(w.end+w.start)/2-d/2;break;case\"center\":case\"center_center\":y=(p.end+p.start)/2-u/2,k=(w.end+w.start)/2-d/2;break;case\"right\":case\"center_right\":y=p.end-o-u,k=(w.end+w.start)/2-d/2}else if(b.isArray(v)&&2==v.length){const[t,e]=v;y=x.bbox.xview.compute(t),k=x.bbox.yview.compute(e)-d}else f.unreachable();return new g.BBox({left:y,top:k,width:u,height:d})}interactive_bbox(){return this.compute_legend_bbox()}interactive_hit(t,e){return this.interactive_bbox().contains(t,e)}on_hit(t,e){let i;const{glyph_width:s}=this.model,{legend_padding:l}=this,n=this.model.spacing,{label_standoff:h}=this.model;let o=i=l;const a=this.compute_legend_bbox(),_=\"vertical\"==this.model.orientation;for(const r of this.model.items){const d=r.get_labels_list_from_label_prop();for(const c of d){const d=a.x+o,m=a.y+i+this.title_height;let b,f;[b,f]=_?[a.width-2*l,this.max_label_height]:[this.text_widths.get(c)+s+h,this.max_label_height];if(new g.BBox({left:d,top:m,width:b,height:f}).contains(t,e)){switch(this.model.click_policy){case\"hide\":for(const t of r.renderers)t.visible=!t.visible;break;case\"mute\":for(const t of r.renderers)t.muted=!t.muted}return!0}_?i+=this.max_label_height+n:o+=this.text_widths.get(c)+s+h+n}}return!1}_render(){if(0==this.model.items.length)return;for(const t of this.model.items)t.legend=this.model;const{ctx:t}=this.layer,e=this.compute_legend_bbox();t.save(),this._draw_legend_box(t,e),this._draw_legend_items(t,e),this._draw_title(t,e),t.restore()}_draw_legend_box(t,e){t.beginPath(),t.rect(e.x,e.y,e.width,e.height),this.visuals.background_fill.set_value(t),t.fill(),this.visuals.border_line.doit&&(this.visuals.border_line.set_value(t),t.stroke())}_draw_legend_items(t,e){const{glyph_width:i,glyph_height:s}=this.model,{legend_padding:l}=this,n=this.model.spacing,{label_standoff:h}=this.model;let o=l,a=l;const _=\"vertical\"==this.model.orientation;for(const r of this.model.items){const d=r.get_labels_list_from_label_prop(),c=r.get_field_from_label_prop();if(0==d.length)continue;const g=(()=>{switch(this.model.click_policy){case\"none\":return!0;case\"hide\":return m.every(r.renderers,(t=>t.visible));case\"mute\":return m.every(r.renderers,(t=>!t.muted))}})();for(const m of d){const d=e.x+o,b=e.y+a+this.title_height,f=d+i,u=b+s;_?a+=this.max_label_height+n:o+=this.text_widths.get(m)+i+h+n,this.visuals.label_text.set_value(t),t.fillText(m,f+h,b+this.max_label_height/2);for(const e of r.renderers){const i=this.plot_view.renderer_view(e);null==i||i.draw_legend(t,d,f,b,u,c,m,r.index)}if(!g){let s,n;[s,n]=_?[e.width-2*l,this.max_label_height]:[this.text_widths.get(m)+i+h,this.max_label_height],t.beginPath(),t.rect(d,b,s,n),this.visuals.inactive_fill.set_value(t),t.fill()}}}}_draw_title(t,e){const{title:i}=this.model;i&&this.visuals.title_text.doit&&(t.save(),t.translate(e.x0,e.y0+this.title_height),this.visuals.title_text.set_value(t),t.fillText(i,this.legend_padding,this.legend_padding-this.model.title_standoff),t.restore())}_get_size(){const{width:t,height:e}=this.compute_legend_bbox();return{width:t+2*this.model.margin,height:e+2*this.model.margin}}}i.LegendView=u,u.__name__=\"LegendView\";class x extends h.Annotation{constructor(t){super(t)}initialize(){super.initialize(),this.item_change=new r.Signal0(this,\"item_change\")}static init_Legend(){this.prototype.default_view=u,this.mixins([[\"label_\",_.Text],[\"title_\",_.Text],[\"inactive_\",_.Fill],[\"border_\",_.Line],[\"background_\",_.Fill]]),this.define((({Number:t,String:e,Array:i,Tuple:s,Or:l,Ref:n,Nullable:h})=>({orientation:[a.Orientation,\"vertical\"],location:[l(a.LegendLocation,s(t,t)),\"top_right\"],title:[h(e),null],title_standoff:[t,5],label_standoff:[t,5],glyph_height:[t,20],glyph_width:[t,20],label_height:[t,20],label_width:[t,20],margin:[t,10],padding:[t,10],spacing:[t,3],items:[i(n(o.LegendItem)),[]],click_policy:[a.LegendClickPolicy,\"none\"]}))),this.override({border_line_color:\"#e5e5e5\",border_line_alpha:.5,border_line_width:1,background_fill_color:\"#ffffff\",background_fill_alpha:.95,inactive_fill_color:\"white\",inactive_fill_alpha:.7,label_text_font_size:\"13px\",label_text_baseline:\"middle\",title_text_font_size:\"13px\",title_text_font_style:\"italic\"})}get_legend_names(){const t=[];for(const e of this.items){const i=e.get_labels_list_from_label_prop();t.push(...i)}return t}}i.Legend=x,x.__name__=\"Legend\",x.init_Legend()},\n",
" function _(e,r,n,l,t){l();const i=e(1),s=e(53),o=e(61),_=e(57),a=e(230),u=i.__importStar(e(18)),d=e(19),c=e(9);class f extends s.Model{constructor(e){super(e)}static init_LegendItem(){this.define((({Int:e,Array:r,Ref:n,Nullable:l})=>({label:[u.NullStringSpec,null],renderers:[r(n(o.GlyphRenderer)),[]],index:[l(e),null]})))}_check_data_sources_on_renderers(){if(null!=this.get_field_from_label_prop()){if(this.renderers.length<1)return!1;const e=this.renderers[0].data_source;if(null!=e)for(const r of this.renderers)if(r.data_source!=e)return!1}return!0}_check_field_label_on_data_source(){const e=this.get_field_from_label_prop();if(null!=e){if(this.renderers.length<1)return!1;const r=this.renderers[0].data_source;if(null!=r&&!c.includes(r.columns(),e))return!1}return!0}initialize(){super.initialize(),this.legend=null,this.connect(this.change,(()=>{var e;return null===(e=this.legend)||void 0===e?void 0:e.item_change.emit()}));this._check_data_sources_on_renderers()||d.logger.error(\"Non matching data sources on legend item renderers\");this._check_field_label_on_data_source()||d.logger.error(`Bad column name on label: ${this.label}`)}get_field_from_label_prop(){const{label:e}=this;return a.isField(e)?e.field:null}get_labels_list_from_label_prop(){if(a.isValue(this.label)){const{value:e}=this.label;return null!=e?[e]:[]}const e=this.get_field_from_label_prop();if(null!=e){let r;if(!this.renderers[0]||null==this.renderers[0].data_source)return[\"No source found\"];if(r=this.renderers[0].data_source,r instanceof _.ColumnarDataSource){const n=r.get_column(e);return null!=n?c.uniq(Array.from(n)):[\"Invalid field\"]}}return[]}}n.LegendItem=f,f.__name__=\"LegendItem\",f.init_LegendItem()},\n",
" function _(i,n,e,t,u){t();const c=i(8);e.isValue=function(i){return c.isPlainObject(i)&&\"value\"in i},e.isField=function(i){return c.isPlainObject(i)&&\"field\"in i},e.isExpr=function(i){return c.isPlainObject(i)&&\"expr\"in i}},\n",
" function _(t,i,s,n,e){n();const o=t(1),l=t(40),a=o.__importStar(t(48)),c=t(20);class h extends l.AnnotationView{connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.request_render()))}_render(){const{xs:t,ys:i}=this.model;if(t.length!=i.length)return;const s=t.length;if(s<3)return;const{frame:n}=this.plot_view,{ctx:e}=this.layer,o=this.coordinates.x_scale,l=this.coordinates.y_scale,{screen:a}=this.model;function c(t,i,s,n){return a?t:\"data\"==i?s.v_compute(t):n.v_compute(t)}const h=c(t,this.model.xs_units,o,n.bbox.xview),r=c(i,this.model.ys_units,l,n.bbox.yview);e.beginPath();for(let t=0;t<s;t++)e.lineTo(h[t],r[t]);e.closePath(),this.visuals.fill.doit&&(this.visuals.fill.set_value(e),e.fill()),this.visuals.hatch.doit&&(this.visuals.hatch.set_value(e),e.fill()),this.visuals.line.doit&&(this.visuals.line.set_value(e),e.stroke())}}s.PolyAnnotationView=h,h.__name__=\"PolyAnnotationView\";class r extends l.Annotation{constructor(t){super(t)}static init_PolyAnnotation(){this.prototype.default_view=h,this.mixins([a.Line,a.Fill,a.Hatch]),this.define((({Number:t,Array:i})=>({xs:[i(t),[]],xs_units:[c.SpatialUnits,\"data\"],ys:[i(t),[]],ys_units:[c.SpatialUnits,\"data\"]}))),this.internal((({Boolean:t})=>({screen:[t,!1]}))),this.override({fill_color:\"#fff9ba\",fill_alpha:.4,line_color:\"#cccccc\",line_alpha:.3})}update({xs:t,ys:i}){this.setv({xs:t,ys:i,screen:!0},{check_eq:!1})}}s.PolyAnnotation=r,r.__name__=\"PolyAnnotation\",r.init_PolyAnnotation()},\n",
" function _(e,t,i,n,o){n();const s=e(1),l=e(40),r=s.__importStar(e(48));class c extends l.AnnotationView{connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.request_render()))}_render(){const{gradient:e,y_intercept:t}=this.model;if(null==e||null==t)return;const{frame:i}=this.plot_view,n=this.coordinates.x_scale,o=this.coordinates.y_scale;let s,l,r,c;if(0==e)s=o.compute(t),l=s,r=i.bbox.left,c=r+i.bbox.width;else{s=i.bbox.top,l=s+i.bbox.height;const a=(o.invert(s)-t)/e,_=(o.invert(l)-t)/e;r=n.compute(a),c=n.compute(_)}const{ctx:a}=this.layer;a.save(),a.beginPath(),this.visuals.line.set_value(a),a.moveTo(r,s),a.lineTo(c,l),a.stroke(),a.restore()}}i.SlopeView=c,c.__name__=\"SlopeView\";class a extends l.Annotation{constructor(e){super(e)}static init_Slope(){this.prototype.default_view=c,this.mixins(r.Line),this.define((({Number:e,Nullable:t})=>({gradient:[t(e),null],y_intercept:[t(e),null]}))),this.override({line_color:\"black\"})}}i.Slope=a,a.__name__=\"Slope\",a.init_Slope()},\n",
" function _(e,i,t,n,o){n();const s=e(1),a=e(40),l=s.__importStar(e(48)),h=e(20);class c extends a.AnnotationView{connect_signals(){super.connect_signals(),this.connect(this.model.change,(()=>this.plot_view.request_paint(this)))}_render(){const{location:e}=this.model;if(null==e)return;const{frame:i}=this.plot_view,t=this.coordinates.x_scale,n=this.coordinates.y_scale,o=(i,t)=>\"data\"==this.model.location_units?i.compute(e):this.model.for_hover?e:t.compute(e);let s,a,l,h;\"width\"==this.model.dimension?(l=o(n,i.bbox.yview),a=i.bbox.left,h=i.bbox.width,s=this.model.line_width):(l=i.bbox.top,a=o(t,i.bbox.xview),h=this.model.line_width,s=i.bbox.height);const{ctx:c}=this.layer;c.save(),c.beginPath(),this.visuals.line.set_value(c),c.moveTo(a,l),\"width\"==this.model.dimension?c.lineTo(a+h,l):c.lineTo(a,l+s),c.stroke(),c.restore()}}t.SpanView=c,c.__name__=\"SpanView\";class d extends a.Annotation{constructor(e){super(e)}static init_Span(){this.prototype.default_view=c,this.mixins(l.Line),this.define((({Number:e,Nullable:i})=>({render_mode:[h.RenderMode,\"canvas\"],location:[i(e),null],location_units:[h.SpatialUnits,\"data\"],dimension:[h.Dimension,\"width\"]}))),this.internal((({Boolean:e})=>({for_hover:[e,!1]}))),this.override({line_color:\"black\"})}}t.Span=d,d.__name__=\"Span\",d.init_Span()},\n",
" function _(i,e,t,o,l){o();const s=i(40),a=i(235),n=i(122),r=i(43),_=i(140),h=i(99);class b extends s.AnnotationView{constructor(){super(...arguments),this._invalidate_toolbar=!0,this._previous_bbox=new h.BBox}update_layout(){this.layout=new _.SideLayout(this.panel,(()=>this.get_size()),!0)}initialize(){super.initialize(),this.el=r.div(),this.plot_view.canvas_view.add_event(this.el)}async lazy_initialize(){await super.lazy_initialize(),this._toolbar_view=await n.build_view(this.model.toolbar,{parent:this}),this.plot_view.visibility_callbacks.push((i=>this._toolbar_view.set_visibility(i)))}remove(){this._toolbar_view.remove(),r.remove(this.el),super.remove()}render(){this.model.visible||r.undisplay(this.el),super.render()}_render(){const{bbox:i}=this.layout;this._previous_bbox.equals(i)||(r.position(this.el,i),this._previous_bbox=i),this._invalidate_toolbar&&(this.el.style.position=\"absolute\",this.el.style.overflow=\"hidden\",this._toolbar_view.render(),r.empty(this.el),this.el.appendChild(this._toolbar_view.el),this._invalidate_toolbar=!1),r.display(this.el)}_get_size(){const{tools:i,logo:e}=this.model.toolbar;return{width:30*i.length+(null!=e?25:0),height:30}}}t.ToolbarPanelView=b,b.__name__=\"ToolbarPanelView\";class d extends s.Annotation{constructor(i){super(i)}static init_ToolbarPanel(){this.prototype.default_view=b,this.define((({Ref:i})=>({toolbar:[i(a.Toolbar)]})))}}t.ToolbarPanel=d,d.__name__=\"ToolbarPanel\",d.init_ToolbarPanel()},\n",
" function _(t,s,e,i,o){i();const c=t(8),n=t(9),a=t(13),l=t(236),r=t(237),_=t(247),p=t(248);e.Drag=l.Tool,e.Inspection=l.Tool,e.Scroll=l.Tool,e.Tap=l.Tool;const u=t=>{switch(t){case\"tap\":return\"active_tap\";case\"pan\":return\"active_drag\";case\"pinch\":case\"scroll\":return\"active_scroll\";case\"multi\":return\"active_multi\"}return null},h=t=>\"tap\"==t||\"pan\"==t;class v extends p.ToolbarBase{constructor(t){super(t)}static init_Toolbar(){this.prototype.default_view=p.ToolbarBaseView,this.define((({Or:t,Ref:s,Auto:i,Null:o,Nullable:c})=>({active_drag:[t(s(e.Drag),i,o),\"auto\"],active_inspect:[t(s(e.Inspection),i,o),\"auto\"],active_scroll:[t(s(e.Scroll),i,o),\"auto\"],active_tap:[t(s(e.Tap),i,o),\"auto\"],active_multi:[c(s(r.GestureTool)),null]})))}connect_signals(){super.connect_signals();const{tools:t,active_drag:s,active_inspect:e,active_scroll:i,active_tap:o,active_multi:c}=this.properties;this.on_change([t,s,e,i,o,c],(()=>this._init_tools()))}_init_tools(){if(super._init_tools(),\"auto\"==this.active_inspect);else if(this.active_inspect instanceof _.InspectTool){let t=!1;for(const s of this.inspectors)s!=this.active_inspect?s.active=!1:t=!0;t||(this.active_inspect=null)}else if(c.isArray(this.active_inspect)){const t=n.intersection(this.active_inspect,this.inspectors);t.length!=this.active_inspect.length&&(this.active_inspect=t);for(const t of this.inspectors)n.includes(this.active_inspect,t)||(t.active=!1)}else if(null==this.active_inspect)for(const t of this.inspectors)t.active=!1;const t=t=>{t.active?this._active_change(t):t.active=!0};for(const t of a.values(this.gestures)){t.tools=n.sort_by(t.tools,(t=>t.default_order));for(const s of t.tools)this.connect(s.properties.active.change,(()=>this._active_change(s)))}for(const[s,e]of a.entries(this.gestures)){const i=u(s);if(i){const o=this[i];\"auto\"==o?0!=e.tools.length&&h(s)&&t(e.tools[0]):null!=o&&(n.includes(this.tools,o)?t(o):this[i]=null)}}}}e.Toolbar=v,v.__name__=\"Toolbar\",v.init_Toolbar()},\n",
" function _(t,e,n,i,o){i();const s=t(42),a=t(9),r=t(53);class l extends s.View{get plot_view(){return this.parent}get plot_model(){return this.parent.model}connect_signals(){super.connect_signals(),this.connect(this.model.properties.active.change,(()=>{this.model.active?this.activate():this.deactivate()}))}activate(){}deactivate(){}}n.ToolView=l,l.__name__=\"ToolView\";class _ extends r.Model{constructor(t){super(t)}static init_Tool(){this.prototype._known_aliases=new Map,this.define((({String:t,Nullable:e})=>({description:[e(t),null]}))),this.internal((({Boolean:t})=>({active:[t,!1]})))}get synthetic_renderers(){return[]}_get_dim_limits([t,e],[n,i],o,s){const r=o.bbox.h_range;let l;\"width\"==s||\"both\"==s?(l=[a.min([t,n]),a.max([t,n])],l=[a.max([l[0],r.start]),a.min([l[1],r.end])]):l=[r.start,r.end];const _=o.bbox.v_range;let c;return\"height\"==s||\"both\"==s?(c=[a.min([e,i]),a.max([e,i])],c=[a.max([c[0],_.start]),a.min([c[1],_.end])]):c=[_.start,_.end],[l,c]}static register_alias(t,e){this.prototype._known_aliases.set(t,e)}static from_string(t){const e=this.prototype._known_aliases.get(t);if(null!=e)return e();{const e=[...this.prototype._known_aliases.keys()];throw new Error(`unexpected tool name '${t}', possible tools are ${e.join(\", \")}`)}}}n.Tool=_,_.__name__=\"Tool\",_.init_Tool()},\n",
" function _(e,o,t,s,n){s();const u=e(238),_=e(246);class l extends u.ButtonToolView{}t.GestureToolView=l,l.__name__=\"GestureToolView\";class i extends u.ButtonTool{constructor(e){super(e),this.button_view=_.OnOffButtonView}}t.GestureTool=i,i.__name__=\"GestureTool\"},\n",
" function _(t,e,o,i,s){i();const n=t(1),l=n.__importDefault(t(239)),r=t(240),a=t(236),u=t(43),h=t(34),_=t(8),c=t(9),d=n.__importStar(t(241)),m=d,p=n.__importDefault(t(242)),g=n.__importDefault(t(243)),v=t(244);class f extends r.DOMView{initialize(){super.initialize();const t=this.model.menu;if(null!=t){const e=this.parent.model.toolbar_location,o=\"left\"==e||\"above\"==e,i=this.parent.model.horizontal?\"vertical\":\"horizontal\";this._menu=new v.ContextMenu(o?c.reversed(t):t,{orientation:i,prevent_hide:t=>t.target==this.el})}this._hammer=new l.default(this.el,{touchAction:\"auto\",inputClass:l.default.TouchMouseInput}),this.connect(this.model.change,(()=>this.render())),this._hammer.on(\"tap\",(t=>{var e;(null===(e=this._menu)||void 0===e?void 0:e.is_open)?this._menu.hide():t.target==this.el&&this._clicked()})),this._hammer.on(\"press\",(()=>this._pressed()))}remove(){var t;this._hammer.destroy(),null===(t=this._menu)||void 0===t||t.remove(),super.remove()}styles(){return[...super.styles(),d.default,p.default,g.default]}css_classes(){return super.css_classes().concat(m.toolbar_button)}render(){u.empty(this.el);const t=this.model.computed_icon;_.isString(t)&&(h.startsWith(t,\"data:image\")?this.el.style.backgroundImage=\"url('\"+t+\"')\":this.el.classList.add(t)),this.el.title=this.model.tooltip,null!=this._menu&&this.root.el.appendChild(this._menu.el)}_pressed(){var t;const{left:e,top:o,right:i,bottom:s}=this.el.getBoundingClientRect(),n=(()=>{switch(this.parent.model.toolbar_location){case\"right\":return{right:e,top:o};case\"left\":return{left:i,top:o};case\"above\":return{left:e,top:s};case\"below\":return{left:e,bottom:o}}})();null===(t=this._menu)||void 0===t||t.toggle(n)}}o.ButtonToolButtonView=f,f.__name__=\"ButtonToolButtonView\";class b extends a.ToolView{}o.ButtonToolView=b,b.__name__=\"ButtonToolView\";class B extends a.Tool{constructor(t){super(t)}static init_ButtonTool(){this.internal((({Boolean:t})=>({disabled:[t,!1]})))}_get_dim_tooltip(t){const{description:e,tool_name:o}=this;return null!=e?e:\"both\"==t?o:`${o} (${\"width\"==t?\"x\":\"y\"}-axis)`}get tooltip(){var t;return null!==(t=this.description)&&void 0!==t?t:this.tool_name}get computed_icon(){return this.icon}get menu(){return null}}o.ButtonTool=B,B.__name__=\"ButtonTool\",B.init_ButtonTool()},\n",
" function _(t,e,i,n,r){\n",
" /*! Hammer.JS - v2.0.7 - 2016-04-22\n",
" * http://hammerjs.github.io/\n",
" *\n",
" * Copyright (c) 2016 Jorik Tangelder;\n",
" * Licensed under the MIT license */\n",
" !function(t,i,n,r){\"use strict\";var s,o=[\"\",\"webkit\",\"Moz\",\"MS\",\"ms\",\"o\"],a=i.createElement(\"div\"),h=Math.round,u=Math.abs,c=Date.now;function l(t,e,i){return setTimeout(T(t,i),e)}function p(t,e,i){return!!Array.isArray(t)&&(f(t,i[e],i),!0)}function f(t,e,i){var n;if(t)if(t.forEach)t.forEach(e,i);else if(t.length!==r)for(n=0;n<t.length;)e.call(i,t[n],n,t),n++;else for(n in t)t.hasOwnProperty(n)&&e.call(i,t[n],n,t)}function v(e,i,n){var r=\"DEPRECATED METHOD: \"+i+\"\\n\"+n+\" AT \\n\";return function(){var i=new Error(\"get-stack-trace\"),n=i&&i.stack?i.stack.replace(/^[^\\(]+?[\\n$]/gm,\"\").replace(/^\\s+at\\s+/gm,\"\").replace(/^Object.<anonymous>\\s*\\(/gm,\"{anonymous}()@\"):\"Unknown Stack Trace\",s=t.console&&(t.console.warn||t.console.log);return s&&s.call(t.console,r,n),e.apply(this,arguments)}}s=\"function\"!=typeof Object.assign?function(t){if(t===r||null===t)throw new TypeError(\"Cannot convert undefined or null to object\");for(var e=Object(t),i=1;i<arguments.length;i++){var n=arguments[i];if(n!==r&&null!==n)for(var s in n)n.hasOwnProperty(s)&&(e[s]=n[s])}return e}:Object.assign;var d=v((function(t,e,i){for(var n=Object.keys(e),s=0;s<n.length;)(!i||i&&t[n[s]]===r)&&(t[n[s]]=e[n[s]]),s++;return t}),\"extend\",\"Use `assign`.\"),m=v((function(t,e){return d(t,e,!0)}),\"merge\",\"Use `assign`.\");function g(t,e,i){var n,r=e.prototype;(n=t.prototype=Object.create(r)).constructor=t,n._super=r,i&&s(n,i)}function T(t,e){return function(){return t.apply(e,arguments)}}function y(t,e){return\"function\"==typeof t?t.apply(e&&e[0]||r,e):t}function E(t,e){return t===r?e:t}function I(t,e,i){f(S(e),(function(e){t.addEventListener(e,i,!1)}))}function A(t,e,i){f(S(e),(function(e){t.removeEventListener(e,i,!1)}))}function _(t,e){for(;t;){if(t==e)return!0;t=t.parentNode}return!1}function C(t,e){return t.indexOf(e)>-1}function S(t){return t.trim().split(/\\s+/g)}function b(t,e,i){if(t.indexOf&&!i)return t.indexOf(e);for(var n=0;n<t.length;){if(i&&t[n][i]==e||!i&&t[n]===e)return n;n++}return-1}function P(t){return Array.prototype.slice.call(t,0)}function D(t,e,i){for(var n=[],r=[],s=0;s<t.length;){var o=e?t[s][e]:t[s];b(r,o)<0&&n.push(t[s]),r[s]=o,s++}return i&&(n=e?n.sort((function(t,i){return t[e]>i[e]})):n.sort()),n}function x(t,e){for(var i,n,s=e[0].toUpperCase()+e.slice(1),a=0;a<o.length;){if((n=(i=o[a])?i+s:e)in t)return n;a++}return r}var w=1;function O(e){var i=e.ownerDocument||e;return i.defaultView||i.parentWindow||t}var R=\"ontouchstart\"in t,M=x(t,\"PointerEvent\")!==r,z=R&&/mobile|tablet|ip(ad|hone|od)|android/i.test(navigator.userAgent),N=\"touch\",X=\"mouse\",Y=24,F=[\"x\",\"y\"],W=[\"clientX\",\"clientY\"];function q(t,e){var i=this;this.manager=t,this.callback=e,this.element=t.element,this.target=t.options.inputTarget,this.domHandler=function(e){y(t.options.enable,[t])&&i.handler(e)},this.init()}function k(t,e,i){var n=i.pointers.length,s=i.changedPointers.length,o=1&e&&n-s==0,a=12&e&&n-s==0;i.isFirst=!!o,i.isFinal=!!a,o&&(t.session={}),i.eventType=e,function(t,e){var i=t.session,n=e.pointers,s=n.length;i.firstInput||(i.firstInput=H(e));s>1&&!i.firstMultiple?i.firstMultiple=H(e):1===s&&(i.firstMultiple=!1);var o=i.firstInput,a=i.firstMultiple,h=a?a.center:o.center,l=e.center=L(n);e.timeStamp=c(),e.deltaTime=e.timeStamp-o.timeStamp,e.angle=G(h,l),e.distance=j(h,l),function(t,e){var i=e.center,n=t.offsetDelta||{},r=t.prevDelta||{},s=t.prevInput||{};1!==e.eventType&&4!==s.eventType||(r=t.prevDelta={x:s.deltaX||0,y:s.deltaY||0},n=t.offsetDelta={x:i.x,y:i.y});e.deltaX=r.x+(i.x-n.x),e.deltaY=r.y+(i.y-n.y)}(i,e),e.offsetDirection=V(e.deltaX,e.deltaY);var p=U(e.deltaTime,e.deltaX,e.deltaY);e.overallVelocityX=p.x,e.overallVelocityY=p.y,e.overallVelocity=u(p.x)>u(p.y)?p.x:p.y,e.scale=a?(f=a.pointers,v=n,j(v[0],v[1],W)/j(f[0],f[1],W)):1,e.rotation=a?function(t,e){return G(e[1],e[0],W)+G(t[1],t[0],W)}(a.pointers,n):0,e.maxPointers=i.prevInput?e.pointers.length>i.prevInput.maxPointers?e.pointers.length:i.prevInput.maxPointers:e.pointers.length,function(t,e){var i,n,s,o,a=t.lastInterval||e,h=e.timeStamp-a.timeStamp;if(8!=e.eventType&&(h>25||a.velocity===r)){var c=e.deltaX-a.deltaX,l=e.deltaY-a.deltaY,p=U(h,c,l);n=p.x,s=p.y,i=u(p.x)>u(p.y)?p.x:p.y,o=V(c,l),t.lastInterval=e}else i=a.velocity,n=a.velocityX,s=a.velocityY,o=a.direction;e.velocity=i,e.velocityX=n,e.velocityY=s,e.direction=o}(i,e);var f,v;var d=t.element;_(e.srcEvent.target,d)&&(d=e.srcEvent.target);e.target=d}(t,i),t.emit(\"hammer.input\",i),t.recognize(i),t.session.prevInput=i}function H(t){for(var e=[],i=0;i<t.pointers.length;)e[i]={clientX:h(t.pointers[i].clientX),clientY:h(t.pointers[i].clientY)},i++;return{timeStamp:c(),pointers:e,center:L(e),deltaX:t.deltaX,deltaY:t.deltaY}}function L(t){var e=t.length;if(1===e)return{x:h(t[0].clientX),y:h(t[0].clientY)};for(var i=0,n=0,r=0;r<e;)i+=t[r].clientX,n+=t[r].clientY,r++;return{x:h(i/e),y:h(n/e)}}function U(t,e,i){return{x:e/t||0,y:i/t||0}}function V(t,e){return t===e?1:u(t)>=u(e)?t<0?2:4:e<0?8:16}function j(t,e,i){i||(i=F);var n=e[i[0]]-t[i[0]],r=e[i[1]]-t[i[1]];return Math.sqrt(n*n+r*r)}function G(t,e,i){i||(i=F);var n=e[i[0]]-t[i[0]],r=e[i[1]]-t[i[1]];return 180*Math.atan2(r,n)/Math.PI}q.prototype={handler:function(){},init:function(){this.evEl&&I(this.element,this.evEl,this.domHandler),this.evTarget&&I(this.target,this.evTarget,this.domHandler),this.evWin&&I(O(this.element),this.evWin,this.domHandler)},destroy:function(){this.evEl&&A(this.element,this.evEl,this.domHandler),this.evTarget&&A(this.target,this.evTarget,this.domHandler),this.evWin&&A(O(this.element),this.evWin,this.domHandler)}};var Z={mousedown:1,mousemove:2,mouseup:4},B=\"mousedown\",$=\"mousemove mouseup\";function J(){this.evEl=B,this.evWin=$,this.pressed=!1,q.apply(this,arguments)}g(J,q,{handler:function(t){var e=Z[t.type];1&e&&0===t.button&&(this.pressed=!0),2&e&&1!==t.which&&(e=4),this.pressed&&(4&e&&(this.pressed=!1),this.callback(this.manager,e,{pointers:[t],changedPointers:[t],pointerType:X,srcEvent:t}))}});var K={pointerdown:1,pointermove:2,pointerup:4,pointercancel:8,pointerout:8},Q={2:N,3:\"pen\",4:X,5:\"kinect\"},tt=\"pointerdown\",et=\"pointermove pointerup pointercancel\";function it(){this.evEl=tt,this.evWin=et,q.apply(this,arguments),this.store=this.manager.session.pointerEvents=[]}t.MSPointerEvent&&!t.PointerEvent&&(tt=\"MSPointerDown\",et=\"MSPointerMove MSPointerUp MSPointerCancel\"),g(it,q,{handler:function(t){var e=this.store,i=!1,n=t.type.toLowerCase().replace(\"ms\",\"\"),r=K[n],s=Q[t.pointerType]||t.pointerType,o=s==N,a=b(e,t.pointerId,\"pointerId\");1&r&&(0===t.button||o)?a<0&&(e.push(t),a=e.length-1):12&r&&(i=!0),a<0||(e[a]=t,this.callback(this.manager,r,{pointers:e,changedPointers:[t],pointerType:s,srcEvent:t}),i&&e.splice(a,1))}});var nt={touchstart:1,touchmove:2,touchend:4,touchcancel:8},rt=\"touchstart\",st=\"touchstart touchmove touchend touchcancel\";function ot(){this.evTarget=rt,this.evWin=st,this.started=!1,q.apply(this,arguments)}function at(t,e){var i=P(t.touches),n=P(t.changedTouches);return 12&e&&(i=D(i.concat(n),\"identifier\",!0)),[i,n]}g(ot,q,{handler:function(t){var e=nt[t.type];if(1===e&&(this.started=!0),this.started){var i=at.call(this,t,e);12&e&&i[0].length-i[1].length==0&&(this.started=!1),this.callback(this.manager,e,{pointers:i[0],changedPointers:i[1],pointerType:N,srcEvent:t})}}});var ht={touchstart:1,touchmove:2,touchend:4,touchcancel:8},ut=\"touchstart touchmove touchend touchcancel\";function ct(){this.evTarget=ut,this.targetIds={},q.apply(this,arguments)}function lt(t,e){var i=P(t.touches),n=this.targetIds;if(3&e&&1===i.length)return n[i[0].identifier]=!0,[i,i];var r,s,o=P(t.changedTouches),a=[],h=this.target;if(s=i.filter((function(t){return _(t.target,h)})),1===e)for(r=0;r<s.length;)n[s[r].identifier]=!0,r++;for(r=0;r<o.length;)n[o[r].identifier]&&a.push(o[r]),12&e&&delete n[o[r].identifier],r++;return a.length?[D(s.concat(a),\"identifier\",!0),a]:void 0}g(ct,q,{handler:function(t){var e=ht[t.type],i=lt.call(this,t,e);i&&this.callback(this.manager,e,{pointers:i[0],changedPointers:i[1],pointerType:N,srcEvent:t})}});function pt(){q.apply(this,arguments);var t=T(this.handler,this);this.touch=new ct(this.manager,t),this.mouse=new J(this.manager,t),this.primaryTouch=null,this.lastTouches=[]}function ft(t,e){1&t?(this.primaryTouch=e.changedPointers[0].identifier,vt.call(this,e)):12&t&&vt.call(this,e)}function vt(t){var e=t.changedPointers[0];if(e.identifier===this.primaryTouch){var i={x:e.clientX,y:e.clientY};this.lastTouches.push(i);var n=this.lastTouches;setTimeout((function(){var t=n.indexOf(i);t>-1&&n.splice(t,1)}),2500)}}function dt(t){for(var e=t.srcEvent.clientX,i=t.srcEvent.clientY,n=0;n<this.lastTouches.length;n++){var r=this.lastTouches[n],s=Math.abs(e-r.x),o=Math.abs(i-r.y);if(s<=25&&o<=25)return!0}return!1}g(pt,q,{handler:function(t,e,i){var n=i.pointerType==N,r=i.pointerType==X;if(!(r&&i.sourceCapabilities&&i.sourceCapabilities.firesTouchEvents)){if(n)ft.call(this,e,i);else if(r&&dt.call(this,i))return;this.callback(t,e,i)}},destroy:function(){this.touch.destroy(),this.mouse.destroy()}});var mt=x(a.style,\"touchAction\"),gt=mt!==r,Tt=\"compute\",yt=\"auto\",Et=\"manipulation\",It=\"none\",At=\"pan-x\",_t=\"pan-y\",Ct=function(){if(!gt)return!1;var e={},i=t.CSS&&t.CSS.supports;return[\"auto\",\"manipulation\",\"pan-y\",\"pan-x\",\"pan-x pan-y\",\"none\"].forEach((function(n){e[n]=!i||t.CSS.supports(\"touch-action\",n)})),e}();function St(t,e){this.manager=t,this.set(e)}St.prototype={set:function(t){t==Tt&&(t=this.compute()),gt&&this.manager.element.style&&Ct[t]&&(this.manager.element.style[mt]=t),this.actions=t.toLowerCase().trim()},update:function(){this.set(this.manager.options.touchAction)},compute:function(){var t=[];return f(this.manager.recognizers,(function(e){y(e.options.enable,[e])&&(t=t.concat(e.getTouchAction()))})),function(t){if(C(t,It))return It;var e=C(t,At),i=C(t,_t);if(e&&i)return It;if(e||i)return e?At:_t;if(C(t,Et))return Et;return yt}(t.join(\" \"))},preventDefaults:function(t){var e=t.srcEvent,i=t.offsetDirection;if(this.manager.session.prevented)e.preventDefault();else{var n=this.actions,r=C(n,It)&&!Ct.none,s=C(n,_t)&&!Ct[\"pan-y\"],o=C(n,At)&&!Ct[\"pan-x\"];if(r){var a=1===t.pointers.length,h=t.distance<2,u=t.deltaTime<250;if(a&&h&&u)return}if(!o||!s)return r||s&&6&i||o&&i&Y?this.preventSrc(e):void 0}},preventSrc:function(t){this.manager.session.prevented=!0,t.preventDefault()}};var bt=32;function Pt(t){this.options=s({},this.defaults,t||{}),this.id=w++,this.manager=null,this.options.enable=E(this.options.enable,!0),this.state=1,this.simultaneous={},this.requireFail=[]}function Dt(t){return 16&t?\"cancel\":8&t?\"end\":4&t?\"move\":2&t?\"start\":\"\"}function xt(t){return 16==t?\"down\":8==t?\"up\":2==t?\"left\":4==t?\"right\":\"\"}function wt(t,e){var i=e.manager;return i?i.get(t):t}function Ot(){Pt.apply(this,arguments)}function Rt(){Ot.apply(this,arguments),this.pX=null,this.pY=null}function Mt(){Ot.apply(this,arguments)}function zt(){Pt.apply(this,arguments),this._timer=null,this._input=null}function Nt(){Ot.apply(this,arguments)}function Xt(){Ot.apply(this,arguments)}function Yt(){Pt.apply(this,arguments),this.pTime=!1,this.pCenter=!1,this._timer=null,this._input=null,this.count=0}function Ft(t,e){return(e=e||{}).recognizers=E(e.recognizers,Ft.defaults.preset),new Wt(t,e)}Pt.prototype={defaults:{},set:function(t){return s(this.options,t),this.manager&&this.manager.touchAction.update(),this},recognizeWith:function(t){if(p(t,\"recognizeWith\",this))return this;var e=this.simultaneous;return e[(t=wt(t,this)).id]||(e[t.id]=t,t.recognizeWith(this)),this},dropRecognizeWith:function(t){return p(t,\"dropRecognizeWith\",this)||(t=wt(t,this),delete this.simultaneous[t.id]),this},requireFailure:function(t){if(p(t,\"requireFailure\",this))return this;var e=this.requireFail;return-1===b(e,t=wt(t,this))&&(e.push(t),t.requireFailure(this)),this},dropRequireFailure:function(t){if(p(t,\"dropRequireFailure\",this))return this;t=wt(t,this);var e=b(this.requireFail,t);return e>-1&&this.requireFail.splice(e,1),this},hasRequireFailures:function(){return this.requireFail.length>0},canRecognizeWith:function(t){return!!this.simultaneous[t.id]},emit:function(t){var e=this,i=this.state;function n(i){e.manager.emit(i,t)}i<8&&n(e.options.event+Dt(i)),n(e.options.event),t.additionalEvent&&n(t.additionalEvent),i>=8&&n(e.options.event+Dt(i))},tryEmit:function(t){if(this.canEmit())return this.emit(t);this.state=bt},canEmit:function(){for(var t=0;t<this.requireFail.length;){if(!(33&this.requireFail[t].state))return!1;t++}return!0},recognize:function(t){var e=s({},t);if(!y(this.options.enable,[this,e]))return this.reset(),void(this.state=bt);56&this.state&&(this.state=1),this.state=this.process(e),30&this.state&&this.tryEmit(e)},process:function(t){},getTouchAction:function(){},reset:function(){}},g(Ot,Pt,{defaults:{pointers:1},attrTest:function(t){var e=this.options.pointers;return 0===e||t.pointers.length===e},process:function(t){var e=this.state,i=t.eventType,n=6&e,r=this.attrTest(t);return n&&(8&i||!r)?16|e:n||r?4&i?8|e:2&e?4|e:2:bt}}),g(Rt,Ot,{defaults:{event:\"pan\",threshold:10,pointers:1,direction:30},getTouchAction:function(){var t=this.options.direction,e=[];return 6&t&&e.push(_t),t&Y&&e.push(At),e},directionTest:function(t){var e=this.options,i=!0,n=t.distance,r=t.direction,s=t.deltaX,o=t.deltaY;return r&e.direction||(6&e.direction?(r=0===s?1:s<0?2:4,i=s!=this.pX,n=Math.abs(t.deltaX)):(r=0===o?1:o<0?8:16,i=o!=this.pY,n=Math.abs(t.deltaY))),t.direction=r,i&&n>e.threshold&&r&e.direction},attrTest:function(t){return Ot.prototype.attrTest.call(this,t)&&(2&this.state||!(2&this.state)&&this.directionTest(t))},emit:function(t){this.pX=t.deltaX,this.pY=t.deltaY;var e=xt(t.direction);e&&(t.additionalEvent=this.options.event+e),this._super.emit.call(this,t)}}),g(Mt,Ot,{defaults:{event:\"pinch\",threshold:0,pointers:2},getTouchAction:function(){return[It]},attrTest:function(t){return this._super.attrTest.call(this,t)&&(Math.abs(t.scale-1)>this.options.threshold||2&this.state)},emit:function(t){if(1!==t.scale){var e=t.scale<1?\"in\":\"out\";t.additionalEvent=this.options.event+e}this._super.emit.call(this,t)}}),g(zt,Pt,{defaults:{event:\"press\",pointers:1,time:251,threshold:9},getTouchAction:function(){return[yt]},process:function(t){var e=this.options,i=t.pointers.length===e.pointers,n=t.distance<e.threshold,r=t.deltaTime>e.time;if(this._input=t,!n||!i||12&t.eventType&&!r)this.reset();else if(1&t.eventType)this.reset(),this._timer=l((function(){this.state=8,this.tryEmit()}),e.time,this);else if(4&t.eventType)return 8;return bt},reset:function(){clearTimeout(this._timer)},emit:function(t){8===this.state&&(t&&4&t.eventType?this.manager.emit(this.options.event+\"up\",t):(this._input.timeStamp=c(),this.manager.emit(this.options.event,this._input)))}}),g(Nt,Ot,{defaults:{event:\"rotate\",threshold:0,pointers:2},getTouchAction:function(){return[It]},attrTest:function(t){return this._super.attrTest.call(this,t)&&(Math.abs(t.rotation)>this.options.threshold||2&this.state)}}),g(Xt,Ot,{defaults:{event:\"swipe\",threshold:10,velocity:.3,direction:30,pointers:1},getTouchAction:function(){return Rt.prototype.getTouchAction.call(this)},attrTest:function(t){var e,i=this.options.direction;return 30&i?e=t.overallVelocity:6&i?e=t.overallVelocityX:i&Y&&(e=t.overallVelocityY),this._super.attrTest.call(this,t)&&i&t.offsetDirection&&t.distance>this.options.threshold&&t.maxPointers==this.options.pointers&&u(e)>this.options.velocity&&4&t.eventType},emit:function(t){var e=xt(t.offsetDirection);e&&this.manager.emit(this.options.event+e,t),this.manager.emit(this.options.event,t)}}),g(Yt,Pt,{defaults:{event:\"tap\",pointers:1,taps:1,interval:300,time:250,threshold:9,posThreshold:10},getTouchAction:function(){return[Et]},process:function(t){var e=this.options,i=t.pointers.length===e.pointers,n=t.distance<e.threshold,r=t.deltaTime<e.time;if(this.reset(),1&t.eventType&&0===this.count)return this.failTimeout();if(n&&r&&i){if(4!=t.eventType)return this.failTimeout();var s=!this.pTime||t.timeStamp-this.pTime<e.interval,o=!this.pCenter||j(this.pCenter,t.center)<e.posThreshold;if(this.pTime=t.timeStamp,this.pCenter=t.center,o&&s?this.count+=1:this.count=1,this._input=t,0===this.count%e.taps)return this.hasRequireFailures()?(this._timer=l((function(){this.state=8,this.tryEmit()}),e.interval,this),2):8}return bt},failTimeout:function(){return this._timer=l((function(){this.state=bt}),this.options.interval,this),bt},reset:function(){clearTimeout(this._timer)},emit:function(){8==this.state&&(this._input.tapCount=this.count,this.manager.emit(this.options.event,this._input))}}),Ft.VERSION=\"2.0.7\",Ft.defaults={domEvents:!1,touchAction:Tt,enable:!0,inputTarget:null,inputClass:null,preset:[[Nt,{enable:!1}],[Mt,{enable:!1},[\"rotate\"]],[Xt,{direction:6}],[Rt,{direction:6},[\"swipe\"]],[Yt],[Yt,{event:\"doubletap\",taps:2},[\"tap\"]],[zt]],cssProps:{userSelect:\"none\",touchSelect:\"none\",touchCallout:\"none\",contentZooming:\"none\",userDrag:\"none\",tapHighlightColor:\"rgba(0,0,0,0)\"}};function Wt(t,e){var i;this.options=s({},Ft.defaults,e||{}),this.options.inputTarget=this.options.inputTarget||t,this.handlers={},this.session={},this.recognizers=[],this.oldCssProps={},this.element=t,this.input=new((i=this).options.inputClass||(M?it:z?ct:R?pt:J))(i,k),this.touchAction=new St(this,this.options.touchAction),qt(this,!0),f(this.options.recognizers,(function(t){var e=this.add(new t[0](t[1]));t[2]&&e.recognizeWith(t[2]),t[3]&&e.requireFailure(t[3])}),this)}function qt(t,e){var i,n=t.element;n.style&&(f(t.options.cssProps,(function(r,s){i=x(n.style,s),e?(t.oldCssProps[i]=n.style[i],n.style[i]=r):n.style[i]=t.oldCssProps[i]||\"\"})),e||(t.oldCssProps={}))}Wt.prototype={set:function(t){return s(this.options,t),t.touchAction&&this.touchAction.update(),t.inputTarget&&(this.input.destroy(),this.input.target=t.inputTarget,this.input.init()),this},stop:function(t){this.session.stopped=t?2:1},recognize:function(t){var e=this.session;if(!e.stopped){var i;this.touchAction.preventDefaults(t);var n=this.recognizers,r=e.curRecognizer;(!r||r&&8&r.state)&&(r=e.curRecognizer=null);for(var s=0;s<n.length;)i=n[s],2===e.stopped||r&&i!=r&&!i.canRecognizeWith(r)?i.reset():i.recognize(t),!r&&14&i.state&&(r=e.curRecognizer=i),s++}},get:function(t){if(t instanceof Pt)return t;for(var e=this.recognizers,i=0;i<e.length;i++)if(e[i].options.event==t)return e[i];return null},add:function(t){if(p(t,\"add\",this))return this;var e=this.get(t.options.event);return e&&this.remove(e),this.recognizers.push(t),t.manager=this,this.touchAction.update(),t},remove:function(t){if(p(t,\"remove\",this))return this;if(t=this.get(t)){var e=this.recognizers,i=b(e,t);-1!==i&&(e.splice(i,1),this.touchAction.update())}return this},on:function(t,e){if(t!==r&&e!==r){var i=this.handlers;return f(S(t),(function(t){i[t]=i[t]||[],i[t].push(e)})),this}},off:function(t,e){if(t!==r){var i=this.handlers;return f(S(t),(function(t){e?i[t]&&i[t].splice(b(i[t],e),1):delete i[t]})),this}},emit:function(t,e){this.options.domEvents&&function(t,e){var n=i.createEvent(\"Event\");n.initEvent(t,!0,!0),n.gesture=e,e.target.dispatchEvent(n)}(t,e);var n=this.handlers[t]&&this.handlers[t].slice();if(n&&n.length){e.type=t,e.preventDefault=function(){e.srcEvent.preventDefault()};for(var r=0;r<n.length;)n[r](e),r++}},destroy:function(){this.element&&qt(this,!1),this.handlers={},this.session={},this.input.destroy(),this.element=null}},s(Ft,{INPUT_START:1,INPUT_MOVE:2,INPUT_END:4,INPUT_CANCEL:8,STATE_POSSIBLE:1,STATE_BEGAN:2,STATE_CHANGED:4,STATE_ENDED:8,STATE_RECOGNIZED:8,STATE_CANCELLED:16,STATE_FAILED:bt,DIRECTION_NONE:1,DIRECTION_LEFT:2,DIRECTION_RIGHT:4,DIRECTION_UP:8,DIRECTION_DOWN:16,DIRECTION_HORIZONTAL:6,DIRECTION_VERTICAL:Y,DIRECTION_ALL:30,Manager:Wt,Input:q,TouchAction:St,TouchInput:ct,MouseInput:J,PointerEventInput:it,TouchMouseInput:pt,SingleTouchInput:ot,Recognizer:Pt,AttrRecognizer:Ot,Tap:Yt,Pan:Rt,Swipe:Xt,Pinch:Mt,Rotate:Nt,Press:zt,on:I,off:A,each:f,merge:m,extend:d,assign:s,inherit:g,bindFn:T,prefixed:x}),(void 0!==t?t:\"undefined\"!=typeof self?self:{}).Hammer=Ft,\"function\"==typeof define&&define.amd?define((function(){return Ft})):void 0!==e&&e.exports?e.exports=Ft:t.Hammer=Ft}(window,document)},\n",
" function _(e,s,t,i,r){i();const n=e(42),a=e(43);class l extends n.View{initialize(){super.initialize(),this.el=this._createElement()}remove(){a.remove(this.el),super.remove()}css_classes(){return[]}render(){}renderTo(e){e.appendChild(this.el),this.render()}_createElement(){return a.createElement(this.tagName,{class:this.css_classes()})}}t.DOMView=l,l.__name__=\"DOMView\",l.prototype.tagName=\"div\"},\n",
" function _(o,b,t,r,e){r(),t.root=\"bk-root\",t.toolbar_hidden=\"bk-toolbar-hidden\",t.toolbar=\"bk-toolbar\",t.button_bar=\"bk-button-bar\",t.logo=\"bk-logo\",t.above=\"bk-above\",t.below=\"bk-below\",t.left=\"bk-left\",t.right=\"bk-right\",t.toolbar_button=\"bk-toolbar-button\",t.active=\"bk-active\",t.default='.bk-root .bk-toolbar-hidden{visibility:hidden;opacity:0;transition:visibility 0.3s linear, opacity 0.3s linear;}.bk-root .bk-toolbar,.bk-root .bk-button-bar{display:flex;display:-webkit-flex;flex-wrap:nowrap;-webkit-flex-wrap:nowrap;align-items:center;-webkit-align-items:center;user-select:none;-ms-user-select:none;-moz-user-select:none;-webkit-user-select:none;}.bk-root .bk-toolbar .bk-logo{flex-shrink:0;-webkit-flex-shrink:0;}.bk-root .bk-toolbar.bk-above,.bk-root .bk-toolbar.bk-below{flex-direction:row;-webkit-flex-direction:row;justify-content:flex-end;-webkit-justify-content:flex-end;}.bk-root .bk-toolbar.bk-above .bk-button-bar,.bk-root .bk-toolbar.bk-below .bk-button-bar{display:flex;display:-webkit-flex;flex-direction:row;-webkit-flex-direction:row;}.bk-root .bk-toolbar.bk-above .bk-logo,.bk-root .bk-toolbar.bk-below .bk-logo{order:1;-webkit-order:1;margin-left:5px;margin-right:0px;}.bk-root .bk-toolbar.bk-left,.bk-root .bk-toolbar.bk-right{flex-direction:column;-webkit-flex-direction:column;justify-content:flex-start;-webkit-justify-content:flex-start;}.bk-root .bk-toolbar.bk-left .bk-button-bar,.bk-root .bk-toolbar.bk-right .bk-button-bar{display:flex;display:-webkit-flex;flex-direction:column;-webkit-flex-direction:column;}.bk-root .bk-toolbar.bk-left .bk-logo,.bk-root .bk-toolbar.bk-right .bk-logo{order:0;-webkit-order:0;margin-bottom:5px;margin-top:0px;}.bk-root .bk-toolbar-button{width:30px;height:30px;cursor:pointer;background-size:60% 60%;background-origin:border-box;background-color:transparent;background-repeat:no-repeat;background-position:center center;}.bk-root .bk-toolbar-button:hover{background-color:rgba(192, 192, 192, 0.15);}.bk-root .bk-toolbar-button:focus{outline:none;}.bk-root .bk-toolbar-button::-moz-focus-inner{border:0;}.bk-root .bk-toolbar.bk-above .bk-toolbar-button{border-bottom:2px solid transparent;}.bk-root .bk-toolbar.bk-above .bk-toolbar-button.bk-active{border-bottom-color:#26aae1;}.bk-root .bk-toolbar.bk-below .bk-toolbar-button{border-top:2px solid transparent;}.bk-root .bk-toolbar.bk-below .bk-toolbar-button.bk-active{border-top-color:#26aae1;}.bk-root .bk-toolbar.bk-right .bk-toolbar-button{border-left:2px solid transparent;}.bk-root .bk-toolbar.bk-right .bk-toolbar-button.bk-active{border-left-color:#26aae1;}.bk-root .bk-toolbar.bk-left .bk-toolbar-button{border-right:2px solid transparent;}.bk-root .bk-toolbar.bk-left .bk-toolbar-button.bk-active{border-right-color:#26aae1;}.bk-root .bk-button-bar + .bk-button-bar:before{content:\" \";display:inline-block;background-color:lightgray;}.bk-root .bk-toolbar.bk-above .bk-button-bar + .bk-button-bar:before,.bk-root .bk-toolbar.bk-below .bk-button-bar + .bk-button-bar:before{height:10px;width:1px;}.bk-root .bk-toolbar.bk-left .bk-button-bar + .bk-button-bar:before,.bk-root .bk-toolbar.bk-right .bk-button-bar + .bk-button-bar:before{height:1px;width:10px;}'},\n",
" function _(A,g,o,C,l){C(),o.root=\"bk-root\",o.tool_icon_copy_to_clipboard=\"bk-tool-icon-copy-to-clipboard\",o.tool_icon_replace_mode=\"bk-tool-icon-replace-mode\",o.tool_icon_append_mode=\"bk-tool-icon-append-mode\",o.tool_icon_intersect_mode=\"bk-tool-icon-intersect-mode\",o.tool_icon_subtract_mode=\"bk-tool-icon-subtract-mode\",o.tool_icon_clear_selection=\"bk-tool-icon-clear-selection\",o.tool_icon_box_select=\"bk-tool-icon-box-select\",o.tool_icon_box_zoom=\"bk-tool-icon-box-zoom\",o.tool_icon_zoom_in=\"bk-tool-icon-zoom-in\",o.tool_icon_zoom_out=\"bk-tool-icon-zoom-out\",o.tool_icon_help=\"bk-tool-icon-help\",o.tool_icon_hover=\"bk-tool-icon-hover\",o.tool_icon_crosshair=\"bk-tool-icon-crosshair\",o.tool_icon_lasso_select=\"bk-tool-icon-lasso-select\",o.tool_icon_pan=\"bk-tool-icon-pan\",o.tool_icon_xpan=\"bk-tool-icon-xpan\",o.tool_icon_ypan=\"bk-tool-icon-ypan\",o.tool_icon_range=\"bk-tool-icon-range\",o.tool_icon_polygon_select=\"bk-tool-icon-polygon-select\",o.tool_icon_redo=\"bk-tool-icon-redo\",o.tool_icon_reset=\"bk-tool-icon-reset\",o.tool_icon_save=\"bk-tool-icon-save\",o.tool_icon_tap_select=\"bk-tool-icon-tap-select\",o.tool_icon_undo=\"bk-tool-icon-undo\",o.tool_icon_wheel_pan=\"bk-tool-icon-wheel-pan\",o.tool_icon_wheel_zoom=\"bk-tool-icon-wheel-zoom\",o.tool_icon_box_edit=\"bk-tool-icon-box-edit\",o.tool_icon_freehand_draw=\"bk-tool-icon-freehand-draw\",o.tool_icon_poly_draw=\"bk-tool-icon-poly-draw\",o.tool_icon_point_draw=\"bk-tool-icon-point-draw\",o.tool_icon_poly_edit=\"bk-tool-icon-poly-edit\",o.tool_icon_line_edit=\"bk-tool-icon-line-edit\",o.default='.bk-root .bk-tool-icon-copy-to-clipboard{background-image:url(\"\");}.bk-root .bk-tool-icon-replace-mode{background-image:url(\"\");}.bk-root .bk-tool-icon-append-mode{background-image:url(\"\");}.bk-root .bk-tool-icon-intersect-mode{background-image:url(\"\");}.bk-root .bk-tool-icon-subtract-mode{background-image:url(\"\");}.bk-root .bk-tool-icon-clear-selection{background-image:url(\"\");}.bk-root .bk-tool-icon-box-select{background-image:url(\"\");}.bk-root .bk-tool-icon-box-zoom{background-image:url(\"\");}.bk-root .bk-tool-icon-zoom-in{background-image:url(\"\");}.bk-root .bk-tool-icon-zoom-out{background-image:url(\"\");}.bk-root .bk-tool-icon-help{background-image:url(\"\");}.bk-root .bk-tool-icon-hover{background-image:url(\"\");}.bk-root .bk-tool-icon-crosshair{background-image:url(\"\");}.bk-root .bk-tool-icon-lasso-select{background-image:url(\"\");}.bk-root .bk-tool-icon-pan{background-image:url(\"\");}.bk-root .bk-tool-icon-xpan{background-image:url(\"\");}.bk-root .bk-tool-icon-ypan{background-image:url(\"\");}.bk-root .bk-tool-icon-range{background-image:url(\"\");}.bk-root .bk-tool-icon-polygon-select{background-image:url(\"\");}.bk-root .bk-tool-icon-redo{background-image:url(\"\");}.bk-root .bk-tool-icon-reset{background-image:url(\"\");}.bk-root .bk-tool-icon-save{background-image:url(\"\");}.bk-root .bk-tool-icon-tap-select{background-image:url(\"\");}.bk-root .bk-tool-icon-undo{background-image:url(\"\");}.bk-root .bk-tool-icon-wheel-pan{background-image:url(\"\");}.bk-root .bk-tool-icon-wheel-zoom{background-image:url(\"\");}.bk-root .bk-tool-icon-box-edit{background-image:url(\"\");}.bk-root .bk-tool-icon-freehand-draw{background-image:url(\"\");}.bk-root .bk-tool-icon-poly-draw{background-image:url(\"\");}.bk-root .bk-tool-icon-point-draw{background-image:url(\"\");}.bk-root .bk-tool-icon-poly-edit{background-image:url(\"\");}.bk-root .bk-tool-icon-line-edit{background-image:url(\"\");}'},\n",
" function _(o,r,e,t,b){t(),e.root=\"bk-root\",e.menu_icon=\"bk-menu-icon\",e.context_menu=\"bk-context-menu\",e.horizontal=\"bk-horizontal\",e.vertical=\"bk-vertical\",e.divider=\"bk-divider\",e.active=\"bk-active\",e.menu=\"bk-menu\",e.above=\"bk-above\",e.below=\"bk-below\",e.caret=\"bk-caret\",e.down=\"bk-down\",e.up=\"bk-up\",e.left=\"bk-left\",e.right=\"bk-right\",e.default=\".bk-root .bk-menu-icon{width:28px;height:28px;background-size:60%;background-color:transparent;background-repeat:no-repeat;background-position:center center;}.bk-root .bk-context-menu{position:absolute;display:inline-flex;display:-webkit-inline-flex;flex-wrap:nowrap;-webkit-flex-wrap:nowrap;user-select:none;-ms-user-select:none;-moz-user-select:none;-webkit-user-select:none;width:auto;height:auto;z-index:100;cursor:pointer;font-size:12px;background-color:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 6px 12px rgba(0, 0, 0, 0.175);}.bk-root .bk-context-menu.bk-horizontal{flex-direction:row;-webkit-flex-direction:row;}.bk-root .bk-context-menu.bk-vertical{flex-direction:column;-webkit-flex-direction:column;}.bk-root .bk-context-menu > .bk-divider{cursor:default;overflow:hidden;background-color:#e5e5e5;}.bk-root .bk-context-menu.bk-horizontal > .bk-divider{width:1px;margin:5px 0;}.bk-root .bk-context-menu.bk-vertical > .bk-divider{height:1px;margin:0 5px;}.bk-root .bk-context-menu > :not(.bk-divider){border:1px solid transparent;}.bk-root .bk-context-menu > :not(.bk-divider).bk-active{border-color:#26aae1;}.bk-root .bk-context-menu > :not(.bk-divider):hover{background-color:#f9f9f9;}.bk-root .bk-context-menu.bk-horizontal > :not(.bk-divider):first-child{border-top-left-radius:4px;border-bottom-left-radius:4px;}.bk-root .bk-context-menu.bk-horizontal > :not(.bk-divider):last-child{border-top-right-radius:4px;border-bottom-right-radius:4px;}.bk-root .bk-context-menu.bk-vertical > :not(.bk-divider):first-child{border-top-left-radius:4px;border-top-right-radius:4px;}.bk-root .bk-context-menu.bk-vertical > :not(.bk-divider):last-child{border-bottom-left-radius:4px;border-bottom-right-radius:4px;}.bk-root .bk-menu{position:absolute;left:0;width:100%;z-index:100;cursor:pointer;font-size:12px;background-color:#fff;border:1px solid #ccc;border-radius:4px;box-shadow:0 6px 12px rgba(0, 0, 0, 0.175);}.bk-root .bk-menu.bk-above{bottom:100%;}.bk-root .bk-menu.bk-below{top:100%;}.bk-root .bk-menu > .bk-divider{height:1px;margin:7.5px 0;overflow:hidden;background-color:#e5e5e5;}.bk-root .bk-menu > :not(.bk-divider){padding:6px 12px;}.bk-root .bk-menu > :not(.bk-divider):hover,.bk-root .bk-menu > :not(.bk-divider).bk-active{background-color:#e6e6e6;}.bk-root .bk-caret{display:inline-block;vertical-align:middle;width:0;height:0;margin:0 5px;}.bk-root .bk-caret.bk-down{border-top:4px solid;}.bk-root .bk-caret.bk-up{border-bottom:4px solid;}.bk-root .bk-caret.bk-down,.bk-root .bk-caret.bk-up{border-right:4px solid transparent;border-left:4px solid transparent;}.bk-root .bk-caret.bk-left{border-right:4px solid;}.bk-root .bk-caret.bk-right{border-left:4px solid;}.bk-root .bk-caret.bk-left,.bk-root .bk-caret.bk-right{border-top:4px solid transparent;border-bottom:4px solid transparent;}\"},\n",
" function _(t,e,i,n,s){n();const o=t(1),l=t(43),h=t(245),d=o.__importStar(t(243));class r{constructor(t,e={}){this.items=t,this.options=e,this.el=l.div(),this._open=!1,this._item_click=t=>{var e;null===(e=this.items[t])||void 0===e||e.handler(),this.hide()},this._on_mousedown=t=>{var e,i;const{target:n}=t;n instanceof Node&&this.el.contains(n)||(null===(i=(e=this.options).prevent_hide)||void 0===i?void 0:i.call(e,t))||this.hide()},this._on_keydown=t=>{t.keyCode==l.Keys.Esc&&this.hide()},this._on_blur=()=>{this.hide()},l.undisplay(this.el)}get is_open(){return this._open}get can_open(){return 0!=this.items.length}remove(){l.remove(this.el),this._unlisten()}_listen(){document.addEventListener(\"mousedown\",this._on_mousedown),document.addEventListener(\"keydown\",this._on_keydown),window.addEventListener(\"blur\",this._on_blur)}_unlisten(){document.removeEventListener(\"mousedown\",this._on_mousedown),document.removeEventListener(\"keydown\",this._on_keydown),window.removeEventListener(\"blur\",this._on_blur)}_position(t){const e=this.el.parentElement;if(null!=e){const i=e.getBoundingClientRect();this.el.style.left=null!=t.left?t.left-i.left+\"px\":\"\",this.el.style.top=null!=t.top?t.top-i.top+\"px\":\"\",this.el.style.right=null!=t.right?i.right-t.right+\"px\":\"\",this.el.style.bottom=null!=t.bottom?i.bottom-t.bottom+\"px\":\"\"}}render(){var t,e;l.empty(this.el,!0);const i=null!==(t=this.options.orientation)&&void 0!==t?t:\"vertical\";l.classes(this.el).add(\"bk-context-menu\",`bk-${i}`);for(const[t,i]of h.enumerate(this.items)){let n;if(null==t)n=l.div({class:d.divider});else{if(null!=t.if&&!t.if())continue;{const i=null!=t.icon?l.div({class:[\"bk-menu-icon\",t.icon]}):null;n=l.div({class:(null===(e=t.active)||void 0===e?void 0:e.call(t))?\"bk-active\":null,title:t.tooltip},i,t.label)}}n.addEventListener(\"click\",(()=>this._item_click(i))),this.el.appendChild(n)}}show(t){if(0!=this.items.length&&!this._open){if(this.render(),0==this.el.children.length)return;this._position(null!=t?t:{left:0,top:0}),l.display(this.el),this._listen(),this._open=!0}}hide(){this._open&&(this._open=!1,this._unlisten(),l.undisplay(this.el))}toggle(t){this._open?this.hide():this.show(t)}}i.ContextMenu=r,r.__name__=\"ContextMenu\"},\n",
" function _(n,e,o,t,r){t();const f=n(9);function*i(n,e){const o=n.length;if(e>o)return;const t=f.range(e);for(yield t.map((e=>n[e]));;){let r;for(const n of f.reversed(f.range(e)))if(t[n]!=n+o-e){r=n;break}if(null==r)return;t[r]+=1;for(const n of f.range(r+1,e))t[n]=t[n-1]+1;yield t.map((e=>n[e]))}}o.enumerate=function*(n){let e=0;for(const o of n)yield[o,e++]},o.combinations=i,o.subsets=function*(n){for(const e of f.range(n.length+1))yield*i(n,e)}},\n",
" function _(t,e,i,n,o){n();const s=t(1),c=t(238),l=s.__importStar(t(241)),a=t(43);class _ extends c.ButtonToolButtonView{render(){super.render(),a.classes(this.el).toggle(l.active,this.model.active)}_clicked(){const{active:t}=this.model;this.model.active=!t}}i.OnOffButtonView=_,_.__name__=\"OnOffButtonView\"},\n",
" function _(t,e,o,n,s){n();const i=t(238),c=t(246);class l extends i.ButtonToolView{}o.InspectToolView=l,l.__name__=\"InspectToolView\";class _ extends i.ButtonTool{constructor(t){super(t),this.event_type=\"move\"}static init_InspectTool(){this.prototype.button_view=c.OnOffButtonView,this.define((({Boolean:t})=>({toggleable:[t,!0]}))),this.override({active:!0})}}o.InspectTool=_,_.__name__=\"InspectTool\",_.init_InspectTool()},\n",
" function _(t,o,e,i,s){i();const l=t(1),n=t(19),a=t(43),r=t(122),c=t(240),_=t(20),u=t(9),h=t(13),v=t(8),p=t(249),d=t(99),b=t(53),g=t(236),f=t(237),m=t(251),w=t(252),y=t(247),T=l.__importStar(t(241)),z=T,B=l.__importStar(t(253)),x=B;class L extends b.Model{constructor(t){super(t)}static init_ToolbarViewModel(){this.define((({Boolean:t,Nullable:o})=>({_visible:[o(t),null],autohide:[t,!1]})))}get visible(){return!this.autohide||null!=this._visible&&this._visible}}e.ToolbarViewModel=L,L.__name__=\"ToolbarViewModel\",L.init_ToolbarViewModel();class M extends c.DOMView{constructor(){super(...arguments),this.layout={bbox:new d.BBox}}initialize(){super.initialize(),this._tool_button_views=new Map,this._toolbar_view_model=new L({autohide:this.model.autohide})}async lazy_initialize(){await super.lazy_initialize(),await this._build_tool_button_views()}connect_signals(){super.connect_signals(),this.connect(this.model.properties.tools.change,(async()=>{await this._build_tool_button_views(),this.render()})),this.connect(this.model.properties.autohide.change,(()=>{this._toolbar_view_model.autohide=this.model.autohide,this._on_visible_change()})),this.connect(this._toolbar_view_model.properties._visible.change,(()=>this._on_visible_change()))}styles(){return[...super.styles(),T.default,B.default]}remove(){r.remove_views(this._tool_button_views),super.remove()}async _build_tool_button_views(){const t=null!=this.model._proxied_tools?this.model._proxied_tools:this.model.tools;await r.build_views(this._tool_button_views,t,{parent:this},(t=>t.button_view))}set_visibility(t){t!=this._toolbar_view_model._visible&&(this._toolbar_view_model._visible=t)}_on_visible_change(){const t=this._toolbar_view_model.visible,o=z.toolbar_hidden;this.el.classList.contains(o)&&t?this.el.classList.remove(o):t||this.el.classList.add(o)}render(){if(a.empty(this.el),this.el.classList.add(z.toolbar),this.el.classList.add(z[this.model.toolbar_location]),this._toolbar_view_model.autohide=this.model.autohide,this._on_visible_change(),null!=this.model.logo){const t=\"grey\"===this.model.logo?x.grey:null,o=a.a({href:\"https://bokeh.org/\",target:\"_blank\",class:[x.logo,x.logo_small,t]});this.el.appendChild(o)}for(const[,t]of this._tool_button_views)t.render();const t=[],o=t=>this._tool_button_views.get(t).el,{gestures:e}=this.model;for(const i of h.values(e))t.push(i.tools.map(o));t.push(this.model.actions.map(o)),t.push(this.model.inspectors.filter((t=>t.toggleable)).map(o));for(const o of t)if(0!==o.length){const t=a.div({class:z.button_bar},o);this.el.appendChild(t)}}update_layout(){}update_position(){}after_layout(){this._has_finished=!0}export(t,o=!0){const e=\"png\"==t?\"canvas\":\"svg\",i=new p.CanvasLayer(e,o);return i.resize(0,0),i}}function V(){return{pan:{tools:[],active:null},scroll:{tools:[],active:null},pinch:{tools:[],active:null},tap:{tools:[],active:null},doubletap:{tools:[],active:null},press:{tools:[],active:null},pressup:{tools:[],active:null},rotate:{tools:[],active:null},move:{tools:[],active:null},multi:{tools:[],active:null}}}e.ToolbarBaseView=M,M.__name__=\"ToolbarBaseView\";class S extends b.Model{constructor(t){super(t)}static init_ToolbarBase(){this.prototype.default_view=M,this.define((({Boolean:t,Array:o,Ref:e,Nullable:i})=>({tools:[o(e(g.Tool)),[]],logo:[i(_.Logo),\"normal\"],autohide:[t,!1]}))),this.internal((({Array:t,Struct:o,Ref:e,Nullable:i})=>{const s=o({tools:t(e(f.GestureTool)),active:i(e(g.Tool))});return{gestures:[o({pan:s,scroll:s,pinch:s,tap:s,doubletap:s,press:s,pressup:s,rotate:s,move:s,multi:s}),V],actions:[t(e(m.ActionTool)),[]],inspectors:[t(e(y.InspectTool)),[]],help:[t(e(w.HelpTool)),[]],toolbar_location:[_.Location,\"right\"]}}))}initialize(){super.initialize(),this._init_tools()}_init_tools(){const t=function(t,o){if(t.length!=o.length)return!0;const e=new Set(o.map((t=>t.id)));return u.some(t,(t=>!e.has(t.id)))},o=this.tools.filter((t=>t instanceof y.InspectTool));t(this.inspectors,o)&&(this.inspectors=o);const e=this.tools.filter((t=>t instanceof w.HelpTool));t(this.help,e)&&(this.help=e);const i=this.tools.filter((t=>t instanceof m.ActionTool));t(this.actions,i)&&(this.actions=i);const s=(t,o)=>{t in this.gestures||n.logger.warn(`Toolbar: unknown event type '${t}' for tool: ${o}`)},l={pan:{tools:[],active:null},scroll:{tools:[],active:null},pinch:{tools:[],active:null},tap:{tools:[],active:null},doubletap:{tools:[],active:null},press:{tools:[],active:null},pressup:{tools:[],active:null},rotate:{tools:[],active:null},move:{tools:[],active:null},multi:{tools:[],active:null}};for(const t of this.tools)if(t instanceof f.GestureTool&&t.event_type)if(v.isString(t.event_type))l[t.event_type].tools.push(t),s(t.event_type,t);else{l.multi.tools.push(t);for(const o of t.event_type)s(o,t)}for(const o of Object.keys(l)){const e=this.gestures[o];t(e.tools,l[o].tools)&&(e.tools=l[o].tools),e.active&&u.every(e.tools,(t=>t.id!=e.active.id))&&(e.active=null)}}get horizontal(){return\"above\"===this.toolbar_location||\"below\"===this.toolbar_location}get vertical(){return\"left\"===this.toolbar_location||\"right\"===this.toolbar_location}_active_change(t){const{event_type:o}=t;if(null==o)return;const e=v.isString(o)?[o]:o;for(const o of e)if(t.active){const e=this.gestures[o].active;null!=e&&t!=e&&(n.logger.debug(`Toolbar: deactivating tool: ${e} for event type '${o}'`),e.active=!1),this.gestures[o].active=t,n.logger.debug(`Toolbar: activating tool: ${t} for event type '${o}'`)}else this.gestures[o].active=null}}e.ToolbarBase=S,S.__name__=\"ToolbarBase\",S.init_ToolbarBase()},\n",
" function _(e,t,i,n,s){n();const o=e(250),a=e(99),r=e(43);function h(e){!function(e){void 0===e.lineDash&&Object.defineProperty(e,\"lineDash\",{get:()=>e.getLineDash(),set:t=>e.setLineDash(t)})}(e),function(e){e.setImageSmoothingEnabled=t=>{e.imageSmoothingEnabled=t,e.mozImageSmoothingEnabled=t,e.oImageSmoothingEnabled=t,e.webkitImageSmoothingEnabled=t,e.msImageSmoothingEnabled=t},e.getImageSmoothingEnabled=()=>{const t=e.imageSmoothingEnabled;return null==t||t}}(e),function(e){e.ellipse||(e.ellipse=function(t,i,n,s,o,a,r,h=!1){const l=.551784;e.translate(t,i),e.rotate(o);let c=n,g=s;h&&(c=-n,g=-s),e.moveTo(-c,0),e.bezierCurveTo(-c,g*l,-c*l,g,0,g),e.bezierCurveTo(c*l,g,c,g*l,c,0),e.bezierCurveTo(c,-g*l,c*l,-g,0,-g),e.bezierCurveTo(-c*l,-g,-c,-g*l,-c,0),e.rotate(-o),e.translate(-t,-i)})}(e)}const l={position:\"absolute\",top:\"0\",left:\"0\",width:\"100%\",height:\"100%\"};class c{constructor(e,t){switch(this.backend=e,this.hidpi=t,this.pixel_ratio=1,this.bbox=new a.BBox,e){case\"webgl\":case\"canvas\":{this._el=this._canvas=r.canvas({style:l});const e=this.canvas.getContext(\"2d\");if(null==e)throw new Error(\"unable to obtain 2D rendering context\");this._ctx=e,t&&(this.pixel_ratio=devicePixelRatio);break}case\"svg\":{const e=new o.SVGRenderingContext2D;this._ctx=e,this._canvas=e.get_svg(),this._el=r.div({style:l},this._canvas);break}}h(this._ctx)}get canvas(){return this._canvas}get ctx(){return this._ctx}get el(){return this._el}resize(e,t){this.bbox=new a.BBox({left:0,top:0,width:e,height:t});const i=this._ctx instanceof o.SVGRenderingContext2D?this._ctx:this.canvas;i.width=e*this.pixel_ratio,i.height=t*this.pixel_ratio}prepare(){const{ctx:e,hidpi:t,pixel_ratio:i}=this;e.save(),t&&(e.scale(i,i),e.translate(.5,.5)),this.clear()}clear(){const{x:e,y:t,width:i,height:n}=this.bbox;this.ctx.clearRect(e,t,i,n)}finish(){this.ctx.restore()}to_blob(){const{_canvas:e}=this;if(e instanceof HTMLCanvasElement)return null!=e.msToBlob?Promise.resolve(e.msToBlob()):new Promise(((t,i)=>{e.toBlob((e=>null!=e?t(e):i()),\"image/png\")}));{const e=this._ctx.get_serialized_svg(!0),t=new Blob([e],{type:\"image/svg+xml\"});return Promise.resolve(t)}}}i.CanvasLayer=c,c.__name__=\"CanvasLayer\"},\n",
" function _(t,e,i,s,n){s();const r=t(168),a=t(8),o=t(43);function l(t){if(!t)throw new Error(\"cannot create a random attribute name for an undefined object\");const e=\"ABCDEFGHIJKLMNOPQRSTUVWXTZabcdefghiklmnopqrstuvwxyz\";let i=\"\";do{i=\"\";for(let t=0;t<12;t++)i+=e[Math.floor(Math.random()*e.length)]}while(t[i]);return i}function h(t){var e;const i={left:\"start\",right:\"end\",center:\"middle\",start:\"start\",end:\"end\"};return null!==(e=i[t])&&void 0!==e?e:i.start}function c(t){var e;const i={alphabetic:\"alphabetic\",hanging:\"hanging\",top:\"text-before-edge\",bottom:\"text-after-edge\",middle:\"central\"};return null!==(e=i[t])&&void 0!==e?e:i.alphabetic}const _=function(t,e){const i=new Map,s=t.split(\",\");e=null!=e?e:10;for(let t=0;t<s.length;t+=2){const n=\"&\"+s[t+1]+\";\",r=parseInt(s[t],e);i.set(n,\"&#\"+r+\";\")}return i.set(\"\\\\xa0\",\"&#160;\"),i}(\"50,nbsp,51,iexcl,52,cent,53,pound,54,curren,55,yen,56,brvbar,57,sect,58,uml,59,copy,5a,ordf,5b,laquo,5c,not,5d,shy,5e,reg,5f,macr,5g,deg,5h,plusmn,5i,sup2,5j,sup3,5k,acute,5l,micro,5m,para,5n,middot,5o,cedil,5p,sup1,5q,ordm,5r,raquo,5s,frac14,5t,frac12,5u,frac34,5v,iquest,60,Agrave,61,Aacute,62,Acirc,63,Atilde,64,Auml,65,Aring,66,AElig,67,Ccedil,68,Egrave,69,Eacute,6a,Ecirc,6b,Euml,6c,Igrave,6d,Iacute,6e,Icirc,6f,Iuml,6g,ETH,6h,Ntilde,6i,Ograve,6j,Oacute,6k,Ocirc,6l,Otilde,6m,Ouml,6n,times,6o,Oslash,6p,Ugrave,6q,Uacute,6r,Ucirc,6s,Uuml,6t,Yacute,6u,THORN,6v,szlig,70,agrave,71,aacute,72,acirc,73,atilde,74,auml,75,aring,76,aelig,77,ccedil,78,egrave,79,eacute,7a,ecirc,7b,euml,7c,igrave,7d,iacute,7e,icirc,7f,iuml,7g,eth,7h,ntilde,7i,ograve,7j,oacute,7k,ocirc,7l,otilde,7m,ouml,7n,divide,7o,oslash,7p,ugrave,7q,uacute,7r,ucirc,7s,uuml,7t,yacute,7u,thorn,7v,yuml,ci,fnof,sh,Alpha,si,Beta,sj,Gamma,sk,Delta,sl,Epsilon,sm,Zeta,sn,Eta,so,Theta,sp,Iota,sq,Kappa,sr,Lambda,ss,Mu,st,Nu,su,Xi,sv,Omicron,t0,Pi,t1,Rho,t3,Sigma,t4,Tau,t5,Upsilon,t6,Phi,t7,Chi,t8,Psi,t9,Omega,th,alpha,ti,beta,tj,gamma,tk,delta,tl,epsilon,tm,zeta,tn,eta,to,theta,tp,iota,tq,kappa,tr,lambda,ts,mu,tt,nu,tu,xi,tv,omicron,u0,pi,u1,rho,u2,sigmaf,u3,sigma,u4,tau,u5,upsilon,u6,phi,u7,chi,u8,psi,u9,omega,uh,thetasym,ui,upsih,um,piv,812,bull,816,hellip,81i,prime,81j,Prime,81u,oline,824,frasl,88o,weierp,88h,image,88s,real,892,trade,89l,alefsym,8cg,larr,8ch,uarr,8ci,rarr,8cj,darr,8ck,harr,8dl,crarr,8eg,lArr,8eh,uArr,8ei,rArr,8ej,dArr,8ek,hArr,8g0,forall,8g2,part,8g3,exist,8g5,empty,8g7,nabla,8g8,isin,8g9,notin,8gb,ni,8gf,prod,8gh,sum,8gi,minus,8gn,lowast,8gq,radic,8gt,prop,8gu,infin,8h0,ang,8h7,and,8h8,or,8h9,cap,8ha,cup,8hb,int,8hk,there4,8hs,sim,8i5,cong,8i8,asymp,8j0,ne,8j1,equiv,8j4,le,8j5,ge,8k2,sub,8k3,sup,8k4,nsub,8k6,sube,8k7,supe,8kl,oplus,8kn,otimes,8l5,perp,8m5,sdot,8o8,lceil,8o9,rceil,8oa,lfloor,8ob,rfloor,8p9,lang,8pa,rang,9ea,loz,9j0,spades,9j3,clubs,9j5,hearts,9j6,diams,ai,OElig,aj,oelig,b0,Scaron,b1,scaron,bo,Yuml,m6,circ,ms,tilde,802,ensp,803,emsp,809,thinsp,80c,zwnj,80d,zwj,80e,lrm,80f,rlm,80j,ndash,80k,mdash,80o,lsquo,80p,rsquo,80q,sbquo,80s,ldquo,80t,rdquo,80u,bdquo,810,dagger,811,Dagger,81g,permil,81p,lsaquo,81q,rsaquo,85c,euro\",32),u={strokeStyle:{svgAttr:\"stroke\",canvas:\"#000000\",svg:\"none\",apply:\"stroke\"},fillStyle:{svgAttr:\"fill\",canvas:\"#000000\",svg:null,apply:\"fill\"},lineCap:{svgAttr:\"stroke-linecap\",canvas:\"butt\",svg:\"butt\",apply:\"stroke\"},lineJoin:{svgAttr:\"stroke-linejoin\",canvas:\"miter\",svg:\"miter\",apply:\"stroke\"},miterLimit:{svgAttr:\"stroke-miterlimit\",canvas:10,svg:4,apply:\"stroke\"},lineWidth:{svgAttr:\"stroke-width\",canvas:1,svg:1,apply:\"stroke\"},globalAlpha:{svgAttr:\"opacity\",canvas:1,svg:1,apply:\"fill stroke\"},font:{canvas:\"10px sans-serif\"},shadowColor:{canvas:\"#000000\"},shadowOffsetX:{canvas:0},shadowOffsetY:{canvas:0},shadowBlur:{canvas:0},textAlign:{canvas:\"start\"},textBaseline:{canvas:\"alphabetic\"},lineDash:{svgAttr:\"stroke-dasharray\",canvas:[],svg:null,apply:\"stroke\"}};class p{constructor(t,e){this.__root=t,this.__ctx=e}addColorStop(t,e){const i=this.__ctx.__createElement(\"stop\");if(i.setAttribute(\"offset\",`${t}`),-1!==e.indexOf(\"rgba\")){const t=/rgba\\(\\s*(\\d+)\\s*,\\s*(\\d+)\\s*,\\s*(\\d+)\\s*,\\s*(\\d?\\.?\\d*)\\s*\\)/gi.exec(e),[,s,n,r,a]=t;i.setAttribute(\"stop-color\",`rgb(${s},${n},${r})`),i.setAttribute(\"stop-opacity\",a)}else i.setAttribute(\"stop-color\",e);this.__root.appendChild(i)}}p.__name__=\"CanvasGradient\";class d{constructor(t,e){this.__root=t,this.__ctx=e}}d.__name__=\"CanvasPattern\";class m{constructor(t){var e,i,s;this.__currentPosition=null,this._transform=new r.AffineTransform,this._clip_path=null,this.__document=null!==(e=null==t?void 0:t.document)&&void 0!==e?e:document,(null==t?void 0:t.ctx)?this.__ctx=t.ctx:(this.__canvas=this.__document.createElement(\"canvas\"),this.__ctx=this.__canvas.getContext(\"2d\")),this.__setDefaultStyles(),this.__stack=[],this.__root=this.__document.createElementNS(\"http://www.w3.org/2000/svg\",\"svg\"),this.__root.setAttribute(\"version\",\"1.1\"),this.__root.setAttribute(\"xmlns\",\"http://www.w3.org/2000/svg\"),this.__root.setAttributeNS(\"http://www.w3.org/2000/xmlns/\",\"xmlns:xlink\",\"http://www.w3.org/1999/xlink\"),this.width=null!==(i=null==t?void 0:t.width)&&void 0!==i?i:500,this.height=null!==(s=null==t?void 0:t.height)&&void 0!==s?s:500,this.__ids={},this.__defs=this.__document.createElementNS(\"http://www.w3.org/2000/svg\",\"defs\"),this.__root.appendChild(this.__defs)}get canvas(){return this}get width(){return this._width}set width(t){this._width=t,this.__root.setAttribute(\"width\",`${t}`)}get height(){return this._height}set height(t){this._height=t,this.__root.setAttribute(\"height\",`${t}`)}__createElement(t,e={},i=!1){const s=this.__document.createElementNS(\"http://www.w3.org/2000/svg\",t);i&&(s.setAttribute(\"fill\",\"none\"),s.setAttribute(\"stroke\",\"none\"));const n=Object.keys(e);for(const t of n)s.setAttribute(t,`${e[t]}`);return s}__setDefaultStyles(){const t=Object.keys(u),e=this;for(let i=0;i<t.length;i++){const s=t[i];e[s]=u[s].canvas}}__applyStyleState(t){const e=Object.keys(t),i=this;for(let s=0;s<e.length;s++){const n=e[s];i[n]=t[n]}}__getStyleState(){const t=Object.keys(u),e={};for(let i=0;i<t.length;i++){const s=t[i];e[s]=this[s]}return e}__applyStyleToCurrentElement(t){var e;const i=this.__currentElement,s=Object.keys(u);for(let n=0;n<s.length;n++){const r=u[s[n]],o=this[s[n]];if(null===(e=r.apply)||void 0===e?void 0:e.includes(t))if(o instanceof d){for(const t of[...o.__ctx.__defs.childNodes])if(t instanceof Element){const e=t.getAttribute(\"id\");this.__ids[e]=e,this.__defs.appendChild(t)}const t=o.__root.getAttribute(\"id\");i.setAttribute(r.apply,`url(#${t})`)}else if(o instanceof p){const t=o.__root.getAttribute(\"id\");i.setAttribute(r.apply,`url(#${t})`)}else if(r.svg!==o)if(\"stroke\"!==r.svgAttr&&\"fill\"!==r.svgAttr||!a.isString(o)||-1===o.indexOf(\"rgba\")){let e=r.svgAttr;if(\"globalAlpha\"===s[n]&&(e=t+\"-\"+r.svgAttr,i.getAttribute(e)))continue;i.setAttribute(e,`${o}`)}else{const t=/rgba\\(\\s*(\\d+)\\s*,\\s*(\\d+)\\s*,\\s*(\\d+)\\s*,\\s*(\\d?\\.?\\d*)\\s*\\)/gi.exec(o),[,e,s,n,a]=t;i.setAttribute(r.svgAttr,`rgb(${e},${s},${n})`);let l=parseFloat(a);const h=this.globalAlpha;null!=h&&(l*=h),i.setAttribute(r.svgAttr+\"-opacity\",`${l}`)}}}get_serialized_svg(t=!1){let e=(new XMLSerializer).serializeToString(this.__root);if(/xmlns=\"http:\\/\\/www\\.w3\\.org\\/2000\\/svg\".+xmlns=\"http:\\/\\/www\\.w3\\.org\\/2000\\/svg/gi.test(e)&&(e=e.replace('xmlns=\"http://www.w3.org/2000/svg','xmlns:xlink=\"http://www.w3.org/1999/xlink')),t)for(const[t,i]of _){const s=new RegExp(t,\"gi\");s.test(e)&&(e=e.replace(s,i))}return e}get_svg(){return this.__root}save(){this.__stack.push({transform:this._transform,clip_path:this._clip_path,attributes:this.__getStyleState()}),this._transform=this._transform.clone()}restore(){if(0==this.__stack.length)return;const{transform:t,clip_path:e,attributes:i}=this.__stack.pop();this._transform=t,this._clip_path=e,this.__applyStyleState(i)}_apply_transform(t,e=this._transform){e.is_identity||t.setAttribute(\"transform\",e.toString())}scale(t,e){isFinite(t)&&(null==e||isFinite(e))&&this._transform.scale(t,null!=e?e:t)}rotate(t){isFinite(t)&&this._transform.rotate(t)}translate(t,e){isFinite(t+e)&&this._transform.translate(t,e)}transform(t,e,i,s,n,r){isFinite(t+e+i+s+n+r)&&this._transform.transform(t,e,i,s,n,r)}beginPath(){this.__currentDefaultPath=\"\",this.__currentPosition=null;const t=this.__createElement(\"path\",{},!0);this.__root.appendChild(t),this.__currentElement=t}__applyCurrentDefaultPath(){const t=this.__currentElement;\"path\"===t.nodeName?t.setAttribute(\"d\",this.__currentDefaultPath):console.error(\"Attempted to apply path command to node\",t.nodeName)}__addPathCommand(t,e,i){const s=this.__currentDefaultPath?\" \":\"\";this.__currentDefaultPath+=s+i,this.__currentPosition={x:t,y:e}}get _hasCurrentDefaultPath(){return!!this.__currentDefaultPath}moveTo(t,e){if(!isFinite(t+e))return;\"path\"!==this.__currentElement.nodeName&&this.beginPath();const[i,s]=this._transform.apply(t,e);this.__addPathCommand(i,s,`M ${i} ${s}`)}closePath(){this._hasCurrentDefaultPath&&this.__addPathCommand(NaN,NaN,\"Z\")}lineTo(t,e){if(isFinite(t+e))if(this._hasCurrentDefaultPath){const[i,s]=this._transform.apply(t,e);this.__addPathCommand(i,s,`L ${i} ${s}`)}else this.moveTo(t,e)}bezierCurveTo(t,e,i,s,n,r){if(!isFinite(t+e+i+s+n+r))return;const[a,o]=this._transform.apply(n,r),[l,h]=this._transform.apply(t,e),[c,_]=this._transform.apply(i,s);this.__addPathCommand(a,o,`C ${l} ${h} ${c} ${_} ${a} ${o}`)}quadraticCurveTo(t,e,i,s){if(!isFinite(t+e+i+s))return;const[n,r]=this._transform.apply(i,s),[a,o]=this._transform.apply(t,e);this.__addPathCommand(n,r,`Q ${a} ${o} ${n} ${r}`)}arcTo(t,e,i,s,n){if(!isFinite(t+e+i+s+n))return;if(null==this.__currentPosition)return;const r=this.__currentPosition.x,a=this.__currentPosition.y;if(n<0)throw new Error(\"IndexSizeError: The radius provided (\"+n+\") is negative.\");if(r===t&&a===e||t===i&&e===s||0===n)return void this.lineTo(t,e);function o([t,e]){const i=Math.sqrt(t**2+e**2);return[t/i,e/i]}const l=o([r-t,a-e]),h=o([i-t,s-e]);if(l[0]*h[1]==l[1]*h[0])return void this.lineTo(t,e);const c=l[0]*h[0]+l[1]*h[1],_=Math.acos(Math.abs(c)),u=o([l[0]+h[0],l[1]+h[1]]),p=n/Math.sin(_/2),d=t+p*u[0],m=e+p*u[1],f=[-l[1],l[0]],g=[h[1],-h[0]];function v(t){const e=t[0];return t[1]>=0?Math.acos(e):-Math.acos(e)}const w=v(f),b=v(g);this.lineTo(d+f[0]*n,m+f[1]*n),this.arc(d,m,n,w,b)}stroke(){\"path\"===this.__currentElement.nodeName&&this.__currentElement.setAttribute(\"paint-order\",\"fill\"),this.__applyCurrentDefaultPath(),this.__applyStyleToCurrentElement(\"stroke\"),null!=this._clip_path&&this.__currentElement.setAttribute(\"clip-path\",this._clip_path)}fill(t){if(\"path\"===this.__currentElement.nodeName&&this.__currentElement.setAttribute(\"paint-order\",\"stroke\"),\"none\"!=this.__currentElement.getAttribute(\"fill\")){const t=this.__currentElement.cloneNode(!0);this.__root.appendChild(t),this.__currentElement=t}this.__applyCurrentDefaultPath(),this.__applyStyleToCurrentElement(\"fill\"),null!=t&&this.__currentElement.setAttribute(\"fill-rule\",t),null!=this._clip_path&&this.__currentElement.setAttribute(\"clip-path\",this._clip_path)}rect(t,e,i,s){isFinite(t+e+i+s)&&(\"path\"!==this.__currentElement.nodeName&&this.beginPath(),this.moveTo(t,e),this.lineTo(t+i,e),this.lineTo(t+i,e+s),this.lineTo(t,e+s),this.lineTo(t,e))}fillRect(t,e,i,s){isFinite(t+e+i+s)&&(this.beginPath(),this.rect(t,e,i,s),this.fill())}strokeRect(t,e,i,s){isFinite(t+e+i+s)&&(this.beginPath(),this.rect(t,e,i,s),this.stroke())}__clearCanvas(){o.empty(this.__defs),o.empty(this.__root),this.__root.appendChild(this.__defs),this.__currentElement=this.__root}clearRect(t,e,i,s){if(!isFinite(t+e+i+s))return;if(0===t&&0===e&&i===this.width&&s===this.height)return void this.__clearCanvas();const n=this.__createElement(\"rect\",{x:t,y:e,width:i,height:s,fill:\"#FFFFFF\"},!0);this._apply_transform(n),this.__root.appendChild(n)}createLinearGradient(t,e,i,s){if(!isFinite(t+e+i+s))throw new Error(\"The provided double value is non-finite\");const[n,r]=this._transform.apply(t,e),[a,o]=this._transform.apply(i,s),h=this.__createElement(\"linearGradient\",{id:l(this.__ids),x1:`${n}px`,x2:`${a}px`,y1:`${r}px`,y2:`${o}px`,gradientUnits:\"userSpaceOnUse\"},!1);return this.__defs.appendChild(h),new p(h,this)}createRadialGradient(t,e,i,s,n,r){if(!isFinite(t+e+i+s+n+r))throw new Error(\"The provided double value is non-finite\");const[a,o]=this._transform.apply(t,e),[h,c]=this._transform.apply(s,n),_=this.__createElement(\"radialGradient\",{id:l(this.__ids),cx:`${h}px`,cy:`${c}px`,r:`${r}px`,fx:`${a}px`,fy:`${o}px`,gradientUnits:\"userSpaceOnUse\"},!1);return this.__defs.appendChild(_),new p(_,this)}__parseFont(){var t,e,i,s,n;const r=/^\\s*(?=(?:(?:[-a-z]+\\s*){0,2}(italic|oblique))?)(?=(?:(?:[-a-z]+\\s*){0,2}(small-caps))?)(?=(?:(?:[-a-z]+\\s*){0,2}(bold(?:er)?|lighter|[1-9]00))?)(?:(?:normal|\\1|\\2|\\3)\\s*){0,3}((?:xx?-)?(?:small|large)|medium|smaller|larger|[.\\d]+(?:\\%|in|[cem]m|ex|p[ctx]))(?:\\s*\\/\\s*(normal|[.\\d]+(?:\\%|in|[cem]m|ex|p[ctx])))?\\s*([-,\\'\\\"\\sa-z0-9]+?)\\s*$/i.exec(this.font),a={style:null!==(t=r[1])&&void 0!==t?t:\"normal\",size:null!==(e=r[4])&&void 0!==e?e:\"10px\",family:null!==(i=r[6])&&void 0!==i?i:\"sans-serif\",weight:null!==(s=r[3])&&void 0!==s?s:\"normal\",decoration:null!==(n=r[2])&&void 0!==n?n:\"normal\"};return\"underline\"===this.__fontUnderline&&(a.decoration=\"underline\"),null!=this.__fontHref&&(a.href=this.__fontHref),a}__wrapTextLink(t,e){if(t.href){const i=this.__createElement(\"a\");return i.setAttributeNS(\"http://www.w3.org/1999/xlink\",\"xlink:href\",t.href),i.appendChild(e),i}return e}__applyText(t,e,i,s){const n=this.__parseFont(),r=this.__createElement(\"text\",{\"font-family\":n.family,\"font-size\":n.size,\"font-style\":n.style,\"font-weight\":n.weight,\"text-decoration\":n.decoration,x:e,y:i,\"text-anchor\":h(this.textAlign),\"dominant-baseline\":c(this.textBaseline)},!0);r.appendChild(this.__document.createTextNode(t)),this._apply_transform(r),this.__currentElement=r,this.__applyStyleToCurrentElement(s),this.__root.appendChild(this.__wrapTextLink(n,r))}fillText(t,e,i){null!=t&&isFinite(e+i)&&this.__applyText(t,e,i,\"fill\")}strokeText(t,e,i){null!=t&&isFinite(e+i)&&this.__applyText(t,e,i,\"stroke\")}measureText(t){return this.__ctx.font=this.font,this.__ctx.measureText(t)}arc(t,e,i,s,n,r=!1){if(!isFinite(t+e+i+s+n))return;if(s===n)return;(s%=2*Math.PI)===(n%=2*Math.PI)&&(n=(n+2*Math.PI-.001*(r?-1:1))%(2*Math.PI));const a=t+i*Math.cos(n),o=e+i*Math.sin(n),l=t+i*Math.cos(s),h=e+i*Math.sin(s),c=r?0:1;let _=0,u=n-s;u<0&&(u+=2*Math.PI),_=r?u>Math.PI?0:1:u>Math.PI?1:0,this.lineTo(l,h);const p=i,d=i,[m,f]=this._transform.apply(a,o);this.__addPathCommand(m,f,`A ${p} ${d} 0 ${_} ${c} ${m} ${f}`)}clip(){const t=this.__createElement(\"clipPath\"),e=l(this.__ids);this.__applyCurrentDefaultPath(),t.setAttribute(\"id\",e),t.appendChild(this.__currentElement),this.__defs.appendChild(t),this._clip_path=`url(#${e})`}drawImage(t,...e){let i,s,n,r,a,o,l,h;if(2==e.length){if([i,s]=e,!isFinite(i+s))return;a=0,o=0,l=t.width,h=t.height,n=l,r=h}else if(4==e.length){if([i,s,n,r]=e,!isFinite(i+s+n+r))return;a=0,o=0,l=t.width,h=t.height}else{if(8!==e.length)throw new Error(`Inavlid number of arguments passed to drawImage: ${arguments.length}`);if([a,o,l,h,i,s,n,r]=e,!isFinite(a+o+l+h+i+s+n+r))return}const c=this.__root,_=this._transform.clone().translate(i,s);if(t instanceof m||t instanceof SVGSVGElement){const e=(t instanceof SVGSVGElement?t:t.get_svg()).cloneNode(!0);let i;_.is_identity?i=c:(i=this.__createElement(\"g\"),this._apply_transform(i,_),c.appendChild(i));for(const t of[...e.childNodes])if(t instanceof SVGDefsElement){for(const e of[...t.childNodes])if(e instanceof Element){const t=e.getAttribute(\"id\");this.__ids[t]=t,this.__defs.appendChild(e)}}else i.appendChild(t)}else if(t instanceof HTMLImageElement||t instanceof SVGImageElement){const e=this.__createElement(\"image\");if(e.setAttribute(\"width\",`${n}`),e.setAttribute(\"height\",`${r}`),e.setAttribute(\"preserveAspectRatio\",\"none\"),a||o||l!==t.width||h!==t.height){const e=this.__document.createElement(\"canvas\");e.width=n,e.height=r;e.getContext(\"2d\").drawImage(t,a,o,l,h,0,0,n,r),t=e}this._apply_transform(e,_);const i=t instanceof HTMLCanvasElement?t.toDataURL():t.getAttribute(\"src\");e.setAttributeNS(\"http://www.w3.org/1999/xlink\",\"xlink:href\",i),c.appendChild(e)}else if(t instanceof HTMLCanvasElement){const e=this.__createElement(\"image\");e.setAttribute(\"width\",`${n}`),e.setAttribute(\"height\",`${r}`),e.setAttribute(\"preserveAspectRatio\",\"none\");const i=this.__document.createElement(\"canvas\");i.width=n,i.height=r;const s=i.getContext(\"2d\");s.imageSmoothingEnabled=!1,s.drawImage(t,a,o,l,h,0,0,n,r),t=i,this._apply_transform(e,_),e.setAttributeNS(\"http://www.w3.org/1999/xlink\",\"xlink:href\",t.toDataURL()),c.appendChild(e)}}createPattern(t,e){const i=this.__document.createElementNS(\"http://www.w3.org/2000/svg\",\"pattern\"),s=l(this.__ids);if(i.setAttribute(\"id\",s),i.setAttribute(\"width\",`${this._to_number(t.width)}`),i.setAttribute(\"height\",`${this._to_number(t.height)}`),i.setAttribute(\"patternUnits\",\"userSpaceOnUse\"),t instanceof HTMLCanvasElement||t instanceof HTMLImageElement||t instanceof SVGImageElement){const e=this.__document.createElementNS(\"http://www.w3.org/2000/svg\",\"image\"),s=t instanceof HTMLCanvasElement?t.toDataURL():t.getAttribute(\"src\");e.setAttributeNS(\"http://www.w3.org/1999/xlink\",\"xlink:href\",s),i.appendChild(e),this.__defs.appendChild(i)}else if(t instanceof m){for(const e of[...t.__root.childNodes])e instanceof SVGDefsElement||i.appendChild(e);this.__defs.appendChild(i)}else{if(!(t instanceof SVGSVGElement))throw new Error(\"unsupported\");for(const e of[...t.childNodes])e instanceof SVGDefsElement||i.appendChild(e);this.__defs.appendChild(i)}return new d(i,this)}setLineDash(t){t&&t.length>0?this.lineDash=t.join(\",\"):this.lineDash=null}_to_number(t){return a.isNumber(t)?t:t.baseVal.value}}i.SVGRenderingContext2D=m,m.__name__=\"SVGRenderingContext2D\"},\n",
" function _(o,t,n,i,e){i();const s=o(238),c=o(15);class l extends s.ButtonToolButtonView{_clicked(){this.model.do.emit(void 0)}}n.ActionToolButtonView=l,l.__name__=\"ActionToolButtonView\";class _ extends s.ButtonToolView{connect_signals(){super.connect_signals(),this.connect(this.model.do,(o=>this.doit(o)))}}n.ActionToolView=_,_.__name__=\"ActionToolView\";class d extends s.ButtonTool{constructor(o){super(o),this.button_view=l,this.do=new c.Signal(this,\"do\")}}n.ActionTool=d,d.__name__=\"ActionTool\"},\n",
" function _(o,e,t,i,l){i();const s=o(251),n=o(242);class r extends s.ActionToolView{doit(){window.open(this.model.redirect)}}t.HelpToolView=r,r.__name__=\"HelpToolView\";class c extends s.ActionTool{constructor(o){super(o),this.tool_name=\"Help\",this.icon=n.tool_icon_help}static init_HelpTool(){this.prototype.default_view=r,this.define((({String:o})=>({redirect:[o,\"https://docs.bokeh.org/en/latest/docs/user_guide/tools.html\"]}))),this.override({description:\"Click the question mark to learn more about Bokeh plot tools.\"}),this.register_alias(\"help\",(()=>new c))}}t.HelpTool=c,c.__name__=\"HelpTool\",c.init_HelpTool()},\n",
" function _(o,l,g,A,r){A(),g.root=\"bk-root\",g.logo=\"bk-logo\",g.grey=\"bk-grey\",g.logo_small=\"bk-logo-small\",g.logo_notebook=\"bk-logo-notebook\",g.default=\".bk-root .bk-logo{margin:5px;position:relative;display:block;background-repeat:no-repeat;}.bk-root .bk-logo.bk-grey{filter:url(\\\"data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg'><filter id='grayscale'><feColorMatrix type='matrix' values='0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0'/></filter></svg>#grayscale\\\");filter:gray;-webkit-filter:grayscale(100%);}.bk-root .bk-logo-small{width:20px;height:20px;background-image:url();}.bk-root .bk-logo-notebook{display:inline-block;vertical-align:middle;margin-right:5px;}\"},\n",
" function _(t,e,i,s,l){s();const o=t(1),n=t(40),h=t(20),a=t(43),r=o.__importStar(t(255)),c=r;class d extends n.AnnotationView{initialize(){super.initialize(),this.el=a.div({class:c.tooltip}),a.undisplay(this.el),this.plot_view.canvas_view.add_overlay(this.el)}remove(){a.remove(this.el),super.remove()}connect_signals(){super.connect_signals(),this.connect(this.model.properties.content.change,(()=>this.render())),this.connect(this.model.properties.position.change,(()=>this._reposition()))}styles(){return[...super.styles(),r.default]}render(){this.model.visible||a.undisplay(this.el),super.render()}_render(){const{content:t}=this.model;null!=t?(a.empty(this.el),a.classes(this.el).toggle(\"bk-tooltip-custom\",this.model.custom),this.el.appendChild(t),this.model.show_arrow&&this.el.classList.add(c.tooltip_arrow)):a.undisplay(this.el)}_reposition(){const{position:t}=this.model;if(null==t)return void a.undisplay(this.el);const[e,i]=t,s=(()=>{const t=this.parent.layout.bbox.relative(),{attachment:s}=this.model;switch(s){case\"horizontal\":return e<t.hcenter?\"right\":\"left\";case\"vertical\":return i<t.vcenter?\"below\":\"above\";default:return s}})();let l;this.el.classList.remove(c.right),this.el.classList.remove(c.left),this.el.classList.remove(c.above),this.el.classList.remove(c.below),a.display(this.el);let o=null,n=null;switch(s){case\"right\":this.el.classList.add(c.left),o=e+(this.el.offsetWidth-this.el.clientWidth)+10,l=i-this.el.offsetHeight/2;break;case\"left\":this.el.classList.add(c.right),n=this.plot_view.layout.bbox.width-e+10,l=i-this.el.offsetHeight/2;break;case\"below\":this.el.classList.add(c.above),l=i+(this.el.offsetHeight-this.el.clientHeight)+10,o=Math.round(e-this.el.offsetWidth/2);break;case\"above\":this.el.classList.add(c.below),l=i-this.el.offsetHeight-10,o=Math.round(e-this.el.offsetWidth/2)}this.el.style.top=`${l}px`,this.el.style.left=null!=o?`${o}px`:\"auto\",this.el.style.right=null!=n?`${n}px`:\"auto\"}}i.TooltipView=d,d.__name__=\"TooltipView\";class p extends n.Annotation{constructor(t){super(t)}static init_Tooltip(){this.prototype.default_view=d,this.define((({Boolean:t})=>({attachment:[h.TooltipAttachment,\"horizontal\"],inner_only:[t,!0],show_arrow:[t,!0]}))),this.internal((({Boolean:t,Number:e,Tuple:i,Ref:s,Nullable:l})=>({position:[l(i(e,e)),null],content:[s(HTMLElement),()=>a.div()],custom:[t]}))),this.override({level:\"overlay\"})}clear(){this.position=null}}i.Tooltip=p,p.__name__=\"Tooltip\",p.init_Tooltip()},\n",
" function _(o,t,r,e,l){e(),r.root=\"bk-root\",r.tooltip=\"bk-tooltip\",r.left=\"bk-left\",r.tooltip_arrow=\"bk-tooltip-arrow\",r.right=\"bk-right\",r.above=\"bk-above\",r.below=\"bk-below\",r.tooltip_row_label=\"bk-tooltip-row-label\",r.tooltip_row_value=\"bk-tooltip-row-value\",r.tooltip_color_block=\"bk-tooltip-color-block\",r.default='.bk-root{}.bk-root .bk-tooltip{font-weight:300;font-size:12px;position:absolute;padding:5px;border:1px solid #e5e5e5;color:#2f2f2f;background-color:white;pointer-events:none;opacity:0.95;z-index:100;}.bk-root .bk-tooltip > div:not(:first-child){margin-top:5px;border-top:#e5e5e5 1px dashed;}.bk-root .bk-tooltip.bk-left.bk-tooltip-arrow::before{position:absolute;margin:-7px 0 0 0;top:50%;width:0;height:0;border-style:solid;border-width:7px 0 7px 0;border-color:transparent;content:\" \";display:block;left:-10px;border-right-width:10px;border-right-color:#909599;}.bk-root .bk-tooltip.bk-left::before{left:-10px;border-right-width:10px;border-right-color:#909599;}.bk-root .bk-tooltip.bk-right.bk-tooltip-arrow::after{position:absolute;margin:-7px 0 0 0;top:50%;width:0;height:0;border-style:solid;border-width:7px 0 7px 0;border-color:transparent;content:\" \";display:block;right:-10px;border-left-width:10px;border-left-color:#909599;}.bk-root .bk-tooltip.bk-right::after{right:-10px;border-left-width:10px;border-left-color:#909599;}.bk-root .bk-tooltip.bk-above::before{position:absolute;margin:0 0 0 -7px;left:50%;width:0;height:0;border-style:solid;border-width:0 7px 0 7px;border-color:transparent;content:\" \";display:block;top:-10px;border-bottom-width:10px;border-bottom-color:#909599;}.bk-root .bk-tooltip.bk-below::after{position:absolute;margin:0 0 0 -7px;left:50%;width:0;height:0;border-style:solid;border-width:0 7px 0 7px;border-color:transparent;content:\" \";display:block;bottom:-10px;border-top-width:10px;border-top-color:#909599;}.bk-root .bk-tooltip-row-label{text-align:right;color:#26aae1;}.bk-root .bk-tooltip-row-value{color:default;}.bk-root .bk-tooltip-color-block{width:12px;height:12px;margin-left:5px;margin-right:5px;outline:#dddddd solid 1px;display:inline-block;}'},\n",
" function _(e,t,i,s,r){s();const a=e(135),h=e(133),_=e(122),l=e(48);class o extends a.UpperLowerView{async lazy_initialize(){await super.lazy_initialize();const{lower_head:e,upper_head:t}=this.model;null!=e&&(this.lower_head=await _.build_view(e,{parent:this})),null!=t&&(this.upper_head=await _.build_view(t,{parent:this}))}set_data(e){var t,i;super.set_data(e),null===(t=this.lower_head)||void 0===t||t.set_data(e),null===(i=this.upper_head)||void 0===i||i.set_data(e)}paint(e){if(this.visuals.line.doit)for(let t=0,i=this._lower_sx.length;t<i;t++)this.visuals.line.set_vectorize(e,t),e.beginPath(),e.moveTo(this._lower_sx[t],this._lower_sy[t]),e.lineTo(this._upper_sx[t],this._upper_sy[t]),e.stroke();const t=\"height\"==this.model.dimension?0:Math.PI/2;if(null!=this.lower_head)for(let i=0,s=this._lower_sx.length;i<s;i++)e.save(),e.translate(this._lower_sx[i],this._lower_sy[i]),e.rotate(t+Math.PI),this.lower_head.render(e,i),e.restore();if(null!=this.upper_head)for(let i=0,s=this._upper_sx.length;i<s;i++)e.save(),e.translate(this._upper_sx[i],this._upper_sy[i]),e.rotate(t),this.upper_head.render(e,i),e.restore()}}i.WhiskerView=o,o.__name__=\"WhiskerView\";class n extends a.UpperLower{constructor(e){super(e)}static init_Whisker(){this.prototype.default_view=o,this.mixins(l.LineVector),this.define((({Ref:e,Nullable:t})=>({lower_head:[t(e(h.ArrowHead)),()=>new h.TeeHead({size:10})],upper_head:[t(e(h.ArrowHead)),()=>new h.TeeHead({size:10})]}))),this.override({level:\"underlay\"})}}i.Whisker=n,n.__name__=\"Whisker\",n.init_Whisker()},\n",
" function _(n,o,t,u,e){u(),e(\"CustomJS\",n(258).CustomJS),e(\"OpenURL\",n(260).OpenURL)},\n",
" function _(t,s,e,n,c){n();const u=t(259),i=t(13),a=t(34);class r extends u.Callback{constructor(t){super(t)}static init_CustomJS(){this.define((({Unknown:t,String:s,Dict:e})=>({args:[e(t),{}],code:[s,\"\"]})))}get names(){return i.keys(this.args)}get values(){return i.values(this.args)}get func(){const t=a.use_strict(this.code);return new Function(...this.names,\"cb_obj\",\"cb_data\",t)}execute(t,s={}){return this.func.apply(t,this.values.concat(t,s))}}e.CustomJS=r,r.__name__=\"CustomJS\",r.init_CustomJS()},\n",
" function _(c,a,l,n,s){n();const e=c(53);class o extends e.Model{constructor(c){super(c)}}l.Callback=o,o.__name__=\"Callback\"},\n",
" function _(e,n,t,o,i){o();const s=e(259),c=e(182),r=e(8);class a extends s.Callback{constructor(e){super(e)}static init_OpenURL(){this.define((({Boolean:e,String:n})=>({url:[n,\"http://\"],same_tab:[e,!1]})))}execute(e,{source:n}){const t=e=>{const t=c.replace_placeholders(this.url,n,e,void 0,void 0,encodeURIComponent);if(!r.isString(t))throw new Error(\"HTML output is not supported in this context\");this.same_tab?window.location.href=t:window.open(t)},{selected:o}=n;for(const e of o.indices)t(e);for(const e of o.line_indices)t(e)}}t.OpenURL=a,a.__name__=\"OpenURL\",a.init_OpenURL()},\n",
" function _(a,n,e,r,s){r(),s(\"Canvas\",a(262).Canvas),s(\"CartesianFrame\",a(144).CartesianFrame)},\n",
" function _(e,t,s,i,a){i();const l=e(14),n=e(240),r=e(19),o=e(43),h=e(20),_=e(13),c=e(263),d=e(99),p=e(249),v=(()=>{const e=document.createElement(\"canvas\"),t=e.getContext(\"webgl\",{premultipliedAlpha:!0});return null!=t?{canvas:e,gl:t}:void r.logger.trace(\"WebGL is not supported\")})(),u={position:\"absolute\",top:\"0\",left:\"0\",width:\"100%\",height:\"100%\"};class b extends n.DOMView{constructor(){super(...arguments),this.bbox=new d.BBox}initialize(){super.initialize(),\"webgl\"==this.model.output_backend&&(this.webgl=v),this.underlays_el=o.div({style:u}),this.primary=this.create_layer(),this.overlays=this.create_layer(),this.overlays_el=o.div({style:u}),this.events_el=o.div({class:\"bk-canvas-events\",style:u});const e=[this.underlays_el,this.primary.el,this.overlays.el,this.overlays_el,this.events_el];_.extend(this.el.style,u),o.append(this.el,...e),this.ui_event_bus=new c.UIEventBus(this)}remove(){this.ui_event_bus.destroy(),super.remove()}add_underlay(e){this.underlays_el.appendChild(e)}add_overlay(e){this.overlays_el.appendChild(e)}add_event(e){this.events_el.appendChild(e)}get pixel_ratio(){return this.primary.pixel_ratio}resize(e,t){this.bbox=new d.BBox({left:0,top:0,width:e,height:t}),this.primary.resize(e,t),this.overlays.resize(e,t)}prepare_webgl(e){const{webgl:t}=this;if(null!=t){const{width:s,height:i}=this.bbox;t.canvas.width=this.pixel_ratio*s,t.canvas.height=this.pixel_ratio*i;const{gl:a}=t;a.enable(a.SCISSOR_TEST);const[l,n,r,o]=e,{xview:h,yview:_}=this.bbox,c=h.compute(l),d=_.compute(n+o),p=this.pixel_ratio;a.scissor(p*c,p*d,p*r,p*o),a.enable(a.BLEND),a.blendFuncSeparate(a.SRC_ALPHA,a.ONE_MINUS_SRC_ALPHA,a.ONE_MINUS_DST_ALPHA,a.ONE),this._clear_webgl()}}blit_webgl(e){const{webgl:t}=this;if(null!=t){if(r.logger.debug(\"Blitting WebGL canvas\"),e.restore(),e.drawImage(t.canvas,0,0),e.save(),this.model.hidpi){const t=this.pixel_ratio;e.scale(t,t),e.translate(.5,.5)}this._clear_webgl()}}_clear_webgl(){const{webgl:e}=this;if(null!=e){const{gl:t,canvas:s}=e;t.viewport(0,0,s.width,s.height),t.clearColor(0,0,0,0),t.clear(t.COLOR_BUFFER_BIT|t.DEPTH_BUFFER_BIT)}}compose(){const e=this.create_layer(),{width:t,height:s}=this.bbox;return e.resize(t,s),e.ctx.drawImage(this.primary.canvas,0,0),e.ctx.drawImage(this.overlays.canvas,0,0),e}create_layer(){const{output_backend:e,hidpi:t}=this.model;return new p.CanvasLayer(e,t)}to_blob(){return this.compose().to_blob()}}s.CanvasView=b,b.__name__=\"CanvasView\";class g extends l.HasProps{constructor(e){super(e)}static init_Canvas(){this.prototype.default_view=b,this.internal((({Boolean:e})=>({hidpi:[e,!0],output_backend:[h.OutputBackend,\"canvas\"]})))}}s.Canvas=g,g.__name__=\"Canvas\",g.init_Canvas()},\n",
" function _(t,e,s,n,i){n();const r=t(1),a=r.__importDefault(t(239)),_=t(15),h=t(19),o=t(43),l=r.__importStar(t(264)),c=t(265),p=t(9),u=t(8),v=t(27),d=t(244);class g{constructor(t){this.canvas_view=t,this.pan_start=new _.Signal(this,\"pan:start\"),this.pan=new _.Signal(this,\"pan\"),this.pan_end=new _.Signal(this,\"pan:end\"),this.pinch_start=new _.Signal(this,\"pinch:start\"),this.pinch=new _.Signal(this,\"pinch\"),this.pinch_end=new _.Signal(this,\"pinch:end\"),this.rotate_start=new _.Signal(this,\"rotate:start\"),this.rotate=new _.Signal(this,\"rotate\"),this.rotate_end=new _.Signal(this,\"rotate:end\"),this.tap=new _.Signal(this,\"tap\"),this.doubletap=new _.Signal(this,\"doubletap\"),this.press=new _.Signal(this,\"press\"),this.pressup=new _.Signal(this,\"pressup\"),this.move_enter=new _.Signal(this,\"move:enter\"),this.move=new _.Signal(this,\"move\"),this.move_exit=new _.Signal(this,\"move:exit\"),this.scroll=new _.Signal(this,\"scroll\"),this.keydown=new _.Signal(this,\"keydown\"),this.keyup=new _.Signal(this,\"keyup\"),this.hammer=new a.default(this.hit_area,{touchAction:\"auto\",inputClass:a.default.TouchMouseInput}),this._prev_move=null,this._curr_pan=null,this._curr_pinch=null,this._curr_rotate=null,this._configure_hammerjs(),this.hit_area.addEventListener(\"mousemove\",(t=>this._mouse_move(t))),this.hit_area.addEventListener(\"mouseenter\",(t=>this._mouse_enter(t))),this.hit_area.addEventListener(\"mouseleave\",(t=>this._mouse_exit(t))),this.hit_area.addEventListener(\"contextmenu\",(t=>this._context_menu(t))),this.hit_area.addEventListener(\"wheel\",(t=>this._mouse_wheel(t))),document.addEventListener(\"keydown\",this),document.addEventListener(\"keyup\",this),this.menu=new d.ContextMenu([],{prevent_hide:t=>2==t.button&&t.target==this.hit_area}),this.hit_area.appendChild(this.menu.el)}get hit_area(){return this.canvas_view.events_el}destroy(){this.menu.remove(),this.hammer.destroy(),document.removeEventListener(\"keydown\",this),document.removeEventListener(\"keyup\",this)}handleEvent(t){\"keydown\"==t.type?this._key_down(t):\"keyup\"==t.type&&this._key_up(t)}_configure_hammerjs(){this.hammer.get(\"doubletap\").recognizeWith(\"tap\"),this.hammer.get(\"tap\").requireFailure(\"doubletap\"),this.hammer.get(\"doubletap\").dropRequireFailure(\"tap\"),this.hammer.on(\"doubletap\",(t=>this._doubletap(t))),this.hammer.on(\"tap\",(t=>this._tap(t))),this.hammer.on(\"press\",(t=>this._press(t))),this.hammer.on(\"pressup\",(t=>this._pressup(t))),this.hammer.get(\"pan\").set({direction:a.default.DIRECTION_ALL}),this.hammer.on(\"panstart\",(t=>this._pan_start(t))),this.hammer.on(\"pan\",(t=>this._pan(t))),this.hammer.on(\"panend\",(t=>this._pan_end(t))),this.hammer.get(\"pinch\").set({enable:!0}),this.hammer.on(\"pinchstart\",(t=>this._pinch_start(t))),this.hammer.on(\"pinch\",(t=>this._pinch(t))),this.hammer.on(\"pinchend\",(t=>this._pinch_end(t))),this.hammer.get(\"rotate\").set({enable:!0}),this.hammer.on(\"rotatestart\",(t=>this._rotate_start(t))),this.hammer.on(\"rotate\",(t=>this._rotate(t))),this.hammer.on(\"rotateend\",(t=>this._rotate_end(t)))}register_tool(t){const e=t.model.event_type;null!=e&&(u.isString(e)?this._register_tool(t,e):e.forEach(((e,s)=>this._register_tool(t,e,s<1))))}_register_tool(t,e,s=!0){const n=t,{id:i}=n.model,r=t=>e=>{e.id==i&&t(e.e)},a=t=>e=>{t(e.e)};switch(e){case\"pan\":null!=n._pan_start&&n.connect(this.pan_start,r(n._pan_start.bind(n))),null!=n._pan&&n.connect(this.pan,r(n._pan.bind(n))),null!=n._pan_end&&n.connect(this.pan_end,r(n._pan_end.bind(n)));break;case\"pinch\":null!=n._pinch_start&&n.connect(this.pinch_start,r(n._pinch_start.bind(n))),null!=n._pinch&&n.connect(this.pinch,r(n._pinch.bind(n))),null!=n._pinch_end&&n.connect(this.pinch_end,r(n._pinch_end.bind(n)));break;case\"rotate\":null!=n._rotate_start&&n.connect(this.rotate_start,r(n._rotate_start.bind(n))),null!=n._rotate&&n.connect(this.rotate,r(n._rotate.bind(n))),null!=n._rotate_end&&n.connect(this.rotate_end,r(n._rotate_end.bind(n)));break;case\"move\":null!=n._move_enter&&n.connect(this.move_enter,r(n._move_enter.bind(n))),null!=n._move&&n.connect(this.move,r(n._move.bind(n))),null!=n._move_exit&&n.connect(this.move_exit,r(n._move_exit.bind(n)));break;case\"tap\":null!=n._tap&&n.connect(this.tap,r(n._tap.bind(n))),null!=n._doubletap&&n.connect(this.doubletap,r(n._doubletap.bind(n)));break;case\"press\":null!=n._press&&n.connect(this.press,r(n._press.bind(n))),null!=n._pressup&&n.connect(this.pressup,r(n._pressup.bind(n)));break;case\"scroll\":null!=n._scroll&&n.connect(this.scroll,r(n._scroll.bind(n)));break;default:throw new Error(`unsupported event_type: ${e}`)}s&&(null!=n._keydown&&n.connect(this.keydown,a(n._keydown.bind(n))),null!=n._keyup&&n.connect(this.keyup,a(n._keyup.bind(n))),v.is_mobile&&null!=n._scroll&&\"pinch\"==e&&(h.logger.debug(\"Registering scroll on touch screen\"),n.connect(this.scroll,r(n._scroll.bind(n)))))}_hit_test_renderers(t,e,s){var n;const i=t.get_renderer_views();for(const t of p.reversed(i))if(null===(n=t.interactive_hit)||void 0===n?void 0:n.call(t,e,s))return t;return null}set_cursor(t=\"default\"){this.hit_area.style.cursor=t}_hit_test_frame(t,e,s){return t.frame.bbox.contains(e,s)}_hit_test_canvas(t,e,s){return t.layout.bbox.contains(e,s)}_hit_test_plot(t,e){for(const s of this.canvas_view.plot_views)if(s.layout.bbox.relative().contains(t,e))return s;return null}_trigger(t,e,s){var n;const{sx:i,sy:r}=e,a=this._hit_test_plot(i,r),_=t=>{const[s,n]=[i,r];return Object.assign(Object.assign({},e),{sx:s,sy:n})};if(\"panstart\"==e.type||\"pan\"==e.type||\"panend\"==e.type){let n;if(\"panstart\"==e.type&&null!=a?(this._curr_pan={plot_view:a},n=a):\"pan\"==e.type&&null!=this._curr_pan?n=this._curr_pan.plot_view:\"panend\"==e.type&&null!=this._curr_pan?(n=this._curr_pan.plot_view,this._curr_pan=null):n=null,null!=n){const e=_();this.__trigger(n,t,e,s)}}else if(\"pinchstart\"==e.type||\"pinch\"==e.type||\"pinchend\"==e.type){let n;if(\"pinchstart\"==e.type&&null!=a?(this._curr_pinch={plot_view:a},n=a):\"pinch\"==e.type&&null!=this._curr_pinch?n=this._curr_pinch.plot_view:\"pinchend\"==e.type&&null!=this._curr_pinch?(n=this._curr_pinch.plot_view,this._curr_pinch=null):n=null,null!=n){const e=_();this.__trigger(n,t,e,s)}}else if(\"rotatestart\"==e.type||\"rotate\"==e.type||\"rotateend\"==e.type){let n;if(\"rotatestart\"==e.type&&null!=a?(this._curr_rotate={plot_view:a},n=a):\"rotate\"==e.type&&null!=this._curr_rotate?n=this._curr_rotate.plot_view:\"rotateend\"==e.type&&null!=this._curr_rotate?(n=this._curr_rotate.plot_view,this._curr_rotate=null):n=null,null!=n){const e=_();this.__trigger(n,t,e,s)}}else if(\"mouseenter\"==e.type||\"mousemove\"==e.type||\"mouseleave\"==e.type){const h=null===(n=this._prev_move)||void 0===n?void 0:n.plot_view;if(null!=h&&(\"mouseleave\"==e.type||h!=a)){const{sx:t,sy:e}=_();this.__trigger(h,this.move_exit,{type:\"mouseleave\",sx:t,sy:e,shiftKey:!1,ctrlKey:!1},s)}if(null!=a&&(\"mouseenter\"==e.type||h!=a)){const{sx:t,sy:e}=_();this.__trigger(a,this.move_enter,{type:\"mouseenter\",sx:t,sy:e,shiftKey:!1,ctrlKey:!1},s)}if(null!=a&&\"mousemove\"==e.type){const e=_();this.__trigger(a,t,e,s)}this._prev_move={sx:i,sy:r,plot_view:a}}else if(null!=a){const e=_();this.__trigger(a,t,e,s)}}__trigger(t,e,s,n){var i,r;const a=t.model.toolbar.gestures,_=e.name.split(\":\")[0],h=this._hit_test_renderers(t,s.sx,s.sy),o=this._hit_test_canvas(t,s.sx,s.sy);switch(_){case\"move\":{const n=a[_].active;null!=n&&this.trigger(e,s,n.id);const r=t.model.toolbar.inspectors.filter((t=>t.active));let l=\"default\";null!=h?(l=null!==(i=h.cursor(s.sx,s.sy))&&void 0!==i?i:l,p.is_empty(r)||(e=this.move_exit)):this._hit_test_frame(t,s.sx,s.sy)&&(p.is_empty(r)||(l=\"crosshair\")),this.set_cursor(l),t.set_toolbar_visibility(o),r.map((t=>this.trigger(e,s,t.id)));break}case\"tap\":{const{target:t}=n;if(null!=t&&t!=this.hit_area)return;null!=h&&null!=h.on_hit&&h.on_hit(s.sx,s.sy);const i=a[_].active;null!=i&&this.trigger(e,s,i.id);break}case\"doubletap\":{const t=null!==(r=a.doubletap.active)&&void 0!==r?r:a.tap.active;null!=t&&this.trigger(e,s,t.id);break}case\"scroll\":{const t=a[v.is_mobile?\"pinch\":\"scroll\"].active;null!=t&&(n.preventDefault(),n.stopPropagation(),this.trigger(e,s,t.id));break}case\"pan\":{const t=a[_].active;null!=t&&(n.preventDefault(),this.trigger(e,s,t.id));break}default:{const t=a[_].active;null!=t&&this.trigger(e,s,t.id)}}this._trigger_bokeh_event(t,s)}trigger(t,e,s=null){t.emit({id:s,e})}_trigger_bokeh_event(t,e){const s=(()=>{const{sx:s,sy:n}=e,i=t.frame.x_scale.invert(s),r=t.frame.y_scale.invert(n);switch(e.type){case\"wheel\":return new l.MouseWheel(s,n,i,r,e.delta);case\"mousemove\":return new l.MouseMove(s,n,i,r);case\"mouseenter\":return new l.MouseEnter(s,n,i,r);case\"mouseleave\":return new l.MouseLeave(s,n,i,r);case\"tap\":return new l.Tap(s,n,i,r);case\"doubletap\":return new l.DoubleTap(s,n,i,r);case\"press\":return new l.Press(s,n,i,r);case\"pressup\":return new l.PressUp(s,n,i,r);case\"pan\":return new l.Pan(s,n,i,r,e.deltaX,e.deltaY);case\"panstart\":return new l.PanStart(s,n,i,r);case\"panend\":return new l.PanEnd(s,n,i,r);case\"pinch\":return new l.Pinch(s,n,i,r,e.scale);case\"pinchstart\":return new l.PinchStart(s,n,i,r);case\"pinchend\":return new l.PinchEnd(s,n,i,r);case\"rotate\":return new l.Rotate(s,n,i,r,e.rotation);case\"rotatestart\":return new l.RotateStart(s,n,i,r);case\"rotateend\":return new l.RotateEnd(s,n,i,r);default:return}})();null!=s&&t.model.trigger_event(s)}_get_sxy(t){const{pageX:e,pageY:s}=function(t){return\"undefined\"!=typeof TouchEvent&&t instanceof TouchEvent}(t)?(0!=t.touches.length?t.touches:t.changedTouches)[0]:t,{left:n,top:i}=o.offset(this.hit_area);return{sx:e-n,sy:s-i}}_pan_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t.srcEvent)),{deltaX:t.deltaX,deltaY:t.deltaY,shiftKey:t.srcEvent.shiftKey,ctrlKey:t.srcEvent.ctrlKey})}_pinch_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t.srcEvent)),{scale:t.scale,shiftKey:t.srcEvent.shiftKey,ctrlKey:t.srcEvent.ctrlKey})}_rotate_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t.srcEvent)),{rotation:t.rotation,shiftKey:t.srcEvent.shiftKey,ctrlKey:t.srcEvent.ctrlKey})}_tap_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t.srcEvent)),{shiftKey:t.srcEvent.shiftKey,ctrlKey:t.srcEvent.ctrlKey})}_move_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t)),{shiftKey:t.shiftKey,ctrlKey:t.ctrlKey})}_scroll_event(t){return Object.assign(Object.assign({type:t.type},this._get_sxy(t)),{delta:c.getDeltaY(t),shiftKey:t.shiftKey,ctrlKey:t.ctrlKey})}_key_event(t){return{type:t.type,keyCode:t.keyCode}}_pan_start(t){const e=this._pan_event(t);e.sx-=t.deltaX,e.sy-=t.deltaY,this._trigger(this.pan_start,e,t.srcEvent)}_pan(t){this._trigger(this.pan,this._pan_event(t),t.srcEvent)}_pan_end(t){this._trigger(this.pan_end,this._pan_event(t),t.srcEvent)}_pinch_start(t){this._trigger(this.pinch_start,this._pinch_event(t),t.srcEvent)}_pinch(t){this._trigger(this.pinch,this._pinch_event(t),t.srcEvent)}_pinch_end(t){this._trigger(this.pinch_end,this._pinch_event(t),t.srcEvent)}_rotate_start(t){this._trigger(this.rotate_start,this._rotate_event(t),t.srcEvent)}_rotate(t){this._trigger(this.rotate,this._rotate_event(t),t.srcEvent)}_rotate_end(t){this._trigger(this.rotate_end,this._rotate_event(t),t.srcEvent)}_tap(t){this._trigger(this.tap,this._tap_event(t),t.srcEvent)}_doubletap(t){this._trigger(this.doubletap,this._tap_event(t),t.srcEvent)}_press(t){this._trigger(this.press,this._tap_event(t),t.srcEvent)}_pressup(t){this._trigger(this.pressup,this._tap_event(t),t.srcEvent)}_mouse_enter(t){this._trigger(this.move_enter,this._move_event(t),t)}_mouse_move(t){this._trigger(this.move,this._move_event(t),t)}_mouse_exit(t){this._trigger(this.move_exit,this._move_event(t),t)}_mouse_wheel(t){this._trigger(this.scroll,this._scroll_event(t),t)}_context_menu(t){!this.menu.is_open&&this.menu.can_open&&t.preventDefault();const{sx:e,sy:s}=this._get_sxy(t);this.menu.toggle({left:e,top:s})}_key_down(t){this.trigger(this.keydown,this._key_event(t))}_key_up(t){this.trigger(this.keyup,this._key_event(t))}}s.UIEventBus=g,g.__name__=\"UIEventBus\"},\n",
" function _(e,t,s,n,_){n();var a=this&&this.__decorate||function(e,t,s,n){var _,a=arguments.length,o=a<3?t:null===n?n=Object.getOwnPropertyDescriptor(t,s):n;if(\"object\"==typeof Reflect&&\"function\"==typeof Reflect.decorate)o=Reflect.decorate(e,t,s,n);else for(var c=e.length-1;c>=0;c--)(_=e[c])&&(o=(a<3?_(o):a>3?_(t,s,o):_(t,s))||o);return a>3&&o&&Object.defineProperty(t,s,o),o};function o(e){return function(t){t.prototype.event_name=e}}class c{to_json(){const{event_name:e}=this;return{event_name:e,event_values:this._to_json()}}}s.BokehEvent=c,c.__name__=\"BokehEvent\";class r extends c{constructor(){super(...arguments),this.origin=null}_to_json(){return{model:this.origin}}}s.ModelEvent=r,r.__name__=\"ModelEvent\";let l=class extends c{_to_json(){return{}}};s.DocumentReady=l,l.__name__=\"DocumentReady\",s.DocumentReady=l=a([o(\"document_ready\")],l);let i=class extends r{};s.ButtonClick=i,i.__name__=\"ButtonClick\",s.ButtonClick=i=a([o(\"button_click\")],i);let u=class extends r{constructor(e){super(),this.item=e}_to_json(){const{item:e}=this;return Object.assign(Object.assign({},super._to_json()),{item:e})}};s.MenuItemClick=u,u.__name__=\"MenuItemClick\",s.MenuItemClick=u=a([o(\"menu_item_click\")],u);class d extends r{}s.UIEvent=d,d.__name__=\"UIEvent\";let h=class extends d{};s.LODStart=h,h.__name__=\"LODStart\",s.LODStart=h=a([o(\"lodstart\")],h);let m=class extends d{};s.LODEnd=m,m.__name__=\"LODEnd\",s.LODEnd=m=a([o(\"lodend\")],m);let x=class extends d{constructor(e,t){super(),this.geometry=e,this.final=t}_to_json(){const{geometry:e,final:t}=this;return Object.assign(Object.assign({},super._to_json()),{geometry:e,final:t})}};s.SelectionGeometry=x,x.__name__=\"SelectionGeometry\",s.SelectionGeometry=x=a([o(\"selectiongeometry\")],x);let p=class extends d{};s.Reset=p,p.__name__=\"Reset\",s.Reset=p=a([o(\"reset\")],p);class j extends d{constructor(e,t,s,n){super(),this.sx=e,this.sy=t,this.x=s,this.y=n}_to_json(){const{sx:e,sy:t,x:s,y:n}=this;return Object.assign(Object.assign({},super._to_json()),{sx:e,sy:t,x:s,y:n})}}s.PointEvent=j,j.__name__=\"PointEvent\";let y=class extends j{constructor(e,t,s,n,_,a){super(e,t,s,n),this.sx=e,this.sy=t,this.x=s,this.y=n,this.delta_x=_,this.delta_y=a}_to_json(){const{delta_x:e,delta_y:t}=this;return Object.assign(Object.assign({},super._to_json()),{delta_x:e,delta_y:t})}};s.Pan=y,y.__name__=\"Pan\",s.Pan=y=a([o(\"pan\")],y);let P=class extends j{constructor(e,t,s,n,_){super(e,t,s,n),this.sx=e,this.sy=t,this.x=s,this.y=n,this.scale=_}_to_json(){const{scale:e}=this;return Object.assign(Object.assign({},super._to_json()),{scale:e})}};s.Pinch=P,P.__name__=\"Pinch\",s.Pinch=P=a([o(\"pinch\")],P);let v=class extends j{constructor(e,t,s,n,_){super(e,t,s,n),this.sx=e,this.sy=t,this.x=s,this.y=n,this.rotation=_}_to_json(){const{rotation:e}=this;return Object.assign(Object.assign({},super._to_json()),{rotation:e})}};s.Rotate=v,v.__name__=\"Rotate\",s.Rotate=v=a([o(\"rotate\")],v);let g=class extends j{constructor(e,t,s,n,_){super(e,t,s,n),this.sx=e,this.sy=t,this.x=s,this.y=n,this.delta=_}_to_json(){const{delta:e}=this;return Object.assign(Object.assign({},super._to_json()),{delta:e})}};s.MouseWheel=g,g.__name__=\"MouseWheel\",s.MouseWheel=g=a([o(\"wheel\")],g);let E=class extends j{};s.MouseMove=E,E.__name__=\"MouseMove\",s.MouseMove=E=a([o(\"mousemove\")],E);let O=class extends j{};s.MouseEnter=O,O.__name__=\"MouseEnter\",s.MouseEnter=O=a([o(\"mouseenter\")],O);let b=class extends j{};s.MouseLeave=b,b.__name__=\"MouseLeave\",s.MouseLeave=b=a([o(\"mouseleave\")],b);let M=class extends j{};s.Tap=M,M.__name__=\"Tap\",s.Tap=M=a([o(\"tap\")],M);let R=class extends j{};s.DoubleTap=R,R.__name__=\"DoubleTap\",s.DoubleTap=R=a([o(\"doubletap\")],R);let f=class extends j{};s.Press=f,f.__name__=\"Press\",s.Press=f=a([o(\"press\")],f);let S=class extends j{};s.PressUp=S,S.__name__=\"PressUp\",s.PressUp=S=a([o(\"pressup\")],S);let D=class extends j{};s.PanStart=D,D.__name__=\"PanStart\",s.PanStart=D=a([o(\"panstart\")],D);let k=class extends j{};s.PanEnd=k,k.__name__=\"PanEnd\",s.PanEnd=k=a([o(\"panend\")],k);let L=class extends j{};s.PinchStart=L,L.__name__=\"PinchStart\",s.PinchStart=L=a([o(\"pinchstart\")],L);let C=class extends j{};s.PinchEnd=C,C.__name__=\"PinchEnd\",s.PinchEnd=C=a([o(\"pinchend\")],C);let T=class extends j{};s.RotateStart=T,T.__name__=\"RotateStart\",s.RotateStart=T=a([o(\"rotatestart\")],T);let B=class extends j{};s.RotateEnd=B,B.__name__=\"RotateEnd\",s.RotateEnd=B=a([o(\"rotateend\")],B)},\n",
" function _(t,e,n,l,o){\n",
" /*!\n",
" * jQuery Mousewheel 3.1.13\n",
" *\n",
" * Copyright jQuery Foundation and other contributors\n",
" * Released under the MIT license\n",
" * http://jquery.org/license\n",
" */\n",
" function u(t){const e=getComputedStyle(t).fontSize;return null!=e?parseInt(e,10):null}l(),n.getDeltaY=function(t){let e=-t.deltaY;if(t.target instanceof HTMLElement)switch(t.deltaMode){case t.DOM_DELTA_LINE:e*=(n=t.target,null!==(a=null!==(o=u(null!==(l=n.offsetParent)&&void 0!==l?l:document.body))&&void 0!==o?o:u(n))&&void 0!==a?a:16);break;case t.DOM_DELTA_PAGE:e*=function(t){return t.clientHeight}(t.target)}var n,l,o,a;return e}},\n",
" function _(m,i,u,s,a){s(),a(\"Expression\",m(124).Expression),a(\"CustomJSExpr\",m(267).CustomJSExpr),a(\"Stack\",m(268).Stack),a(\"CumSum\",m(269).CumSum),a(\"ScalarExpression\",m(124).ScalarExpression),a(\"Minimum\",m(270).Minimum),a(\"Maximum\",m(271).Maximum)},\n",
" function _(t,e,s,n,r){n();const i=t(14),o=t(124),a=t(24),c=t(9),u=t(13),l=t(34),h=t(8);class p extends o.Expression{constructor(t){super(t)}static init_CustomJSExpr(){this.define((({Unknown:t,String:e,Dict:s})=>({args:[s(t),{}],code:[e,\"\"]})))}connect_signals(){super.connect_signals();for(const t of u.values(this.args))t instanceof i.HasProps&&t.change.connect((()=>{this._result.clear(),this.change.emit()}))}get names(){return u.keys(this.args)}get values(){return u.values(this.args)}get func(){const t=l.use_strict(this.code);return new a.GeneratorFunction(...this.names,t)}_v_compute(t){const e=this.func.apply(t,this.values);let s=e.next();if(s.done&&void 0!==s.value){const{value:e}=s;return h.isArray(e)||h.isTypedArray(e)?e:h.isIterable(e)?[...e]:c.repeat(e,t.length)}{const t=[];do{t.push(s.value),s=e.next()}while(!s.done);return t}}}s.CustomJSExpr=p,p.__name__=\"CustomJSExpr\",p.init_CustomJSExpr()},\n",
" function _(t,n,e,i,s){i();const a=t(124);class c extends a.Expression{constructor(t){super(t)}static init_Stack(){this.define((({String:t,Array:n})=>({fields:[n(t),[]]})))}_v_compute(t){var n;const e=null!==(n=t.get_length())&&void 0!==n?n:0,i=new Float64Array(e);for(const n of this.fields){const s=t.data[n];if(null!=s)for(let t=0,n=Math.min(e,s.length);t<n;t++)i[t]+=s[t]}return i}}e.Stack=c,c.__name__=\"Stack\",c.init_Stack()},\n",
" function _(e,t,n,i,u){i();const o=e(124);class r extends o.Expression{constructor(e){super(e)}static init_CumSum(){this.define((({Boolean:e,String:t})=>({field:[t],include_zero:[e,!1]})))}_v_compute(e){var t;const n=new Float64Array(null!==(t=e.get_length())&&void 0!==t?t:0),i=e.data[this.field],u=this.include_zero?1:0;n[0]=this.include_zero?0:i[0];for(let e=1;e<n.length;e++)n[e]=n[e-1]+i[e-u];return n}}n.CumSum=r,r.__name__=\"CumSum\",r.init_CumSum()},\n",
" function _(i,n,t,l,u){l();const e=i(124),m=i(9);class s extends e.ScalarExpression{constructor(i){super(i)}static init_Minimum(){this.define((({Number:i,String:n,Nullable:t})=>({field:[n],initial:[t(i),null]})))}_compute(i){var n,t;const l=null!==(n=i.data[this.field])&&void 0!==n?n:[];return Math.min(null!==(t=this.initial)&&void 0!==t?t:1/0,m.min(l))}}t.Minimum=s,s.__name__=\"Minimum\",s.init_Minimum()},\n",
" function _(i,t,a,n,l){n();const u=i(124),e=i(9);class m extends u.ScalarExpression{constructor(i){super(i)}static init_Maximum(){this.define((({Number:i,String:t,Nullable:a})=>({field:[t],initial:[a(i),null]})))}_compute(i){var t,a;const n=null!==(t=i.data[this.field])&&void 0!==t?t:[];return Math.max(null!==(a=this.initial)&&void 0!==a?a:-1/0,e.max(n))}}a.Maximum=m,m.__name__=\"Maximum\",m.init_Maximum()},\n",
" function _(e,t,l,r,i){r(),i(\"BooleanFilter\",e(273).BooleanFilter),i(\"CustomJSFilter\",e(274).CustomJSFilter),i(\"Filter\",e(121).Filter),i(\"GroupFilter\",e(275).GroupFilter),i(\"IndexFilter\",e(276).IndexFilter)},\n",
" function _(e,n,l,o,t){o();const i=e(121),s=e(24);class a extends i.Filter{constructor(e){super(e)}static init_BooleanFilter(){this.define((({Boolean:e,Array:n,Nullable:l})=>({booleans:[l(n(e)),null]})))}compute_indices(e){const n=e.length,{booleans:l}=this;return null==l?s.Indices.all_set(n):s.Indices.from_booleans(n,l)}}l.BooleanFilter=a,a.__name__=\"BooleanFilter\",a.init_BooleanFilter()},\n",
" function _(e,t,s,n,r){n();const i=e(121),o=e(24),u=e(13),c=e(8),a=e(34);class l extends i.Filter{constructor(e){super(e)}static init_CustomJSFilter(){this.define((({Unknown:e,String:t,Dict:s})=>({args:[s(e),{}],code:[t,\"\"]})))}get names(){return u.keys(this.args)}get values(){return u.values(this.args)}get func(){const e=a.use_strict(this.code);return new Function(...this.names,\"source\",e)}compute_indices(e){const t=e.length,s=this.func(...this.values,e);if(null==s)return o.Indices.all_set(t);if(c.isArrayOf(s,c.isInteger))return o.Indices.from_indices(t,s);if(c.isArrayOf(s,c.isBoolean))return o.Indices.from_booleans(t,s);throw new Error(`expect an array of integers or booleans, or null, got ${s}`)}}s.CustomJSFilter=l,l.__name__=\"CustomJSFilter\",l.init_CustomJSFilter()},\n",
" function _(n,t,e,i,o){i();const r=n(121),u=n(24),s=n(19);class c extends r.Filter{constructor(n){super(n)}static init_GroupFilter(){this.define((({String:n})=>({column_name:[n],group:[n]})))}compute_indices(n){const t=n.get_column(this.column_name);if(null==t)return s.logger.warn(`${this}: groupby column '${this.column_name}' not found in the data source`),new u.Indices(n.length,1);{const e=new u.Indices(n.length);for(let n=0;n<e.size;n++)t[n]===this.group&&e.set(n);return e}}}e.GroupFilter=c,c.__name__=\"GroupFilter\",c.init_GroupFilter()},\n",
" function _(e,n,i,t,s){t();const l=e(121),c=e(24);class r extends l.Filter{constructor(e){super(e)}static init_IndexFilter(){this.define((({Int:e,Array:n,Nullable:i})=>({indices:[i(n(e)),null]})))}compute_indices(e){const n=e.length,{indices:i}=this;return null==i?c.Indices.all_set(n):c.Indices.from_indices(n,i)}}i.IndexFilter=r,r.__name__=\"IndexFilter\",r.init_IndexFilter()},\n",
" function _(e,a,l,i,t){i(),t(\"AnnularWedge\",e(278).AnnularWedge),t(\"Annulus\",e(279).Annulus),t(\"Arc\",e(280).Arc),t(\"Bezier\",e(281).Bezier),t(\"Circle\",e(282).Circle),t(\"Ellipse\",e(286).Ellipse),t(\"EllipseOval\",e(287).EllipseOval),t(\"Glyph\",e(98).Glyph),t(\"HArea\",e(117).HArea),t(\"HBar\",e(289).HBar),t(\"HexTile\",e(291).HexTile),t(\"Image\",e(292).Image),t(\"ImageRGBA\",e(294).ImageRGBA),t(\"ImageURL\",e(295).ImageURL),t(\"Line\",e(63).Line),t(\"MultiLine\",e(127).MultiLine),t(\"MultiPolygons\",e(297).MultiPolygons),t(\"Oval\",e(298).Oval),t(\"Patch\",e(116).Patch),t(\"Patches\",e(128).Patches),t(\"Quad\",e(299).Quad),t(\"Quadratic\",e(300).Quadratic),t(\"Ray\",e(301).Ray),t(\"Rect\",e(302).Rect),t(\"Scatter\",e(303).Scatter),t(\"Segment\",e(306).Segment),t(\"Spline\",e(307).Spline),t(\"Step\",e(309).Step),t(\"Text\",e(310).Text),t(\"VArea\",e(119).VArea),t(\"VBar\",e(311).VBar),t(\"Wedge\",e(312).Wedge)},\n",
" function _(e,t,s,i,r){i();const n=e(1),a=e(64),o=e(106),_=e(48),d=e(24),u=e(20),h=n.__importStar(e(18)),l=e(10),c=e(59);class g extends a.XYGlyphView{_map_data(){\"data\"==this.model.properties.inner_radius.units?this.sinner_radius=this.sdist(this.renderer.xscale,this._x,this.inner_radius):this.sinner_radius=d.to_screen(this.inner_radius),\"data\"==this.model.properties.outer_radius.units?this.souter_radius=this.sdist(this.renderer.xscale,this._x,this.outer_radius):this.souter_radius=d.to_screen(this.outer_radius)}_render(e,t,s){const{sx:i,sy:r,start_angle:n,end_angle:a,sinner_radius:o,souter_radius:_}=null!=s?s:this,d=\"anticlock\"==this.model.direction;for(const s of t){const t=i[s],u=r[s],h=o[s],l=_[s],c=n.get(s),g=a.get(s);if(isNaN(t+u+h+l+c+g))continue;const x=g-c;e.translate(t,u),e.rotate(c),e.beginPath(),e.moveTo(l,0),e.arc(0,0,l,0,x,d),e.rotate(x),e.lineTo(h,0),e.arc(0,0,h,0,-x,!d),e.closePath(),e.rotate(-x-c),e.translate(-t,-u),this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(e,s),e.fill()),this.visuals.hatch.doit&&(this.visuals.hatch.set_vectorize(e,s),e.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(e,s),e.stroke())}}_hit_point(e){const{sx:t,sy:s}=e,i=this.renderer.xscale.invert(t),r=this.renderer.yscale.invert(s);let n,a,o,_;if(\"data\"==this.model.properties.outer_radius.units)n=i-this.max_outer_radius,o=i+this.max_outer_radius,a=r-this.max_outer_radius,_=r+this.max_outer_radius;else{const e=t-this.max_outer_radius,i=t+this.max_outer_radius;[n,o]=this.renderer.xscale.r_invert(e,i);const r=s-this.max_outer_radius,d=s+this.max_outer_radius;[a,_]=this.renderer.yscale.r_invert(r,d)}const d=[];for(const e of this.index.indices({x0:n,x1:o,y0:a,y1:_})){const t=this.souter_radius[e]**2,s=this.sinner_radius[e]**2,[n,a]=this.renderer.xscale.r_compute(i,this._x[e]),[o,_]=this.renderer.yscale.r_compute(r,this._y[e]),u=(n-a)**2+(o-_)**2;u<=t&&u>=s&&d.push(e)}const u=\"anticlock\"==this.model.direction,h=[];for(const e of d){const i=Math.atan2(s-this.sy[e],t-this.sx[e]);l.angle_between(-i,-this.start_angle.get(e),-this.end_angle.get(e),u)&&h.push(e)}return new c.Selection({indices:h})}draw_legend_for_index(e,t,s){o.generic_area_vector_legend(this.visuals,e,t,s)}scenterxy(e){const t=(this.sinner_radius[e]+this.souter_radius[e])/2,s=(this.start_angle.get(e)+this.end_angle.get(e))/2;return[this.sx[e]+t*Math.cos(s),this.sy[e]+t*Math.sin(s)]}}s.AnnularWedgeView=g,g.__name__=\"AnnularWedgeView\";class x extends a.XYGlyph{constructor(e){super(e)}static init_AnnularWedge(){this.prototype.default_view=g,this.mixins([_.LineVector,_.FillVector,_.HatchVector]),this.define((({})=>({direction:[u.Direction,\"anticlock\"],inner_radius:[h.DistanceSpec,{field:\"inner_radius\"}],outer_radius:[h.DistanceSpec,{field:\"outer_radius\"}],start_angle:[h.AngleSpec,{field:\"start_angle\"}],end_angle:[h.AngleSpec,{field:\"end_angle\"}]})))}}s.AnnularWedge=x,x.__name__=\"AnnularWedge\",x.init_AnnularWedge()},\n",
" function _(s,i,t,e,r){e();const n=s(1),a=s(64),u=s(24),_=s(48),o=n.__importStar(s(18)),h=s(27),d=s(59);class c extends a.XYGlyphView{_map_data(){\"data\"==this.model.properties.inner_radius.units?this.sinner_radius=this.sdist(this.renderer.xscale,this._x,this.inner_radius):this.sinner_radius=u.to_screen(this.inner_radius),\"data\"==this.model.properties.outer_radius.units?this.souter_radius=this.sdist(this.renderer.xscale,this._x,this.outer_radius):this.souter_radius=u.to_screen(this.outer_radius)}_render(s,i,t){const{sx:e,sy:r,sinner_radius:n,souter_radius:a}=null!=t?t:this;for(const t of i){const i=e[t],_=r[t],o=n[t],d=a[t];function u(){if(s.beginPath(),h.is_ie)for(const t of[!1,!0])s.arc(i,_,o,0,Math.PI,t),s.arc(i,_,d,Math.PI,0,!t);else s.arc(i,_,o,0,2*Math.PI,!0),s.arc(i,_,d,2*Math.PI,0,!1)}isNaN(i+_+o+d)||(this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(s,t),u(),s.fill()),this.visuals.hatch.doit&&(this.visuals.hatch.set_vectorize(s,t),u(),s.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(s,t),s.beginPath(),s.arc(i,_,o,0,2*Math.PI),s.moveTo(i+d,_),s.arc(i,_,d,0,2*Math.PI),s.stroke()))}}_hit_point(s){const{sx:i,sy:t}=s,e=this.renderer.xscale.invert(i),r=this.renderer.yscale.invert(t);let n,a,u,_;if(\"data\"==this.model.properties.outer_radius.units)n=e-this.max_outer_radius,u=e+this.max_outer_radius,a=r-this.max_outer_radius,_=r+this.max_outer_radius;else{const s=i-this.max_outer_radius,e=i+this.max_outer_radius;[n,u]=this.renderer.xscale.r_invert(s,e);const r=t-this.max_outer_radius,o=t+this.max_outer_radius;[a,_]=this.renderer.yscale.r_invert(r,o)}const o=[];for(const s of this.index.indices({x0:n,x1:u,y0:a,y1:_})){const i=this.souter_radius[s]**2,t=this.sinner_radius[s]**2,[n,a]=this.renderer.xscale.r_compute(e,this._x[s]),[u,_]=this.renderer.yscale.r_compute(r,this._y[s]),h=(n-a)**2+(u-_)**2;h<=i&&h>=t&&o.push(s)}return new d.Selection({indices:o})}draw_legend_for_index(s,{x0:i,y0:t,x1:e,y1:r},n){const a=n+1,u=new Array(a);u[n]=(i+e)/2;const _=new Array(a);_[n]=(t+r)/2;const o=.5*Math.min(Math.abs(e-i),Math.abs(r-t)),h=new Array(a);h[n]=.4*o;const d=new Array(a);d[n]=.8*o,this._render(s,[n],{sx:u,sy:_,sinner_radius:h,souter_radius:d})}}t.AnnulusView=c,c.__name__=\"AnnulusView\";class l extends a.XYGlyph{constructor(s){super(s)}static init_Annulus(){this.prototype.default_view=c,this.mixins([_.LineVector,_.FillVector,_.HatchVector]),this.define((({})=>({inner_radius:[o.DistanceSpec,{field:\"inner_radius\"}],outer_radius:[o.DistanceSpec,{field:\"outer_radius\"}]})))}}t.Annulus=l,l.__name__=\"Annulus\",l.init_Annulus()},\n",
" function _(e,i,s,t,n){t();const r=e(1),a=e(64),c=e(106),d=e(48),_=e(24),l=e(20),o=r.__importStar(e(18));class h extends a.XYGlyphView{_map_data(){\"data\"==this.model.properties.radius.units?this.sradius=this.sdist(this.renderer.xscale,this._x,this.radius):this.sradius=_.to_screen(this.radius)}_render(e,i,s){if(this.visuals.line.doit){const{sx:t,sy:n,sradius:r,start_angle:a,end_angle:c}=null!=s?s:this,d=\"anticlock\"==this.model.direction;for(const s of i){const i=t[s],_=n[s],l=r[s],o=a.get(s),h=c.get(s);isNaN(i+_+l+o+h)||(e.beginPath(),e.arc(i,_,l,o,h,d),this.visuals.line.set_vectorize(e,s),e.stroke())}}}draw_legend_for_index(e,i,s){c.generic_line_vector_legend(this.visuals,e,i,s)}}s.ArcView=h,h.__name__=\"ArcView\";class u extends a.XYGlyph{constructor(e){super(e)}static init_Arc(){this.prototype.default_view=h,this.mixins(d.LineVector),this.define((({})=>({direction:[l.Direction,\"anticlock\"],radius:[o.DistanceSpec,{field:\"radius\"}],start_angle:[o.AngleSpec,{field:\"start_angle\"}],end_angle:[o.AngleSpec,{field:\"end_angle\"}]})))}}s.Arc=u,u.__name__=\"Arc\",u.init_Arc()},\n",
" function _(e,t,i,s,n){s();const o=e(1),c=e(48),r=e(98),a=e(106),_=e(65),d=o.__importStar(e(18));function l(e,t,i,s,n,o,c,r){const a=[],_=[[],[]];for(let _=0;_<=2;_++){let d,l,x;if(0===_?(l=6*e-12*i+6*n,d=-3*e+9*i-9*n+3*c,x=3*i-3*e):(l=6*t-12*s+6*o,d=-3*t+9*s-9*o+3*r,x=3*s-3*t),Math.abs(d)<1e-12){if(Math.abs(l)<1e-12)continue;const e=-x/l;0<e&&e<1&&a.push(e);continue}const h=l*l-4*x*d,y=Math.sqrt(h);if(h<0)continue;const p=(-l+y)/(2*d);0<p&&p<1&&a.push(p);const f=(-l-y)/(2*d);0<f&&f<1&&a.push(f)}let d=a.length;const l=d;for(;d--;){const l=a[d],x=1-l,h=x*x*x*e+3*x*x*l*i+3*x*l*l*n+l*l*l*c;_[0][d]=h;const y=x*x*x*t+3*x*x*l*s+3*x*l*l*o+l*l*l*r;_[1][d]=y}return _[0][l]=e,_[1][l]=t,_[0][l+1]=c,_[1][l+1]=r,[Math.min(..._[0]),Math.max(..._[1]),Math.max(..._[0]),Math.min(..._[1])]}class x extends r.GlyphView{_project_data(){_.inplace.project_xy(this._x0,this._y0),_.inplace.project_xy(this._x1,this._y1)}_index_data(e){const{data_size:t,_x0:i,_y0:s,_x1:n,_y1:o,_cx0:c,_cy0:r,_cx1:a,_cy1:_}=this;for(let d=0;d<t;d++){const t=i[d],x=s[d],h=n[d],y=o[d],p=c[d],f=r[d],u=a[d],m=_[d];if(isNaN(t+h+x+y+p+f+u+m))e.add_empty();else{const[i,s,n,o]=l(t,x,h,y,p,f,u,m);e.add(i,s,n,o)}}}_render(e,t,i){if(this.visuals.line.doit){const{sx0:s,sy0:n,sx1:o,sy1:c,scx0:r,scy0:a,scx1:_,scy1:d}=null!=i?i:this;for(const i of t){const t=s[i],l=n[i],x=o[i],h=c[i],y=r[i],p=a[i],f=_[i],u=d[i];isNaN(t+l+x+h+y+p+f+u)||(e.beginPath(),e.moveTo(t,l),e.bezierCurveTo(y,p,f,u,x,h),this.visuals.line.set_vectorize(e,i),e.stroke())}}}draw_legend_for_index(e,t,i){a.generic_line_vector_legend(this.visuals,e,t,i)}scenterxy(){throw new Error(`${this}.scenterxy() is not implemented`)}}i.BezierView=x,x.__name__=\"BezierView\";class h extends r.Glyph{constructor(e){super(e)}static init_Bezier(){this.prototype.default_view=x,this.define((({})=>({x0:[d.XCoordinateSpec,{field:\"x0\"}],y0:[d.YCoordinateSpec,{field:\"y0\"}],x1:[d.XCoordinateSpec,{field:\"x1\"}],y1:[d.YCoordinateSpec,{field:\"y1\"}],cx0:[d.XCoordinateSpec,{field:\"cx0\"}],cy0:[d.YCoordinateSpec,{field:\"cy0\"}],cx1:[d.XCoordinateSpec,{field:\"cx1\"}],cy1:[d.YCoordinateSpec,{field:\"cy1\"}]}))),this.mixins(c.LineVector)}}i.Bezier=h,h.__name__=\"Bezier\",h.init_Bezier()},\n",
" function _(s,i,e,t,r){t();const a=s(1),n=s(64),h=s(283),d=s(48),l=s(24),c=s(20),_=a.__importStar(s(107)),u=a.__importStar(s(18)),o=s(9),x=s(12),m=s(59);class y extends n.XYGlyphView{initialize(){super.initialize();const{webgl:s}=this.renderer.plot_view.canvas_view;null!=s&&(this.glglyph=new h.MarkerGL(s.gl,this,\"circle\"))}get use_radius(){return!(this.radius.is_Scalar()&&isNaN(this.radius.value))}_map_data(){if(this.use_radius)if(\"data\"==this.model.properties.radius.units)switch(this.model.radius_dimension){case\"x\":this.sradius=this.sdist(this.renderer.xscale,this._x,this.radius);break;case\"y\":this.sradius=this.sdist(this.renderer.yscale,this._y,this.radius);break;case\"max\":{const s=this.sdist(this.renderer.xscale,this._x,this.radius),i=this.sdist(this.renderer.yscale,this._y,this.radius);this.sradius=x.map(s,((s,e)=>Math.max(s,i[e])));break}case\"min\":{const s=this.sdist(this.renderer.xscale,this._x,this.radius),i=this.sdist(this.renderer.yscale,this._y,this.radius);this.sradius=x.map(s,((s,e)=>Math.min(s,i[e])));break}}else this.sradius=l.to_screen(this.radius),this._configure(\"max_size\",{value:2*this.max_radius});else{const s=new l.ScreenArray(this.size);this.sradius=x.map(s,(s=>s/2))}}_mask_data(){const{frame:s}=this.renderer.plot_view,i=s.x_target,e=s.y_target;let t,r;return this.use_radius&&\"data\"==this.model.properties.radius.units?(t=i.map((s=>this.renderer.xscale.invert(s))).widen(this.max_radius),r=e.map((s=>this.renderer.yscale.invert(s))).widen(this.max_radius)):(t=i.widen(this.max_size).map((s=>this.renderer.xscale.invert(s))),r=e.widen(this.max_size).map((s=>this.renderer.yscale.invert(s)))),this.index.indices({x0:t.start,x1:t.end,y0:r.start,y1:r.end})}_render(s,i,e){const{sx:t,sy:r,sradius:a}=null!=e?e:this;for(const e of i){const i=t[e],n=r[e],h=a[e];isNaN(i+n+h)||(s.beginPath(),s.arc(i,n,h,0,2*Math.PI,!1),this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(s,e),s.fill()),this.visuals.hatch.doit&&(this.visuals.hatch.set_vectorize(s,e),s.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(s,e),s.stroke()))}}_hit_point(s){const{sx:i,sy:e}=s,t=this.renderer.xscale.invert(i),r=this.renderer.yscale.invert(e),{hit_dilation:a}=this.model;let n,h,d,l;if(this.use_radius&&\"data\"==this.model.properties.radius.units)n=t-this.max_radius*a,h=t+this.max_radius*a,d=r-this.max_radius*a,l=r+this.max_radius*a;else{const s=i-this.max_size*a,t=i+this.max_size*a;[n,h]=this.renderer.xscale.r_invert(s,t);const r=e-this.max_size*a,c=e+this.max_size*a;[d,l]=this.renderer.yscale.r_invert(r,c)}const c=this.index.indices({x0:n,x1:h,y0:d,y1:l}),_=[];if(this.use_radius&&\"data\"==this.model.properties.radius.units)for(const s of c){const i=(this.sradius[s]*a)**2,[e,n]=this.renderer.xscale.r_compute(t,this._x[s]),[h,d]=this.renderer.yscale.r_compute(r,this._y[s]);(e-n)**2+(h-d)**2<=i&&_.push(s)}else for(const s of c){const t=(this.sradius[s]*a)**2;(this.sx[s]-i)**2+(this.sy[s]-e)**2<=t&&_.push(s)}return new m.Selection({indices:_})}_hit_span(s){const{sx:i,sy:e}=s,t=this.bounds();let r,a,n,h;if(\"h\"==s.direction){let s,e;if(n=t.y0,h=t.y1,this.use_radius&&\"data\"==this.model.properties.radius.units)s=i-this.max_radius,e=i+this.max_radius,[r,a]=this.renderer.xscale.r_invert(s,e);else{const t=this.max_size/2;s=i-t,e=i+t,[r,a]=this.renderer.xscale.r_invert(s,e)}}else{let s,i;if(r=t.x0,a=t.x1,this.use_radius&&\"data\"==this.model.properties.radius.units)s=e-this.max_radius,i=e+this.max_radius,[n,h]=this.renderer.yscale.r_invert(s,i);else{const t=this.max_size/2;s=e-t,i=e+t,[n,h]=this.renderer.yscale.r_invert(s,i)}}const d=[...this.index.indices({x0:r,x1:a,y0:n,y1:h})];return new m.Selection({indices:d})}_hit_rect(s){const{sx0:i,sx1:e,sy0:t,sy1:r}=s,[a,n]=this.renderer.xscale.r_invert(i,e),[h,d]=this.renderer.yscale.r_invert(t,r),l=[...this.index.indices({x0:a,x1:n,y0:h,y1:d})];return new m.Selection({indices:l})}_hit_poly(s){const{sx:i,sy:e}=s,t=o.range(0,this.sx.length),r=[];for(let s=0,a=t.length;s<a;s++){const a=t[s];_.point_in_poly(this.sx[s],this.sy[s],i,e)&&r.push(a)}return new m.Selection({indices:r})}draw_legend_for_index(s,{x0:i,y0:e,x1:t,y1:r},a){const n=a+1,h=new Array(n);h[a]=(i+t)/2;const d=new Array(n);d[a]=(e+r)/2;const l=new Array(n);l[a]=.2*Math.min(Math.abs(t-i),Math.abs(r-e)),this._render(s,[a],{sx:h,sy:d,sradius:l})}}e.CircleView=y,y.__name__=\"CircleView\";class p extends n.XYGlyph{constructor(s){super(s)}static init_Circle(){this.prototype.default_view=y,this.mixins([d.LineVector,d.FillVector,d.HatchVector]),this.define((({Number:s})=>({angle:[u.AngleSpec,0],size:[u.ScreenDistanceSpec,{value:4}],radius:[u.NullDistanceSpec,null],radius_dimension:[c.RadiusDimension,\"x\"],hit_dilation:[s,1]})))}}e.Circle=p,p.__name__=\"Circle\",p.init_Circle()},\n",
" function _(t,e,s,i,a){i();const r=t(1),o=t(109),_=t(113),l=r.__importDefault(t(284)),h=r.__importDefault(t(285)),n=t(282),f=t(12),u=t(19),c=t(24),g=t(22),b=t(11);function d(t,e,s,i,a,r,o){if(a.doit)if(r.is_Scalar()&&o.is_Scalar()){e.used=!1;const[i,a,_,l]=g.color2rgba(r.value,o.value);t.set_attribute(s,\"vec4\",[i/255,a/255,_/255,l/255])}else{let a;if(e.used=!0,r.is_Vector()){const t=new c.ColorArray(r.array);if(a=new c.RGBAArray(t.buffer),!o.is_Scalar()||1!=o.value)for(let t=0;t<i;t++){const e=4*t+3;255==a[e]&&(a[e]=255*o.get(t))}}else if(r.is_Scalar()&&o.is_Vector()){const t=new c.ColorArray(i);t.fill(r.value),a=new c.RGBAArray(t.buffer);for(let t=0;t<i;t++)for(let t=0;t<i;t++){const e=4*t+3;255==a[e]&&(a[e]=255*o.get(t))}}else b.unreachable();e.set_size(4*i),e.set_data(0,a),t.set_attribute(s,\"vec4_uint8\",e,0,0,!0)}else e.used=!1,t.set_attribute(s,\"vec4\",[0,0,0,0])}class p extends _.BaseGLGlyph{constructor(t,e,s){super(t,e),this.glyph=e,this.marker_type=s;const i=[`#define USE_${s.toUpperCase()}`],a=l.default,r=`${i.join(\"\\n\")}\\n\\n${h.default}`;this.prog=new o.Program(t),this.prog.set_shaders(a,r),this.vbo_sx=new o.VertexBuffer(t),this.prog.set_attribute(\"a_sx\",\"float\",this.vbo_sx),this.vbo_sy=new o.VertexBuffer(t),this.prog.set_attribute(\"a_sy\",\"float\",this.vbo_sy),this.vbo_s=new o.VertexBuffer(t),this.prog.set_attribute(\"a_size\",\"float\",this.vbo_s),this.vbo_a=new o.VertexBuffer(t),this.prog.set_attribute(\"a_angle\",\"float\",this.vbo_a),this.vbo_linewidth=new o.VertexBuffer(t),this.vbo_fg_color=new o.VertexBuffer(t),this.vbo_bg_color=new o.VertexBuffer(t),this.index_buffer=new o.IndexBuffer(t)}static is_supported(t){switch(t){case\"asterisk\":case\"circle\":case\"circle_cross\":case\"circle_x\":case\"cross\":case\"diamond\":case\"diamond_cross\":case\"hex\":case\"inverted_triangle\":case\"square\":case\"square_cross\":case\"square_x\":case\"star\":case\"triangle\":case\"x\":return!0;default:return!1}}draw(t,e,s){const i=e.glglyph,{nvertices:a}=i;if(i.data_changed&&(i._set_data(a),this.glyph instanceof n.CircleView&&null!=this.glyph.radius&&this.vbo_s.set_data(0,f.map(this.glyph.sradius,(t=>2*t))),i.data_changed=!1),this.visuals_changed&&(this._set_visuals(a),this.visuals_changed=!1),this.prog.set_uniform(\"u_pixel_ratio\",\"float\",[s.pixel_ratio]),this.prog.set_uniform(\"u_canvas_size\",\"vec2\",[s.width,s.height]),this.prog.set_attribute(\"a_sx\",\"float\",i.vbo_sx),this.prog.set_attribute(\"a_sy\",\"float\",i.vbo_sy),this.prog.set_attribute(\"a_size\",\"float\",i.vbo_s),this.prog.set_attribute(\"a_angle\",\"float\",i.vbo_a),0!=t.length)if(t.length===a)this.prog.draw(this.gl.POINTS,[0,a]);else if(a<65535){const e=window.navigator.userAgent;e.indexOf(\"MSIE \")+e.indexOf(\"Trident/\")+e.indexOf(\"Edge/\")>0&&u.logger.warn(\"WebGL warning: IE is known to produce 1px sprites whith selections.\"),this.index_buffer.set_size(2*t.length),this.index_buffer.set_data(0,new Uint16Array(t)),this.prog.draw(this.gl.POINTS,this.index_buffer)}else{const e=64e3,s=[];for(let t=0,i=Math.ceil(a/e);t<i;t++)s.push([]);for(let i=0,a=t.length;i<a;i++){const a=t[i]%e;s[Math.floor(t[i]/e)].push(a)}for(let t=0,a=s.length;t<a;t++){const a=new Uint16Array(s[t]),r=t*e*4;0!==a.length&&(this.prog.set_attribute(\"a_sx\",\"float\",i.vbo_sx,0,r),this.prog.set_attribute(\"a_sy\",\"float\",i.vbo_sy,0,r),this.prog.set_attribute(\"a_size\",\"float\",i.vbo_s,0,r),this.prog.set_attribute(\"a_angle\",\"float\",i.vbo_a,0,r),this.vbo_linewidth.used&&this.prog.set_attribute(\"a_linewidth\",\"float\",this.vbo_linewidth,0,r),this.vbo_fg_color.used&&this.prog.set_attribute(\"a_fg_color\",\"vec4_uint8\",this.vbo_fg_color,0,4*r,!0),this.vbo_bg_color.used&&this.prog.set_attribute(\"a_bg_color\",\"vec4_uint8\",this.vbo_bg_color,0,4*r,!0),this.index_buffer.set_size(2*a.length),this.index_buffer.set_data(0,a),this.prog.draw(this.gl.POINTS,this.index_buffer))}}}_set_data(t){const e=4*t;this.vbo_sx.set_size(e),this.vbo_sy.set_size(e),this.vbo_a.set_size(e),this.vbo_s.set_size(e),this.vbo_sx.set_data(0,this.glyph.sx),this.vbo_sy.set_data(0,this.glyph.sy),null!=this.glyph.angle&&this.vbo_a.set_data(0,new Float32Array(this.glyph.angle)),this.glyph instanceof n.CircleView&&null!=this.glyph.radius?this.vbo_s.set_data(0,f.map(this.glyph.sradius,(t=>2*t))):this.vbo_s.set_data(0,new Float32Array(this.glyph.size))}_set_visuals(t){const{line:e,fill:s}=this.glyph.visuals;!function(t,e,s,i,a,r){if(a.doit){if(r.is_Scalar())e.used=!1,t.set_attribute(s,\"float\",[r.value]);else if(r.is_Vector()){e.used=!0;const a=new Float32Array(r.array);e.set_size(4*i),e.set_data(0,a),t.set_attribute(s,\"float\",e)}}else e.used=!1,t.set_attribute(s,\"float\",[0])}(this.prog,this.vbo_linewidth,\"a_linewidth\",t,e,e.line_width),d(this.prog,this.vbo_fg_color,\"a_fg_color\",t,e,e.line_color,e.line_alpha),d(this.prog,this.vbo_bg_color,\"a_bg_color\",t,s,s.fill_color,s.fill_alpha),this.prog.set_uniform(\"u_antialias\",\"float\",[.8])}}s.MarkerGL=p,p.__name__=\"MarkerGL\"},\n",
" function _(n,i,a,o,_){o();a.default=\"\\nprecision mediump float;\\nconst float SQRT_2 = 1.4142135623730951;\\n//\\nuniform float u_pixel_ratio;\\nuniform vec2 u_canvas_size;\\nuniform vec2 u_offset;\\nuniform vec2 u_scale;\\nuniform float u_antialias;\\n//\\nattribute float a_sx;\\nattribute float a_sy;\\nattribute float a_size;\\nattribute float a_angle; // in radians\\nattribute float a_linewidth;\\nattribute vec4 a_fg_color;\\nattribute vec4 a_bg_color;\\n//\\nvarying float v_linewidth;\\nvarying float v_size;\\nvarying vec4 v_fg_color;\\nvarying vec4 v_bg_color;\\nvarying vec2 v_rotation;\\n\\nvoid main (void)\\n{\\n v_size = a_size * u_pixel_ratio;\\n v_linewidth = a_linewidth * u_pixel_ratio;\\n v_fg_color = a_fg_color;\\n v_bg_color = a_bg_color;\\n v_rotation = vec2(cos(-a_angle), sin(-a_angle));\\n vec2 pos = vec2(a_sx, a_sy); // in pixels\\n pos += 0.5; // make up for Bokeh's offset\\n pos /= u_canvas_size / u_pixel_ratio; // in 0..1\\n gl_Position = vec4(pos*2.0-1.0, 0.0, 1.0);\\n gl_Position.y *= -1.0;\\n gl_PointSize = SQRT_2 * v_size + 2.0 * (v_linewidth + 1.5*u_antialias);\\n}\\n\"},\n",
" function _(n,a,s,e,t){e();s.default='\\nprecision mediump float;\\n\\nconst float SQRT_2 = 1.4142135623730951;\\nconst float PI = 3.14159265358979323846264;\\n\\nconst float IN_ANGLE = 0.6283185307179586; // PI/5. = 36 degrees (star of 5 pikes)\\n//const float OUT_ANGLE = PI/2. - IN_ANGLE; // External angle for regular stars\\nconst float COS_A = 0.8090169943749475; // cos(IN_ANGLE)\\nconst float SIN_A = 0.5877852522924731; // sin(IN_ANGLE)\\nconst float COS_B = 0.5877852522924731; // cos(OUT_ANGLE)\\nconst float SIN_B = 0.8090169943749475; // sin(OUT_ANGLE)\\n\\n//\\nuniform float u_antialias;\\n//\\nvarying vec4 v_fg_color;\\nvarying vec4 v_bg_color;\\nvarying float v_linewidth;\\nvarying float v_size;\\nvarying vec2 v_rotation;\\n\\n#ifdef USE_ASTERISK\\n// asterisk\\nfloat marker(vec2 P, float size)\\n{\\n // Masks\\n float diamond = max(abs(SQRT_2 / 2.0 * (P.x - P.y)), abs(SQRT_2 / 2.0 * (P.x + P.y))) - size / (2.0 * SQRT_2);\\n float square = max(abs(P.x), abs(P.y)) - size / (2.0 * SQRT_2);\\n // Shapes\\n float X = min(abs(P.x - P.y), abs(P.x + P.y)) - size / 100.0; // bit of \"width\" for aa\\n float cross = min(abs(P.x), abs(P.y)) - size / 100.0; // bit of \"width\" for aa\\n // Result is union of masked shapes\\n return min(max(X, diamond), max(cross, square));\\n}\\n#endif\\n\\n#ifdef USE_CIRCLE\\n// circle\\nfloat marker(vec2 P, float size)\\n{\\n return length(P) - size/2.0;\\n}\\n#endif\\n\\n#ifdef USE_SQUARE\\n// square\\nfloat marker(vec2 P, float size)\\n{\\n return max(abs(P.x), abs(P.y)) - size/2.0;\\n}\\n#endif\\n\\n#ifdef USE_DIAMOND\\n// diamond\\nfloat marker(vec2 P, float size)\\n{\\n float x = SQRT_2 / 2.0 * (P.x * 1.5 - P.y);\\n float y = SQRT_2 / 2.0 * (P.x * 1.5 + P.y);\\n float r1 = max(abs(x), abs(y)) - size / (2.0 * SQRT_2);\\n return r1 / SQRT_2;\\n}\\n#endif\\n\\n#ifdef USE_HEX\\n// hex\\nfloat marker(vec2 P, float size)\\n{\\n vec2 q = abs(P);\\n return max(q.y * 0.57735 + q.x - 1.0 * size/2.0, q.y - 0.866 * size/2.0);\\n}\\n#endif\\n\\n#ifdef USE_STAR\\n// star\\n// https://iquilezles.org/www/articles/distfunctions2d/distfunctions2d.htm\\nfloat marker(vec2 P, float size)\\n{\\n float bn = mod(atan(P.x, -P.y), 2.0*IN_ANGLE) - IN_ANGLE;\\n P = length(P)*vec2(cos(bn), abs(sin(bn)));\\n P -= size*vec2(COS_A, SIN_A)/2.;\\n P += vec2(COS_B, SIN_B)*clamp(-(P.x*COS_B + P.y*SIN_B), 0.0, size*SIN_A/SIN_B/2.);\\n\\n return length(P)*sign(P.x);\\n}\\n#endif\\n\\n#ifdef USE_TRIANGLE\\n// triangle\\nfloat marker(vec2 P, float size)\\n{\\n P.y -= size * 0.3;\\n float x = SQRT_2 / 2.0 * (P.x * 1.7 - P.y);\\n float y = SQRT_2 / 2.0 * (P.x * 1.7 + P.y);\\n float r1 = max(abs(x), abs(y)) - size / 1.6;\\n float r2 = P.y;\\n return max(r1 / SQRT_2, r2); // Intersect diamond with rectangle\\n}\\n#endif\\n\\n#ifdef USE_INVERTED_TRIANGLE\\n// inverted_triangle\\nfloat marker(vec2 P, float size)\\n{\\n P.y += size * 0.3;\\n float x = SQRT_2 / 2.0 * (P.x * 1.7 - P.y);\\n float y = SQRT_2 / 2.0 * (P.x * 1.7 + P.y);\\n float r1 = max(abs(x), abs(y)) - size / 1.6;\\n float r2 = - P.y;\\n return max(r1 / SQRT_2, r2); // Intersect diamond with rectangle\\n}\\n#endif\\n\\n#ifdef USE_CROSS\\n// cross\\nfloat marker(vec2 P, float size)\\n{\\n float square = max(abs(P.x), abs(P.y)) - size / 2.5; // 2.5 is a tweak\\n float cross = min(abs(P.x), abs(P.y)) - size / 100.0; // bit of \"width\" for aa\\n return max(square, cross);\\n}\\n#endif\\n\\n#ifdef USE_CIRCLE_CROSS\\n// circle_cross\\nfloat marker(vec2 P, float size)\\n{\\n // Define quadrants\\n float qs = size / 2.0; // quadrant size\\n float s1 = max(abs(P.x - qs), abs(P.y - qs)) - qs;\\n float s2 = max(abs(P.x + qs), abs(P.y - qs)) - qs;\\n float s3 = max(abs(P.x - qs), abs(P.y + qs)) - qs;\\n float s4 = max(abs(P.x + qs), abs(P.y + qs)) - qs;\\n // Intersect main shape with quadrants (to form cross)\\n float circle = length(P) - size/2.0;\\n float c1 = max(circle, s1);\\n float c2 = max(circle, s2);\\n float c3 = max(circle, s3);\\n float c4 = max(circle, s4);\\n // Union\\n return min(min(min(c1, c2), c3), c4);\\n}\\n#endif\\n\\n#ifdef USE_SQUARE_CROSS\\n// square_cross\\nfloat marker(vec2 P, float size)\\n{\\n // Define quadrants\\n float qs = size / 2.0; // quadrant size\\n float s1 = max(abs(P.x - qs), abs(P.y - qs)) - qs;\\n float s2 = max(abs(P.x + qs), abs(P.y - qs)) - qs;\\n float s3 = max(abs(P.x - qs), abs(P.y + qs)) - qs;\\n float s4 = max(abs(P.x + qs), abs(P.y + qs)) - qs;\\n // Intersect main shape with quadrants (to form cross)\\n float square = max(abs(P.x), abs(P.y)) - size/2.0;\\n float c1 = max(square, s1);\\n float c2 = max(square, s2);\\n float c3 = max(square, s3);\\n float c4 = max(square, s4);\\n // Union\\n return min(min(min(c1, c2), c3), c4);\\n}\\n#endif\\n\\n#ifdef USE_DIAMOND_CROSS\\n// diamond_cross\\nfloat marker(vec2 P, float size)\\n{\\n // Define quadrants\\n float qs = size / 2.0; // quadrant size\\n float s1 = max(abs(P.x - qs), abs(P.y - qs)) - qs;\\n float s2 = max(abs(P.x + qs), abs(P.y - qs)) - qs;\\n float s3 = max(abs(P.x - qs), abs(P.y + qs)) - qs;\\n float s4 = max(abs(P.x + qs), abs(P.y + qs)) - qs;\\n // Intersect main shape with quadrants (to form cross)\\n float x = SQRT_2 / 2.0 * (P.x * 1.5 - P.y);\\n float y = SQRT_2 / 2.0 * (P.x * 1.5 + P.y);\\n float diamond = max(abs(x), abs(y)) - size / (2.0 * SQRT_2);\\n diamond /= SQRT_2;\\n float c1 = max(diamond, s1);\\n float c2 = max(diamond, s2);\\n float c3 = max(diamond, s3);\\n float c4 = max(diamond, s4);\\n // Union\\n return min(min(min(c1, c2), c3), c4);\\n}\\n#endif\\n\\n#ifdef USE_X\\n// x\\nfloat marker(vec2 P, float size)\\n{\\n float circle = length(P) - size / 1.6;\\n float X = min(abs(P.x - P.y), abs(P.x + P.y)) - size / 100.0; // bit of \"width\" for aa\\n return max(circle, X);\\n}\\n#endif\\n\\n#ifdef USE_CIRCLE_X\\n// circle_x\\nfloat marker(vec2 P, float size)\\n{\\n float x = P.x - P.y;\\n float y = P.x + P.y;\\n // Define quadrants\\n float qs = size / 2.0; // quadrant size\\n float s1 = max(abs(x - qs), abs(y - qs)) - qs;\\n float s2 = max(abs(x + qs), abs(y - qs)) - qs;\\n float s3 = max(abs(x - qs), abs(y + qs)) - qs;\\n float s4 = max(abs(x + qs), abs(y + qs)) - qs;\\n // Intersect main shape with quadrants (to form cross)\\n float circle = length(P) - size/2.0;\\n float c1 = max(circle, s1);\\n float c2 = max(circle, s2);\\n float c3 = max(circle, s3);\\n float c4 = max(circle, s4);\\n // Union\\n float almost = min(min(min(c1, c2), c3), c4);\\n // In this case, the X is also outside of the main shape\\n float Xmask = length(P) - size / 1.6; // a circle\\n float X = min(abs(P.x - P.y), abs(P.x + P.y)) - size / 100.0; // bit of \"width\" for aa\\n return min(max(X, Xmask), almost);\\n}\\n#endif\\n\\n#ifdef USE_SQUARE_X\\n// square_x\\nfloat marker(vec2 P, float size)\\n{\\n float x = P.x - P.y;\\n float y = P.x + P.y;\\n // Define quadrants\\n float qs = size / 2.0; // quadrant size\\n float s1 = max(abs(x - qs), abs(y - qs)) - qs;\\n float s2 = max(abs(x + qs), abs(y - qs)) - qs;\\n float s3 = max(abs(x - qs), abs(y + qs)) - qs;\\n float s4 = max(abs(x + qs), abs(y + qs)) - qs;\\n // Intersect main shape with quadrants (to form cross)\\n float square = max(abs(P.x), abs(P.y)) - size/2.0;\\n float c1 = max(square, s1);\\n float c2 = max(square, s2);\\n float c3 = max(square, s3);\\n float c4 = max(square, s4);\\n // Union\\n return min(min(min(c1, c2), c3), c4);\\n}\\n#endif\\n\\nvec4 outline(float distance, float linewidth, float antialias, vec4 fg_color, vec4 bg_color)\\n{\\n vec4 frag_color;\\n float t = linewidth/2.0 - antialias;\\n float signed_distance = distance;\\n float border_distance = abs(signed_distance) - t;\\n float alpha = border_distance/antialias;\\n alpha = exp(-alpha*alpha);\\n\\n // If fg alpha is zero, it probably means no outline. To avoid a dark outline\\n // shining through due to aa, we set the fg color to the bg color. Avoid if (i.e. branching).\\n float select = float(bool(fg_color.a));\\n fg_color.rgb = select * fg_color.rgb + (1.0 - select) * bg_color.rgb;\\n // Similarly, if we want a transparent bg\\n select = float(bool(bg_color.a));\\n bg_color.rgb = select * bg_color.rgb + (1.0 - select) * fg_color.rgb;\\n\\n if( border_distance < 0.0)\\n frag_color = fg_color;\\n else if( signed_distance < 0.0 ) {\\n frag_color = mix(bg_color, fg_color, sqrt(alpha));\\n } else {\\n if( abs(signed_distance) < (linewidth/2.0 + antialias) ) {\\n frag_color = vec4(fg_color.rgb, fg_color.a * alpha);\\n } else {\\n discard;\\n }\\n }\\n return frag_color;\\n}\\n\\nvoid main()\\n{\\n vec2 P = gl_PointCoord.xy - vec2(0.5, 0.5);\\n P = vec2(v_rotation.x*P.x - v_rotation.y*P.y,\\n v_rotation.y*P.x + v_rotation.x*P.y);\\n float point_size = SQRT_2*v_size + 2.0 * (v_linewidth + 1.5*u_antialias);\\n float distance = marker(P*point_size, v_size);\\n gl_FragColor = outline(distance, v_linewidth, u_antialias, v_fg_color, v_bg_color);\\n}\\n'},\n",
" function _(e,l,i,s,t){s();const _=e(287);class p extends _.EllipseOvalView{}i.EllipseView=p,p.__name__=\"EllipseView\";class n extends _.EllipseOval{constructor(e){super(e)}static init_Ellipse(){this.prototype.default_view=p}}i.Ellipse=n,n.__name__=\"Ellipse\",n.init_Ellipse()},\n",
" function _(t,s,i,e,h){e();const r=t(1),a=t(288),n=r.__importStar(t(107)),l=t(24),o=t(59);class _ extends a.CenterRotatableView{_map_data(){\"data\"==this.model.properties.width.units?this.sw=this.sdist(this.renderer.xscale,this._x,this.width,\"center\"):this.sw=l.to_screen(this.width),\"data\"==this.model.properties.height.units?this.sh=this.sdist(this.renderer.yscale,this._y,this.height,\"center\"):this.sh=l.to_screen(this.height)}_render(t,s,i){const{sx:e,sy:h,sw:r,sh:a,angle:n}=null!=i?i:this;for(const i of s){const s=e[i],l=h[i],o=r[i],_=a[i],d=n.get(i);isNaN(s+l+o+_+d)||(t.beginPath(),t.ellipse(s,l,o/2,_/2,d,0,2*Math.PI),this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(t,i),t.fill()),this.visuals.hatch.doit&&(this.visuals.hatch.set_vectorize(t,i),t.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(t,i),t.stroke()))}}_hit_point(t){let s,i,e,h,r,a,l,_,d;const{sx:c,sy:x}=t,w=this.renderer.xscale.invert(c),p=this.renderer.yscale.invert(x);\"data\"==this.model.properties.width.units?(s=w-this.max_width,i=w+this.max_width):(a=c-this.max_width,l=c+this.max_width,[s,i]=this.renderer.xscale.r_invert(a,l)),\"data\"==this.model.properties.height.units?(e=p-this.max_height,h=p+this.max_height):(_=x-this.max_height,d=x+this.max_height,[e,h]=this.renderer.yscale.r_invert(_,d));const m=this.index.indices({x0:s,x1:i,y0:e,y1:h}),v=[];for(const t of m)r=n.point_in_ellipse(c,x,this.angle.get(t),this.sh[t]/2,this.sw[t]/2,this.sx[t],this.sy[t]),r&&v.push(t);return new o.Selection({indices:v})}draw_legend_for_index(t,{x0:s,y0:i,x1:e,y1:h},r){const a=r+1,n=new Array(a);n[r]=(s+e)/2;const l=new Array(a);l[r]=(i+h)/2;const o=this.sw[r]/this.sh[r],_=.8*Math.min(Math.abs(e-s),Math.abs(h-i)),d=new Array(a),c=new Array(a);o>1?(d[r]=_,c[r]=_/o):(d[r]=_*o,c[r]=_),this._render(t,[r],{sx:n,sy:l,sw:d,sh:c,_angle:[0]})}}i.EllipseOvalView=_,_.__name__=\"EllipseOvalView\";class d extends a.CenterRotatable{constructor(t){super(t)}}i.EllipseOval=d,d.__name__=\"EllipseOval\"},\n",
" function _(t,e,i,a,n){a();const s=t(1),h=t(64),r=t(48),o=s.__importStar(t(18));class _ extends h.XYGlyphView{get max_w2(){return\"data\"==this.model.properties.width.units?this.max_width/2:0}get max_h2(){return\"data\"==this.model.properties.height.units?this.max_height/2:0}_bounds({x0:t,x1:e,y0:i,y1:a}){const{max_w2:n,max_h2:s}=this;return{x0:t-n,x1:e+n,y0:i-s,y1:a+s}}}i.CenterRotatableView=_,_.__name__=\"CenterRotatableView\";class l extends h.XYGlyph{constructor(t){super(t)}static init_CenterRotatable(){this.mixins([r.LineVector,r.FillVector,r.HatchVector]),this.define((({})=>({angle:[o.AngleSpec,0],width:[o.DistanceSpec,{field:\"width\"}],height:[o.DistanceSpec,{field:\"height\"}]})))}}i.CenterRotatable=l,l.__name__=\"CenterRotatable\",l.init_CenterRotatable()},\n",
" function _(t,e,s,i,h){i();const r=t(1),a=t(290),n=t(24),_=r.__importStar(t(18));class o extends a.BoxView{scenterxy(t){return[(this.sleft[t]+this.sright[t])/2,this.sy[t]]}_lrtb(t){const e=this._left[t],s=this._right[t],i=this._y[t],h=this.height.get(t)/2;return[Math.min(e,s),Math.max(e,s),i+h,i-h]}_map_data(){this.sy=this.renderer.yscale.v_compute(this._y),this.sh=this.sdist(this.renderer.yscale,this._y,this.height,\"center\"),this.sleft=this.renderer.xscale.v_compute(this._left),this.sright=this.renderer.xscale.v_compute(this._right);const t=this.sy.length;this.stop=new n.ScreenArray(t),this.sbottom=new n.ScreenArray(t);for(let e=0;e<t;e++)this.stop[e]=this.sy[e]-this.sh[e]/2,this.sbottom[e]=this.sy[e]+this.sh[e]/2;this._clamp_viewport()}}s.HBarView=o,o.__name__=\"HBarView\";class c extends a.Box{constructor(t){super(t)}static init_HBar(){this.prototype.default_view=o,this.define((({})=>({left:[_.XCoordinateSpec,{value:0}],y:[_.YCoordinateSpec,{field:\"y\"}],height:[_.NumberSpec,{value:1}],right:[_.XCoordinateSpec,{field:\"right\"}]})))}}s.HBar=c,c.__name__=\"HBar\",c.init_HBar()},\n",
" function _(t,e,s,i,r){i();const n=t(48),o=t(98),a=t(106),h=t(59);class c extends o.GlyphView{get_anchor_point(t,e,s){const i=Math.min(this.sleft[e],this.sright[e]),r=Math.max(this.sright[e],this.sleft[e]),n=Math.min(this.stop[e],this.sbottom[e]),o=Math.max(this.sbottom[e],this.stop[e]);switch(t){case\"top_left\":return{x:i,y:n};case\"top\":case\"top_center\":return{x:(i+r)/2,y:n};case\"top_right\":return{x:r,y:n};case\"bottom_left\":return{x:i,y:o};case\"bottom\":case\"bottom_center\":return{x:(i+r)/2,y:o};case\"bottom_right\":return{x:r,y:o};case\"left\":case\"center_left\":return{x:i,y:(n+o)/2};case\"center\":case\"center_center\":return{x:(i+r)/2,y:(n+o)/2};case\"right\":case\"center_right\":return{x:r,y:(n+o)/2}}}_index_data(t){const{min:e,max:s}=Math,{data_size:i}=this;for(let r=0;r<i;r++){const[i,n,o,a]=this._lrtb(r);isNaN(i+n+o+a)||!isFinite(i+n+o+a)?t.add_empty():t.add(e(i,n),e(o,a),s(n,i),s(o,a))}}_render(t,e,s){const{sleft:i,sright:r,stop:n,sbottom:o}=null!=s?s:this;for(const s of e){const e=i[s],h=n[s],c=r[s],_=o[s];function a(){t.beginPath(),t.rect(e,h,c-e,_-h)}isNaN(e+h+c+_)||(this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(t,s),a(),t.fill()),this.visuals.hatch.doit&&(this.visuals.hatch.set_vectorize(t,s),a(),t.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(t,s),a(),t.stroke()))}}_clamp_viewport(){const t=this.renderer.plot_view.frame.bbox.h_range,e=this.renderer.plot_view.frame.bbox.v_range,s=this.stop.length;for(let i=0;i<s;i++)this.stop[i]=Math.max(this.stop[i],e.start),this.sbottom[i]=Math.min(this.sbottom[i],e.end),this.sleft[i]=Math.max(this.sleft[i],t.start),this.sright[i]=Math.min(this.sright[i],t.end)}_hit_rect(t){return this._hit_rect_against_index(t)}_hit_point(t){const{sx:e,sy:s}=t,i=this.renderer.xscale.invert(e),r=this.renderer.yscale.invert(s),n=[...this.index.indices({x0:i,y0:r,x1:i,y1:r})];return new h.Selection({indices:n})}_hit_span(t){const{sx:e,sy:s}=t;let i;if(\"v\"==t.direction){const t=this.renderer.yscale.invert(s),e=this.renderer.plot_view.frame.bbox.h_range,[r,n]=this.renderer.xscale.r_invert(e.start,e.end);i=[...this.index.indices({x0:r,y0:t,x1:n,y1:t})]}else{const t=this.renderer.xscale.invert(e),s=this.renderer.plot_view.frame.bbox.v_range,[r,n]=this.renderer.yscale.r_invert(s.start,s.end);i=[...this.index.indices({x0:t,y0:r,x1:t,y1:n})]}return new h.Selection({indices:i})}draw_legend_for_index(t,e,s){a.generic_area_vector_legend(this.visuals,t,e,s)}}s.BoxView=c,c.__name__=\"BoxView\";class _ extends o.Glyph{constructor(t){super(t)}static init_Box(){this.mixins([n.LineVector,n.FillVector,n.HatchVector])}}s.Box=_,_.__name__=\"Box\",_.init_Box()},\n",
" function _(e,t,s,i,r){i();const n=e(1),o=e(98),a=n.__importStar(e(107)),c=n.__importStar(e(18)),l=e(48),h=e(20),_=e(65),d=e(106),x=e(59);class p extends o.GlyphView{scenterxy(e){return[this.sx[e],this.sy[e]]}_set_data(){const{orientation:e,size:t,aspect_scale:s}=this.model,{q:i,r}=this,n=this.q.length;this._x=new Float64Array(n),this._y=new Float64Array(n);const{_x:o,_y:a}=this,c=Math.sqrt(3);if(\"pointytop\"==e)for(let e=0;e<n;e++){const n=i.get(e),l=r.get(e)/2;o[e]=t*c*(n+l)/s,a[e]=-3*t*l}else for(let e=0;e<n;e++){const n=i.get(e)/2,l=r.get(e);o[e]=3*t*n,a[e]=-t*c*(l+n)*s}}_project_data(){_.inplace.project_xy(this._x,this._y)}_index_data(e){let t=this.model.size,s=Math.sqrt(3)*t/2;\"flattop\"==this.model.orientation?([s,t]=[t,s],t*=this.model.aspect_scale):s/=this.model.aspect_scale;const{data_size:i}=this;for(let r=0;r<i;r++){const i=this._x[r],n=this._y[r];isNaN(i+n)||!isFinite(i+n)?e.add_empty():e.add(i-s,n-t,i+s,n+t)}}map_data(){[this.sx,this.sy]=this.renderer.coordinates.map_to_screen(this._x,this._y),[this.svx,this.svy]=this._get_unscaled_vertices()}_get_unscaled_vertices(){const e=this.model.size,t=this.model.aspect_scale;if(\"pointytop\"==this.model.orientation){const s=this.renderer.yscale,i=this.renderer.xscale,r=Math.abs(s.compute(0)-s.compute(e)),n=Math.sqrt(3)/2*Math.abs(i.compute(0)-i.compute(e))/t,o=r/2;return[[0,-n,-n,0,n,n],[r,o,-o,-r,-o,o]]}{const s=this.renderer.xscale,i=this.renderer.yscale,r=Math.abs(s.compute(0)-s.compute(e)),n=Math.sqrt(3)/2*Math.abs(i.compute(0)-i.compute(e))*t,o=r/2;return[[r,o,-o,-r,-o,o],[0,-n,-n,0,n,n]]}}_render(e,t,s){const{sx:i,sy:r,svx:n,svy:o,scale:a}=null!=s?s:this;for(const s of t){const t=i[s],c=r[s],l=a.get(s);if(!isNaN(t+c+l)){e.translate(t,c),e.beginPath();for(let t=0;t<6;t++)e.lineTo(n[t]*l,o[t]*l);e.closePath(),e.translate(-t,-c),this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(e,s),e.fill()),this.visuals.hatch.doit&&(this.visuals.hatch.set_vectorize(e,s),e.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(e,s),e.stroke())}}}_hit_point(e){const{sx:t,sy:s}=e,i=this.renderer.xscale.invert(t),r=this.renderer.yscale.invert(s),n=this.index.indices({x0:i,y0:r,x1:i,y1:r}),o=[];for(const e of n)a.point_in_poly(t-this.sx[e],s-this.sy[e],this.svx,this.svy)&&o.push(e);return new x.Selection({indices:o})}_hit_span(e){const{sx:t,sy:s}=e;let i;if(\"v\"==e.direction){const e=this.renderer.yscale.invert(s),t=this.renderer.plot_view.frame.bbox.h_range,[r,n]=this.renderer.xscale.r_invert(t.start,t.end);i=[...this.index.indices({x0:r,y0:e,x1:n,y1:e})]}else{const e=this.renderer.xscale.invert(t),s=this.renderer.plot_view.frame.bbox.v_range,[r,n]=this.renderer.yscale.r_invert(s.start,s.end);i=[...this.index.indices({x0:e,y0:r,x1:e,y1:n})]}return new x.Selection({indices:i})}_hit_rect(e){const{sx0:t,sx1:s,sy0:i,sy1:r}=e,[n,o]=this.renderer.xscale.r_invert(t,s),[a,c]=this.renderer.yscale.r_invert(i,r),l=[...this.index.indices({x0:n,x1:o,y0:a,y1:c})];return new x.Selection({indices:l})}draw_legend_for_index(e,t,s){d.generic_area_vector_legend(this.visuals,e,t,s)}}s.HexTileView=p,p.__name__=\"HexTileView\";class y extends o.Glyph{constructor(e){super(e)}static init_HexTile(){this.prototype.default_view=p,this.mixins([l.LineVector,l.FillVector,l.HatchVector]),this.define((({Number:e})=>({r:[c.NumberSpec,{field:\"r\"}],q:[c.NumberSpec,{field:\"q\"}],scale:[c.NumberSpec,1],size:[e,1],aspect_scale:[e,1],orientation:[h.HexTileOrientation,\"pointytop\"]}))),this.override({line_color:null})}}s.HexTile=y,y.__name__=\"HexTile\",y.init_HexTile()},\n",
" function _(e,a,t,_,s){_();const i=e(293),n=e(203),r=e(214);class o extends i.ImageBaseView{connect_signals(){super.connect_signals(),this.connect(this.model.color_mapper.change,(()=>this._update_image()))}_update_image(){null!=this.image_data&&(this._set_data(null),this.renderer.request_render())}_flat_img_to_buf8(e){return this.model.color_mapper.rgba_mapper.v_compute(e)}}t.ImageView=o,o.__name__=\"ImageView\";class m extends i.ImageBase{constructor(e){super(e)}static init_Image(){this.prototype.default_view=o,this.define((({Ref:e})=>({color_mapper:[e(n.ColorMapper),()=>new r.LinearColorMapper({palette:[\"#000000\",\"#252525\",\"#525252\",\"#737373\",\"#969696\",\"#bdbdbd\",\"#d9d9d9\",\"#f0f0f0\",\"#ffffff\"]})]})))}}t.Image=m,m.__name__=\"Image\",m.init_Image()},\n",
" function _(e,t,i,s,a){s();const h=e(1),n=e(64),r=e(24),_=h.__importStar(e(18)),d=e(59),l=e(9),g=e(29),o=e(11);class c extends n.XYGlyphView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.global_alpha.change,(()=>this.renderer.request_render()))}_render(e,t,i){const{image_data:s,sx:a,sy:h,sw:n,sh:r}=null!=i?i:this,_=e.getImageSmoothingEnabled();e.setImageSmoothingEnabled(!1),e.globalAlpha=this.model.global_alpha;for(const i of t){const t=s[i],_=a[i],d=h[i],l=n[i],g=r[i];if(null==t||isNaN(_+d+l+g))continue;const o=d;e.translate(0,o),e.scale(1,-1),e.translate(0,-o),e.drawImage(t,0|_,0|d,l,g),e.translate(0,o),e.scale(1,-1),e.translate(0,-o)}e.setImageSmoothingEnabled(_)}_set_data(e){this._set_width_heigh_data();for(let t=0,i=this.image.length;t<i;t++){if(null!=e&&e.indexOf(t)<0)continue;const i=this.image.get(t);let s;g.is_NDArray(i)?(o.assert(2==i.dimension,\"expected a 2D array\"),s=i,this._height[t]=i.shape[0],this._width[t]=i.shape[1]):(s=l.concat(i),this._height[t]=i.length,this._width[t]=i[0].length);const a=this._flat_img_to_buf8(s);this._set_image_data_from_buffer(t,a)}}_index_data(e){const{data_size:t}=this;for(let i=0;i<t;i++){const[t,s,a,h]=this._lrtb(i);isNaN(t+s+a+h)||!isFinite(t+s+a+h)?e.add_empty():e.add(t,h,s,a)}}_lrtb(e){const t=this.dw.get(e),i=this.dh.get(e),s=this.renderer.xscale.source_range,a=this._x[e],h=s.is_reversed?a-t:a+t,n=this.renderer.yscale.source_range,r=this._y[e],_=n.is_reversed?r-i:r+i,[d,l]=a<h?[a,h]:[h,a],[g,o]=r<_?[r,_]:[_,r];return[d,l,o,g]}_set_width_heigh_data(){null!=this.image_data&&this.image_data.length==this.image.length||(this.image_data=new Array(this.image.length)),null!=this._width&&this._width.length==this.image.length||(this._width=new Uint32Array(this.image.length)),null!=this._height&&this._height.length==this.image.length||(this._height=new Uint32Array(this.image.length))}_get_or_create_canvas(e){const t=this.image_data[e];if(null!=t&&t.width==this._width[e]&&t.height==this._height[e])return t;{const t=document.createElement(\"canvas\");return t.width=this._width[e],t.height=this._height[e],t}}_set_image_data_from_buffer(e,t){const i=this._get_or_create_canvas(e),s=i.getContext(\"2d\"),a=s.getImageData(0,0,this._width[e],this._height[e]);a.data.set(t),s.putImageData(a,0,0),this.image_data[e]=i}_map_data(){\"data\"==this.model.properties.dw.units?this.sw=this.sdist(this.renderer.xscale,this._x,this.dw,\"edge\",this.model.dilate):this.sw=r.to_screen(this.dw),\"data\"==this.model.properties.dh.units?this.sh=this.sdist(this.renderer.yscale,this._y,this.dh,\"edge\",this.model.dilate):this.sh=r.to_screen(this.dh)}_image_index(e,t,i){const[s,a,h,n]=this._lrtb(e),r=this._width[e],_=this._height[e],d=(a-s)/r,l=(h-n)/_;let g=Math.floor((t-s)/d),o=Math.floor((i-n)/l);return this.renderer.xscale.source_range.is_reversed&&(g=r-g-1),this.renderer.yscale.source_range.is_reversed&&(o=_-o-1),{index:e,dim1:g,dim2:o,flat_index:o*r+g}}_hit_point(e){const{sx:t,sy:i}=e,s=this.renderer.xscale.invert(t),a=this.renderer.yscale.invert(i),h=this.index.indices({x0:s,x1:s,y0:a,y1:a}),n=new d.Selection;for(const e of h)t!=1/0&&i!=1/0&&n.image_indices.push(this._image_index(e,s,a));return n}}i.ImageBaseView=c,c.__name__=\"ImageBaseView\";class m extends n.XYGlyph{constructor(e){super(e)}static init_ImageBase(){this.define((({Boolean:e,Alpha:t})=>({image:[_.NDArraySpec,{field:\"image\"}],dw:[_.DistanceSpec,{field:\"dw\"}],dh:[_.DistanceSpec,{field:\"dh\"}],dilate:[e,!1],global_alpha:[t,1]})))}}i.ImageBase=m,m.__name__=\"ImageBase\",m.init_ImageBase()},\n",
" function _(e,a,t,_,i){_();const n=e(293),s=e(8);class r extends n.ImageBaseView{_flat_img_to_buf8(e){let a;return a=s.isArray(e)?new Uint32Array(e):e,new Uint8ClampedArray(a.buffer)}}t.ImageRGBAView=r,r.__name__=\"ImageRGBAView\";class m extends n.ImageBase{constructor(e){super(e)}static init_ImageRGBA(){this.prototype.default_view=r}}t.ImageRGBA=m,m.__name__=\"ImageRGBA\",m.init_ImageRGBA()},\n",
" function _(e,t,s,r,a){r();const i=e(1),n=e(64),o=e(24),c=e(20),_=i.__importStar(e(18)),h=e(12),l=e(296);class d extends n.XYGlyphView{constructor(){super(...arguments),this._images_rendered=!1,this._set_data_iteration=0}connect_signals(){super.connect_signals(),this.connect(this.model.properties.global_alpha.change,(()=>this.renderer.request_render()))}_index_data(e){const{data_size:t}=this;for(let s=0;s<t;s++)e.add_empty()}_set_data(){this._set_data_iteration++;const e=this.url.length;this.image=new Array(e);const{retry_attempts:t,retry_timeout:s}=this.model,{_set_data_iteration:r}=this;for(let a=0;a<e;a++){const e=this.url.get(a);e&&new l.ImageLoader(e,{loaded:e=>{this._set_data_iteration==r&&(this.image[a]=e,this.renderer.request_render())},attempts:t+1,timeout:s})}const a=\"data\"==this.model.properties.w.units,i=\"data\"==this.model.properties.h.units,n=this._x.length,c=new o.ScreenArray(a?2*n:n),_=new o.ScreenArray(i?2*n:n),{anchor:d}=this.model;function m(e,t){switch(d){case\"top_left\":case\"bottom_left\":case\"left\":case\"center_left\":return[e,e+t];case\"top\":case\"top_center\":case\"bottom\":case\"bottom_center\":case\"center\":case\"center_center\":return[e-t/2,e+t/2];case\"top_right\":case\"bottom_right\":case\"right\":case\"center_right\":return[e-t,e]}}function g(e,t){switch(d){case\"top_left\":case\"top\":case\"top_center\":case\"top_right\":return[e,e-t];case\"bottom_left\":case\"bottom\":case\"bottom_center\":case\"bottom_right\":return[e+t,e];case\"left\":case\"center_left\":case\"center\":case\"center_center\":case\"right\":case\"center_right\":return[e+t/2,e-t/2]}}if(a)for(let e=0;e<n;e++)[c[e],c[n+e]]=m(this._x[e],this.w.get(e));else c.set(this._x,0);if(i)for(let e=0;e<n;e++)[_[e],_[n+e]]=g(this._y[e],this.h.get(e));else _.set(this._y,0);const[u,p]=h.minmax(c),[f,b]=h.minmax(_);this._bounds_rect={x0:u,x1:p,y0:f,y1:b}}has_finished(){return super.has_finished()&&1==this._images_rendered}_map_data(){\"data\"==this.model.properties.w.units?this.sw=this.sdist(this.renderer.xscale,this._x,this.w,\"edge\",this.model.dilate):this.sw=o.to_screen(this.w),\"data\"==this.model.properties.h.units?this.sh=this.sdist(this.renderer.yscale,this._y,this.h,\"edge\",this.model.dilate):this.sh=o.to_screen(this.h)}_render(e,t,s){const{image:r,sx:a,sy:i,sw:n,sh:o,angle:c}=null!=s?s:this,{frame:_}=this.renderer.plot_view;e.rect(_.bbox.left+1,_.bbox.top+1,_.bbox.width-2,_.bbox.height-2),e.clip();let h=!0;for(const s of t){if(isNaN(a[s]+i[s]+c.get(s)))continue;const t=r[s];null!=t?this._render_image(e,s,t,a,i,n,o,c):h=!1}h&&!this._images_rendered&&(this._images_rendered=!0,this.notify_finished())}_final_sx_sy(e,t,s,r,a){switch(e){case\"top_left\":return[t,s];case\"top\":case\"top_center\":return[t-r/2,s];case\"top_right\":return[t-r,s];case\"right\":case\"center_right\":return[t-r,s-a/2];case\"bottom_right\":return[t-r,s-a];case\"bottom\":case\"bottom_center\":return[t-r/2,s-a];case\"bottom_left\":return[t,s-a];case\"left\":case\"center_left\":return[t,s-a/2];case\"center\":case\"center_center\":return[t-r/2,s-a/2]}}_render_image(e,t,s,r,a,i,n,o){isNaN(i[t])&&(i[t]=s.width),isNaN(n[t])&&(n[t]=s.height);const c=i[t],_=n[t],{anchor:h}=this.model,[l,d]=this._final_sx_sy(h,r[t],a[t],c,_),m=o.get(t);e.save(),e.globalAlpha=this.model.global_alpha;const g=c/2,u=_/2;m?(e.translate(l,d),e.translate(g,u),e.rotate(m),e.translate(-g,-u),e.drawImage(s,0,0,c,_),e.translate(g,u),e.rotate(-m),e.translate(-g,-u),e.translate(-l,-d)):e.drawImage(s,l,d,c,_),e.restore()}bounds(){return this._bounds_rect}}s.ImageURLView=d,d.__name__=\"ImageURLView\";class m extends n.XYGlyph{constructor(e){super(e)}static init_ImageURL(){this.prototype.default_view=d,this.define((({Boolean:e,Int:t,Alpha:s})=>({url:[_.StringSpec,{field:\"url\"}],anchor:[c.Anchor,\"top_left\"],global_alpha:[s,1],angle:[_.AngleSpec,0],w:[_.NullDistanceSpec,null],h:[_.NullDistanceSpec,null],dilate:[e,!1],retry_attempts:[t,0],retry_timeout:[t,0]})))}}s.ImageURL=m,m.__name__=\"ImageURL\",m.init_ImageURL()},\n",
" function _(i,e,t,s,o){s();const a=i(19);class n{constructor(i,e={}){this._image=new Image,this._finished=!1;const{attempts:t=1,timeout:s=1}=e;this.promise=new Promise(((o,n)=>{this._image.crossOrigin=\"anonymous\";let r=0;this._image.onerror=()=>{if(++r==t){const s=`unable to load ${i} image after ${t} attempts`;if(a.logger.warn(s),null==this._image.crossOrigin)return void(null!=e.failed&&e.failed());a.logger.warn(`attempting to load ${i} without a cross origin policy`),this._image.crossOrigin=null,r=0}setTimeout((()=>this._image.src=i),s)},this._image.onload=()=>{this._finished=!0,null!=e.loaded&&e.loaded(this._image),o(this._image)},this._image.src=i}))}get finished(){return this._finished}get image(){if(this._finished)return this._image;throw new Error(\"not loaded yet\")}}t.ImageLoader=n,n.__name__=\"ImageLoader\"},\n",
" function _(t,s,e,i,n){i();const o=t(1),l=t(101),r=t(98),h=t(106),_=t(12),a=t(12),c=t(48),d=o.__importStar(t(107)),x=o.__importStar(t(18)),y=t(59),f=t(11);class g extends r.GlyphView{_project_data(){}_index_data(t){const{min:s,max:e}=Math,{data_size:i}=this;for(let n=0;n<i;n++){const i=this._xs[n],o=this._ys[n];if(0==i.length||0==o.length){t.add_empty();continue}let l=1/0,r=-1/0,h=1/0,a=-1/0;for(let t=0,n=i.length;t<n;t++){const n=i[t][0],c=o[t][0];if(0!=n.length&&0!=c.length){const[t,i]=_.minmax(n),[o,d]=_.minmax(c);l=s(l,t),r=e(r,i),h=s(h,o),a=e(a,d)}}isFinite(l+r+h+a)?t.add(l,h,r,a):t.add_empty()}this._hole_index=this._index_hole_data()}_index_hole_data(){const{min:t,max:s}=Math,{data_size:e}=this,i=new l.SpatialIndex(e);for(let n=0;n<e;n++){const e=this._xs[n],o=this._ys[n];if(0==e.length||0==o.length){i.add_empty();continue}let l=1/0,r=-1/0,h=1/0,a=-1/0;for(let i=0,n=e.length;i<n;i++){const n=e[i],c=o[i];if(n.length>1&&c.length>1)for(let e=1,i=n.length;e<i;e++){const[i,o]=_.minmax(n[e]),[d,x]=_.minmax(c[e]);l=t(l,i),r=s(r,o),h=t(h,d),a=s(a,x)}}isFinite(l+r+h+a)?i.add(l,h,r,a):i.add_empty()}return i.finish(),i}_mask_data(){const{x_range:t,y_range:s}=this.renderer.plot_view.frame;return this.index.indices({x0:t.min,x1:t.max,y0:s.min,y1:s.max})}_inner_loop(t,s,e){t.beginPath();for(let i=0,n=s.length;i<n;i++)for(let n=0,o=s[i].length;n<o;n++){const o=s[i][n],l=e[i][n];for(let s=0,e=o.length;s<e;s++)0!=s?t.lineTo(o[s],l[s]):t.moveTo(o[s],l[s]);t.closePath()}}_render(t,s,e){if(this.visuals.fill.doit||this.visuals.line.doit){const{sxs:i,sys:n}=null!=e?e:this;for(const e of s){const s=i[e],o=n[e];this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(t,e),this._inner_loop(t,s,o),t.fill(\"evenodd\")),this.visuals.hatch.doit&&(this.visuals.hatch.set_vectorize(t,e),this._inner_loop(t,s,o),t.fill(\"evenodd\")),this.visuals.line.doit&&(this.visuals.line.set_vectorize(t,e),this._inner_loop(t,s,o),t.stroke())}}}_hit_rect(t){const{sx0:s,sx1:e,sy0:i,sy1:n}=t,o=[s,e,e,s],l=[i,i,n,n],[r,h]=this.renderer.xscale.r_invert(s,e),[_,a]=this.renderer.yscale.r_invert(i,n),c=this.index.indices({x0:r,x1:h,y0:_,y1:a}),x=[];for(const t of c){const s=this.sxs[t],e=this.sys[t];let i=!0;for(let t=0,n=s.length;t<n;t++){for(let n=0,r=s[t][0].length;n<r;n++){const r=s[t][0][n],h=e[t][0][n];if(!d.point_in_poly(r,h,o,l)){i=!1;break}}if(!i)break}i&&x.push(t)}return new y.Selection({indices:x})}_hit_point(t){const{sx:s,sy:e}=t,i=this.renderer.xscale.invert(s),n=this.renderer.yscale.invert(e),o=this.index.indices({x0:i,y0:n,x1:i,y1:n}),l=this._hole_index.indices({x0:i,y0:n,x1:i,y1:n}),r=[];for(const t of o){const i=this.sxs[t],n=this.sys[t];for(let o=0,h=i.length;o<h;o++){const h=i[o].length;if(d.point_in_poly(s,e,i[o][0],n[o][0]))if(1==h)r.push(t);else if(l.get(t)){if(h>1){let l=!1;for(let t=1;t<h;t++){const r=i[o][t],h=n[o][t];if(d.point_in_poly(s,e,r,h)){l=!0;break}}l||r.push(t)}}else r.push(t)}}return new y.Selection({indices:r})}_get_snap_coord(t){return a.sum(t)/t.length}scenterxy(t,s,e){if(1==this.sxs[t].length){return[this._get_snap_coord(this.sxs[t][0][0]),this._get_snap_coord(this.sys[t][0][0])]}{const i=this.sxs[t],n=this.sys[t];for(let t=0,o=i.length;t<o;t++)if(d.point_in_poly(s,e,i[t][0],n[t][0])){return[this._get_snap_coord(i[t][0]),this._get_snap_coord(n[t][0])]}}f.unreachable()}map_data(){const t=this._xs.length;this.sxs=new Array(t),this.sys=new Array(t);for(let s=0;s<t;s++){const t=this._xs[s].length;this.sxs[s]=new Array(t),this.sys[s]=new Array(t);for(let e=0;e<t;e++){const t=this._xs[s][e].length;this.sxs[s][e]=new Array(t),this.sys[s][e]=new Array(t);for(let i=0;i<t;i++){const[t,n]=this.renderer.coordinates.map_to_screen(this._xs[s][e][i],this._ys[s][e][i]);this.sxs[s][e][i]=t,this.sys[s][e][i]=n}}}}draw_legend_for_index(t,s,e){h.generic_area_vector_legend(this.visuals,t,s,e)}}e.MultiPolygonsView=g,g.__name__=\"MultiPolygonsView\";class p extends r.Glyph{constructor(t){super(t)}static init_MultiPolygons(){this.prototype.default_view=g,this.define((({})=>({xs:[x.XCoordinateSeqSeqSeqSpec,{field:\"xs\"}],ys:[x.YCoordinateSeqSeqSeqSpec,{field:\"ys\"}]}))),this.mixins([c.LineVector,c.FillVector,c.HatchVector])}}e.MultiPolygons=p,p.__name__=\"MultiPolygons\",p.init_MultiPolygons()},\n",
" function _(a,t,e,l,s){l();const _=a(287),i=a(12);class n extends _.EllipseOvalView{_map_data(){super._map_data(),i.mul(this.sw,.75)}}e.OvalView=n,n.__name__=\"OvalView\";class v extends _.EllipseOval{constructor(a){super(a)}static init_Oval(){this.prototype.default_view=n}}e.Oval=v,v.__name__=\"Oval\",v.init_Oval()},\n",
" function _(t,e,i,o,s){o();const r=t(1),_=t(290),d=r.__importStar(t(18));class n extends _.BoxView{scenterxy(t){return[this.sleft[t]/2+this.sright[t]/2,this.stop[t]/2+this.sbottom[t]/2]}_lrtb(t){return[this._left[t],this._right[t],this._top[t],this._bottom[t]]}}i.QuadView=n,n.__name__=\"QuadView\";class a extends _.Box{constructor(t){super(t)}static init_Quad(){this.prototype.default_view=n,this.define((({})=>({right:[d.XCoordinateSpec,{field:\"right\"}],bottom:[d.YCoordinateSpec,{field:\"bottom\"}],left:[d.XCoordinateSpec,{field:\"left\"}],top:[d.YCoordinateSpec,{field:\"top\"}]})))}}i.Quad=a,a.__name__=\"Quad\",a.init_Quad()},\n",
" function _(e,t,i,s,n){s();const a=e(1),c=e(48),o=e(65),r=e(98),_=e(106),d=a.__importStar(e(18));function l(e,t,i){if(t==(e+i)/2)return[e,i];{const s=(e-t)/(e-2*t+i),n=e*(1-s)**2+2*t*(1-s)*s+i*s**2;return[Math.min(e,i,n),Math.max(e,i,n)]}}class x extends r.GlyphView{_project_data(){o.inplace.project_xy(this._x0,this._y0),o.inplace.project_xy(this._x1,this._y1)}_index_data(e){const{_x0:t,_x1:i,_y0:s,_y1:n,_cx:a,_cy:c,data_size:o}=this;for(let r=0;r<o;r++){const o=t[r],_=i[r],d=s[r],x=n[r],y=a[r],h=c[r];if(isNaN(o+_+d+x+y+h))e.add_empty();else{const[t,i]=l(o,y,_),[s,n]=l(d,h,x);e.add(t,s,i,n)}}}_render(e,t,i){if(this.visuals.line.doit){const{sx0:s,sy0:n,sx1:a,sy1:c,scx:o,scy:r}=null!=i?i:this;for(const i of t){const t=s[i],_=n[i],d=a[i],l=c[i],x=o[i],y=r[i];isNaN(t+_+d+l+x+y)||(e.beginPath(),e.moveTo(t,_),e.quadraticCurveTo(x,y,d,l),this.visuals.line.set_vectorize(e,i),e.stroke())}}}draw_legend_for_index(e,t,i){_.generic_line_vector_legend(this.visuals,e,t,i)}scenterxy(){throw new Error(`${this}.scenterxy() is not implemented`)}}i.QuadraticView=x,x.__name__=\"QuadraticView\";class y extends r.Glyph{constructor(e){super(e)}static init_Quadratic(){this.prototype.default_view=x,this.define((({})=>({x0:[d.XCoordinateSpec,{field:\"x0\"}],y0:[d.YCoordinateSpec,{field:\"y0\"}],x1:[d.XCoordinateSpec,{field:\"x1\"}],y1:[d.YCoordinateSpec,
@gjoseph92
Copy link

NEED NASA URS credentials in ~/.netrc for GDAL to access these urls

Did you see rmg55/CloudDAAC_Binders#1 (comment)? Might be a helpful example of how to get these credentials loaded on distributed clusters.

@scottyhq
Copy link
Author

scottyhq commented Apr 20, 2021

Yep, unfortunately https://lpdaac.earthdata.nasa.gov/s3credentials only for LPDAAC-curated datasets, so harmonized landsat-sentinel (HLS) for example. NASA data centers are distributed, not all data is cloud hosted, and servers have different capabilities. Unfortunately the local ~/.netrc is the only way to get GDAL /vsicurl/ to get at a lot of this data. So that file would have to be created on distributed workers for now. Related discussion: https://discourse.pangeo.io/t/earthdata-password-pop-up-box/1358

@gjoseph92
Copy link

Oh interesting. I bet we could roll generating a temporary netrc file and setting NETRC into LayeredEnv to handle this for you.

@RichardScottOZ
Copy link

Thanks for this.

Btw, typo - # Gett all the items with gamma0 assets at [8]

Pretty sure lots of people would like you handling the login part!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment