MAJ terminée. Nous sommes passés en version 14.6.2 . Pour consulter les "releases notes" associées c'est ici :

https://about.gitlab.com/releases/2022/01/11/security-release-gitlab-14-6-2-released/
https://about.gitlab.com/releases/2022/01/04/gitlab-14-6-1-released/

M2_gene_expression.ipynb 2.8 MB
Newer Older
FAGES Francois's avatar
FAGES Francois committed
1
2
3
4
5
6
{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
FAGES Francois's avatar
M2    
FAGES Francois committed
7
    "# CRN models of gene expression\n",
FAGES Francois's avatar
Modal2    
FAGES Francois committed
8
    "Modal INF473L Ecole Polytechnique\n",
9
    "\n",
FAGES Francois's avatar
Modal2    
FAGES Francois committed
10
11
    "F. Fages, Feb. 2020\n",
    "\n",
FAGES Francois's avatar
FAGES Francois committed
12
13
14
15
    "In this session, we explore\n",
    "* the process of gene expression: activation by *promotor*, *trancription* in RNA, and *translation* in proteins (discovered by François Jacob and Jacques Monod, Nobel prize 1965)\n",
    "* the stochastic effects caused by low numbers of molecules (a gene is in one single copy)\n",
    "* the expressive power of autocatalysis\n",
FAGES Francois's avatar
Modal2    
FAGES Francois committed
16
    "\n",
FAGES Francois's avatar
FAGES Francois committed
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
    "The importance of stochastic effects in gene expression will lead us in the sequel of the MODAL to favor programming with high numbers of molecules, i.e. using proteins, enzymes and post-translational regulation, instead of gene networks.\n",
    "\n",
    "A *gene* is sequence of DNA which codes for an *RNA*, itself coding for a *protein*. \n",
    "\n",
    "The *RNA polymerase* is a protein complex which transcripts the *DNA sequence* of the gene in the corresponding *RNA sequence*. \n",
    "\n",
    "The binding of the RNA polymerase on the binding site of the DNA can be\n",
    "* either spontaneous (*basal expression*)\n",
    "* or facilitated by the binding of a *promotor* protein already bound on that site (*gene activation*)\n",
    "* or inhibited by the binding of a repressor protein (*gene repression*)\n",
    "\n",
    "<img src=\"gene.png\" alt=\"gene.png\" style=\"width: 400px;\"/>"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
FAGES Francois's avatar
Modal2    
FAGES Francois committed
35
36
37
38
39
40
41
    "# Part I: Basal expression\n",
    "\n",
    "* Transcription: gene + RNApolymerase => geneRNApolymerase => gene + RNApolymerase + RNAnucleus\n",
    "<img src=\"transcription.png\" alt=\"transcription.png\" style=\"width: 500px;\"/>\n",
    "* Translocation: RNAnucleus => RNAcytoplasm\n",
    "* Translation: RNAcytoplasm + ribosome => RNAcytoplasmRibosome => ribosome + protein \n",
    "<img src=\"translation.png\" alt=\"translation.png\" style=\"width: 500px;\"/>"
FAGES Francois's avatar
FAGES Francois committed
42
43
44
45
46
47
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
FAGES Francois's avatar
M2    
FAGES Francois committed
48
    "### Reaction-based modeling\n",
Sylvain Soliman's avatar
Sylvain Soliman committed
49
    "* chemical reaction structure: `reactants => products`\n",
FAGES Francois's avatar
Modal2    
FAGES Francois committed
50
    "* rate function: mass action law kinetics `MA(k)`, Michaelis-Menten kinetics `MM(v,k)`, any mathematical expression over the reactants"
FAGES Francois's avatar
FAGES Francois committed
51
52
53
54
55
56
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
Sylvain Soliman's avatar
Sylvain Soliman committed
57
58
59
60
61
   "outputs": [
    {
     "data": {
      "text/plain": [
       "From inherited 'initial':\r\n",
FAGES Francois's avatar
Modal2    
FAGES Francois committed
62
63
64
65
66
       "[0] function MA(k)=k*product(S*M in [reactants],M^S)\r\n",
       "[1] function MAI(k)=k*product(S*M in [reactants],M^S)/(1+sum(M in [inhibitors],M))\r\n",
       "[2] function MM(Vm, Km)=Vm*single_reactant/(Km+single_reactant)\r\n",
       "[3] function Hill(Vm, Km, n)=Vm*single_reactant^n/(Km^n+single_reactant^n)\r\n",
       "[4] function HillI(Vm, Km, n)=Vm*single_reactant^n/(Km^n+single_reactant^n+sum(M in [inhibitors],M^n))\r\n"
Sylvain Soliman's avatar
Sylvain Soliman committed
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "list_functions."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
FAGES Francois's avatar
FAGES Francois committed
82
83
84
85
86
87
88
   "outputs": [],
   "source": [
    "MA(k1) for gene + RNApolymerase => geneRNApolymerase."
   ]
  },
  {
   "cell_type": "code",
Sylvain Soliman's avatar
Sylvain Soliman committed
89
   "execution_count": 3,
FAGES Francois's avatar
FAGES Francois committed
90
91
92
   "metadata": {},
   "outputs": [],
   "source": [
FAGES Francois's avatar
M2    
FAGES Francois committed
93
    "MA(k2) for geneRNApolymerase => gene + RNApolymerase."
FAGES Francois's avatar
FAGES Francois committed
94
95
96
97
   ]
  },
  {
   "cell_type": "code",
Sylvain Soliman's avatar
Sylvain Soliman committed
98
   "execution_count": 4,
FAGES Francois's avatar
FAGES Francois committed
99
100
101
   "metadata": {},
   "outputs": [],
   "source": [
FAGES Francois's avatar
M2    
FAGES Francois committed
102
    "MA(k3) for geneRNApolymerase => RNAnucleus + geneRNApolymerase."
FAGES Francois's avatar
FAGES Francois committed
103
104
105
106
   ]
  },
  {
   "cell_type": "code",
Sylvain Soliman's avatar
Sylvain Soliman committed
107
   "execution_count": 5,
FAGES Francois's avatar
FAGES Francois committed
108
109
110
   "metadata": {},
   "outputs": [],
   "source": [
FAGES Francois's avatar
M2    
FAGES Francois committed
111
    "MA(k4) for RNAnucleus => RNAcytoplasm."
FAGES Francois's avatar
FAGES Francois committed
112
113
114
115
   ]
  },
  {
   "cell_type": "code",
Sylvain Soliman's avatar
Sylvain Soliman committed
116
   "execution_count": 6,
FAGES Francois's avatar
FAGES Francois committed
117
118
119
   "metadata": {},
   "outputs": [],
   "source": [
FAGES Francois's avatar
M2    
FAGES Francois committed
120
    "MA(k5) for RNAcytoplasm + ribosome => RNAcytoplasmRibosome."
FAGES Francois's avatar
FAGES Francois committed
121
122
123
124
   ]
  },
  {
   "cell_type": "code",
Sylvain Soliman's avatar
Sylvain Soliman committed
125
   "execution_count": 7,
FAGES Francois's avatar
FAGES Francois committed
126
127
128
   "metadata": {},
   "outputs": [],
   "source": [
FAGES Francois's avatar
M2    
FAGES Francois committed
129
    "MA(k6) for RNAcytoplasmRibosome => protein + ribosome."
FAGES Francois's avatar
FAGES Francois committed
130
131
132
133
   ]
  },
  {
   "cell_type": "code",
Sylvain Soliman's avatar
Sylvain Soliman committed
134
   "execution_count": 8,
FAGES Francois's avatar
FAGES Francois committed
135
136
137
   "metadata": {},
   "outputs": [],
   "source": [
FAGES Francois's avatar
M2    
FAGES Francois committed
138
139
140
141
142
143
144
145
146
    "MA(k7) for protein => _."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
FAGES Francois's avatar
FAGES Francois committed
147
    "parameter(k1=1, k2=1, k3=1, k4=1, k5=1, k6=1, k7=0.1)."
FAGES Francois's avatar
FAGES Francois committed
148
149
150
151
152
153
154
155
156
157
158
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Initial state"
   ]
  },
  {
   "cell_type": "code",
FAGES Francois's avatar
M2    
FAGES Francois committed
159
   "execution_count": 10,
FAGES Francois's avatar
FAGES Francois committed
160
161
162
   "metadata": {},
   "outputs": [],
   "source": [
Sylvain Soliman's avatar
Sylvain Soliman committed
163
164
165
    "present(gene, nbgene).\n",
    "present(RNApolymerase, nbRNApolymerase).\n",
    "present(ribosome, nbribosome)."
FAGES Francois's avatar
FAGES Francois committed
166
167
168
169
   ]
  },
  {
   "cell_type": "code",
FAGES Francois's avatar
M2    
FAGES Francois committed
170
   "execution_count": 11,
FAGES Francois's avatar
FAGES Francois committed
171
172
173
   "metadata": {},
   "outputs": [],
   "source": [
FAGES Francois's avatar
Modal2    
FAGES Francois committed
174
    "parameter(nbgene=1, nbRNApolymerase=10, nbribosome=10)."
FAGES Francois's avatar
FAGES Francois committed
175
176
177
178
179
180
181
182
183
184
185
186
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Chemical reaction network (CRN)\n",
    "* hypergraph represented by a bipartite species-reactions graph"
   ]
  },
  {
   "cell_type": "code",
FAGES Francois's avatar
M2    
FAGES Francois committed
187
   "execution_count": 12,
FAGES Francois's avatar
FAGES Francois committed
188
189
190
191
   "metadata": {},
   "outputs": [
    {
     "data": {
192
      "image/png": "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AAIIxFkg7WpXpCuxuqa6LL333ns2cuRI11IRjetorMWYMWNcF6n777/f0tLSonFazoEAAggggAACCCCAAAIFE8iMaTChtKir09y5c61nz57WrFmzgiUvx9779++38ePHu3ESQ4cOzfEtvyKAAAIIIIAAAggggEAcBWIfTCgzGow9ffp014rQrl07a9CggYUaVJ1b5vfu3WurVq2yDz74wA3Q1ixQHTp0sJo1a+a2O58hgAACCCCAAAIIIIBA7AXiE0x4+di8ebOtXLnS9u3b5wIKzcRUo0YN12VJYx80zeuZM2dMC9UpANF+u3btMh3XrVs306rXjz32mH344YemBevuuOMO+973vmdt27b1LsFPBBBAAAEEEEAAAQQQiI9AfIMJL08alL1z505Ti4O6LmlmprNnz7pZnhRUaDYoLUhXvXp11/qgVoy3337bHnnkEXecxkpkZGS4lo777rvPJkyY4J2anwgggAACCCCAAAIIIBAfgcQEE5Hkbd26dbZo0SI3mPu3v/2t/fKXv3QtFc8884wpuGBDAAEEEEAAAQQQQACBuAokTzAhltmzZ9vRo0etR48erpXipZdeshUrVrjVtgcPHmylS5eOqx4XQwABBBBAAAEEEEAgwALJFUxoWtg333zT6tata506dbpWbmqxWL16tWuhYEXsayy8QQABBBBAAAEEEEAglgKZMVu0LhapLlKkiA0bNswN4tbq196mgdlaCXvs2LFuKlrvc34igAACCCCAAAIIIIBA7ARivs5ELJKugdvjxo2zJ554wm6++eZrlzh06JC9++67Vr9+fbeuBQvaXaPhDQIIIIAAAggggAAC0RZIrm5O2XOvsRKfffaZCyg0pay3nT9/3iZNmuRmhxo+fLibGcr7jp8IIIAAAggggAACCCAQNYHkDSZEMHnyZCcxaNCgG0S8cRTqFlWtWrUbvucDBBBAAAEEEEAAAQQQKJRAco2ZyJnVr33ta/bFF1/Yp59+mvMrN21s37597e9//7utWbPmhu/5AAEEEEAAAQQQQAABBAonkFQDsHNmVYvZaY2JxYsX2+eff57zazd2QitmL1myxGbOnGmaDYoNAQQQQAABBBBAAAEEoiOQ1MGECMqVK2fq5jR+/HjTyto5twoVKriF7k6cOOGmlT1z5kzOXfgdAQQQQAABBBBAAAEEIhBI+mBCea5Tp461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AAE/C9AyEYfSKV26tFsM7rnnnnOV/ocfftgFAS1btnQtELt27XItCwoYtI9WotbaD7Vr13bdnBRcDBw40LZt22Z169Z175XsevXquSlc1epRoUKFmOekYcOG9uijj9pHH31kM2fOzHWF75gnggsggAACCCCAAAII+EaAYCIORXHq1CkXCGRmZroWhxdeeMG0SvbYsWPt/PnzrpVBgcWTTz5pc+bMserVq7vvdu7caRkZGS4QGTdunFtMTudQcKHAQsHHsmXLbO7cufbAAw/EISfmBmU/9dRTrpuVVvkOd2G8uCSOiyCAAAIIIIAAAgjEVSDtar/9K3G9YgAutnTpUjt79mzIbkcXLlxwYx0uX77sxkSoCNTlSeMl1N1JW/b3+l3n0zoQOTedQ8fmXLFagcrdd9/tWjJyHhOt39XtavXq1TZ8+HDXBSpa5+U8CCCAAAIIIIAAAkkhkEnLRALKSYOmtXmDq71AwAsk9F329/o9t0BCn3tjL/Q+3lvnzp2tb9++pvUo1qxZE+/Lcz0EEEAAAQQQQACBBAsQTCS4AJL98vXr17fHH3/clixZYjNmzDC1lLAhgAACCCCAAAIIBEOAYCIY5RzTXGrw98iRI00DwTWOQmNE2BBAAAEEEEAAAQRSX4BgIvXLOC45LF68uN1///1ujIbWo9i7d29crstFEEAAAQQQQAABBBInQDCROPuUvHKnTp2sX79+bmVuDc5mQwABBBBAAAEEEEhdAWZzikHZ7t69237729+6ReW802ssgVa41pSu99xzj/dxWD8PHjzoBmCXLVs2rP21k1bZ/tnPfma33HJL2MdEc0dd/91333UrZ/fp0+faYPNoXoNzIYAAAggggAACCCRUIJNgIsb+Wkfik08+sVdeecXmz59vDz74oD3//PMFuurmzZttxYoV9tBDDxXouETvrClwJ0+ebCdPnnSrfxckGEp02rk+AggggAACCCCAQL4CTA2bL1EhdsjKyrKhQ4fa4MGDbcyYMVauXDl7+umnC3zGBg0a2P79++306dMFPjaRB2gK3GHDhplmfHrttddsz549iUwO10YAAQQQQAABBBCIsgBjJqIMmv10ehJfsWJFt1q0PvcGKGffJ5z3WktCAcXGjRvD2d13+6hbV//+/U2reH/22We+Sx8JQgABBBBAAAEEEIhMgGAiMrewjtIUqU2aNHHd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abZr1y579NFHTQu9peKmp++NGzemq1M+hatF/rQehRb6e//995lSNx8vvkYAAQQQQAABBEIJpHwwceXKFZszZ44dOnTIHnnkEStevHgoi5T4vEmTJrZu3bqUyEssM6FxFF5gyTiKWEpzbgQQQAABBBBIZYGUDiYuX77snjwrkPj6179uxYoVS+WydHnTWhkaaMxibfkXtTeOon379vb666+7lor8j2IPBBBAAAEEEEAAAU8gZYOJS5cu2bvvvmuqMKqPvBYyC8KWlpbmujppDQ228ARatWplDz74oKkr3EcffRTeQeyFAAIIIIAAAgggYCkZTJw/f96tKVCmTBkbMmSIqYIdpE2zOhFMFKzEtdbIyJEjbceOHTZu3DjGURSMj70RQAABBBBAIKACKRdMnD171t566y23eNvAgQMDF0joPtZCbVq87uDBgwG9rSPLtoJPjaspV66cjRo1yg4fPhzZiTgKAQQQQAABBBAIiEBKBROnT5+2N954wzRuoHfv3gEpwtyz2bx5c1oncqfJ81N1i+vTp4917NjR3Uua8YkNAQQQQAABBBBAIHeBlAkmjh8/7gbRqhLdvXv33HMboE81qxML2EVe4C1btnTjKGbMmGGLFi2K/EQciQACCCCAAAIIpLBASgQTmrlIs/G0a9fOPVFO4fIKO2saA6CxIllZWWEfw47XC1SrVs2eeuopy8jIcIP5NRaHDQEEEEAAAQQQQOArgaQPJr744gsbM2aMde3a1Vq3bv1VznhnTZs2pXWikPdByZIl3TiK8uXL29/+9je3XkkhT8nhCCCAAAIIIIBAyggkdTCxb98+e/vtt61Xr16mbils1wswq9P1HpH+phYejcHp1KmTC1y3bNkS6ak4DgEEEEAAAQQQSCmBosmam88//9zee+89GzBggNWvXz9ZsxHTdFesWNFKlSplu3fvtpo1a8b0WkE4eYsWLezWW291993+/futc+fOQcg2eUQAAQQQQAABBEIKpF25uoX81qdfaC2AyZMnuzUkatWq5dNU+iNZS5YssRMnTrgZivyRouRPhWYNmzBhgltR/b777rMSJUokf6bIAQIIIIAAAgggUHCBzLgFExcuXDCtAXHu3Dm3IJh+v3jxomml6suXL7uXupN4L61YrVexYsWsePHi7qX+66oYax2JBx54wKpXr17wLAfsCM1y9dprr9mz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i002P/zhD+2vf/1ryNmpvLJXsKV7QVZKl1f+uhe8sTHaV5t+D3fTMd5g63CPyb6fBgY/8MADrjVKsx/9x3/8h2+etodTxvKTaSTjirI7hHqvsQb/+q//an/5y1+sVq1aoXZzZap0eGWpvwH9TaicvTJX+es+CPfvP+TF/vFFYcveO7/SpS5vzZo1sz/84Q+u5fGJJ57wvuYnAgggEAiB9H+/ugUip2SywALqJ67KwLBhw6xHjx7XKnEFPlE+B/z4xz92FbIJEya4sQqqMKib0MCBA11FWqtf670qtj/60Y/cuAxVyPPafvGLX7gnxepWkahNA88HDx7sZo5R/3s9vdZsUT/4wQ9cBVoBhsaYaKyJKltKq4KFBg0auCe5TZs2dZUUWbRu3dpZaGyKzhXJpgq80qQnxTp3qG4mGg/yq1/9yk0Pet999103Veann37quvWEe30NZB4+fLirBGrwtIIYBXpjx4615557zgVZoc6lQdjqPqKuZaNHj3bdSx5++GE3OLtTp0721FNPOSsNiH/rrbfcE2Kvj3uoc2b//P3333crpN9zzz3ZPy7w+4YNG7rBxHJT2YW7KTjU35YqpLLR7GGa9liVe90bkWzhlrHK5fXXXzf986+ASGnwNgUBut/C3TSOQPnQ36eXD+Vtzpw57h7K72/1nXfecfeCugoq/fobUJno70L3+qOPPupaADSbU7h//55DqDxEq+y988uvc+fOtnDhQvfvZLVq1byv+IkAAgikusCxr/4PkupZJX8FFtD/GB966KFrYwPCOYFaMvQ/alUM9IROlSONsxgxYoR7QqkKrCoHevKorkAad6BWD32uJ5J///vfXUuIKo3aT91INCZD037q3KpoqaVET7QnT57sBnRqxqX/9//+n1vxWtft27evq4wrKPn5z39uClamTJli+h+8BoCqv7NaDvT0Vmn88MMP3Wwt+kzv1YVBgyqVRk3TqQGXOlfv3r1t5syZrkLer1+/cDjcPs8++6z99re/NR2jQCJam8ZiaBpPteYoz+qXroBF/fk1F78+U2uI/Bs3buwqYn/605/c4Fd1XZs/f74rJ+2nsR56CixndeH53e9+5wIKVZAVgHibWklWrVrlftV1dUxem8pD19fAZVW6vbEkGmeQX4W5SZMmrjKpyq7S8/vf/96NqVAwpK5i6ruuMtOmMlUeNHWu0qx86p7Ssepupm5U6nKmwEazM6m1SGmQjyqe3r2o8v36179u6rbyne98x90PCoDyK2/9nWja3IKstq5WK3UfVLqUV+VFlWf9rXibWquUb7krXdpffzO6d/XSE3FVZGWsp+16Oh5OGctJ3Y40c5Za07Jvoco4VHl7+dD9pHyojNUVTNcIZypl/f3r3tCA++9+97v27W9/26VNgY6CRP39yyXn37/+PvXvg8qvffv2pkBXwbs8X3nlFXes8uf9m6CHFTpGW58+fa6VvewU8OjvXu9rXx0PpXMoMFKe9QBA5a905rc9+eSTLvDV4Hw2BBBAICgCiVmZKSi6SZ5PVe7DqQxkz6aeRqrCr/7w+h+3BteqIq7/IavSoUqdBiL/7//+r5s/fvHixe5wBQYvvPCCW+FaH2hg97/8y7+4yr5XYVUFT/9D1wBmVR5V6dEgZz3BfPvtt13FQudXq4Q2dZNQ+rUStjZVLr31CFR5UaVbFVO1wOgpuJ58avpXVQiU5g8++MB1W1AlUS0IL730kqtYq9Je0E0DN72uOAU9NtT+qriqYq9gSZUnPcFXXtUVSDNNLVq0yAV2emosB1WSVNHLuFqBVgVLFTHPS57drvb/VoVQT/plK3dVDrNvOre35kP2n3rSnf13771svfLTPaGn2Kr0hdt9SulSP3Qt5Kb7Sl1hdB+ooqlKpDbNAqWKpspXQYEqht69NmnSJBdA6j5RcKz7Tq1s2SuG2e9FBWiqXGswvda3UGAczlSwyk8oG88i509NPapNf2e6lspFwW72TcGd0qJgWQG0ulbpb0bBoPKsp/r6XJVopTPcMpajpmbVjGwaSJx9032aM615/a4y1qZ8aIzEzp07XZDidUfLfu5Q75VvBRP6O9amAG701dYoPVBQVzRtOf/+FfirNUdjuLwHAfp70FgGWSgf2e9x5WHo0KHub13BpDbd57pv9PezYsUKN1GCAhfdPwpq5s6d635qoHU4m/Ic7b/zcK7LPggggEAiBWiZSKS+z6+tJ6AaJ6Gng3pqF86m7hF//OMf7Z//+Z/d/1RV0VDfeFXS9QRVL1XU1Q1CT4b1UxUJPQ1XhUrH/vSnP3VPXfVkU5UDPS1URUUBiSoX+p+1Kviq6KoioKeH6hqhp7Z6mqhWBVVg9Xr66addVxkFBqp86vpepVT50bnU7UbXUsVCFXKlVRVPVdZVYfvlL3/pWkO8NSX0VFPp0bXD2fRkXBUZddUKd5s2bZprzVBLg7pPKBjJbVNwpDzJ7je/+Y2ryKlyrONU4dQsUnpSr/dKsyq8clGlR5VZz0vn1nnkof30hFvWqshmr3grKMnvKX32dKpiqbJSZVetBHpiq/JSi4rc5R1qUzpUWVSlUvehBmrrabw+e+ONN1zLhMYqKIBQ9xddQ4GkKpfKi16615QnrROgvOuaCnh1j+g+kEX2e1EVelVe9dLxP/nJT1wAomAmr00Bklp/CmKjir/GE+h+UsCnQE8Bbs5NwY1e2dOp49RyoifvCgpU+fXKLpwyloNaNb71rW/d8MBA91RB8qEueqqMq4VL+VDFXvej7mE9FMhvU7o1QFsteHqAoADJa3X52c9+5v72nnnmmRv+/pV+PawYMGCAK2f9VIChGcF0TgVM2e9x3Xf6m9U97P0boRYzuWt/pVvO6oKnfXW8gjkFirqPwtn0oCEa45rCuRb7IIAAAn4RYMyEX0rCh+nQ/3A1jaOe3qtiFU4XDlXC9VRclSt1PVDFRE8+FTjof+x6sqr/Uevpv55CqqKsp5n6n/z3v/99V/lVFx1VJlTxVFcWnUOVQVX8vD7xqljpf/x6Kq2gR/vpf/x6Mv/E1a5LesKsiqoCDgUJqrDpqbiuo4q0KpJ63+3q03g9pVfFVZUMXVvp1meq4KiSoSBEgYC6yKirhFo18uuio+JUhW3MmDGusqtKmyokCoj08iqsClzkopeewntPgBUE6ImzKkd6uq4uPKrY66m6npxq074KFFQJUkVWXbmUT7UIKS9Ku5726umqumip5UVPZJVvPblVJdDz0vXlpWP0vVpqFMjJTy0V3qZyVVmGu+kJs1o/9NKYEK9irIqa8qXgU+9z2xRkqswVRKhSqvtI5aMuNCoDzZ6lclTAovtU95VM1C1LwZN3r6llQ0/zVcnTOAtVQGWmMlB+s9+LqliqjHVunUcOqiTn1Qde+6h7lPKo/IW7KUBX9ygFQWpdU15yjplQftWio/tNZe/9zehYBerKsyraClh1LyvN4ZSx7gX5617POc6joGMmcsuHPtO9rdYxrytWKBcFQtr096XyUH51P6qM9W+A7ht1Zcz596/95aW/e92nyrv+rdDfgv79kKncvHtc3dt0bnWb0r8JupbuLd1XuobuewVictTfrs6lhwn6W9LflO5VeYfaFDzp3wpv/Eio/fgcAQQQSDGBY2lX/4HOu9NziuWY7BRcQBVWVUhVOVAlSxU7/Q88t01dlfQ/YFVW9YRQlYpYbc8//7yrEGggb26bAgQFFuqHrYAjXpsqeQoGVElRgKBWBT3dVGVFlRHvpUq0PvN+ah+9V+CmCqpadLSpoqRKjyo8evrqBVTxyk/266iVQa090djUpUpT5ipQU6tPsm2qYCpIUT7U1UyVz8Ju6paj1qJ43q8506xWI7UERWPTwwUFpWotUguX7vdYbPr3SdMMa7xIqAq/Aje1QCrgjuamBxfqpqngRH8bscpjNNPMuRBAAIEoCmQSTERRM9VPpSeeqiSroqvKn55o6mmvup0EfdMTTz0hV6uMKhV68q2nqpFWMPVUXgNx1aKhLmAKJPTkU0/IUyWY0D2jLjrqaqLWD7UuKAj1+6byVaCosTt6+q0++nrSH40t1YIJmejfDVX2FVirVUtBRbS8omEeyTn0oEKBsFo91NKoWcfUAsOGAAIIBFAgkzETASz1SLOsCp+ejKvbh7oBafCmKlTqNqTuBKoIqrKr1ohUfjqnLjRqrVG/cHXRUiChp8ka5Kun7OF0B8uvDDR1q8aKpPqmVhsFpHp6rXEtap1Ry5e6qqibnV82NeCqvNUlR8F07avjHTQGxOty5pd0+jEd+ndDM1Hpb0ZdqP72t7+5LmjqxqSyj2XrZTQ91OVMXSVV/hlXx9bo3zy1ICkfbAgggECQBQgmglz6EeZd3XA0nkAvberW41Wq1XKh/srq164+zHrpvV6qcCvwSJZN3bXUV1v5Ux9udfPSU1b1p1Yl0mslUACR10DiZMlvotKpwFP90fXyBuSPvjroWl3pNK5DLwVo6rser01PnlXuqjzq3lbffN3L6nKm1qJIW5zilX4/XkezbOlBhMbvqBVPrVLqmqTgXGWsoEMVdAUXobpRxitfGjuhv3d1YdJLDwz074GCSAXA6iqV6DTGy4LrIIAAAvkJEEzkJ8T3+Qp4wYLX/UbdQFQR05NIVcLV9UcBhl4aE6BBuaqMqXKo7g56qTKul/4HrUGs3iDpfC9egB1UQVTFRQOhFRBoDn/91MsbGK0Kg15Kq9KhtOqliqS6Lqmio9/ZYiOgbkN6qdKpwE1PgDXwXOtKqHVAFU4NrFY56P5RWeie0b0Tqq98qJRqzIPKXgGj91JXHFUi9VPXUeVWT56pPIZSLPjnCh7ViqeXNv29qdVHlXYN2Ja9NpWxWqdUxnoQoX8n9NP7t6IwrZ8agO393Xt/8yp3TfSgn/pM/67pflMgqxYIpYcNAQQQQOBGAcZM3GjCJzEU0P/ANYtO9sq7ug94FXv9T17vVeFXxV8z3HiDktUi4r2URFUeVaHQSwGMKpvefAJ6sqjKol4KInRefafzeTMKeZUSVUa9oEY/VYFRpUXX8tOmKVA1W4zSnahN3Xy0AF8iNlXwFKSqsqlgTwGAdy+pfOWie8G7R/RTQal3H2T/qftD94UX1Kq8VWn1AhVVHHXfxXvT1LAaj5HIp96JLGPPW/8mqFLvlbPKWv9m6HO99O+IusR5L5Wz92+B91Pl7f2boH9P9FLAon8DVN4qezkrKNVLY7/00oMDxoF5JcFPBBBAIF8BBmDnS8QOCCCAAAIpIaAua1qIULNV0VUtJYqUTCCAQOIFMmMzT1/iM0YKEEAAAQQQuE5As9Ddddddbk2W677gFwQQQACBiAUIJiKm40AEEEAAgWQT6NSpk1ucTgswsiGAAAIIFF6AYKLwhpwBAQQQQCCJBO677z432FuD/NkQQAABBAonQDBROD+ORgABBBBIMgENwNYMXRMmTHAD9JMs+SQXAQQQ8JUAwYSvioPEIIAAAgjEQ0ALQ2oMxcyZM+NxOa6BAAIIpKwAwUTKFi0ZQwABBBDIS0DrmWihxK1bt+a1G98hgAACCOQhQDCRBw5fIYAAAgikroDWItH4iQ8++MCtY5G6OSVnCCCAQOwECCZiZ8uZEUAAAQR8LlCtWjVr166dTZo0yecpJXkIIICAPwUIJvxZLqQKAQQQQCBOAh06dLC0tDRbsmRJnK7IZRBAAIHUESCYSJ2yJCcIIIAAAhEKDB482LT2xL59+yI8A4chgAACwRQgmAhmuZNrBBBAAIFsAmXKlDENyNZ0sefPn8/2DW8RQAABBPISIJjIS4fvEEAAAQQCI9CwYUOrU6eOTZ8+PTB5JqMIIIBAYQUIJgoryPEIIIAAAikj0KtXL9fVaf369SmTJzKCAAIIxFKAYCKWupwbAQQQQCCpBDRd7NChQ2327Nl2/PjxpEo7iUUAAQQSIUAwkQh1rokAAggg4FuBW2+91Tp27OjGT1y5csW36SRhCCCAgB8ECCb8UAqkAQEEEEDAVwJt27a1kiVL2qJFi3yVLhKDAAII+E2AYMJvJUJ6EEAAAQR8ITBw4ED77LPPbPfu3b5ID4lAAAEE/ChAMOHHUiFNCCCAAAIJFyhdurQNGjTIJk+ezHSxCS8NEoAAAn4VIJjwa8mQLgQQQACBhAtoqthGjRrZ1KlTE54WEoAAAgj4UYBgwo+lQpoQQAABBHwj0L17dzt8+LCtXr3aN2kiIQgggIBfBAgm/FISpAMBBBBAwJcC6enpNmTIEJs7d64LKnyZSBKFAAIIJEiAYCJB8FwWAQQQQCB5BCpWrGhqoZg4caIxXWzylBspRQCB2AsQTMTemCsggAACCKSAwB133GHlypWzefPmpUBuyAICCCAQHQGCieg4chYEEEAAgQAIDBgwwNavX28ZGRkByC1ZRAABBPIXIJjI34g9EEAAAQQQcAJayM6bLvbMmTOoIIAAAoEXIJgI/C0AAAIIIIBAQQRq1aplLVu2tClTphTkMPZFAAEEUlKAYCIli5VMIYAAAgjEUqBr1652+vRpW7lyZSwvw7kRQAAB3wsQTPi+iEggAggggIDfBNLS0mzw4MG2YMECO3jwoN+SR3oQQACBuAkQTMSNmgshgAACCKSSQPny5a1nz542YcIEu3TpUipljbwggAACYQsQTIRNxY4IIIAAAghcL9CiRQu79dZbbc6cOdd/wW8IIIBAQAQIJgJS0GQTAQQQQCA2Av369bMtW7bYtm3bYnMBzooAAgj4WIBgwseFQ9IQQAABBPwvUKJECRsyZIhNmzbNTp065f8Ek0IEEEAgigIEE1HE5FQIIIAAAsEUqFGjhmmF7MmTJwcTgFwjgEBgBQgmAlv0ZBwBBBBAIJoCnTp1sgsXLtiyZcuieVrOhQACCPhagGDC18VD4hBAAAEEkkXAmy526dKllpWVlSzJJp0IIIBAoQQIJgrFx8EIIIAAAgh8JVCuXDnr06ePTZw40bVSfPUN7xBAAIHUFCCYSM1yJVcIIIAAAgkSaNKkid122202a9asBKWAyyKAAALxEyCYiJ81V0IAAQQQCIiAWid27dplmzZtCkiOySYCCARVgGAiqCVPvhFAAAEEYiZQrFgxN13s9OnT7cSJEzG7DidGAAEEEi1AMJHoEuD6CCCAAAIpKVC1alVr166dGz+RkhkkUwgggMBVAYIJbgMEEEAAAQRiJNChQwdLT0+3JUuWxOgKnBYBBBBIrADBRGL9uToCCCCAQIoLDBo0yJYvX2579+5N8ZySPQQQCKIAwUQQS508I4AAAgjETaBs2bLWv39/mzBhgp0/fz5u1+VCCCCAQDwECCbiocw1EEAAAQQCLdCgQQOrV6+eTZs2LdAOZB4BBFJPgGAi9cqUHCGAAAII+FCgZ8+etn//flu3bp0PU0eSEEAAgcgECCYic+MoBBBAAAEECiRQtGhRGzp0qM2ePduOHTtWoGPZGQEEEPCrAMGEX0uGdCGAAAIIpJxApUqVrFOnTm78xJUrV1Iuf2QIAQSCJ0AwEbwyJ8cIIIAAAgkUaNOmjZUqVcoWLlyYwFRwaQQQQCA6AgQT0XHkLAgggAACCIQtMHDgQFu9erXt3r077GPYEQEEEPCjAMGEH0uFNCGAAAIIpLRA6dKlTetPTJo0yc6dO5fSeSVzCCCQ2gIEE6ldvuQOAQQQQMCnArVr17bGjRvb1KlTfZpCkoUAAgjkL0Awkb8ReyCAAAIIIBATgR49etiRI0ds1apVMTk/J0UAgf/f3nlASVXdf/xSFJQidVdYWJYOIkVA7ICgEhW7Ro1Ro7HFxGg0puo/aDwnxXLsUZNoFIyKJSpiAREQUBFRemeBBelFkCIo8Ofz07sZJjuzMzvtzcz3nvN4b165777PHXbu991fEYFUE5CYSDVh1S8CIiACIiACEQhUr17dnXPOOW7s2LFu48aNEc7SbhEQAREILgGJieD2jVomAiIgAiKQBwQaN27sTjzxRAsXu2fPnjx4Yj2iCIhALhGQmMil3tSziIAIiIAIZCWBHj16uIYNG7px48ZlZfvVaBEQgfwlIDGRv32vJxcBERABEQgQgdNOO83Nnj3bLVmyJECtUlNEQAREIDoBiYnofHRUBERABERABNJCoHbt2u6ss85yI0aMcNu3b0/LPXUTERABEUiUgMREogR1vQiIgAiIgAgkiUBxcbHr1q2bwsUmiaeqEQERSD0BiYnUM9YdREAEREAERCBmAv3793c7duxwU6dOjfkanSgCIiACmSIgMZEp8rqvCIiACIiACEQggLnThAkT3Lp16yKcod0iIAIiEAwCEhPB6Ae1QgREQAREQATKCTRo0MANHDjQwsXu3r27fL82REAERCBoBCQmgtYjao8IiIAIiIAI7CPQtWtXV1hY6N59913xEAEREIHAEpCYCGzXqGEiIAIiIAL5ToBwsaWlpW7x4sX5jkLPLwIiEFACEhMB7Rg1SwREQAREQAQOOOAAd+aZZ1p0p61btwqICIiACASOgMRE4LpEDRIBERABERCB/xIoKipyvXr1cq+//vp/d2pLBERABAJCQGIiIB2hZoiACIiACIhAJALHH3+8++abb9ywYcPcoEGD3PLlyyOdqv0iIAIikFYCEhNpxa2biYAIiIAIiEDVCHz11VfuzjvvdKNGjXIjR46sWiW6SgREQASSTEBiIslAVZ0IiIAIiIAIpILAfffd5xYuXGhVv/POO27v3r2puI3qFAEREIG4CEhMxIVLJ4uACIiACIhAZgiMHTvWXXfdde6QQw4xUbFixYrMNER3FQEREIEQAhITITC0KQIiIAIiIAJBJdCsWTP34IMPukcffdRVq1bNffbZZ0FtqtolAiKQRwSq7Zsm1TxpHnW4HlUEREAERCDYBB5++GFH1us6depEbOjq1avdzp07XatWrSKeU9UD27dvN7Fyww03VLWKtF0Hpy+//NIRNpd2b9u2ze3YscMWfEzYhtOuXbscn7/++mvbxpmdUrNmTVejRg1bs41IC104xj0YKvmF66iH/SzUtWfPHqvjwAMPdITzZX3QQQfZunbt2q5WrVru4IMPtn2s6VuWunXr2jHqVBGBLCVQVjNLG65mi4AIiIAIiEBOEqhevbr74Q9/6Bo0aJCR59u8ebNFjcrIzcNuyiB906ZNbsOGDe6LL76wbdq3ZcsWExGIBMy+GLj7AbofpDdp0sT2M5DnOIN8P9BnsJ/s4oVK6NoLGwQNYmb9+vUmeBA+HONZKPXq1XP169e3Z6HfWRo2bOgaN25sgiTZbVV9IpBMAhITyaSpukRABERABERABKpEgNkFZlxWrVrl1q1b59auXWuD7UaNGtngmgE2g+t27drZG30G34iEoBQvVuJtD4KI2RUWL5jmz59v24gPZjYKCgpc06ZN3aGHHmoLTFREICgEJCaC0hNqhwiIgAiIgAjkEQHeyi9evNhyZpSVlZkZUWFhoQ2Wu3Tp4vr27esYNDNTk8uFWRJEEktFBU7MzCC05s2b58aNG2ezHC1atHDFxcWupKTEmFV0rfaJQDoISEykg7LuIQIiIAIiIAIi4DZu3OhmzZplg2LMfNq3b+9at25twgGzHpX/JYAZF0ubNm3KD8IOAUZEr9dee838QpixQYSlwo+m/MbaEIEKCEhMVABFu0RABERABERABJJHgBmIjz76yHweDj/8cHfGGWc4olOpVI0A5l0dO3a0ZeDAgWYStWjRIjdmzBgTFsccc4zr1q1bzs/qVI2erko2AYmJZBNVfSIgAiIgAiKQYQLY4Q8bNsxdeeWVUVuCI/P777/vBg8eHPW8qh7EgfqFF14wf4D+/fu7Dh06xFTVk08+aY7KRFPiGZYsWWJZv2+55Ra3bNky99JLL7mf/OQn5nSN2c/RRx9tvgUxVR7hJPJ44Bh9+umnRzhj/93MDhCml4hMDO4vu+wyx4B+6dKlNrjv3LmzzRTsf1VqPuFP0rt3b1tWrlzpJk2a5D7++GN39tlnm79Fau6qWkXgWwK5bYioXhYBERABERCBHCCAYy5284QiRQBQcNj10YAIW7pmzRobDA8ZMsTO8wKBSEKETKVwPrb3DPIpjz/+uA087UMC/zCA5W34r371K5uBwJmaezz33HPW3muuuSZmIUEzeE4iHOFDceeddzoG5oiju+66y3wEcHYmahOF3Bsc8wVWDPSJAsVCW3Bkhgv7w3ng7E14V3wW5syZY74bn3/+uVVHOxAyHPf1wJp6ERBkJD/22GPNbOvll182U6QePXrYucuXL9+vf7iGgmDBRIkS2hbqp38Qgv5czgnd5nNlpXnz5u6CCy5wffr0cXfccYfVV9k1Oi4CiRCose8/15BEKtC1IiACIiACIiACySMwZcoU17Vr1/I37aNHj3a/+MUvbPDKG/lHHnnEHXXUUTaIHjVqlA3iH3jgARvQ0goG8D179nS33Xab69Wrl3viiSccdRCa9KqrrrLBPYKCATP3YQB90kknlT8AA9x3333XBtUMpJkJKC0ttUE1b93ZF75/2rRp7vXXX3dvvfWWe+WVV+x+//nPfxxOwswgxFumT59ujsYk5jvvvPNc27ZtLUQqZjz4DyBUGLRPnTrVnpXnv+KKKxw8iAb12GOP2UB95MiRJiQY+D/11FN2zTPPPGPtw7Gbawgde/fddztmTphZeO+99+xezFQMHz7cTIUI93rxxRfbwPz+++93PC+O0zhEE3lp9uzZNjPxwQcfWBsQQlz/t7/9zR133HEmgohORXuZdaEv8BHxfYM4uvbaa63Pb731VjtOXdRL3zF71K9fv7gwEvkJgULfIcZURCBFBDbXTFHFqlYEREAEREAERCAJBBgI8pYZR2UG8QxmGRwzqGagP3HiRHtLT5I5hAD5Fbp3725J1BjQ4pSLo/O///1ve3N+ySWX2DYDYQackydPNkdeBv6+YF5EcjUKSdx4Gx++bTu++4f2cB7FJ2cjlGkiWbqPPPJIM5Gi7RQG/0OHDnWnnHKKO/fcc23f22+/bc+EmQ8CCAFzzz33uBNOOMEG+2eddZZFPMJ/AC60J5QHIuW6666zwbpVuO8fzkUgMPj/3ve+Z0IAdjg4cy7MzznnHItExTX0zYcffuiKioqM/9y5c60qZgcQbW+++aaZQl199dXu/PPPd4MGDTKTLU4KbUvLli3d5Zdf7saPH++Yyfn1r3/tmPH585//XM7fKo7jH5ilIqdGHE3QqXlAQGZOedDJekQREAEREIHsJcDbcga3vInHifn55583MxkGzxTMYpgVwByIwSsRkziG8MA595133jFTJmYfGAjzthsTHAbIzF7wxjtUSFAnJj/4IbAwC1LRtt/HmsE7YoeBL7MTI0aMsDfw2PEzm4K5UDyFQf+CBQvszf0PfvADex4G5Zg2Pf300zZo5y0/5kvMGOBXgUkPQoPPzz77rIkbxISPEgUXhInnwYwH5l/whAH3w1GczzCdOXOm8Ua40B54MiPBmvM4H0GGudlNN93kEGnMqNBfhLRF5DH7g4jABI0ZmwsvvNBMo3BCxzzKt+XMM8+0PiXSFX09Y8YM+0yfIx7ps3gL3wFmNQYMGBDvpTpfBOIiUG3f24ZvXzfEdZlOFgEREAEREAERSJQA9vCY0JCAjeRkFJx6GUDztj28YN7DzzYzB2wzG+BnBPjMm2gG7hz3hf3sw5QmloLdPj4IP/3pT2M5Peo5+Bq88cYbNqjG3AezqtC2Rb04ysHwZww91R9jUM69b7zxRpul8ftDeVx00UUOs6fQt/eeox8ecV3NmvEbcvDsoddh2kQfUx/F9yGfo/UN349ox0OfnW3MmhAytP/73/++zWKFn6PPIpBEAmXx/+9I4t1VlQiIgAiIgAjkM4Hrr7/efBZ8LgHMjnjbjpioqCAWfAndZp//HD5YZ78/5q9N15rBNBGFMNdhVoXIS506dTJnbPIhhLc11nZFu84fw3cCMyU/oPf7PQ/8CRA4nBeam8Gz8iLNXx9r2/x54dd5sejbwXm+Lf6aitaxCAmeAWdwZjYwM2O2CM4qIpAOAhIT6aCse4iACIiACIhACAFmJEg4hh0/Ji0UHIExScEEJtcKEYYwF8KsCJMdQpdi9oNpFCZW+AuQd8IP4JPx/P33OVRHK4R0xc8kGwvfH0zW+A5hVoWAIOwufhr4qqiIQDoJSEykk7buJQIiIAIikHcECEeK7Txvj1nzlp631Aywcd5FRODci1nRpZdeamY3uQoJnweemQWzn6X7okMRJpU36gyQ8dVAVLDgd4DYwrk7XwumUsxU4e+BPwwL3yOYIMCKi4stezhmcioikCkCEhOZIq/7ioAIiIAI5BwBBsh+0IdoYMHmncEx4gGHZNY+UhI5IyZMmGD5GRAU+VQQVJjieHMcfAf8YBnRhbMzA2nMfDADw5HaL8wqMIAmBGssZkBB5Yp/Bg7cLJhdIRrIk+EX9iGwEFXMOGC+xHcpnwVWUPsyn9slMZHPva9nFwEREAERqDIBhANRehAMfhBMQjL8HhjwMUg+8cQTy6MJVXQjBsTkGlD51iGZ8KosoQXTKGYtWBhkM5uBkzgDcMQYvgmIMxZmPhAaCBUWZn0YeLNwHsIDZ2v247vA4n0kQu8Z6zZOzoggRAHfB6JAIR5Zs/gkeRxjQRzwHeGZOMbihRHfBUQT3x3CATMzw2cVEQg6AUVzCnoPqX0iIAIiIAIZJ8DA1c84ICDYJqcDwoEszQwAWRgAJlrISs3AM5FBbiJtYIDLG/+qJJtL5L5VvZZBO4N0BugM1Gk/2zCkj/jMOWz7gT7mQ+zzQgBRgchAHOC3AXu/Riiw3y+0k3qog3O4FpHihQr3IUQsGcH5biBcEDaIHUQNgodtRIRmGKra67ouQATKJCYC1BtqigiIgAiIQGYJMHAkWRmCwa/ZZqBZUFBQLh4QERWFbs1s63X3oBDAB4Q8D2QiP/744zMmDIPCQ+3IaQISEzndvXo4ERABERCBiASwT1+3bp2JBtYszEBgl49wYOHNMoveIEfEqAMRCDA7MmrUKPt+kZSOmSsVEchBAhITOdipeiQREAEREIHvCGCagmjYsGGDiQXWfhszE5xaEQ2sWXB0TWZ4UnWECJAlm0zXJOzr27dved4LkRGBHCEgMZEjHanHEAEREIG8JoCdOiLBCwecdTFTYo1jKyLBL4gHIuSEJxXLa4B6+JQSwG9j9OjRFhp48ODBFtY1pTdU5SKQPgISE+ljrTuJgAiIgAgkQgCHWcRCaGQfLyBwiEUg4ADtQ2n6bRxkVUQgCARIMPfmm29atCaS6mVzWNsg8FQbAkFAYiIQ3aBGiIAIiIAIWHhNQn36GPs+/CeCAQGBYEAg+FwDfps1JksqIpANBJhFGzNmjFuyZIk7/fTTXUlJSTY0W20UgUgEJCYikdF+ERABERCB5BIgbCdiwecHYJvFJ+vCYZWQpERJYiHGvt9GQBBSU0UEcoUAYmLkyJGubdu2buDAgRYxLFeeTc+RVwQkJvKqu/WwIiACIpBkAswWYA/OgkhAGPgFccA2x5hlIN6+z1ocukYw+M9yfk5yB6m6QBPg/8/YsWPd/Pnz3amnnuryLQt6oDtHjYuVgMRErKR0ngiIgAjkGgFyKjCYYSEBF4tP9IUpBov/jL+CTwjG2m8z+PeJuHz2Yb/G9IhtZhvYlu9Crn2D9DzJIlBWVubeeOMNV1xc7E466SRLcpesulWPCKSYgMREigGr+hgIMJDhDSaLf8PJ2g9iOM5Axg94fMZSBkKcw5psoj47qX+zyedYt/25rH3h2tD9/rM/7td+v1+zP3S7os/h1ybrc0X3Cm9LRedE2hdpf0V1Rjo32n6ORSrx3oN6Il1T2bFsOB5LG/05/J/wC9/h8G3//4ksvz5zL5GN2Gb2IHQhc6/P4Ms2woH/bz6bryIiQV1FBBIngJgfP368mz17ths0aJDr2LFj4pWqBhFIPQGJidQz1h0wbwh1qOSzt5PGLIKBDiYODFJCFwYrfqBD9lkWPjNgZBDEwptOBktss/aDf86hXtYUfw7b7A8/3x/3x/y1vr7QNXVwPedQ/AA2dF/odug5bIce89eynxJ6jM/xHq/omvA6KjqHfeH3Zh+lov0V1cm58e6vqG7qocRbF9dUpT6uo0S637dHKz8e7d7UkejxWOrw5/jvM/fkuVj7bQb/XjhwvooIiECwCHz++eduxIgRlm39lFNOMeEerBaqNSKwHwGJif1w6EOVCTBrQPbY9evX20L4Rh/C0dtCe4dK71TpTSF466kiAiIgAiIgAiLwLQFm4CdOnOg+++wzd/LJJ7suXboIjQgElYDERFB7JsjtYpZh9erVbs2aNbYgIjBR8plkCdMYushOOsi9qbaJgAiIgAgElQC/tcxS8DIOB22FQA5qT+V1uyQm8rr7Y3h4RAJTritWrDABsWrVKrOfPvTQQ20KtrCw0EQEf+hUREAEREAEREAEkksAk9pJkya5Tz75xA0YMMB17949uTdQbSKQGAGJicT45dbV2Fkz2+DFA2scnIuKilyLFi1sQTzghKkiAiIgAiIgAiKQPgJYATBLgW/h4MGDLUpa+u6uO4lARAISExHR5MEBbDKZcVi2bJkjLB2zDswwIBwQECyNGzfOAxJ6RBEQAREQAREIPgFe+n300Udu8uTJrm/fvq5nz57Bb7RamOsEJCZyvYdDn48/QgiGpUuX2sLMQ0FBgWvdurVr2bKliQciJqmIgAiIgAiIgAgElwABTpilwCeRWQqZGge3r/KgZRITud7JGzZscKWlpSYemH0gklJJSYktJMeReMj1b4CeTwREQAREIFcJTJkyxaI+HXfcca5Pnz65+ph6rmATkJgIdv/E3zpMl5h5WLRokS3ElvfigTW2lioiIAIiIAIiIAK5QYAIi2TPJundGWecIfPk3OjWbHoKiYls6q1IbSXxmxcP+D8Qaaldu3a2NGnSJNJl2i8CIiACIiACIpAjBMhJMW7cOHf00UfbQsJKFRFIAwGJiTRATsktiLo0f/58t2DBAoeYaNu2rWvfvr1r06aNhW5NyU1VqQiIgAiIgAiIQGAJMB5466233NatW22WgvxPKiKQYgISEykGnNTqV65c6ebNm+fmzp3rMF/q3LmzCQiiLqmIgAiIgAiIgAiIAARmzJjhxowZ43r37u3wp2DMoCICKSIgMZEisEmrdvny5SYemIWoVauW69Spky1EYVIRAREQAREQAREQgYoIMDvBLAU+FfhSYAKtIgIpICAxkQKoCVdJyNZZs2bZLETdunVNPDAL0ahRo4TrVgUiIAIiIAIiIAL5Q2DOnDlu1KhRljm7f//+Tr4U+dP3aXpSiYk0ga70NoRwRUCwHHDAAe7www93Xbt2VYbLSsnpBBEQAREQAREQgWgEtm/f7t555x23du1ay0sh8+hotHQsTgISE3ECS+rpOErNnj3bFv6jd+nSxZbCwsKk3keViYAIiIAIiIAIiMDChQvN9AlrhwEDBljSO1ERgQQJSEwkCDDuy7/++mvzgZg5c6a9IcAHAhFBAjkVERABERABERABEUglga+++sqNHj3aYVJ92mmnafyRStj5UbfERLr6GUfqadOmWSjXVq1auR49elgYV0VYSFcP6D4iIAIiIAIiIAKeQGlpqRs5cqTlpDr55JNdzZo1/SGtRSAeAhIT8dCK91wiKUyfPt0WIjF169bNfCGUhTpekjpfBERABERABEQg2QR27dplIWSXLFniTj31VNe6detk30L15T4BiYlk9/HevXsdNonMQqxYscIddthhNguhkGzJJq36REAEREAEREAEkkFg2bJlbsSIEa6kpMSdcsop7sADD0xGtaojPwhITCSrn7ds2eJIZc9MRMOGDV3Pnj0tpGuNGjWSdQvVIwIiIAIiIAIiIAIpIYBP59ixY80ce9CgQZYUNyU3UqW5RkBiItEeXbRokfv0008d2akJ53rEEUe4xo0bJ1qtrhcBERABERABERCBtBNgPPPaa6+5Zs2amenTsGHDXMuWLW3GIu2N0Q2zgYDERFV6iTCuzEBMnTrVkVSuV69eFpFJztRVoalrREAEREAEREAEgkRg9+7dbvz48W7y5Mlu6NChDr/PF1980Zy1g9ROtSUQBCQm4umGVatWuU8++cR8IojRjCmTckLEQ1DnioAIiIAIiIAIZAMBQshefPHF7tVXX7XmnnPOOe6pp55yhxxySDY0X21MH4EyxQGrBPaePXssL8SUKVPcjh07TEAQQq127dqVXKnDIiACIiACIiACIpCdBDZt2uSYoejevbtbvHixOWj/5S9/cbxLEs0AABjwSURBVHfddZeTJUZ29mmqWl1tX/ShvamqPJvrRTjgUM1MRJMmTdyRRx4pZ6Rs7lC1XQREQAREQAREIG4Cq1evdvfee69ZZZAz6/TTT3fpjlD5xRdfuPPOO8917Ngx7vZX5YL169e7devWOdYbN250mLcTRpeFl8xEu2LB/KtBgwY2TsRfFj+TdOXreOCBB9wBBxxQlcdLyjVr1651119/vSsoKNDMRDhRvjTYCM6ZM8f8IJjia9q0afhp+iwCIiACIiACIiACOU8A4dCiRQv3+9//PmPPSh6MBQsWpExMMAND/czAsJAPDHHAy+T27dvbZy8gGMBjArZz5073zTffmOggm/jMmTMdwgtWbdq0sdQA9erVSxkzzM3OPvvslNVfWcW8cJ8/fz5iwsnM6TtaxFj+6KOP3Jo1a8yUCbWl5HKVfZV0XAREQAREQAREINcJYNbEG/hMlVS97UcUMPZjYFxUVGQO5ieccEJcfiFt27Ytx0J43aVLlzrEzz//+U/XvHlzd9xxx1nd5SclaYPUA0Hpk7wWE1h4zZs3z3344YeOL8DRRx/tLrjgAtkCJumLrmpEQAREQAREQAREIIgECOv//vvvmxXKVVdd5ZIxi8CsBTMZLCeddJKbMWOGObAjKkgGWKdOnSCiSLhNeSkmsHdDhaJGUXV9+/ZVuLOEv0qqQAREQAREQAREQASCTYAXyaNHj7Zx4LXXXpuyt/vM5vTo0cN169bNTZw40SJhXXbZZa5+/frBBlSF1uWVmMC+DYdqFmzaCHOGWlQRAREQAREQAREQARHIbQIIieHDh5t/A1Gp0lEQFby0xlTrZz/7mcNxumHDhum4ddrukRdiYtu2be7jjz82FdqhQweHMsy1jkzbN0Y3EgEREAEREAEREIE4CWBOzktdkv1GK0RMIqJmKvJZEGAHQZFsIUEY3crGlccee6wJipdfftldeeWVgTCp//LLL80/OBaflC1btkScVakerUOz/djWrVvdqFGj3OOPP26xkq+++mo3ePDgSjs8259b7RcBERABERABERCBoBAgUtKKFSscfgrRyptvvuluvvlmy2kR7bxYjt1xxx3upZdeckRaomDijnn7qaeeGsvlEc/hWUIL4uett94K3RVxu0+fPu7ggw+2MLsRT6rgwG233Wa+FyRPTkZB1JWVlbmpU6eW84lULy/jn3/+eRtHRzonJ2cmUE+TJk0y52rs1a677jrrvEgQtF8EREAEREAEREAERCA2Aq+99pqbPn26+QQQVtXngXj99dfNkZlcFO+++66FWyVM6nPPPed+/OMf28zEwoULbRCLM3KrVq0c12BBMmTIEDdmzBiLhHTTTTfF1pAoZ40fP9798Y9/tBCtPXv2NIdo3sBHmvFgoP7oo4/aoBkz+A8++MAx44D4QAjxjCQt5sX0k08+ac7V7BswYIDNpIwcOdLGnQzUf/e730VsGbkyiPgUT84MnuWvf/2rPQt5zwgWxOxNaMF8ivbi6F1aWmqhbYk0hRM44Vu7du1qz0TU0pUrV5q46tSpk4W/jdYnhATmfoTBjVRySkxs3rzZnFxQjb169bJkGiQUUREBERABERABERABEUgOAQaWDFR5ecugltwMDKyrVatmIVFZM4Dt16+fmRV16dLFcnYx8/Dss8+6Z555xv3oRz9yv/nNbywkP2/sJ0yYYMnxyPN155132jmh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n7K0tNT17NnT9enTxx100EH+sNYiIAIiIAIiIAIikHECjFM+/vhjR66IXr162VK7du2Mt0sNEIHvCOSvmPBfgc2bN5uowLeiQ4cOpvTTlb3bt0FrERABERABERABEfAECJc/a9YsExH4fPLCk9kIHKxVRCBgBCQmfIfs3LnTffLJJ7Y0a9bMHXnkkYoA5eFoLQIiIAIiIAIikHIC5OCaOnWqmzZtmmvZsqWNRVq1apXy++oGIpAAAYmJcHjkrCDE2uTJkx3bvA3o2rWrkr2Eg9JnERABERABERCBpBBYvny5zULg14kvZ+/eveUPkRSyqiQNBCQmokHmPzV2iitXrnTdunWz/9z16tWLdomOiYAIiIAIiIAIiEClBHbt2uXIicVMBOZLCAheXtasWbPSa3WCCASIgMRELJ3BtCOiYsaMGWb6hANUcXFxLJfqHBEQAREQAREQAREoJ7Bu3Tr32WefmU8ECXU1pihHo43sJCAxEU+/kaMChyjiO1P8WwSFlo2Hos4VAREQAREQgfwigEM1gV4QEbygJIok5kx169bNLxB62lwkIDFR1V4tKyuzzJOLFy92hx12mL1ZKCgoqGp1uk4EREAEREAERCDHCDALQXI5zJmKiopMRLRt21ZRmXKsn/P8cSQmEv0CkImSqAuktCd5DG8aEBearUiUrK4XAREQAREQgewjgBUDgVyYhdi6das74ogjzO+yfv362fcwarEIVE5AYqJyRrGfwSwFfzyYtejUqZPr0aOHa968eewV6EwREAEREAEREIGsJEDQFmYgFi5c6AjnyhigTZs2WfksarQIxEFAYiIOWDGfymwFztrMWBCVgT8oJJtRhu2YEepEERABERABEQg8gY0bN5qA4De/Tp06Fo1Jv/eB7zY1MLkEJCaSy/N/a2OWAnvJBQsWOOwk+SMje8n/5aQ9IiACIiACIpANBL766itzpkZA4EzN7zohXZs2bZoNzVcbRSDZBCQmkk00Un1k2J47d67NWPAmo0uXLvbH59BDD410ifaLgAiIgAiIgAgEgABJbJcsWWIWB0uXLnXt2rWz33BCu5IjQkUE8piAxEQmOv+LL76waVFsK3HU5q0GSfGYIlURAREQAREQARHIPIG9e/eagCCkK9YFhYWF9nvduXNnd+CBB2a+gWqBCASDgMREpvthxYoVJizmz59vU6REgsJ5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"
FAGES Francois's avatar
FAGES Francois committed
193
194
195
196
197
198
199
200
201
202
203
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "draw_reactions."
   ]
  },
  {
   "cell_type": "code",
FAGES Francois's avatar
M2    
FAGES Francois committed
204
   "execution_count": 13,
FAGES Francois's avatar
FAGES Francois committed
205
206
207
208
209
210
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "gene+geneRNApolymerase\r\n",
211
212
       "RNAcytoplasmRibosome+ribosome\r\n",
       "RNApolymerase+geneRNApolymerase\r\n",
FAGES Francois's avatar
FAGES Francois committed
213
       "3 complex invariant(s)\r\n"
FAGES Francois's avatar
FAGES Francois committed
214
215
      ]
     },
FAGES Francois's avatar
M2    
FAGES Francois committed
216
     "execution_count": 13,
FAGES Francois's avatar
FAGES Francois committed
217
218
219
220
221
222
223
224
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "search_conservations."
   ]
  },
FAGES Francois's avatar
Modal2    
FAGES Francois committed
225
226
227
228
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
FAGES Francois's avatar
FAGES Francois committed
229
    "# Question 1) explain and interpret those 3 invariants\n",
FAGES Francois's avatar
Modal2    
FAGES Francois committed
230
231
232
233
234
235
236
237
238
239
240
241
    "Your answer:\n",
    "\n",
    "* \n",
    "\n",
    "* \n",
    "\n",
    "* \n",
    "\n",
    "* \n",
    "\n"
   ]
  },
FAGES Francois's avatar
FAGES Francois committed
242
243
244
245
246
247
248
249
250
251
252
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Influence graph\n",
    "* positive and negative influences between molecular species\n",
    "* abstraction of the reaction hypergraph"
   ]
  },
  {
   "cell_type": "code",
FAGES Francois's avatar
M2    
FAGES Francois committed
253
   "execution_count": 14,
FAGES Francois's avatar
FAGES Francois committed
254
255
256
257
   "metadata": {},
   "outputs": [
    {
     "data": {
258
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAxYAAAIcCAYAAABrUjh1AAAAAXNSR0IArs4c6QAAAERlWElmTU0AKgAAAAgAAYdpAAQAAAABAAAAGgAAAAAAA6ABAAMAAAABAAEAAKACAAQAAAABAAADFqADAAQAAAABAAACHAAAAADx31eSAABAAElEQVR4AeydB3wUxR/FXyC00HvvvSMqivSqoCKCYkWx/QVEQUVQEUURCyhNqiAqdgV7pQnSi1QBBeldeguEdv95c268hORIcpcryRs/691tmZ357gLzZn4lwmUKVERABERABERABERABERABEQg5QQmZ0j5tbpSBERABERABERABERABERABNwEJCz0JoiACIiACIiACIiACIiACPhMQMLCZ4SqQAREQAREQAREQAREQAREQMJC74AIiIAIiIAIiIAIiIAIiIDPBCQsfEaoCkRABERABERABERABERABCQs9A6IgAiIgAiIgAiIgAiIgAj4TEDCwmeEqkAEREAEREAEREAEREAEREDCQu+ACIiACIiACIiACIiACIiAzwQkLHxGqApEQAREQAREQAREQAREQAQkLPQOiIAIiIAIiIAIiIAIiIAI+ExAwsJnhKpABERABERABERABERABERAwkLvgAiIgAiIgAiIgAiIgAiIgM8EJCx8RqgKREAEREAEREAEREAEREAEJCz0DoiACIiACIiACIiACIiACPhMQMLCZ4SqQAREQAREQAREQAREQAREQMJC74AIiIAIiIAIiIAIiIAIiIDPBCQsfEaoCkRABERABERABERABERABCQs9A6IgAiIgAiIgAiIgAiIgAj4TEDCwmeEqkAEREAEREAEREAEREAEREDCQu+ACIiACIiACIiACIiACIiAzwQkLHxGqApEQAREQAREQAREQAREQAQkLPQOiIAIiIAIiIAIiIAIiIAI+ExAwsJnhKpABERABERABERABERABERAwkLvgAiIgAiIgAiIgAiIgAiIgM8EJCx8RqgKREAEREAEREAEREAEREAEJCz0DoiACIiACIiACIiACIiACPhMQMLCZ4SqQAREQAREQAREQAREQAREQMJC74AIiIAIiIAIiIAIiIAIiIDPBCQsfEaoCkRABERABERABERABERABCQs9A6IgAiIgAiIgAiIgAiIgAj4TEDCwmeEqkAEREAEREAEREAEREAEREDCQu+ACIiACIiACIiACIiACIiAzwQkLHxGqApEQAREQAREQAREQAREQAQkLPQOiIAIiIAIiIAIiIAIiIAI+ExAwsJnhKpABERABERABERABERABERAwkLvgAiIgAiIgAiIgAiIgAiIgM8EJCx8RqgKREAEREAEREAEREAEREAEJCz0DoiACIiACIiACIiACIiACPhMQMLCZ4SqQAREQAREQAREQAREQAREQMJC74AIiIAIiIAIiIAIiIAIiIDPBCQsfEaoCkRABERABERABERABERABCQs9A6IgAiIgAiIgAiIgAiIgAj4TEDCwmeEqkAEREAEREAEREAEREAEREDCQu+ACIiACIiACIiACIiACIiAzwQkLHxGqApEQAREQAREQAREQAREQAQkLPQOiIAIiIAIiIAIiIAIiIAI+ExAwsJnhKpABERABERABERABERABERAwkLvgAiIgAiIgAiIgAiIgAiIgM8EJCx8RqgKREAEREAEREAEREAEREAEJCz0DoiACIiACIiACIiACIiACPhMQMLCZ4SqQAREQAREQAREQAREQAREQMJC74AIiIAIiIAIiIAIiIAIiIDPBCQsfEaoCkRABERABERABERABERABCQs9A6IgAiIgAiIgAiIgAiIgAj4TEDCwmeEqkAEREAEREAEREAEREAEREDCQu+ACIiACIiACIiACIiACIiAzwQkLHxGqApEQAREQAREQAREQAREQAQkLPQOiIAIiIAIiIAIiIAIiIAI+Ewg0ucaglnB4cPA/v3AoUPA0aPA8ePAyZPAqVPAmTPu7cKF/1oYabrLLUsWICoKyJ4dyJkTyJMHyJcPKFTI/fu/K/RNBERABERABERABERABEQgCQTCQ1hQPKxbB2zYAGzeDGzfDuzcCeTKBeTN+58goEjgli0bUKAAEBEBZDCLMhQT5865ccTEANwoPvbtA6KjgQMHgCNHgL17AQqREiWAMmWAsmWBypWB6tUlOJLwMukUERABERABERABERCB9EsgwmVKyHWfA/8lS4B584Bly9wrDxzgV6vmHvCXKwcULepeefB34yk0HOHy11/Axo3AmjVAsWLAlVcCjRoBdeq4RYu/7636REAEREAEREAEREAERCA8CUwOLWHBgfzUqcDs2e5VgsaNgbp1gdKlg4uX2ottW7oU+PVXt/nVtdcCHTu6BU5wW6e7i4AIiIAIiIAIiIAIiECwCYSIsOCqwNix7pWCW28FWrd2mzgFG09i99+9G/j2W+C774D69YH//c9tjpXY+dovAiIgAiIgAiIgAiIgAmmbQJCFxfnzwIQJ7gE6B+ft2oWXidHp08DHH7tXWR56CGjfPm2/LuqdCIiACIiACIiACIiACCRMYHLwnLdpXvTkk0DmzMAnn7gdsRNuZOjuzZoVuP9+9wpLrVpu5++uXUO3vWqZCIiACIiACIiACIiACKQSgeAJi4cfdjtfDx6cSl0LYLWMIrVjB9C0qTsC1YMPBvDmupUIiIAIiIAIiIAIiIAIBJ+AicUahPLTT+5QryNHBuHmqXRL5sSgYzd9LxgWV0UEREAEREAEREAEREAE0hGB4AgLmj4NHBhe/hRJeSly5AA6dwa++CIpZ+scERABERABERABERABEUgzBAIvLE6cAPbsAeiTkBZLw4bA8uVpsWfqkwiIgAiIgAiIgAiIgAgkSiA4wiJ37kQbFPYH8uQBjh0L+26oAyIgAiIgAiIgAiIgAiKQHAKBFxb58gFHjgAXLiSnneFz7r59QIEC4dNetVQEREAEREAEREAEREAE/EAg8MKC4WXLlQOWLfND80OwigULgCuuCMGGqUkiIAIiIAIiIAIiIAIikHoEghNu9uabgfffB+rV82vPzp07h82bN2Pnzp3Yv3+/WRg5gpiYGJw3ifgiIyOR1eSdyGdWTAoVKoRSpUrZLSIiwn9tOHsW+Owz4M03/VenahIBERABERABERABERCBMCAQ4TIl4O2kGRQzVVNg3HBDim9PIbHcOEovXLjQfm7fvh0lTE6JMmXKIH/+/HbLlCkTsmTJglOnTuGsGfhTcBw8eBCbNm3CgQMHULlyZdStWxcNGjRAtWrVUtwWe+Grr7pNvPr1860eXS0CIiACIiACIiACIiAC4UVgcnCEBSFt2wZ07w489ZQ7sVwywG3ZsgVfffUVpk+fjpIlS6JZs2YmyFQtVK1aFRkyJN26i0Jj1apVWLlyJWbNmoXo6Gi0a9cON910kxUlyWgS8MEH7s20C8xpoSICIiACIiACIiACIiAC6YdAEIUFIZtBPerUAaZOBTp0uCT2rVu3YsKECVizZo0VAB3MNTRt8lfZZsTOFyYHxYwZM9CiRQs8aDJo582b1139yZNAzZrA+PFAq1Zxb0nzp4kTge+/d2cTj3tUv0RABERABERABERABEQgrRMIsrAg3t273WZRTzwBM5pPEDhXFsabAf0PP/yA+++/32iQDsiYMWOC5/pj5wmTa+MDswLxrcmiTXHB+0W0aQNMmwZja+X+rFLFfatJk4AffwRGjACKF/fH7VWHCIiACIiACIiACIiACIQbgRAQFkRmHK7xzDPA5ZcDPXvGmfXfbYTHM+ZYORNJ6rHHHvtvBSEAqLmC8arxm6APRufatZHt1luBHTuA1q2Bd9+FsZ8CFi92ZxFn/goVERABERABERABERABEUifBEJEWBC+8W/A0KHAihXAs89akcGoTnTCnmRWBe69996gPKILxtF8zJgxWLRoEd4zjt6Rr70GMJJU2bLAqFFAo0Ywjh1BaZtuKgIiIAIiIAIiIAIiIAIhQmBycMLNJtT7qCjguedgRvAwywQ4eNVVuNusCHxv/Bba0AwpSIXO4D169AAjUDV67z3MN+3MYKJJ4fhxoFIliYogPRfdVgREQAREQAREQAREILQIBC8qlBcOp8ygfdiNN6KeERotW7b0cmZgDz1n2tPqzz/ReP58RJiwtbjzTmDy5MA2QncTAREQAREQAREQAREQgdAjMDkkbXjGmQhLkW3bhpSo4LMbOHAgPjRRorbRF4TO4z/95I4EFXoPVi0SAREQAREQAREQAREQgYASCDlh8c8//+CXX34xKS5MjosQK8zS/eSTT6KfySnoMs7kNl/FZZeFWCvVHBEQAREQAREQAREQAREIPIGQExbfffcdrr32WuTIkSPwNJJwxyomzGyuUqWw+JVX3BGhFGI2CdR0igiIgAiIgAiIgAiIQFonEHLCYt68ebjuuutCmjvbN2v9eqBw4ZBupxonAiIgAiIgAiIgAiIgAoEiEFLCgpGXmDuisgnrmpxywERp4rWehUn1zpw5E7vrpMmczdCxPNdlTJk8C48lp9SqVQtr165NziU6VwREQAREQAREQAREQATSNIHQCTdrMB87dsyaQDHEa1IKBUKXLl1MSomyGDt2LJo1a2ZSYQzFzJkzsXXrVpupu0+fPsicOTM6deqE2267DatXr0arVq3wmslHMd9Ed+K5CxcuxGXGV+IVmjcloeQxyfCOM9ysigiIgAiIgAiIgAiIgAiIgCWQtBF8gGDROTr+yoO3W1MYrDcmSQMGDEC7du1M4u7LkTt3bgwZMsSKiWLFilkBccMNNyBTpkx4+umn8fnnn+Ojjz6y1fbv39+eV716dStIDh065O12sceS08bYi/RFBERABERABERABERABNIwgZBasciVKxdOnTplxUVk5KWbVqFCBbsywVWHgwcP4vrrr8dvv/2GvCYkbN++feM8Nq6CcOUiyiS442oDzZ+WLFliE/Bx3xtvvBHnfG8/KECYEVxFBERABERABERABERABETATSCkViwymtwQFStWTLL/Agf3t99+u/WbeOedd1CtWjW7akHTpjVr1tge0kQqOjo69nk7/hXZs2e3JlTvv/++PUZxsnLlytjzvH2hORXvpSICIiACIiACIiACIiACIuAmEFLCgk1q2rSpXUVIygPatGkTJppkeoMGDUL79u3x0ksvoVChQtY0qnHjxmjUqBGKm3CwXJk4cuSIrfeLL76wvhxc2aBPBc2matSoYf0s6tSpk5TbgiFxmzdvnqRzdZIIiIAIiIAIiIAIiIAIpAcCEWYGP26IpCD3+ujRo3YVYvLkyShYsKDX1nz44Yc4ffo0WrRoYcUChcJ7772HbNmyWVMnmjjRb8Nbob8EI0jxmqQUipQRI0aA975U3UmpT+eIgAiIgAiIgAiIgAiIQBogMPnSjgwB7iWdr2+55RYMGzbsklGaZsyYgT179lhhsGvXLhvZyREINHVKSqEvR1L8OVgXBQjb9cgjj0hUJAWuzhEBERABERABERABEUg3BEJuxYLkuYrQrVs3lC9f3kZySuxpnD9/HkuXLrU+FjR7oihJzUJTK/qB9OvXLzVvo7pFQAREQAREQAREQAREINwITA5JYUGKzGlRtWpVvPzyy7jvvvuCDrZ3797W7IorFgxdqyICIiACIiACIiACIiACIhBLYHLIOW87TWPo2T///BM///wz3n777YuyZTvnpfZnTEwMBg4ciJ07d2LkyJESFakNXPWLgAiIgAiIgAiIgAiEJYGQFRakmTNnTkyYMMEKDPo1bNu2LaCQF371MTrd1wlZsmSxSfWSmhE8oI3UzURABERABERABERABEQgBAiEtLAgH65cDB06FM2aNUPXrl1tRCZGjkrNsn37dnx2661YPPQuLKg9HVvrbsXqg6tT85aqWwREQAREQAREQAREQATCmkDI+lgkRPXw4cN25eD7779HgwYN0LFjR78lqnMcwb/8/HPUNXkqbtq3D+fOHseVT0Tir7znUCxHMVTMWxE96vZA27JtERUZlVATtU8EREAEREAEREAEREAE0iOB0HXe9vY0oqdMwZ4xY/B80aI4fvw4mjRpgtq1a9vtUrkvnHqZvmP37t1Yvny5zbg9d+5c5C53AldvWYWe812IPBUDVKmCyW/di57rXsWR00fspXmy5kGhbIVwd7W70fPynsiVOZdTpT5FQAREQAREQAREQAREIL0SCENhsWYN0LcvjPMFTFpt7NixAwsWLMCKFSuwbt06REdHo1y5csibNy/y589vna2zZs1q93NVYp9ZiTh06BC2bNliE/DVrFnT5r9oZM7N8+ij6F94Bc4ZA7FXjjVAxKef4WyRgmjwcQMs3bs0zksSmSESdQrVwdK74+6Pc5J+iIAIiIAIiIAIiIAIiED6IBBmwuLgQZjYs8CzzwJXX53gI+IKBiM47d+/H/TFYGZu5sVgiFgKjHz58qFAgQIoXbq0dcq2lZjkemjYENi6FRcK5MPjt0ehXKYi6PnafCBzZkzbNg13/3A39kfvj71n1fxV8UOHH1A2d9nYffoiAiIgAiIgAiIgAiIgAumUQBgJCyMOTNY8twC4917/Pq/27YFp02BUB/DCCzh1393oMawxrsxWCV17fGTv1WZqG/y85Wf7vXiO4nio9kN4of4L/m2HahMBERABERABERABERCB8CQQunksLuI5YgRQuDDgb1HBGxmfDTz1FPDBB8BDDyFbZDYMe/gHzN49F59+YsyuTHm54csonL0wiucsjsnXT8bmI5vx5rI37TH9TwREQAREQAREQAREQATSO4HwiAr166/A6NHA5MlAVOCiMR3cuBIPTrwWD7d/Dc2vugtP//Y02pRtg1alWyH6XDSemvMUahaoiYdqPYSMERnT+7uk/ouACIiACIiACIiACKRfAmFgCmUiN+GBB2ASWACVKgX8Ue384SN0W/gUend5F00qXBvn/mcvnMXz85/HqXOn8Frj15A1Y9Y4x/VDBERABERABERABERABNIJgRA3haJfRb9+bmERBFHBl6DE9XdhaN578NqUR7Bs37I470WmDJnwaqNXUTCqIB6d+ShOnD0R57h+iIAIiIAIiIAIiIAIiEB6IRDambdHjTIj+xLALbcE9XlUfPQlvLGhEp7/uhvWHVx3UVv6XdUPlxW6DA9PexgH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iECBCUhYFBiZThABERABEQgLAbr/TJw40SRI+ty+jT/XZHLq0qULKCb8WZTC0pPovQktGrTsTDIpa2nloWXnkksusaIsekelnouACHiUgISFRx+MuiUCIiACcUuA2Zvef/99vPfeezZW4qKLLkLnzp1RvHjxuGUSjIHv27cPEyZMwMcff2wzVV1//fW44IILbHrcYFxf1xABEYh7AhIWcf8TEAAREAER8BABWidefvlltG7dGjealLD169f3UO9ipyvz58/HG6YYHwPC77zzTtC1TE0EREAEikhAwqKIAHW6CIiACIhAEAhsNqlUhw4dagvP3XvvvTbTURAuq0sch8BPP/2EkSNHWsvFFVdcYetpHOcUfS0CIiACRyMwttjRvtF+ERABERABEQgHAdZwuOqqq6z//yuvvCJREQ7o2fdgzMW4ceNsDY2///3voLuUmgiIgAgUlkBClmmFPVnniYAIiIAIiEBRCNAVh6Ji4MCB9q15Qa/FqtVffvml/7QyZcpYgcKaFWzMjMQicy1btsRJJ51k9zGImbUu2K688kp/jMGvv/5qC+exaF64GrM3ffrpp7j//vsjHkPCPnz99ddgytrk5ORwIdB9REAEYoeALBax8yw1EhEQARGIPgKPPfYYXBBxYXpfrlw5bNmyBddcc40tgEdxwGrUTmwwg9Szzz6Ls88+2x7He7CQ3COPPGILyRUrdsRwP3jwYLz44ouF6YY9h8X5CvqujlXCH374YRw4cKDQ9w3WicOGDbPWotdeey1Yl9R1REAE4ozAkf+jxtnANVwREAEREIHIEmAVadanuOWWW4rUEdZpoEBgrQa+dWfg95gxY+w1WRyOBfMqVqwIxhBwAk8x0rZtW3Tr1s1/39WrV4P1HygsmJUqd9u5cycOHz5sd/MaTggwJS63GSNy8cUX53AlYqrXgwcP5rjU3r17bUamtLQ0u59F7BISEnIcs2HDhhyf09PTrShy1+L9eF+6kLnGY4LR3nrrLYwfP972MRjX0zVEQATii4CERXw9b41WBERABDxDgG/46aIUzLZw4UKsWLEih2hgmlqmWOV3d999t70dXX0CrRXMRPXBBx/Y+hjvvvuuv0sUFEOGDMGHH35oq3oz2Pm8887DmWeeaSf2zGJ19dVX2xoRFCajR4+2k/JBgwbh9ddfR58+ffDUU0+B1cJ79OiBTp064fLLL0eDBg3w2Wef+e/DDYoOFrGj+9all15qxQrdku677z6MGjXKBlmzHkXt2rVx6623WiFFccQxsT99+/bNcb3CfKAQo8WHDNVEQAREoKAEkgp6go4XAREQAREQgWAQ4OTevfkv6vX4Np8Wi2nTptn6F3/6059yXLJRo0agYDj//POtRSPwS77tZxwGYzAYwMxJPN2z2N5++20rAnr37o3y5cvbytX8nveipWHNmjV46KGHrFWExzNWZM6cOX4hw2szZuO6666zKV0ZU0IRw2s8//zz1srB89h4bNeuXW0fn376acyePdtWGZ81axa++uorLFu2zBa2K1GiBG677Tbr0sXtd955B3QpYwVyun0VtZFlUpKmB0XlqPNFIB4JyGIRj09dYxYBERABDxCgtYJVoYMhLjgR/t///oeTTz7ZWhfyGt4555xjrQd82z937lz/IZyY022Jb/zXrVsH1niYOnWq/f6TTz5BlSpV7DYDvXn9Fi1aWFcqxiIsWLDAfuYBzqWJRehcoHjJkiVx+umn28J0tJCULl3aXosF/1atWmW33V9Vq1a1Lk5M/8rzGH9xww03oE6dOrZQID+zcaz8nmuKHW4zaJ0Wj6I2uqbRFeuEE04o6qV0vgiIQBwSkLCIw4euIYuACIiAFwjUqFEDbdq0sW4/RekPhQmDpunGQ5cluhjR/cg1uiG5mIZ+/frZTFDMxsTG8z766CNrzeDbfqa77dmzJ2gxYOvYsSNeeukl0CWKMSFffPGF3U/3JFoJTjnlFPuZooLXYuwDq1kz85QL5E5NTQVFDZuL05g3b569j92Z/RfdtVhxnIHliYmJ9nzejy5aw4cPt9YQHuquy23eL/Az9xWlcVx07VJWqKJQ1LkiEL8EJCzi99lr5CIgAiIQcQJ0I6J7EIvjFaZRNFAMcIL9+OOPo0mTJjZw+4EHHrCfmcp1ypQp1l3JXf/VV1+1goafGezNeAJnPWAdB1oWaKl48803bWA5RQkDwJ977jmce+659jKMhWhg4iSYjYqNooYB4YyNSElJwU033eSPjbj55putmxKPY0zGgw8+aK99++232zWFwb///W9rlSALXpPCgpYLxoVwor99+3Z/LAfdttg/ig6KlrFjx1pBwutTWBW20YrCeJRevXoV9hI6TwREIM4JqI5FnP8ANHwREAERiDQB1qKgGxKDhll1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0T4REAEREAERCBaBLGRZkeEEB8XH3gN7/TEjgfspSChEXAYunussIhQgFCQUHTnESLaVxH5nYknsd0agsHq8VxrHtW7POjSr3CzfXZo6daqdfDFmokuXLtb3PNzBrPnurA70BAEGH3///ff48ssvbYD4BRdcYLKi/skG43uhg8y+9ICpXzF06FC0bt3aC10qcB8YF8MsXzeZWhZPPvlk7uByCYsCE9UJIiACIiACIhAmAgcOH/BbSegOtDdzrxUdFCNucdYRfscAeCtUjHhJLJZoRUbZ5JyChMKD++w6W6zQouKsJAx0Z5auYLa7Jt2FF+e+iHManIM+LfvgnPrnoHix4nnegqk2x5g0nMzLf7nJSsPsOF5885xn57XTMwSYcerjjz/GJ598Yt2kbjYB0sctCBfC3jMVL4OzKSoYGxLt7e6777bWw78Y96iAJmERAEObIiACIiACIhAzBJidyYkOm3UrO+0vBYgVJUao0HrC79xxTqxQ0NBSQrFBoeFEiNumdaRUcim73+3jmq5eXOeu2n79F9dj3KJxli0zP1UvVR03nXYTrml6DWqUqmH3MxMQ34CyMNxtt91mA3SL+jA4sWShNzYWoGPQL4N/2Xi/n009AaaYZe7+wH3c7tatm005y20GEtOFhYXEwtWYKYmT4q5du9rYgWDc91g8eP2XXnrJuucwsJhv/e+8885g3Dai12DdjQ8//BDvmJSpdD268cYb7W8h3J16yBTEY1Yr3j+SjTyeffZZ3HfffUUKFudv5Oqrr7aB3czeld3GesdO6rqktQiIgAiIgAiIQJEJuExKzKZU0MZ4ErpruZgRCg5+Dlyv37veWlAC96UdTLMuXrwfxQhFBsXJ4h2L/V1g9icug6YNwrM/P4uz652NS6teimf6P2MDWi+88EL/sUXd4ISHQd2cSLEoG91P+vXrhyFDhthUpi+++KKdGH333Xd2As86CnyjzIDgK6+80n/7N954A5+Z7D0TJkzw7yvIBisccynIG3PGDzBrEPvCoORgtGPx4PUpZjjx5JrBxbEgLEqWLInrrrsOl1xyCZ4wNSPefPNNO7kPZqYwui6+MPcFK5Qblm/4h0dFnixAN2jQoD98F4odjDtp2rRpnsKBdV2Y0reojamayZW1Nyia/M3kCVYTAREQAREQAREQgaARMNaSLCMeslanrs5auG1hVttx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"
FAGES Francois's avatar
FAGES Francois committed
259
260
261
262
263
264
265
266
267
268
269
270
271
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "draw_influences."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
FAGES Francois's avatar
Modal2    
FAGES Francois committed
272
    "### Differential semantics\n",
FAGES Francois's avatar
FAGES Francois committed
273
274
275
276
277
    "* interpretration by Ordinary Differential Equation (ODE)"
   ]
  },
  {
   "cell_type": "code",
FAGES Francois's avatar
M2    
FAGES Francois committed
278
   "execution_count": 15,
FAGES Francois's avatar
FAGES Francois committed
279
280
281
282
283
284
285
286
287
288
289
290
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/latex": [
       "\\begin{align*}\n",
       "{protein}_0 &= 0\\\\\n",
       "{ribosome}_0 &= 10\\\\\n",
       "{RNAcytoplasmRibosome}_0 &= 0\\\\\n",
       "{RNAcytoplasm}_0 &= 0\\\\\n",
       "{RNAnucleus}_0 &= 0\\\\\n",
       "{gene}_0 &= 1\\\\\n",
291
       "{RNApolymerase}_0 &= 10\\\\\n",
FAGES Francois's avatar
FAGES Francois committed
292
293
294
295
296
297
298
       "{geneRNApolymerase}_0 &= 0\\\\\n",
       "k1 &= 1\\\\\n",
       "k2 &= 1\\\\\n",
       "k3 &= 1\\\\\n",
       "k4 &= 1\\\\\n",
       "k5 &= 1\\\\\n",
       "k6 &= 1\\\\\n",
FAGES Francois's avatar
FAGES Francois committed
299
       "k7 &= 0.1\\\\\n",
FAGES Francois's avatar
FAGES Francois committed
300
       "nbgene &= 1\\\\\n",
FAGES Francois's avatar
Modal2    
FAGES Francois committed
301
       "nbRNApolymerase &= 10\\\\\n",
FAGES Francois's avatar
FAGES Francois committed
302
       "nbribosome &= 10\\\\\n",
FAGES Francois's avatar
M2    
FAGES Francois committed
303
304
305
306
307
       "\\frac{dprotein}{dt} &= k6*RNAcytoplasmRibosome-k7*protein\\\\\n",
       "\\frac{dribosome}{dt} &= k6*RNAcytoplasmRibosome-k5*RNAcytoplasm*ribosome\\\\\n",
       "\\frac{dRNAcytoplasmRibosome}{dt} &= k5*RNAcytoplasm*ribosome-k6*RNAcytoplasmRibosome\\\\\n",
       "\\frac{dRNAcytoplasm}{dt} &= k4*RNAnucleus-k5*RNAcytoplasm*ribosome\\\\\n",
       "\\frac{dRNAnucleus}{dt} &= k3*geneRNApolymerase-k4*RNAnucleus\\\\\n",
308
309
310
       "\\frac{dgene}{dt} &= k2*geneRNApolymerase-k1*RNApolymerase*gene\\\\\n",
       "\\frac{dRNApolymerase}{dt} &= k2*geneRNApolymerase-k1*RNApolymerase*gene\\\\\n",
       "\\frac{dgeneRNApolymerase}{dt} &= k1*RNApolymerase*gene-k2*geneRNApolymerase\\\\\n",
FAGES Francois's avatar
FAGES Francois committed
311
312
313
314
315
316
317
318
319
320
321
322
323
       "\\end{align*}\n"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "list_ode."
   ]
  },
  {
   "cell_type": "code",
FAGES Francois's avatar
M2    
FAGES Francois committed
324
   "execution_count": 16,
FAGES Francois's avatar
FAGES Francois committed
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
   "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",
       "  var JS_MIME_TYPE = 'application/javascript';\n",
       "  var HTML_MIME_TYPE = 'text/html';\n",
       "  var EXEC_MIME_TYPE = 'application/vnd.bokehjs_exec.v0+json';\n",
       "  var CLASS_NAME = 'output_bokeh rendered_html';\n",
       "\n",
       "  /**\n",
       "   * Render data to the DOM node\n",
       "   */\n",
       "  function render(props, node) {\n",
       "    var script = document.createElement(\"script\");\n",
       "    node.appendChild(script);\n",
       "  }\n",
       "\n",
       "  /**\n",
       "   * Handle when an output is cleared or removed\n",
       "   */\n",
       "  function handleClearOutput(event, handle) {\n",
       "    var cell = handle.cell;\n",
       "\n",
       "    var id = cell.output_area._bokeh_element_id;\n",
       "    var server_id = cell.output_area._bokeh_server_id;\n",
       "    // Clean up Bokeh references\n",
       "    if (id != null && id in Bokeh.index) {\n",
       "      Bokeh.index[id].model.document.clear();\n",
       "      delete Bokeh.index[id];\n",
       "    }\n",
       "\n",
       "    if (server_id !== undefined) {\n",
       "      // Clean up Bokeh references\n",
       "      var cmd = \"from bokeh.io.state import curstate; print(curstate().uuid_to_server['\" + server_id + \"'].get_sessions()[0].document.roots[0]._id)\";\n",
       "      cell.notebook.kernel.execute(cmd, {\n",
       "        iopub: {\n",
       "          output: function(msg) {\n",
       "            var id = msg.content.text.trim();\n",
       "            if (id in Bokeh.index) {\n",
       "              Bokeh.index[id].model.document.clear();\n",
       "              delete Bokeh.index[id];\n",
       "            }\n",
       "          }\n",
       "        }\n",
       "      });\n",
       "      // Destroy server and session\n",
       "      var cmd = \"import bokeh.io.notebook as ion; ion.destroy_server('\" + server_id + \"')\";\n",
       "      cell.notebook.kernel.execute(cmd);\n",
       "    }\n",
       "  }\n",
       "\n",
       "  /**\n",
       "   * Handle when a new output is added\n",
       "   */\n",
       "  function handleAddOutput(event, handle) {\n",
       "    var output_area = handle.output_area;\n",
       "    var output = handle.output;\n",
       "\n",
       "    // limit handleAddOutput to display_data with EXEC_MIME_TYPE content only\n",
       "    if ((output.output_type != \"display_data\") || (!output.data.hasOwnProperty(EXEC_MIME_TYPE))) {\n",
       "      return\n",
       "    }\n",
       "\n",
       "    var toinsert = output_area.element.find(\".\" + CLASS_NAME.split(' ')[0]);\n",
       "\n",
       "    if (output.metadata[EXEC_MIME_TYPE][\"id\"] !== undefined) {\n",
       "      toinsert[toinsert.length - 1].firstChild.textContent = output.data[JS_MIME_TYPE];\n",
       "      // store reference to embed id on output_area\n",
       "      output_area._bokeh_element_id = output.metadata[EXEC_MIME_TYPE][\"id\"];\n",
       "    }\n",
       "    if (output.metadata[EXEC_MIME_TYPE][\"server_id\"] !== undefined) {\n",
       "      var bk_div = document.createElement(\"div\");\n",
       "      bk_div.innerHTML = output.data[HTML_MIME_TYPE];\n",
       "      var script_attrs = bk_div.children[0].attributes;\n",
       "      for (var i = 0; i < script_attrs.length; i++) {\n",
       "        toinsert[toinsert.length - 1].firstChild.setAttribute(script_attrs[i].name, script_attrs[i].value);\n",
415
       "        toinsert[toinsert.length - 1].firstChild.textContent = bk_div.children[0].textContent\n",
FAGES Francois's avatar
FAGES Francois committed
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
       "      }\n",
       "      // store reference to server id on output_area\n",
       "      output_area._bokeh_server_id = output.metadata[EXEC_MIME_TYPE][\"server_id\"];\n",
       "    }\n",
       "  }\n",
       "\n",
       "  function register_renderer(events, OutputArea) {\n",
       "\n",
       "    function append_mime(data, metadata, element) {\n",
       "      // create a DOM node to render to\n",
       "      var toinsert = this.create_output_subarea(\n",
       "        metadata,\n",
       "        CLASS_NAME,\n",
       "        EXEC_MIME_TYPE\n",
       "      );\n",
       "      this.keyboard_manager.register_events(toinsert);\n",
       "      // Render to node\n",
       "      var props = {data: data, metadata: metadata[EXEC_MIME_TYPE]};\n",
       "      render(props, toinsert[toinsert.length - 1]);\n",
       "      element.append(toinsert);\n",
       "      return toinsert\n",
       "    }\n",
       "\n",
       "    /* Handle when an output is cleared or removed */\n",
       "    events.on('clear_output.CodeCell', handleClearOutput);\n",
       "    events.on('delete.Cell', handleClearOutput);\n",
       "\n",
       "    /* Handle when a new output is added */\n",
       "    events.on('output_added.OutputArea', handleAddOutput);\n",
       "\n",
       "    /**\n",
       "     * Register the mime type and append_mime function with output_area\n",
       "     */\n",
       "    OutputArea.prototype.register_mime_type(EXEC_MIME_TYPE, append_mime, {\n",
       "      /* Is output safe? */\n",
       "      safe: true,\n",
       "      /* Index of renderer in `output_area.display_order` */\n",
       "      index: 0\n",
       "    });\n",
       "  }\n",
       "\n",
       "  // register the mime type if in Jupyter Notebook environment and previously unregistered\n",
       "  if (root.Jupyter !== undefined) {\n",
       "    var events = require('base/js/events');\n",
       "    var OutputArea = require('notebook/js/outputarea').OutputArea;\n",
       "\n",
       "    if (OutputArea.prototype.mime_types().indexOf(EXEC_MIME_TYPE) == -1) {\n",
       "      register_renderer(events, OutputArea);\n",
       "    }\n",
       "  }\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",
       "  var NB_LOAD_WARNING = {'data': {'text/html':\n",
       "     \"<div style='background-color: #fdd'>\\n\"+\n",
       "     \"<p>\\n\"+\n",
       "     \"BokehJS does not appear to have successfully loaded. If loading BokehJS from CDN, this \\n\"+\n",
       "     \"may be due to a slow or bad network connection. Possible fixes:\\n\"+\n",
       "     \"</p>\\n\"+\n",
       "     \"<ul>\\n\"+\n",
       "     \"<li>re-rerun `output_notebook()` to attempt to load from CDN again, or</li>\\n\"+\n",
       "     \"<li>use INLINE resources instead, as so:</li>\\n\"+\n",
       "     \"</ul>\\n\"+\n",
       "     \"<code>\\n\"+\n",
       "     \"from bokeh.resources import INLINE\\n\"+\n",
       "     \"output_notebook(resources=INLINE)\\n\"+\n",
       "     \"</code>\\n\"+\n",
       "     \"</div>\"}};\n",
       "\n",
       "  function display_loaded() {\n",
       "    var el = document.getElementById(null);\n",
       "    if (el != null) {\n",
       "      el.textContent = \"BokehJS is loading...\";\n",
       "    }\n",
       "    if (root.Bokeh !== undefined) {\n",
       "      if (el != null) {\n",
       "        el.textContent = \"BokehJS \" + root.Bokeh.version + \" successfully loaded.\";\n",
       "      }\n",
       "    } else if (Date.now() < root._bokeh_timeout) {\n",
       "      setTimeout(display_loaded, 100)\n",
       "    }\n",
       "  }\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, callback) {\n",
       "    if (css_urls == null) css_urls = [];\n",
       "    if (js_urls == null) js_urls = [];\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 == null || js_urls.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;\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",
556
557
       "    const hashes = {};\n",
       "\n",
FAGES Francois's avatar
FAGES Francois committed
558
559
560
561
562
563
564
       "    for (var i = 0; i < js_urls.length; i++) {\n",
       "      var url = js_urls[i];\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",
565
566
567
568
       "      if (url in hashes) {\n",
       "        element.crossOrigin = \"anonymous\";\n",
       "        element.integrity = \"sha384-\" + hashes[url];\n",
       "      }\n",
FAGES Francois's avatar
FAGES Francois committed
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
       "      console.debug(\"Bokeh: injecting script tag for BokehJS library: \", url);\n",
       "      document.head.appendChild(element);\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",
       "  \n",
       "  var js_urls = [];\n",
       "  var css_urls = [];\n",
       "  \n",
       "\n",
       "  var inline_js = [\n",
       "    function(Bokeh) {\n",
       "      /* BEGIN bokeh.min.js */\n",
       "      /*!\n",
589
       "       * Copyright (c) 2012 - 2020, Anaconda, Inc., and Bokeh Contributors\n",
FAGES Francois's avatar
FAGES Francois committed
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
       "       * 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",
       "        root[\"Bokeh\"] = factory();\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",
       "            var prefix = \"@bokehjs/\"\n",
       "            if (name.slice(0, prefix.length) === prefix)\n",
       "              name = name.slice(prefix.length)\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",
660
       "                  if (externals[id] === false || (externals[id] == true && parent_require)) {\n",
FAGES Francois's avatar
FAGES Francois committed
661
       "                    try {\n",
662
       "                      mod = {exports: externals[id] ? parent_require(id) : {}};\n",
FAGES Francois's avatar
FAGES Francois committed
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
       "                      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",
       "                modules[id].call(mod.exports, require, mod, mod.exports);\n",
       "              } else\n",
       "                cache[name] = mod;\n",
       "            }\n",
       "\n",
       "            return mod.exports;\n",
       "          }\n",
       "\n",
       "          var main = require(entry);\n",
       "          main.require = require;\n",
       "\n",
686
687
688
689
690
691
692
693
694
       "          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",
FAGES Francois's avatar
FAGES Francois committed
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
       "          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",
723
       "      function _(e,t,_){Object.defineProperty(_,\"__esModule\",{value:!0}),e(1).__exportStar(e(2),_)},\n",
FAGES Francois's avatar
FAGES Francois committed
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
       "      function _(t,e,n){\n",
       "      /*! *****************************************************************************\n",
       "          Copyright (c) Microsoft Corporation. All rights reserved.\n",
       "          Licensed under the Apache License, Version 2.0 (the \"License\"); you may not use\n",
       "          this file except in compliance with the License. You may obtain a copy of the\n",
       "          License at http://www.apache.org/licenses/LICENSE-2.0\n",
       "          \n",
       "          THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY\n",
       "          KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED\n",
       "          WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,\n",
       "          MERCHANTABLITY OR NON-INFRINGEMENT.\n",
       "          \n",
       "          See the Apache Version 2.0 License for specific language governing permissions\n",
       "          and limitations under the License.\n",
       "          ***************************************************************************** */\n",
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
804
805
806
807
808
809
810
811
812
813
814
815
816
817
818
819
820
821
822
823
824
825
826
827
828
829
830
831
832
833
834
835
836
837
838
839
840
841
842
843
844
845
846
847
848
849
850
851
852
853
854
855
856
857
858
859
860
861
862
863
864
865
866
867
868
869
870
871
872
873
874
875
876
877
878
879
880
881
882
883
884
885
886
887
888
889
890
891
892
893
894
895
896
897
898
899
900
901
902
903
904
905
906
907
908
       "      Object.defineProperty(n,\"__esModule\",{value:!0});var r=function(t,e){return(r=Object.setPrototypeOf||{__proto__:[]}instanceof Array&&function(t,e){t.__proto__=e}||function(t,e){for(var n in e)e.hasOwnProperty(n)&&(t[n]=e[n])})(t,e)};function o(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 a(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 i(t){return this instanceof i?(this.v=t,this):new i(t)}n.__extends=function(t,e){function n(){this.constructor=t}r(t,e),t.prototype=null===e?Object.create(e):(n.prototype=e.prototype,new n)},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 u=t.length-1;u>=0;u--)(o=t[u])&&(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{c(r.next(t))}catch(t){a(t)}}function u(t){try{c(r.throw(t))}catch(t){a(t)}}function c(t){var e;t.done?o(t.value):(e=t.value,e instanceof n?e:new n((function(t){t(e)}))).then(i,u)}c((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:u(0),throw:u(1),return:u(2)},\"function\"==typeof Symbol&&(a[Symbol.iterator]=function(){return this}),a;function u(a){return function(u){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,u])}}},n.__exportStar=function(t,e){for(var n in t)e.hasOwnProperty(n)||(e[n]=t[n])},n.__values=o,n.__read=a,n.__spread=function(){for(var t=[],e=0;e<arguments.length;e++)t=t.concat(a(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,u=a.length;i<u;i++,o++)r[o]=a[i];return r},n.__await=i,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={},u(\"next\"),u(\"throw\"),u(\"return\"),r[Symbol.asyncIterator]=function(){return this},r;function u(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 i?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:i(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=o(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},n.__importStar=function(t){if(t&&t.__esModule)return t;var e={};if(null!=t)for(var n in t)Object.hasOwnProperty.call(t,n)&&(e[n]=t[n]);return e.default=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,r,t){var l=this&&this.__importStar||function(e){if(e&&e.__esModule)return e;var r={};if(null!=e)for(var t in e)Object.hasOwnProperty.call(e,t)&&(r[t]=e[t]);return r.default=e,r};Object.defineProperty(t,\"__esModule\",{value:!0});var o=e(3);t.version=o.version;var s=e(4);t.index=s.index,t.embed=l(e(4)),t.protocol=l(e(354)),t._testing=l(e(355));var n=e(70);t.logger=n.logger,t.set_log_level=n.set_log_level;var a=e(26);t.settings=a.settings;var i=e(7);t.Models=i.Models;var v=e(5);t.documents=v.documents;var _=e(356);t.safely=_.safely},\n",
       "      function _(e,n,o){Object.defineProperty(o,\"__esModule\",{value:!0}),o.version=\"2.0.1\"},\n",
       "      function _(e,o,n){Object.defineProperty(n,\"__esModule\",{value:!0});const t=e(5),s=e(70),d=e(25),r=e(8),_=e(17),c=e(345),i=e(347),a=e(346);var u=e(345);n.add_document_standalone=u.add_document_standalone,n.index=u.index;var l=e(347);n.add_document_from_session=l.add_document_from_session;var m=e(352);n.embed_items_notebook=m.embed_items_notebook,n.kernels=m.kernels;var f=e(346);async function g(e,o,n,_){r.isString(e)&&(e=JSON.parse(d.unescape(e)));const u={};for(const o in e){const n=e[o];u[o]=t.Document.from_json(n)}const l=[];for(const e of o){const o=a._resolve_element(e),t=a._resolve_root_elements(e);if(null!=e.docid)l.push(await c.add_document_standalone(u[e.docid],o,t,e.use_for_title));else{if(null==e.token)throw new Error(\"Error rendering Bokeh items: either 'docid' or 'token' was expected.\");{const d=i._get_ws_url(n,_);s.logger.debug(`embed: computed ws url: ${d}`);try{l.push(await i.add_document_from_session(d,e.token,o,t,e.use_for_title)),console.log(\"Bokeh items were rendered successfully\")}catch(e){console.log(\"Error rendering Bokeh items:\",e)}}}}return l}n.BOKEH_ROOT=f.BOKEH_ROOT,n.embed_item=async function(e,o){const n={},t=d.uuid4();n[t]=e.doc,null==o&&(o=e.target_id);const s=document.getElementById(o);null!=s&&s.classList.add(a.BOKEH_ROOT);const r={roots:{[e.root_id]:o},root_ids:[e.root_id],docid:t},[c]=await _.defer(()=>g(n,[r]));return c},n.embed_items=async function(e,o,n,t){return await _.defer(()=>g(e,o,n,t))}},\n",
       "      function _(e,t,_){Object.defineProperty(_,\"__esModule\",{value:!0});const o=e(1);o.__exportStar(e(6),_),o.__exportStar(e(103),_)},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});const o=e(7),n=e(3),i=e(70),r=e(281),_=e(13),l=e(14),a=e(24),c=e(100),d=e(15),h=e(9),f=e(23),u=e(16),m=e(8),g=e(244),v=e(73),p=e(69),w=e(103);class b{constructor(e){this.document=e,this.session=null,this.subscribed_models=new Set}send_event(e){const t=new w.MessageSentEvent(this.document,\"bokeh_event\",e.to_json());this.document._trigger_on_change(t)}trigger(e){for(const t of this.subscribed_models){if(null!=e.origin&&e.origin.id!==t)continue;const s=this.document._all_models[t];null!=s&&s instanceof p.Model&&s._process_event(e)}}}s.EventManager=b,b.__name__=\"EventManager\",s.documents=[],s.DEFAULT_TITLE=\"Bokeh Application\";class y{constructor(){s.documents.push(this),this._init_timestamp=Date.now(),this._title=s.DEFAULT_TITLE,this._roots=[],this._all_models={},this._all_models_by_name=new d.MultiDict,this._all_models_freeze_count=0,this._callbacks=[],this._message_callbacks=new Map,this.event_manager=new b(this),this.idle=new l.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 g.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&&(i.logger.info(`document idle at ${Date.now()-this._init_timestamp} ms`),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 r.LODStart)),this._interactive_timestamp=Date.now()}interactive_stop(e){null!=this._interactive_plot&&this._interactive_plot.id===e.id&&this._interactive_plot.trigger_event(new r.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=h.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!==Object.keys(this._all_models).length)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(){i.logger.debug(\"invalidating document models\"),0===this._all_models_freeze_count&&this._recompute_all_models()}_recompute_all_models(){let e=new d.Set;for(const t of this._roots)e=e.union(t.references());const t=new d.Set(f.values(this._all_models)),s=t.diff(e),o=e.diff(t),n={};for(const t of e.values)n[t.id]=t;for(const e of s.values)e.detach_document(),e instanceof p.Model&&null!=e.name&&this._all_models_by_name.remove_value(e.name,e);for(const e of o.values)e.attach_document(this),e instanceof p.Model&&null!=e.name&&this._all_models_by_name.add_value(e.name,e);this._all_models=n}roots(){return this._roots}add_root(e,t){if(i.logger.debug(`Adding root: ${e}`),!h.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 w.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 w.RootRemovedEvent(this,e,t))}}title(){return this._title}set_title(e,t){e!==this._title&&(this._title=e,this._trigger_on_change(new w.TitleChangedEvent(this,e,t)))}get_model_by_id(e){return e in this._all_models?this._all_models[e]:null}get_model_by_name(e){return this._all_models_by_name.get_one(e,`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){h.includes(this._callbacks,e)||this._callbacks.push(e)}remove_on_change(e){const t=this._callbacks.indexOf(e);t>=0&&this._callbacks.splice(t,1)}_trigger_on_change(e){for(const t of this._callbacks)t(e)}_notify_change(e,t,s,o,n){\"name\"===t&&(this._all_models_by_name.remove_value(s,e),null!=o&&this._all_models_by_name.add_value(o,e));const i=null!=n?n.setter_id:void 0,r=null!=n?n.hint:void 0;this._trigger_on_change(new w.ModelChangedEvent(this,e,t,s,o,i,r))}static _references_json(e,t=!0){const s=[];for(const o of e){const e=o.struct();e.attributes=o.attributes_as_json(t),delete e.attributes.id,s.push(e)}return s}static _instantiate_object(e,t,s){const n=Object.assign(Object.assign({},s),{id:e,__deferred__:!0});return new(o.Models(t))(n)}static _instantiate_references_json(e,t){const s={};for(const o of e){const e=o.id,n=o.type,i=o.attributes||{};let r;e in t?r=t[e]:(r=y._instantiate_object(e,n,i),null!=o.subtype&&r.set_subtype(o.subtype)),s[r.id]=r}return s}static _resolve_refs(e,t,s){function o(e){if(a.is_ref(e)){if(e.id in t)return t[e.id];if(e.id in s)return s[e.id];throw new Error(`reference ${JSON.stringify(e)} isn't known (not in Document?)`)}return m.isArray(e)?function(e){const t=[];for(const s of e)t.push(o(s));return t}(e):m.isPlainObject(e)?function(e){const t={};for(const s in e){const n=e[s];t[s]=o(n)}return t}(e):e}return o(e)}static _initialize_references_json(e,t,s){const o={};for(const n of e){const e=n.id,i=n.attributes,r=!(e in t),_=r?s[e]:t[e],l=y._resolve_refs(i,t,s);o[_.id]=[_,l,r]}function n(e,t){const s={};function o(n){if(n instanceof _.HasProps){if(!(n.id in s)&&n.id in e){s[n.id]=!0;const[,i,r]=e[n.id];for(const e in i){o(i[e])}t(n,i,r)}}else if(m.isArray(n))for(const e of n)o(e);else if(m.isPlainObject(n))for(const e in n){o(n[e])}}for(const t in e){const[s,,]=e[t];o(s)}}n(o,(function(e,t,s){s&&e.setv(t,{silent:!0})})),n(o,(function(e,t,s){s&&e.finalize()}))}static _event_for_attribute_change(e,t,s,o,n){if(o.get_model_by_id(e.id).attribute_is_serializable(t)){const i={kind:\"ModelChanged\",model:{id:e.id},attr:t,new:s};return _.HasProps._json_record_references(o,s,n,!0),i}return null}static _events_to_sync_objects(e,t,s,o){const n=Object.keys(e.attributes),r=Object.keys(t.attributes),_=h.difference(n,r),l=h.difference(r,n),a=h.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 i=t.attributes[n];c.push(y._event_for_attribute_change(e,n,i,s,o))}for(const n of a){const i=e.attributes[n],r=t.attributes[n];null==i&&null==r||(null==i||null==r?c.push(y._event_for_attribute_change(e,n,r,s,o)):u.isEqual(i,r)||c.push(y._event_for_attribute_change(e,n,r,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={};for(const s of e.roots.references)t[s.id]=s;return t}const n=o(e),i={},r=[];for(const t of e.roots.root_ids)i[t]=n[t],r.push(t);const _=o(s),l={},a=[];for(const e of s.roots.root_ids)l[e]=_[e],a.push(e);if(r.sort(),a.sort(),h.difference(r,a).length>0||h.difference(a,r).length>0)throw new Error(\"Not implemented: computing add/remove of document roots\");const c={};let d=[];for(const e in t._all_models)if(e in n){const s=y._events_to_sync_objects(n[e],_[e],t,c);d=d.concat(s)}return{references:y._references_json(f.values(c),!1),events:d}}to_json_string(e=!0){return JSON.stringify(this.to_json(e))}to_json(e=!0){const t=this._roots.map(e=>e.id),s=f.values(this._all_models);return{version:n.version,title:this._title,roots:{root_ids:t,references:y._references_json(s,e)}}}static from_json_string(e){const t=JSON.parse(e);return y.from_json(t)}static from_json(e){i.logger.debug(\"Creating Document from JSON\");const t=e.version,s=-1!==t.indexOf(\"+\")||-1!==t.indexOf(\"-\"),o=`Library versions: JS (${n.version}) / Python (${t})`;s||n.version.replace(/-(dev|rc)\\./,\"$1\")==t?i.logger.debug(o):(i.logger.warn(\"JS/Python version mismatch\"),i.logger.warn(o));const r=e.roots,_=r.root_ids,l=r.references,a=y._instantiate_references_json(l,{});y._initialize_references_json(l,{},a);const c=new y;for(const e of _)c.add_root(a[e]);return c.set_title(e.title),c}replace_with_json(e){y.from_json(e).destructively_move(this)}create_json_patch_string(e){return JSON.stringify(this.create_json_patch(e))}create_json_patch(e){const t={},s=[];for(const o of e){if(o.document!==this)throw i.logger.warn(\"Cannot create a patch using events from a different document, event had \",o.document,\" we are \",this),new Error(\"Cannot create a patch using events from a different document\");s.push(o.json(t))}return{events:s,references:y._references_json(f.values(t))}}apply_json_patch(e,t=[],s){const o=e.references,n=e.events,r=y._instantiate_references_json(o,this._all_models);for(const e of n)switch(e.kind){case\"RootAdded\":case\"RootRemoved\":case\"ModelChanged\":{const t=e.model.id;if(t in this._all_models)r[t]=this._all_models[t];else if(!(t in r))throw i.logger.warn(\"Got an event for unknown model \",e.model),new Error(\"event model wasn't known\");break}}const _={},l={};for(const e in r){const t=r[e];e in this._all_models?_[e]=t:l[e]=t}y._initialize_references_json(o,_,l);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.length)throw new Error(\"expected exactly one buffer\");{const[[,e]]=t;n=e}}else n=y._resolve_refs(o,_,l);this._trigger_on_message(s,n);break}case\"ModelChanged\":{const o=e.model.id;if(!(o in this._all_models))throw new Error(`Cannot apply patch to ${o} which is not in the document`);const n=this._all_models[o],i=e.attr;if(\"data\"===i&&\"ColumnDataSource\"===n.type){const[o,i]=c.decode_column_data(e.new,t);n.setv({_shapes:i,data:o},{setter_id:s})}else{const t=y._resolve_refs(e.new,_,l);n.setv({[i]:t},{setter_id:s})}break}case\"ColumnDataChanged\":{const o=e.column_source.id;if(!(o in this._all_models))throw new Error(`Cannot stream to ${o} which is not in the document`);const n=this._all_models[o],[i,r]=c.decode_column_data(e.new,t);if(null!=e.cols){for(const e in n.data)e in i||(i[e]=n.data[e]);for(const e in n._shapes)e in r||(r[e]=n._shapes[e])}n.setv({_shapes:r,data:i},{setter_id:s,check_eq:!1});break}case\"ColumnsStreamed\":{const t=e.column_source.id;if(!(t in this._all_models))throw new Error(`Cannot stream to ${t} which is not in the document`);const o=this._all_models[t];if(!(o instanceof v.ColumnDataSource))throw new Error(\"Cannot stream to non-ColumnDataSource\");const n=e.data,i=e.rollover;o.stream(n,i,s);break}case\"ColumnsPatched\":{const t=e.column_source.id;if(!(t in this._all_models))throw new Error(`Cannot patch ${t} which is not in the document`);const o=this._all_models[t];if(!(o instanceof v.ColumnDataSource))throw new Error(\"Cannot patch non-ColumnDataSource\");const n=e.patches;o.patch(n,s);break}case\"RootAdded\":{const t=r[e.model.id];this.add_root(t,s);break}case\"RootRemoved\":{const t=r[e.model.id];this.remove_root(t,s);break}case\"TitleChanged\":this.set_title(e.title,s);break;default:throw new Error(\"Unknown patch event \"+JSON.stringify(e))}}}s.Document=y,y.__name__=\"Document\"},\n",
       "      function _(e,r,s){Object.defineProperty(s,\"__esModule\",{value:!0});const o=e(1),t=e(8),d=e(13);s.overrides={};const i=new Map;s.Models=e=>{const r=s.overrides[e]||i.get(e);if(null==r)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.`);return r},s.Models.register=(e,r)=>{s.overrides[e]=r},s.Models.unregister=e=>{delete s.overrides[e]},s.Models.register_models=(e,r=!1,s)=>{var o;if(null!=e)for(const l in e){const n=e[l];if(o=n,t.isObject(o)&&o.prototype instanceof d.HasProps){const e=n.__qualified__;r||!i.has(e)?i.set(e,n):null!=s?s(e):console.warn(`Model '${e}' was already registered`)}}},s.register_models=s.Models.register_models,s.Models.registered_names=()=>Array.from(i.keys());const l=o.__importStar(e(27));s.register_models(l)},\n",
       "      function _(n,t,r){Object.defineProperty(r,\"__esModule\",{value:!0});\n",
       "      //     (c) 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n",
       "      //     Underscore may be freely distributed under the MIT license.\n",
       "      const e=n(9),o=Object.prototype.toString;function i(n){return\"[object Number]\"===o.call(n)}function u(n){const t=typeof n;return\"function\"===t||\"object\"===t&&!!n}r.isBoolean=function(n){return!0===n||!1===n||\"[object Boolean]\"===o.call(n)},r.isNumber=i,r.isInteger=function(n){return i(n)&&isFinite(n)&&Math.floor(n)===n},r.isString=function(n){return\"[object String]\"===o.call(n)},r.isStrictNaN=function(n){return i(n)&&n!==+n},r.isFunction=function(n){return\"[object Function]\"===o.call(n)},r.isArray=function(n){return Array.isArray(n)},r.isArrayOf=function(n,t){return e.every(n,t)},r.isArrayableOf=function(n,t){for(let r=0,e=n.length;r<e;r++)if(!t(n[r]))return!1;return!0},r.isTypedArray=function(n){return null!=n&&n.buffer instanceof ArrayBuffer},r.isObject=u,r.isPlainObject=function(n){return u(n)&&(null==n.constructor||n.constructor===Object)}},\n",
       "      function _(n,t,e){Object.defineProperty(e,\"__esModule\",{value:!0});\n",
       "      //     (c) 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n",
       "      //     Underscore may be freely distributed under the MIT license.\n",
       "      const r=n(10),o=n(11),i=n(12);e.map=i.map,e.reduce=i.reduce,e.min=i.min,e.min_by=i.min_by,e.max=i.max,e.max_by=i.max_by,e.sum=i.sum,e.cumsum=i.cumsum,e.every=i.every,e.some=i.some,e.find=i.find,e.find_last=i.find_last,e.find_index=i.find_index,e.find_last_index=i.find_last_index,e.sorted_index=i.sorted_index;const u=Array.prototype.slice;function c(n){return u.call(n)}function f(n){return[].concat(...n)}function s(n,t){return-1!==n.indexOf(t)}function l(n,t,e=1){o.assert(e>0,\"'step' must be a positive number\"),null==t&&(t=n,n=0);const{max:r,ceil:i,abs:u}=Math,c=n<=t?e:-e,f=r(i(u(t-n)/e),0),s=Array(f);for(let t=0;t<f;t++,n+=c)s[t]=n;return s}function a(n){const t=[];for(const e of n)s(t,e)||t.push(e);return t}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=c,e.concat=f,e.includes=s,e.contains=s,e.nth=function(n,t){return n[t>=0?t:n.length+t]},e.zip=function(...n){if(0==n.length)return[];const t=i.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=i.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=l,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 i.min_by(l(n.length),t=>n[t])},e.argmax=function(n){return i.max_by(l(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=a,e.uniq_by=function(n,t){const e=[],r=[];for(const o of n){const n=t(o);s(r,n)||(r.push(n),e.push(o))}return e},e.union=function(...n){return a(f(n))},e.intersection=function(n,...t){const e=[];n:for(const r of n)if(!s(e,r)){for(const n of t)if(!s(n,r))continue n;e.push(r)}return e},e.difference=function(n,...t){const e=f(t);return n.filter(n=>!s(e,n))},e.remove_at=function(n,t){const e=c(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 o=0;o<t;o++){const t=r.randomIn(0,o);t!==o&&(e[o]=e[t]),e[t]=n[o]}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,t,r){function e(n){if(0==n)return 0;for(;n<=0;)n+=2*Math.PI;for(;n>2*Math.PI;)n-=2*Math.PI;return n}function o(n,t){return e(n-t)}function a(){return Math.random()}Object.defineProperty(r,\"__esModule\",{value:!0}),r.angle_norm=e,r.angle_dist=o,r.angle_between=function(n,t,r,a){const u=o(t,r);if(0==u)return!1;if(u==2*Math.PI)return!0;const f=e(n),i=o(t,f)<=u&&o(f,r)<=u;return 0==a?i:!i},r.random=a,r.randomIn=function(n,t){return null==t&&(t=n,n=0),n+Math.floor(Math.random()*(t-n+1))},r.atan2=function(n,t){return Math.atan2(t[1]-n[1],t[0]-n[0])},r.rnorm=function(n,t){let r,e;for(;r=a(),e=a(),e=(2*e-1)*Math.sqrt(1/Math.E*2),!(-4*r*r*Math.log(r)>=e*e););let o=e/r;return o=n+t*o,o},r.clamp=function(n,t,r){return n>r?r:n<t?t:n}},\n",
       "      function _(e,r,n){Object.defineProperty(n,\"__esModule\",{value:!0});class o extends Error{}n.AssertionError=o,o.__name__=\"AssertionError\",n.assert=function(e,r){if(!(!0===e||!1!==e&&e()))throw new o(null!=r?r:\"Assertion failed\")},n.unreachable=function(){throw new Error(\"unreachable code\")}},\n",
       "      function _(n,t,e){function r(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 u=o-e+r.length,i=new n.constructor(u);let f=0;for(;f<t;f++)i[f]=n[f];for(const n of r)i[f++]=n;for(let r=t+e;r<o;r++)i[f++]=n[r];return i}function o(n,t){return r(n,t,n.length-t)}function u(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,u;for(void 0===e?(o=n[0],u=1):(o=e,u=0);u<r;u++)o=t(o,n[u],u,n);return o}function i(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}}Object.defineProperty(e,\"__esModule\",{value:!0}),e.splice=r,e.head=o,e.insert=function(n,t,e){return r(n,e,0,t)},e.append=function(n,t){return r(n,n.length,0,t)},e.prepend=function(n,t){return r(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.map=function(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},e.filter=function(n,t){const e=n.length,r=new n.constructor(e);let u=0;for(let o=0;o<e;o++){const e=n[o];t(e,o,n)&&(r[u++]=e)}return o(r,u)},e.reduce=u,e.min=function(n){let t,e=1/0;for(let r=0,o=n.length;r<o;r++)t=n[r],t<e&&(e=t);return e},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,u=n.length;o<u;o++){const u=n[o],i=t(u);i<r&&(e=u,r=i)}return e},e.max=function(n){let t,e=-1/0;for(let r=0,o=n.length;r<o;r++)t=n[r],t>e&&(e=t);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,u=n.length;o<u;o++){const u=n[o],i=t(u);i>r&&(e=u,r=i)}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 u(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=i(1),e.find_last_index=i(-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=function(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}},\n",
       "      function _(t,e,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=t(1),n=t(14),r=i.__importStar(t(18)),o=t(24),c=i.__importStar(t(19)),a=t(25),_=t(9),l=t(23),h=t(8),p=t(16);class u extends(n.Signalable()){constructor(t={}){super(),this._subtype=void 0,this.document=null,this.destroyed=new n.Signal0(this,\"destroyed\"),this.change=new n.Signal0(this,\"change\"),this.transformchange=new n.Signal0(this,\"transformchange\"),this.attributes={},this.properties={},this._set_after_defaults={},this._pending=!1,this._changing=!1;for(const t in this.props){const{type:e,default_value:s}=this.props[t];if(null==e)throw new Error(`undefined property type for ${this.type}.${t}`);this.properties[t]=new e(this,t,s)}null==t.id&&this.setv({id:a.uniqueId()},{silent:!0});const e=t.__deferred__||!1;e&&delete(t=l.clone(t)).__deferred__,this.setv(t,{silent:!0}),e||this.finalize()}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 init_HasProps(){this.prototype.props={},this.prototype.mixins=[],this.define({id:[c.Any]})}static _fix_default(t,e){return void 0===t?void 0:h.isFunction(t)?t:h.isObject(t)?h.isArray(t)?()=>_.copy(t):()=>l.clone(t):()=>t}static define(t){for(const e in t){const s=t[e];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.getv(e)},set(t){return this.setv({[e]:t}),this},configurable:!1,enumerable:!0});const[i,n,r]=s,o={type:i,default_value:this._fix_default(n,e),internal:r||!1},c=l.clone(this.prototype.props);c[e]=o,this.prototype.props=c}}static internal(t){const e={};for(const s in t){const i=t[s],[n,r]=i;e[s]=[n,r,!0]}this.define(e)}static mixin(...t){this.define(r.create(t));const e=this.prototype.mixins.concat(t);this.prototype.mixins=e}static mixins(t){this.mixin(...t)}static override(t){for(const e in t){const s=this._fix_default(t[e],e),i=this.prototype.props[e];if(null==i)throw new Error(`attempted to override nonexistent '${this.prototype.type}.${e}'`);const n=l.clone(this.prototype.props);n[e]=Object.assign(Object.assign({},i),{default_value:s}),this.prototype.props=n}}toString(){return`${this.type}(${this.id})`}finalize(){for(const t in this.properties){const e=this.properties[t];e.update(),null!=e.spec.transform&&this.connect(e.spec.transform.change,()=>this.transformchange.emit())}this.initialize(),this.connect_signals()}initialize(){}connect_signals(){}disconnect_signals(){n.Signal.disconnectReceiver(this)}destroy(){this.disconnect_signals(),this.destroyed.emit()}clone(){return new this.constructor(this.attributes)}_setv(t,e){const s=e.check_eq,i=e.silent,n=[],r=this._changing;this._changing=!0;const o=this.attributes;for(const e in t){const i=t[e];!1!==s&&p.isEqual(o[e],i)||n.push(e),o[e]=i}if(!i){n.length>0&&(this._pending=!0);for(let t=0;t<n.length;t++)this.properties[n[t]].change.emit()}if(!r){if(!i&&!e.no_change)for(;this._pending;)this._pending=!1,this.change.emit();this._pending=!1,this._changing=!1}}setv(t,e={}){for(const s in t){if(!t.hasOwnProperty(s))continue;const i=s;if(null==this.props[i])throw new Error(`property ${this.type}.${i} wasn't declared`);null!=e&&e.defaults||(this._set_after_defaults[s]=!0)}if(!l.isEmpty(t)){const s={};for(const e in t)s[e]=this.getv(e);this._setv(t,e);const i=e.silent;if(null==i||!i)for(const i in t)this._tell_document_about_change(i,s[i],this.getv(i),e)}}getv(t){if(null==this.props[t])throw new Error(`property ${this.type}.${t} wasn't declared`);return this.attributes[t]}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}attribute_is_serializable(t){const e=this.props[t];if(null==e)throw new Error(`${this.type}.attribute_is_serializable('${t}'): ${t} wasn't declared`);return!e.internal}serializable_attributes(){const t={};for(const e in this.attributes){const s=this.attributes[e];this.attribute_is_serializable(e)&&(t[e]=s)}return t}static _value_to_json(t,e,s){if(e instanceof u)return e.ref();if(h.isArray(e)){const t=[];for(let s=0;s<e.length;s++){const i=e[s];t.push(u._value_to_json(s.toString(),i,e))}return t}if(h.isPlainObject(e)){const t={};for(const s in e)e.hasOwnProperty(s)&&(t[s]=u._value_to_json(s,e[s],e));return t}return e}attributes_as_json(t=!0,e=u._value_to_json){const s=this.serializable_attributes(),i={};for(const e in s)if(s.hasOwnProperty(e)){const n=s[e];(t||e in this._set_after_defaults)&&(i[e]=n)}return e(\"attributes\",i,this)}static _json_record_references(t,e,s,i){if(null==e);else if(o.is_ref(e)){if(!(e.id in s)){const n=t.get_model_by_id(e.id);u._value_record_references(n,s,i)}}else if(h.isArray(e))for(const n of e)u._json_record_references(t,n,s,i);else if(h.isPlainObject(e))for(const n in e)if(e.hasOwnProperty(n)){const r=e[n];u._json_record_references(t,r,s,i)}}static _value_record_references(t,e,s){if(null==t);else if(t instanceof u){if(!(t.id in e)&&(e[t.id]=t,s)){const s=t._immediate_references();for(const t of s)u._value_record_references(t,e,!0)}}else if(t.buffer instanceof ArrayBuffer);else if(h.isArray(t))for(const i of t)u._value_record_references(i,e,s);else if(h.isPlainObject(t))for(const i in t)if(t.hasOwnProperty(i)){const n=t[i];u._value_record_references(n,e,s)}}_immediate_references(){const t={},e=this.serializable_attributes();for(const s in e){const i=e[s];u._value_record_references(i,t,!1)}return l.values(t)}references(){const t={};return u._value_record_references(this,t,!0),l.values(t)}_doc_attached(){}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.document=null}_tell_document_about_change(t,e,s,i){if(this.attribute_is_serializable(t)&&null!=this.document){const n={};u._value_record_references(s,n,!1);const r={};u._value_record_references(e,r,!1);let o=!1;for(const t in n)if(!(t in r)){o=!0;break}if(!o)for(const t in r)if(!(t in n)){o=!0;break}o&&this.document._invalidate_all_models(),this.document._notify_change(this,t,e,s,i)}}materialize_dataspecs(t){const e={};for(const s in this.properties){const i=this.properties[s];if(!(i instanceof c.VectorSpec))continue;if(i.optional&&null==i.spec.value&&!(s in this._set_after_defaults))continue;const n=i.array(t);e[`_${s}`]=n,null!=i.spec.field&&i.spec.field in t._shapes&&(e[`_${s}_shape`]=t._shapes[i.spec.field]),i instanceof c.DistanceSpec&&(e[`max_${s}`]=_.max(n))}return e}}s.HasProps=u,u.init_HasProps()},\n",
       "      function _(n,t,e){Object.defineProperty(e,\"__esModule\",{value:!0});const s=n(15),l=n(17),i=n(9);class o{constructor(n,t){this.sender=n,this.name=t}connect(n,t=null){r.has(this.sender)||r.set(this.sender,[]);const e=r.get(this.sender);if(null!=g(e,this,n,t))return!1;const s=t||n;u.has(s)||u.set(s,[]);const l=u.get(s),i={signal:this,slot:n,context:t};return e.push(i),l.push(i),!0}disconnect(n,t=null){const e=r.get(this.sender);if(null==e||0===e.length)return!1;const s=g(e,this,n,t);if(null==s)return!1;const l=t||n,i=u.get(l);return s.signal=null,f(e),f(i),!0}emit(n){const t=r.get(this.sender)||[];for(const{signal:e,slot:s,context:l}of t)e===this&&s.call(l,n,this.sender)}}e.Signal=o,o.__name__=\"Signal\";class c extends o{emit(){super.emit(void 0)}}e.Signal0=c,c.__name__=\"Signal0\",function(n){n.disconnectBetween=function(n,t){const e=r.get(n);if(null==e||0===e.length)return;const s=u.get(t);if(null!=s&&0!==s.length){for(const t of s){if(null==t.signal)return;t.signal.sender===n&&(t.signal=null)}f(e),f(s)}},n.disconnectSender=function(n){const t=r.get(n);if(null!=t&&0!==t.length){for(const n of t){if(null==n.signal)return;const t=n.context||n.slot;n.signal=null,f(u.get(t))}f(t)}},n.disconnectReceiver=function(n){const t=u.get(n);if(null!=t&&0!==t.length){for(const n of t){if(null==n.signal)return;const t=n.signal.sender;n.signal=null,f(r.get(t))}f(t)}},n.disconnectAll=function(n){const t=r.get(n);if(null!=t&&0!==t.length){for(const n of t)n.signal=null;f(t)}const e=u.get(n);if(null!=e&&0!==e.length){for(const n of e)n.signal=null;f(e)}}}(o||(e.Signal=o={})),e.Signalable=function(){return class{connect(n,t){return n.connect(t,this)}disconnect(n,t){return n.disconnect(t,this)}}};const r=new WeakMap,u=new WeakMap;function g(n,t,e,s){return i.find(n,n=>n.signal===t&&n.slot===e&&n.context===s)}const a=new s.Set;function f(n){0===a.size&&l.defer(h),a.add(n)}function h(){a.forEach(n=>{i.remove_by(n,n=>null==n.signal)}),a.clear()}},\n",
       "      function _(t,s,e){Object.defineProperty(e,\"__esModule\",{value:!0});const i=t(9),n=t(16),r=t(8);class o{constructor(){this._dict={}}_existing(t){return t in this._dict?this._dict[t]:null}add_value(t,s){const e=this._existing(t);null==e?this._dict[t]=s:r.isArray(e)?e.push(s):this._dict[t]=[e,s]}remove_value(t,s){const e=this._existing(t);if(r.isArray(e)){const n=i.difference(e,[s]);n.length>0?this._dict[t]=n:delete this._dict[t]}else n.isEqual(e,s)&&delete this._dict[t]}get_one(t,s){const e=this._existing(t);if(r.isArray(e)){if(1===e.length)return e[0];throw new Error(s)}return e}}e.MultiDict=o,o.__name__=\"MultiDict\";class a{constructor(t){if(null==t)this._values=[];else if(t instanceof a)this._values=i.copy(t._values);else{this._values=[];for(const s of t)this.add(s)}}get values(){return i.copy(this._values).sort()}toString(){return`Set([${this.values.join(\",\")}])`}get size(){return this._values.length}has(t){return-1!==this._values.indexOf(t)}add(t){this.has(t)||this._values.push(t)}remove(t){const s=this._values.indexOf(t);-1!==s&&this._values.splice(s,1)}toggle(t){const s=this._values.indexOf(t);-1===s?this._values.push(t):this._values.splice(s,1)}clear(){this._values=[]}union(t){return t=new a(t),new a(this._values.concat(t._values))}intersect(t){t=new a(t);const s=new a;for(const e of t._values)this.has(e)&&t.has(e)&&s.add(e);return s}diff(t){t=new a(t);const s=new a;for(const e of this._values)t.has(e)||s.add(e);return s}forEach(t,s){for(const e of this._values)t.call(s||this,e,e,this)}}e.Set=a,a.__name__=\"Set\";class h{constructor(t,s,e){this.nrows=t,this.ncols=s,this._matrix=new Array(t);for(let i=0;i<t;i++){this._matrix[i]=new Array(s);for(let t=0;t<s;t++)this._matrix[i][t]=e(i,t)}}at(t,s){return this._matrix[t][s]}map(t){return new h(this.nrows,this.ncols,(s,e)=>t(this.at(s,e),s,e))}apply(t){const s=h.from(t),{nrows:e,ncols:i}=this;if(e==s.nrows&&i==s.ncols)return new h(e,i,(t,e)=>s.at(t,e)(this.at(t,e),t,e));throw new Error(\"dimensions don't match\")}to_sparse(){const t=[];for(let s=0;s<this.nrows;s++)for(let e=0;e<this.ncols;e++){const i=this._matrix[s][e];t.push([i,s,e])}return t}static from(t){if(t instanceof h)return t;{const s=t.length,e=i.min(t.map(t=>t.length));return new h(s,e,(s,e)=>t[s][e])}}}e.Matrix=h,h.__name__=\"Matrix\"},\n",
       "      function _(t,e,n){Object.defineProperty(n,\"__esModule\",{value:!0});\n",
       "      //     (c) 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n",
       "      //     Underscore may be freely distributed under the MIT license.\n",
       "      const r=t(8),o=Object.prototype.toString;n.isEqual=function(t,e){return function t(e,n,c,u){if(e===n)return 0!==e||1/e==1/n;if(null==e||null==n)return e===n;const i=o.call(e);if(i!==o.call(n))return!1;switch(i){case\"[object RegExp]\":case\"[object String]\":return\"\"+e==\"\"+n;case\"[object Number]\":return+e!=+e?+n!=+n:0==+e?1/+e==1/n:+e==+n;case\"[object Date]\":case\"[object Boolean]\":return+e==+n}const s=\"[object Array]\"===i;if(!s){if(\"object\"!=typeof e||\"object\"!=typeof n)return!1;const t=e.constructor,o=n.constructor;if(t!==o&&!(r.isFunction(t)&&t instanceof t&&r.isFunction(o)&&o instanceof o)&&\"constructor\"in e&&\"constructor\"in n)return!1}u=u||[];let f=(c=c||[]).length;for(;f--;)if(c[f]===e)return u[f]===n;if(c.push(e),u.push(n),s){if(f=e.length,f!==n.length)return!1;for(;f--;)if(!t(e[f],n[f],c,u))return!1}else{const r=Object.keys(e);let o;if(f=r.length,Object.keys(n).length!==f)return!1;for(;f--;)if(o=r[f],!n.hasOwnProperty(o)||!t(e[o],n[o],c,u))return!1}return c.pop(),u.pop(),!0}(t,e)}},\n",
       "      function _(n,e,t){Object.defineProperty(t,\"__esModule\",{value:!0}),t.delay=\n",
       "      //     (c) 2009-2015 Jeremy Ashkenas, DocumentCloud and Investigative Reporters & Editors\n",
       "      //     Underscore may be freely distributed under the MIT license.\n",
       "      function(n,e){return setTimeout(n,e)};const u=\"function\"==typeof requestAnimationFrame?requestAnimationFrame:setImmediate;t.defer=function(n){return new Promise(e=>{u(()=>e(n()))})},t.throttle=function(n,e,t={}){let u,o,i,r=null,l=0;const c=function(){l=!1===t.leading?0:Date.now(),r=null,i=n.apply(u,o),r||(u=o=null)};return function(){const a=Date.now();l||!1!==t.leading||(l=a);const f=e-(a-l);return u=this,o=arguments,f<=0||f>e?(r&&(clearTimeout(r),r=null),l=a,i=n.apply(u,o),r||(u=o=null)):r||!1===t.trailing||(r=setTimeout(c,f)),i}},t.once=function(n){let e,t=!1;return function(){return t||(t=!0,e=n()),e}}},\n",
       "      function _(e,t,n){Object.defineProperty(n,\"__esModule\",{value:!0});const l=e(1).__importStar(e(19)),c=e(23);function o(e,t){const n={};for(const l in e){const c=e[l];n[t+l]=c}return n}const a={line_color:[l.ColorSpec,\"black\"],line_width:[l.NumberSpec,1],line_alpha:[l.NumberSpec,1],line_join:[l.LineJoin,\"bevel\"],line_cap:[l.LineCap,\"butt\"],line_dash:[l.Array,[]],line_dash_offset:[l.Number,0]};n.line=(e=\"\")=>o(a,e);const r={fill_color:[l.ColorSpec,\"gray\"],fill_alpha:[l.NumberSpec,1]};n.fill=(e=\"\")=>o(r,e);const i={hatch_color:[l.ColorSpec,\"black\"],hatch_alpha:[l.NumberSpec,1],hatch_scale:[l.NumberSpec,12],hatch_pattern:[l.StringSpec,null],hatch_weight:[l.NumberSpec,1],hatch_extra:[l.Any,{}]};n.hatch=(e=\"\")=>o(i,e);const _={text_font:[l.Font,\"helvetica\"],text_font_size:[l.FontSizeSpec,\"12pt\"],text_font_style:[l.FontStyle,\"normal\"],text_color:[l.ColorSpec,\"#444444\"],text_alpha:[l.NumberSpec,1],text_align:[l.TextAlign,\"left\"],text_baseline:[l.TextBaseline,\"bottom\"],text_line_height:[l.Number,1.2]};n.text=(e=\"\")=>o(_,e),n.create=function(e){const t={};for(const l of e){const[e,o]=l.split(\":\");let a;switch(e){case\"line\":a=n.line;break;case\"fill\":a=n.fill;break;case\"hatch\":a=n.hatch;break;case\"text\":a=n.text;break;default:throw new Error(`Unknown property mixin kind '${e}'`)}c.extend(t,a(o))}return t}},\n",
       "      function _(e,t,n){Object.defineProperty(n,\"__esModule\",{value:!0});const i=e(1),s=e(14),a=i.__importStar(e(20)),r=e(9),o=e(12),l=e(21),c=e(8);function _(e){try{return JSON.stringify(e)}catch(t){return e.toString()}}function u(e){return c.isPlainObject(e)&&(void 0===e.value?0:1)+(void 0===e.field?0:1)+(void 0===e.expr?0:1)==1}s.Signal,n.isSpec=u;class d extends(s.Signalable()){constructor(e,t,n){super(),this.obj=e,this.attr=t,this.default_value=n,this.optional=!1,this.change=new s.Signal0(this.obj,\"change\"),this._init(),this.connect(this.change,()=>this._init())}update(){this._init()}init(){}transform(e){return e}validate(e){if(!this.valid(e))throw new Error(`${this.obj.type}.${this.attr} given invalid value: ${_(e)}`)}valid(e){return!0}value(e=!0){if(void 0===this.spec.value)throw new Error(\"attempted to retrieve property value for property without value specification\");let t=this.transform([this.spec.value])[0];return null!=this.spec.transform&&e&&(t=this.spec.transform.compute(t)),t}_init(){const e=this.obj,t=this.attr;let n=e.getv(t);if(void 0===n){const i=this.default_value;n=void 0!==i?i(e):null,e.setv({[t]:n},{silent:!0,defaults:!0})}c.isArray(n)?this.spec={value:n}:u(n)?this.spec=n:this.spec={value:n},null!=this.spec.value&&this.validate(this.spec.value),this.init()}toString(){return`Prop(${this.obj}.${this.attr}, spec: ${_(this.spec)})`}}n.Property=d,d.__name__=\"Property\";class p extends d{}n.Any=p,p.__name__=\"Any\";class h extends d{valid(e){return c.isArray(e)||e instanceof Float64Array}}n.Array=h,h.__name__=\"Array\";class m extends d{valid(e){return c.isBoolean(e)}}n.Boolean=m,m.__name__=\"Boolean\";class S extends d{valid(e){return c.isString(e)&&l.is_color(e)}}n.Color=S,S.__name__=\"Color\";class g extends d{}n.Instance=g,g.__name__=\"Instance\";class v extends d{valid(e){return c.isNumber(e)}}n.Number=v,v.__name__=\"Number\";class x extends v{valid(e){return c.isNumber(e)&&(0|e)==e}}n.Int=x,x.__name__=\"Int\";class f extends v{}n.Angle=f,f.__name__=\"Angle\";class y extends v{valid(e){return c.isNumber(e)&&0<=e&&e<=1}}n.Percent=y,y.__name__=\"Percent\";class P extends d{valid(e){return c.isString(e)}}n.String=P,P.__name__=\"String\";class L extends P{}n.FontSize=L,L.__name__=\"FontSize\";class T extends P{}n.Font=T,T.__name__=\"Font\";class A extends d{valid(e){return c.isString(e)&&r.includes(this.enum_values,e)}}function b(e){return class extends A{get enum_values(){return e}}}n.EnumProperty=A,A.__name__=\"EnumProperty\",n.Enum=b;class M extends A{get enum_values(){return a.Direction}transform(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=M,M.__name__=\"Direction\",n.Anchor=b(a.Anchor),n.AngleUnits=b(a.AngleUnits),n.BoxOrigin=b(a.BoxOrigin),n.ButtonType=b(a.ButtonType),n.CalendarPosition=b(a.CalendarPosition),n.Dimension=b(a.Dimension),n.Dimensions=b(a.Dimensions),n.Distribution=b(a.Distribution),n.FontStyle=b(a.FontStyle),n.HatchPatternType=b(a.HatchPatternType),n.HTTPMethod=b(a.HTTPMethod),n.HexTileOrientation=b(a.HexTileOrientation),n.HoverMode=b(a.HoverMode),n.LatLon=b(a.LatLon),n.LegendClickPolicy=b(a.LegendClickPolicy),n.LegendLocation=b(a.LegendLocation),n.LineCap=b(a.LineCap),n.LineJoin=b(a.LineJoin),n.LinePolicy=b(a.LinePolicy),n.Location=b(a.Location),n.Logo=b(a.Logo),n.MarkerType=b(a.MarkerType),n.Orientation=b(a.Orientation),n.OutputBackend=b(a.OutputBackend),n.PaddingUnits=b(a.PaddingUnits),n.Place=b(a.Place),n.PointPolicy=b(a.PointPolicy),n.RadiusDimension=b(a.RadiusDimension),n.RenderLevel=b(a.RenderLevel),n.RenderMode=b(a.RenderMode),n.ResetPolicy=b(a.ResetPolicy),n.RoundingFunction=b(a.RoundingFunction),n.Side=b(a.Side),n.SizingMode=b(a.SizingMode),n.Sort=b(a.Sort),n.SpatialUnits=b(a.SpatialUnits),n.StartEnd=b(a.StartEnd),n.StepMode=b(a.StepMode),n.TapBehavior=b(a.TapBehavior),n.TextAlign=b(a.TextAlign),n.TextBaseline=b(a.TextBaseline),n.TextureRepetition=b(a.TextureRepetition),n.TickLabelOrientation=b(a.TickLabelOrientation),n.TooltipAttachment=b(a.TooltipAttachment),n.UpdateMode=b(a.UpdateMode),n.VerticalAlign=b(a.VerticalAlign);class B extends d{}n.ScalarSpec=B,B.__name__=\"ScalarSpec\";class D extends d{array(e){let t;if(null!=this.spec.field){if(t=this.transform(e.get_column(this.spec.field)),null==t)throw new Error(`attempted to retrieve property array for nonexistent field '${this.spec.field}'`)}else if(null!=this.spec.expr)t=this.transform(this.spec.expr.v_compute(e));else{let n=e.get_length();null==n&&(n=1);const i=this.value(!1);t=r.repeat(i,n)}return null!=this.spec.transform&&(t=this.spec.transform.v_compute(t)),t}}n.VectorSpec=D,D.__name__=\"VectorSpec\";class C extends D{}n.DataSpec=C,C.__name__=\"DataSpec\";class k extends D{init(){null==this.spec.units&&(this.spec.units=this.default_units);const e=this.spec.units;if(!r.includes(this.valid_units,e))throw new Error(`units must be one of ${this.valid_units.join(\", \")}; got: ${e}`)}get units(){return this.spec.units}set units(e){this.spec.units=e}}n.UnitsSpec=k,k.__name__=\"UnitsSpec\";class O extends k{get default_units(){return\"rad\"}get valid_units(){return a.AngleUnits}transform(e){return\"deg\"==this.spec.units&&(e=o.map(e,e=>e*Math.PI/180)),e=o.map(e,e=>-e),super.transform(e)}}n.AngleSpec=O,O.__name__=\"AngleSpec\";class U extends C{}n.BooleanSpec=U,U.__name__=\"BooleanSpec\";class w extends C{}n.ColorSpec=w,w.__name__=\"ColorSpec\";class R extends C{}n.CoordinateSpec=R,R.__name__=\"CoordinateSpec\";class F extends C{}n.CoordinateSeqSpec=F,F.__name__=\"CoordinateSeqSpec\";class N extends k{get default_units(){return\"data\"}get valid_units(){return a.SpatialUnits}}n.DistanceSpec=N,N.__name__=\"DistanceSpec\";class E extends C{}n.FontSizeSpec=E,E.__name__=\"FontSizeSpec\";class $ extends C{}n.MarkerSpec=$,$.__name__=\"MarkerSpec\";class j extends C{}n.NumberSpec=j,j.__name__=\"NumberSpec\";class H extends C{}n.StringSpec=H,H.__name__=\"StringSpec\";class z extends C{}n.NullStringSpec=z,z.__name__=\"NullStringSpec\"},\n",
       "      function _(e,t,n){Object.defineProperty(n,\"__esModule\",{value:!0}),n.Align=[\"start\",\"center\",\"end\"],n.Anchor=[\"top_left\",\"top_center\",\"top_right\",\"center_left\",\"center\",\"center_right\",\"bottom_left\",\"bottom_center\",\"bottom_right\"],n.AngleUnits=[\"deg\",\"rad\"],n.BoxOrigin=[\"corner\",\"center\"],n.ButtonType=[\"default\",\"primary\",\"success\",\"warning\",\"danger\"],n.CalendarPosition=[\"auto\",\"above\",\"below\"],n.Dimension=[\"width\",\"height\"],n.Dimensions=[\"width\",\"height\",\"both\"],n.Direction=[\"clock\",\"anticlock\"],n.Distribution=[\"uniform\",\"normal\"],n.FontStyle=[\"normal\",\"italic\",\"bold\",\"bold italic\"],n.HatchPatternType=[\"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\",\">\",\"*\"],n.HTTPMethod=[\"POST\",\"GET\"],n.HexTileOrientation=[\"pointytop\",\"flattop\"],n.HoverMode=[\"mouse\",\"hline\",\"vline\"],n.LatLon=[\"lat\",\"lon\"],n.LegendClickPolicy=[\"none\",\"hide\",\"mute\"],n.LegendLocation=n.Anchor,n.LineCap=[\"butt\",\"round\",\"square\"],n.LineJoin=[\"miter\",\"round\",\"bevel\"],n.LinePolicy=[\"prev\",\"next\",\"nearest\",\"interp\",\"none\"],n.Location=[\"above\",\"below\",\"left\",\"right\"],n.Logo=[\"normal\",\"grey\"],n.MarkerType=[\"asterisk\",\"circle\",\"circle_cross\",\"circle_x\",\"cross\",\"dash\",\"diamond\",\"diamond_cross\",\"hex\",\"inverted_triangle\",\"square\",\"square_cross\",\"square_x\",\"triangle\",\"x\"],n.Orientation=[\"vertical\",\"horizontal\"],n.OutputBackend=[\"canvas\",\"svg\",\"webgl\"],n.PaddingUnits=[\"percent\",\"absolute\"],n.Place=[\"above\",\"below\",\"left\",\"right\",\"center\"],n.PointPolicy=[\"snap_to_data\",\"follow_mouse\",\"none\"],n.RadiusDimension=[\"x\",\"y\",\"max\",\"min\"],n.RenderLevel=[\"image\",\"underlay\",\"glyph\",\"annotation\",\"overlay\"],n.RenderMode=[\"canvas\",\"css\"],n.ResetPolicy=[\"standard\",\"event_only\"],n.RoundingFunction=[\"round\",\"nearest\",\"floor\",\"rounddown\",\"ceil\",\"roundup\"],n.Side=[\"above\",\"below\",\"left\",\"right\"],n.SizingMode=[\"stretch_width\",\"stretch_height\",\"stretch_both\",\"scale_width\",\"scale_height\",\"scale_both\",\"fixed\"],n.Sort=[\"ascending\",\"descending\"],n.SpatialUnits=[\"screen\",\"data\"],n.StartEnd=[\"start\",\"end\"],n.StepMode=[\"after\",\"before\",\"center\"],n.TapBehavior=[\"select\",\"inspect\"],n.TextAlign=[\"left\",\"right\",\"center\"],n.TextBaseline=[\"top\",\"middle\",\"bottom\",\"alphabetic\",\"hanging\",\"ideographic\"],n.TextureRepetition=[\"repeat\",\"repeat_x\",\"repeat_y\",\"no_repeat\"],n.TickLabelOrientation=[\"vertical\",\"horizontal\",\"parallel\",\"normal\"],n.TooltipAttachment=[\"horizontal\",\"vertical\",\"left\",\"right\",\"above\",\"below\"],n.UpdateMode=[\"replace\",\"append\"],n.VerticalAlign=[\"top\",\"middle\",\"bottom\"]},\n",
       "      function _(e,r,t){Object.defineProperty(t,\"__esModule\",{value:!0});const n=e(22),o=e(9);function l(e){const r=Number(e).toString(16);return 1==r.length?`0${r}`:r}function a(e){if(0==(e+=\"\").indexOf(\"#\"))return e;if(n.is_svg_color(e))return n.svg_colors[e];if(0==e.indexOf(\"rgb\")){const r=e.replace(/^rgba?\\(|\\s+|\\)$/g,\"\").split(\",\");let t=r.slice(0,3).map(l).join(\"\");return 4==r.length&&(t+=l(Math.floor(255*parseFloat(r[3])))),`#${t.slice(0,8)}`}return e}function c(e){let r;switch(e.substring(0,4)){case\"rgba\":r={start:\"rgba(\",len:4,alpha:!0};break;case\"rgb(\":r={start:\"rgb(\",len:3,alpha:!1};break;default:return!1}if(new RegExp(\".*?(\\\\.).*(,)\").test(e))throw new Error(`color expects integers for rgb in rgb/rgba tuple, received ${e}`);const t=e.replace(r.start,\"\").replace(\")\",\"\").split(\",\").map(parseFloat);if(t.length!=r.len)throw new Error(`color expects rgba ${r.len}-tuple, received ${e}`);if(r.alpha&&!(0<=t[3]&&t[3]<=1))throw new Error(\"color expects rgba 4-tuple to have alpha value between 0 and 1\");if(o.includes(t.slice(0,3).map(e=>0<=e&&e<=255),!1))throw new Error(\"color expects rgb to have value between 0 and 255\");return!0}t.is_color=function(e){return n.is_svg_color(e.toLowerCase())||\"#\"==e.substring(0,1)||c(e)},t.rgb2hex=function(e,r,t){return`#${l(255&e)}${l(255&r)}${l(255&t)}`},t.color2hex=a,t.color2rgba=function(e,r=1){if(!e)return[0,0,0,0];let t=a(e);t=t.replace(/ |#/g,\"\"),t.length<=4&&(t=t.replace(/(.)/g,\"$1$1\"));const n=t.match(/../g).map(e=>parseInt(e,16)/255);for(;n.length<3;)n.push(0);return n.length<4&&n.push(r),n.slice(0,4)},t.valid_rgb=c},\n",
       "      function _(e,F,r){Object.defineProperty(r,\"__esModule\",{value:!0}),r.svg_colors={indianred:\"#CD5C5C\",lightcoral:\"#F08080\",salmon:\"#FA8072\",darksalmon:\"#E9967A\",lightsalmon:\"#FFA07A\",crimson:\"#DC143C\",red:\"#FF0000\",firebrick:\"#B22222\",darkred:\"#8B0000\",pink:\"#FFC0CB\",lightpink:\"#FFB6C1\",hotpink:\"#FF69B4\",deeppink:\"#FF1493\",mediumvioletred:\"#C71585\",palevioletred:\"#DB7093\",coral:\"#FF7F50\",tomato:\"#FF6347\",orangered:\"#FF4500\",darkorange:\"#FF8C00\",orange:\"#FFA500\",gold:\"#FFD700\",yellow:\"#FFFF00\",lightyellow:\"#FFFFE0\",lemonchiffon:\"#FFFACD\",lightgoldenrodyellow:\"#FAFAD2\",papayawhip:\"#FFEFD5\",moccasin:\"#FFE4B5\",peachpuff:\"#FFDAB9\",palegoldenrod:\"#EEE8AA\",khaki:\"#F0E68C\",darkkhaki:\"#BDB76B\",lavender:\"#E6E6FA\",thistle:\"#D8BFD8\",plum:\"#DDA0DD\",violet:\"#EE82EE\",orchid:\"#DA70D6\",fuchsia:\"#FF00FF\",magenta:\"#FF00FF\",mediumorchid:\"#BA55D3\",mediumpurple:\"#9370DB\",blueviolet:\"#8A2BE2\",darkviolet:\"#9400D3\",darkorchid:\"#9932CC\",darkmagenta:\"#8B008B\",purple:\"#800080\",indigo:\"#4B0082\",slateblue:\"#6A5ACD\",darkslateblue:\"#483D8B\",mediumslateblue:\"#7B68EE\",greenyellow:\"#ADFF2F\",chartreuse:\"#7FFF00\",lawngreen:\"#7CFC00\",lime:\"#00FF00\",limegreen:\"#32CD32\",palegreen:\"#98FB98\",lightgreen:\"#90EE90\",mediumspringgreen:\"#00FA9A\",springgreen:\"#00FF7F\",mediumseagreen:\"#3CB371\",seagreen:\"#2E8B57\",forestgreen:\"#228B22\",green:\"#008000\",darkgreen:\"#006400\",yellowgreen:\"#9ACD32\",olivedrab:\"#6B8E23\",olive:\"#808000\",darkolivegreen:\"#556B2F\",mediumaquamarine:\"#66CDAA\",darkseagreen:\"#8FBC8F\",lightseagreen:\"#20B2AA\",darkcyan:\"#008B8B\",teal:\"#008080\",aqua:\"#00FFFF\",cyan:\"#00FFFF\",lightcyan:\"#E0FFFF\",paleturquoise:\"#AFEEEE\",aquamarine:\"#7FFFD4\",turquoise:\"#40E0D0\",mediumturquoise:\"#48D1CC\",darkturquoise:\"#00CED1\",cadetblue:\"#5F9EA0\",steelblue:\"#4682B4\",lightsteelblue:\"#B0C4DE\",powderblue:\"#B0E0E6\",lightblue:\"#ADD8E6\",skyblue:\"#87CEEB\",lightskyblue:\"#87CEFA\",deepskyblue:\"#00BFFF\",dodgerblue:\"#1E90FF\",cornflowerblue:\"#6495ED\",royalblue:\"#4169E1\",blue:\"#0000FF\",mediumblue:\"#0000CD\",darkblue:\"#00008B\",navy:\"#000080\",midnightblue:\"#191970\",cornsilk:\"#FFF8DC\",blanchedalmond:\"#FFEBCD\",bisque:\"#FFE4C4\",navajowhite:\"#FFDEAD\",wheat:\"#F5DEB3\",burlywood:\"#DEB887\",tan:\"#D2B48C\",rosybrown:\"#BC8F8F\",sandybrown:\"#F4A460\",goldenrod:\"#DAA520\",darkgoldenrod:\"#B8860B\",peru:\"#CD853F\",chocolate:\"#D2691E\",saddlebrown:\"#8B4513\",sienna:\"#A0522D\",brown:\"#A52A2A\",maroon:\"#800000\",white:\"#FFFFFF\",snow:\"#FFFAFA\",honeydew:\"#F0FFF0\",mintcream:\"#F5FFFA\",azure:\"#F0FFFF\",aliceblue:\"#F0F8FF\",ghostwhite:\"#F8F8FF\",whitesmoke:\"#F5F5F5\",seashell:\"#FFF5EE\",beige:\"#F5F5DC\",oldlace:\"#FDF5E6\",floralwhite:\"#FFFAF0\",ivory:\"#FFFFF0\",antiquewhite:\"#FAEBD7\",linen:\"#FAF0E6\",lavenderblush:\"#FFF0F5\",mistyrose:\"#FFE4E1\",gainsboro:\"#DCDCDC\",lightgray:\"#D3D3D3\",lightgrey:\"#D3D3D3\",silver:\"#C0C0C0\",darkgray:\"#A9A9A9\",darkgrey:\"#A9A9A9\",gray:\"#808080\",grey:\"#808080\",dimgray:\"#696969\",dimgrey:\"#696969\",lightslategray:\"#778899\",lightslategrey:\"#778899\",slategray:\"#708090\",slategrey:\"#708090\",darkslategray:\"#2F4F4F\",darkslategrey:\"#2F4F4F\",black:\"#000000\"},r.is_svg_color=function(e){return e in r.svg_colors}},\n",
       "      function _(e,t,n){Object.defineProperty(n,\"__esModule\",{value:!0});const c=e(9);function o(e){return Object.keys(e).length}n.keys=Object.keys,n.extend=Object.assign,n.values=void 0!==Object.values?Object.values:e=>{const t=Object.keys(e),n=t.length,c=new Array(n);for(let o=0;o<n;o++)c[o]=e[t[o]];return c},n.clone=function(e){return Object.assign({},e)},n.merge=function(e,t){const n=Object.create(Object.prototype),o=c.concat([Object.keys(e),Object.keys(t)]);for(const r of o){const o=e.hasOwnProperty(r)?e[r]:[],s=t.hasOwnProperty(r)?t[r]:[];n[r]=c.union(o,s)}return n},n.size=o,n.isEmpty=function(e){return 0===o(e)}},\n",
       "      function _(e,n,t){Object.defineProperty(t,\"__esModule\",{value:!0});const i=e(8),r=e(23);t.is_ref=function(e){if(i.isPlainObject(e)){const n=r.keys(e);return 1==n.length&&\"id\"==n[0]}return!1}},\n",
       "      function _(t,e,r){Object.defineProperty(r,\"__esModule\",{value:!0});const n=t(26);function u(){const t=new Array(32);for(let e=0;e<32;e++)t[e]=\"0123456789ABCDEF\".substr(Math.floor(16*Math.random()),1);return t[12]=\"4\",t[16]=\"0123456789ABCDEF\".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=u;let s=1e3;r.uniqueId=function(t){const e=n.settings.dev?`j${s++}`:u();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}`}},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});class n{constructor(){this._dev=!1}set dev(e){this._dev=e}get dev(){return this._dev}}s.Settings=n,n.__name__=\"Settings\",s.settings=new n},\n",
       "      function _(t,_,r){Object.defineProperty(r,\"__esModule\",{value:!0});const e=t(1);e.__exportStar(t(28),r),e.__exportStar(t(147),r),e.__exportStar(t(174),r),e.__exportStar(t(178),r),e.__exportStar(t(193),r),e.__exportStar(t(197),r),e.__exportStar(t(203),r),e.__exportStar(t(207),r),e.__exportStar(t(237),r),e.__exportStar(t(240),r),e.__exportStar(t(242),r),e.__exportStar(t(255),r),e.__exportStar(t(122),r),e.__exportStar(t(261),r),e.__exportStar(t(265),r),e.__exportStar(t(288),r),e.__exportStar(t(289),r),e.__exportStar(t(290),r),e.__exportStar(t(291),r),e.__exportStar(t(292),r),e.__exportStar(t(297),r),e.__exportStar(t(299),r),e.__exportStar(t(309),r),e.__exportStar(t(313),r)},\n",
       "      function _(a,e,o){Object.defineProperty(o,\"__esModule\",{value:!0});var r=a(29);o.Annotation=r.Annotation;var n=a(71);o.Arrow=n.Arrow;var t=a(72);o.ArrowHead=t.ArrowHead;var v=a(72);o.OpenHead=v.OpenHead;var l=a(72);o.NormalHead=l.NormalHead;var d=a(72);o.TeeHead=d.TeeHead;var i=a(72);o.VeeHead=i.VeeHead;var A=a(104);o.Band=A.Band;var H=a(105);o.BoxAnnotation=H.BoxAnnotation;var T=a(107);o.ColorBar=T.ColorBar;var p=a(132);o.Label=p.Label;var L=a(134);o.LabelSet=L.LabelSet;var b=a(135);o.Legend=b.Legend;var B=a(136);o.LegendItem=B.LegendItem;var S=a(138);o.PolyAnnotation=S.PolyAnnotation;var P=a(139);o.Slope=P.Slope;var g=a(140);o.Span=g.Span;var m=a(133);o.TextAnnotation=m.TextAnnotation;var w=a(141);o.Title=w.Title;var x=a(142);o.ToolbarPanel=x.ToolbarPanel;var s=a(143);o.Tooltip=s.Tooltip;var u=a(146);o.Whisker=u.Whisker},\n",
       "      function _(t,e,n){Object.defineProperty(n,\"__esModule\",{value:!0});const i=t(1).__importStar(t(30)),s=t(23),o=t(63);class _ extends o.RendererView{get panel(){return this.layout}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}}connect_signals(){super.connect_signals();const t=this.model.properties;this.on_change(t.visible,()=>this.plot_view.request_layout())}_get_size(){throw new Error(\"not implemented\")}get ctx(){return this.plot_view.canvas_view.ctx}set_data(t){const e=this.model.materialize_dataspecs(t);if(s.extend(this,e),this.plot_model.use_map){const t=this;null!=t._x&&([t._x,t._y]=i.project_xy(t._x,t._y)),null!=t._xs&&([t._xs,t._ys]=i.project_xsys(t._xs,t._ys))}}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})}}n.AnnotationView=_,_.__name__=\"AnnotationView\";class a extends o.Renderer{constructor(t){super(t)}static init_Annotation(){this.override({level:\"annotation\"})}}n.Annotation=a,a.__name__=\"Annotation\",a.init_Annotation()},\n",
       "      function _(t,n,e){Object.defineProperty(e,\"__esModule\",{value:!0});const r=t(1),o=r.__importDefault(t(31)),a=r.__importDefault(t(32)),c=new a.default(\"GOOGLE\"),l=new a.default(\"WGS84\");e.wgs84_mercator=o.default(l,c);const u={lon:[-20026376.39,20026376.39],lat:[-20048966.1,20048966.1]},f={lon:[-180,180],lat:[-85.06,85.06]};function s(t,n){const r=Math.min(t.length,n.length),o=new Array(r),a=new Array(r);for(let c=0;c<r;c++){const[r,l]=e.wgs84_mercator.forward([t[c],n[c]]);o[c]=r,a[c]=l}return[o,a]}e.clip_mercator=function(t,n,e){const[r,o]=u[e];return[Math.max(t,r),Math.min(n,o)]},e.in_bounds=function(t,n){const[e,r]=f[n];return e<t&&t<r},e.project_xy=s,e.project_xsys=function(t,n){const e=Math.min(t.length,n.length),r=new Array(e),o=new Array(e);for(let a=0;a<e;a++){const[e,c]=s(t[a],n[a]);r[a]=e,o[a]=c}return[r,o]}},\n",
       "      function _(e,n,t){Object.defineProperty(t,\"__esModule\",{value:!0});const r=e(1),o=r.__importDefault(e(32)),a=r.__importDefault(e(57));var i=o.default(\"WGS84\");function c(e,n,t){var r,o,i;return Array.isArray(t)?(r=a.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=a.default(e,n,t),2===(i=Object.keys(t)).length||i.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 u(e){return e instanceof o.default?e:e.oProj?e.oProj:o.default(e)}t.default=function(e,n,t){e=u(e);var r,o=!1;return void 0===n?(n=e,e=i,o=!0):(void 0!==n.x||Array.isArray(n))&&(t=n,n=e,e=i,o=!0),n=u(n),t?c(e,n,t):(r={forward:function(t){return c(e,n,t)},inverse:function(t){return c(n,e,t)}},o&&(r.oProj=n),r)}},\n",
       "      function _(e,t,a){Object.defineProperty(a,\"__esModule\",{value:!0});const s=e(1),i=s.__importDefault(e(33)),u=s.__importDefault(e(44)),l=s.__importDefault(e(45)),o=e(53),r=s.__importDefault(e(55)),f=s.__importDefault(e(56)),d=s.__importDefault(e(40));function p(e,t){if(!(this instanceof p))return new p(e);t=t||function(e){if(e)throw e};var a=i.default(e);if(\"object\"==typeof a){var s=p.projections.get(a.projName);if(s){if(a.datumCode&&\"none\"!==a.datumCode){var l=d.default(r.default,a.datumCode);l&&(a.datum_params=l.towgs84?l.towgs84.split(\",\"):null,a.ellps=l.ellipse,a.datumName=l.datumName?l.datumName:a.datumCode)}a.k0=a.k0||1,a.axis=a.axis||\"enu\",a.ellps=a.ellps||\"wgs84\";var m=o.sphere(a.a,a.b,a.rf,a.ellps,a.sphere),n=o.eccentricity(m.a,m.b,m.rf,a.R_A),h=a.datum||f.default(a.datumCode,a.datum_params,m.a,m.b,n.es,n.ep2);u.default(this,a),u.default(this,s),this.a=m.a,this.b=m.b,this.rf=m.rf,this.sphere=m.sphere,this.es=n.es,this.e=n.e,this.ep2=n.ep2,this.datum=h,this.init(),t(null,this)}else t(e)}else t(e)}p.projections=l.default,p.projections.start(),a.default=p},\n",
       "      function _(t,e,r){Object.defineProperty(r,\"__esModule\",{value:!0});const u=t(1),n=u.__importDefault(t(34)),f=u.__importDefault(t(41)),i=u.__importDefault(t(36)),a=u.__importDefault(t(40));var o=[\"PROJECTEDCRS\",\"PROJCRS\",\"GEOGCS\",\"GEOCCS\",\"PROJCS\",\"LOCAL_CS\",\"GEODCRS\",\"GEODETICCRS\",\"GEODETICDATUM\",\"ENGCRS\",\"ENGINEERINGCRS\"];var l=[\"3857\",\"900913\",\"3785\",\"102113\"];r.default=function(t){if(!function(t){return\"string\"==typeof t}(t))return t;if(function(t){return t in n.default}(t))return n.default[t];if(function(t){return o.some((function(e){return t.indexOf(e)>-1}))}(t)){var e=f.default(t);if(function(t){var e=a.default(t,\"authority\");if(e){var r=a.default(e,\"epsg\");return r&&l.indexOf(r)>-1}}(e))return n.default[\"EPSG:3857\"];var r=function(t){var e=a.default(t,\"extension\");if(e)return a.default(e,\"proj4\")}(e);return r?i.default(r):e}return function(t){return\"+\"===t[0]}(t)?i.default(t):void 0}},\n",
       "      function _(t,e,r){Object.defineProperty(r,\"__esModule\",{value:!0});const i=t(1),n=i.__importDefault(t(35)),f=i.__importDefault(t(36)),a=i.__importDefault(t(41));function l(t){var e=this;if(2===arguments.length){var r=arguments[1];\"string\"==typeof r?\"+\"===r.charAt(0)?l[t]=f.default(arguments[1]):l[t]=a.default(arguments[1]):l[t]=r}else if(1===arguments.length){if(Array.isArray(t))return t.map((function(t){Array.isArray(t)?l.apply(e,t):l(t)}));if(\"string\"==typeof t){if(t in l)return l[t]}else\"EPSG\"in t?l[\"EPSG:\"+t.EPSG]=t:\"ESRI\"in t?l[\"ESRI:\"+t.ESRI]=t:\"IAU2000\"in t?l[\"IAU2000:\"+t.IAU2000]=t:console.log(t);return}}n.default(l),r.default=l},\n",
       "      function _(e,t,l){Object.defineProperty(l,\"__esModule\",{value:!0}),l.default=function(e){e(\"EPSG:4326\",\"+title=WGS 84 (long/lat) +proj=longlat +ellps=WGS84 +datum=WGS84 +units=degrees\"),e(\"EPSG:4269\",\"+title=NAD83 (long/lat) +proj=longlat +a=6378137.0 +b=6356752.31414036 +ellps=GRS80 +datum=NAD83 +units=degrees\"),e(\"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\"),e.WGS84=e[\"EPSG:4326\"],e[\"EPSG:3785\"]=e[\"EPSG:3857\"],e.GOOGLE=e[\"EPSG:3857\"],e[\"EPSG:900913\"]=e[\"EPSG:3857\"],e[\"EPSG:102113\"]=e[\"EPSG:3857\"]}},\n",
       "      function _(t,n,o){Object.defineProperty(o,\"__esModule\",{value:!0});const e=t(1),a=t(37),u=e.__importDefault(t(38)),r=e.__importDefault(t(39)),i=e.__importDefault(t(40));o.default=function(t){var n,o,e,f={},l=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){f.rf=parseFloat(t)},lat_0:function(t){f.lat0=t*a.D2R},lat_1:function(t){f.lat1=t*a.D2R},lat_2:function(t){f.lat2=t*a.D2R},lat_ts:function(t){f.lat_ts=t*a.D2R},lon_0:function(t){f.long0=t*a.D2R},lon_1:function(t){f.long1=t*a.D2R},lon_2:function(t){f.long2=t*a.D2R},alpha:function(t){f.alpha=parseFloat(t)*a.D2R},lonc:function(t){f.longc=t*a.D2R},x_0:function(t){f.x0=parseFloat(t)},y_0:function(t){f.y0=parseFloat(t)},k_0:function(t){f.k0=parseFloat(t)},k:function(t){f.k0=parseFloat(t)},a:function(t){f.a=parseFloat(t)},b:function(t){f.b=parseFloat(t)},r_a:function(){f.R_A=!0},zone:function(t){f.zone=parseInt(t,10)},south:function(){f.utmSouth=!0},towgs84:function(t){f.datum_params=t.split(\",\").map((function(t){return parseFloat(t)}))},to_meter:function(t){f.to_meter=parseFloat(t)},units:function(t){f.units=t;var n=i.default(r.default,t);n&&(f.to_meter=n.to_meter)},from_greenwich:function(t){f.from_greenwich=t*a.D2R},pm:function(t){var n=i.default(u.default,t);f.from_greenwich=(n||parseFloat(t))*a.D2R},nadgrids:function(t){\"@null\"===t?f.datumCode=\"none\":f.nadgrids=t},axis:function(t){3===t.length&&-1!==\"ewnsud\".indexOf(t.substr(0,1))&&-1!==\"ewnsud\".indexOf(t.substr(1,1))&&-1!==\"ewnsud\".indexOf(t.substr(2,1))&&(f.axis=t)}};for(n in l)o=l[n],n in c?\"function\"==typeof(e=c[n])?e(o):f[e]=o:f[n]=o;return\"string\"==typeof f.datumCode&&\"WGS84\"!==f.datumCode&&(f.datumCode=f.datumCode.toLowerCase()),f}},\n",
       "      function _(P,_,e){Object.defineProperty(e,\"__esModule\",{value:!0}),e.PJD_3PARAM=1,e.PJD_7PARAM=2,e.PJD_WGS84=4,e.PJD_NODATUM=5,e.SEC_TO_RAD=484813681109536e-20,e.HALF_PI=Math.PI/2,e.SIXTH=.16666666666666666,e.RA4=.04722222222222222,e.RA6=.022156084656084655,e.EPSLN=1e-10,e.D2R=.017453292519943295,e.R2D=57.29577951308232,e.FORTPI=Math.PI/4,e.TWO_PI=2*Math.PI,e.SPI=3.14159265359},\n",
       "      function _(e,o,r){Object.defineProperty(r,\"__esModule\",{value:!0});var a={};r.default=a,a.greenwich=0,a.lisbon=-9.131906111111,a.paris=2.337229166667,a.bogota=-74.080916666667,a.madrid=-3.687938888889,a.rome=12.452333333333,a.bern=7.439583333333,a.jakarta=106.807719444444,a.ferro=-17.666666666667,a.brussels=4.367975,a.stockholm=18.058277777778,a.athens=23.7163375,a.oslo=10.722916666667},\n",
       "      function _(e,t,f){Object.defineProperty(f,\"__esModule\",{value:!0}),f.default={ft:{to_meter:.3048},\"us-ft\":{to_meter:1200/3937}}},\n",
       "      function _(e,r,t){Object.defineProperty(t,\"__esModule\",{value:!0});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){Object.defineProperty(a,\"__esModule\",{value:!0});const o=e(1);const d=o.__importDefault(e(42)),r=e(43);function n(e){return.017453292519943295*e}a.default=function(e){var t=d.default(e),a=t.shift(),o=t.shift();t.unshift([\"name\",o]),t.unshift([\"type\",a]);var l={};return r.sExpr(t,l),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 l(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\",n],[\"longitude_of_center\",\"Longitude_Of_Center\"],[\"longitude_of_center\",\"Longitude_of_center\"],[\"longc\",\"longitude_of_center\",n],[\"x0\",\"false_easting\",l],[\"y0\",\"false_northing\",l],[\"long0\",\"central_meridian\",n],[\"lat0\",\"latitude_of_origin\",n],[\"lat0\",\"standard_parallel_1\",n],[\"lat1\",\"standard_parallel_1\",n],[\"lat2\",\"standard_parallel_2\",n],[\"azimuth\",\"Azimuth\"],[\"alpha\",\"azimuth\",n],[\"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=n(e.lat1>0?90:-90),e.lat_ts=e.lat1)}(l),l}},\n",
       "      function _(t,e,r){Object.defineProperty(r,\"__esModule\",{value:!0}),r.default=function(t){return new a(t).output()};var i=/\\s/,s=/[A-Za-z]/,h=/[A-Za-z84]/,o=/[,\\]]/,n=/[\\d\\.E\\-\\+]/;function a(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}a.prototype.readCharicter=function(){var t=this.text[this.place++];if(4!==this.state)for(;i.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}},a.prototype.afterquote=function(t){if('\"'===t)return this.word+='\"',void(this.state=4);if(o.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)},a.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},a.prototype.number=function(t){if(!n.test(t)){if(o.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},a.prototype.quoted=function(t){'\"'!==t?this.word+=t:this.state=5},a.prototype.keyword=function(t){if(h.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(!o.test(t))throw new Error(\"havn't handled \\\"\"+t+'\" in keyword yet, index '+this.place);this.afterItem(t)}},a.prototype.neutral=function(t){if(s.test(t))return this.word=t,void(this.state=2);if('\"'===t)return this.word=\"\",void(this.state=4);if(n.test(t))return this.word=t,void(this.state=3);if(!o.test(t))throw new Error(\"havn't handled \\\"\"+t+'\" in neutral yet, index '+this.place);this.afterItem(t)},a.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,r,a){function s(e,r,a){Array.isArray(r)&&(a.unshift(r),r=null);var s=r?{}:e,n=a.reduce((function(e,r){return c(r,e),e}),s);r&&(e[r]=n)}function c(e,r){if(Array.isArray(e)){var a=e.shift();if(\"PARAMETER\"===a&&(a=e.shift()),1===e.length)return Array.isArray(e[0])?(r[a]={},void c(e[0],r[a])):void(r[a]=e[0]);if(e.length)if(\"TOWGS84\"!==a){if(\"AXIS\"===a)return a in r||(r[a]=[]),void r[a].push(e);var n;switch(Array.isArray(a)||(r[a]={}),a){case\"UNIT\":case\"PRIMEM\":case\"VERT_DATUM\":return r[a]={name:e[0].toLowerCase(),convert:e[1]},void(3===e.length&&c(e[2],r[a]));case\"SPHEROID\":case\"ELLIPSOID\":return r[a]={name:e[0],a:e[1],rf:e[2]},void(4===e.length&&c(e[3],r[a]));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 s(r,a,e);default:for(n=-1;++n<e.length;)if(!Array.isArray(e[n]))return c(e,r[a]);return s(r,a,e)}}else r[a]=e;else r[a]=!0}else r[e]=!0}Object.defineProperty(a,\"__esModule\",{value:!0}),a.sExpr=c},\n",
       "      function _(e,n,r){Object.defineProperty(r,\"__esModule\",{value:!0}),r.default=function(e,n){var r,t;if(e=e||{},!n)return e;for(t in n)void 0!==(r=n[t])&&(e[t]=r);return e}},\n",
       "      function _(t,e,o){Object.defineProperty(o,\"__esModule\",{value:!0});const a=t(1),n=a.__importDefault(t(46)),r=a.__importDefault(t(52));var u=[n.default,r.default],f={},i=[];function d(t,e){var o=i.length;return t.names?(i[o]=t,t.names.forEach((function(t){f[t.toLowerCase()]=o})),this):(console.log(e),!0)}function c(t){if(!t)return!1;var e=t.toLowerCase();return void 0!==f[e]&&i[f[e]]?i[f[e]]:void 0}function l(){u.forEach(d)}o.add=d,o.get=c,o.start=l,o.default={start:l,add:d,get:c}},\n",
       "      function _(t,i,s){Object.defineProperty(s,\"__esModule\",{value:!0});const h=t(1),a=h.__importDefault(t(47)),e=h.__importDefault(t(48)),r=h.__importDefault(t(50)),n=h.__importDefault(t(51)),l=t(37);function u(){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=a.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 o(t){var i,s,h=t.x,a=t.y;if(a*l.R2D>90&&a*l.R2D<-90&&h*l.R2D>180&&h*l.R2D<-180)return null;if(Math.abs(Math.abs(a)-l.HALF_PI)<=l.EPSLN)return null;if(this.sphere)i=this.x0+this.a*this.k0*e.default(h-this.long0),s=this.y0+this.a*this.k0*Math.log(Math.tan(l.FORTPI+.5*a));else{var n=Math.sin(a),u=r.default(this.e,a,n);i=this.x0+this.a*this.k0*e.default(h-this.long0),s=this.y0-this.a*this.k0*Math.log(u)}return t.x=i,t.y=s,t}function f(t){var i,s,h=t.x-this.x0,a=t.y-this.y0;if(this.sphere)s=l.HALF_PI-2*Math.atan(Math.exp(-a/(this.a*this.k0)));else{var r=Math.exp(-a/(this.a*this.k0));if(-9999===(s=n.default(this.e,r)))return null}return i=e.default(this.long0+h/(this.a*this.k0)),t.x=i,t.y=s,t}s.init=u,s.forward=o,s.inverse=f,s.names=[\"Mercator\",\"Popular Visualisation Pseudo Mercator\",\"Mercator_1SP\",\"Mercator_Auxiliary_Sphere\",\"merc\"],s.default={init:u,forward:o,inverse:f,names:s.names}},\n",
       "      function _(e,t,n){Object.defineProperty(n,\"__esModule\",{value:!0}),n.default=function(e,t,n){var r=e*t;return n/Math.sqrt(1-r*r)}},\n",
       "      function _(e,t,u){Object.defineProperty(u,\"__esModule\",{value:!0});const n=e(1),a=e(37),f=n.__importDefault(e(49));u.default=function(e){return Math.abs(e)<=a.SPI?e:e-f.default(e)*a.TWO_PI}},\n",
       "      function _(e,n,t){Object.defineProperty(t,\"__esModule\",{value:!0}),t.default=function(e){return e<0?-1:1}},\n",
       "      function _(t,e,n){Object.defineProperty(n,\"__esModule\",{value:!0});const a=t(37);n.default=function(t,e,n){var o=t*n,u=.5*t;return o=Math.pow((1-o)/(1+o),u),Math.tan(.5*(a.HALF_PI-e))/o}},\n",
       "      function _(t,a,e){Object.defineProperty(e,\"__esModule\",{value:!0});const n=t(37);e.default=function(t,a){for(var e,r,o=.5*t,u=n.HALF_PI-2*Math.atan(a),f=0;f<=15;f++)if(e=t*Math.sin(u),u+=r=n.HALF_PI-2*Math.atan(a*Math.pow((1-e)/(1+e),o))-u,Math.abs(r)<=1e-10)return u;return-9999}},\n",
       "      function _(e,n,i){function t(){}function r(e){return e}Object.defineProperty(i,\"__esModule\",{value:!0}),i.init=t,i.forward=r,i.inverse=r,i.names=[\"longlat\",\"identity\"],i.default={init:t,forward:r,inverse:r,names:i.names}},\n",
       "      function _(e,t,r){Object.defineProperty(r,\"__esModule\",{value:!0});const a=e(1),n=e(37),f=a.__importStar(e(54)),u=a.__importDefault(e(40));r.eccentricity=function(e,t,r,a){var f=e*e,u=t*t,i=(f-u)/f,c=0;return a?(f=(e*=1-i*(n.SIXTH+i*(n.RA4+i*n.RA6)))*e,i=0):c=Math.sqrt(i),{es:i,e:c,ep2:(f-u)/u}},r.sphere=function(e,t,r,a,i){if(!e){var c=u.default(f.default,a);c||(c=f.WGS84),e=c.a,t=c.b,r=c.rf}return r&&!t&&(t=(1-1/r)*e),(0===r||Math.abs(e-t)<n.EPSLN)&&(i=!0,t=e),{a:e,b:t,rf:r,sphere:i}}},\n",
       "      function _(e,a,l){Object.defineProperty(l,\"__esModule\",{value:!0});var s={};l.default=s,s.MERIT={a:6378137,rf:298.257,ellipseName:\"MERIT 1983\"},s.SGS85={a:6378136,rf:298.257,ellipseName:\"Soviet Geodetic System 85\"},s.GRS80={a:6378137,rf:298.257222101,ellipseName:\"GRS 1980(IUGG, 1980)\"},s.IAU76={a:6378140,rf:298.257,ellipseName:\"IAU 1976\"},s.airy={a:6377563.396,b:6356256.91,ellipseName:\"Airy 1830\"},s.APL4={a:6378137,rf:298.25,ellipseName:\"Appl. Physics. 1965\"},s.NWL9D={a:6378145,rf:298.25,ellipseName:\"Naval Weapons Lab., 1965\"},s.mod_airy={a:6377340.189,b:6356034.446,ellipseName:\"Modified Airy\"},s.andrae={a:6377104.43,rf:300,ellipseName:\"Andrae 1876 (Den., Iclnd.)\"},s.aust_SA={a:6378160,rf:298.25,ellipseName:\"Australian Natl & S. Amer. 1969\"},s.GRS67={a:6378160,rf:298.247167427,ellipseName:\"GRS 67(IUGG 1967)\"},s.bessel={a:6377397.155,rf:299.1528128,ellipseName:\"Bessel 1841\"},s.bess_nam={a:6377483.865,rf:299.1528128,ellipseName:\"Bessel 1841 (Namibia)\"},s.clrk66={a:6378206.4,b:6356583.8,ellipseName:\"Clarke 1866\"},s.clrk80={a:6378249.145,rf:293.4663,ellipseName:\"Clarke 1880 mod.\"},s.clrk58={a:6378293.645208759,rf:294.2606763692654,ellipseName:\"Clarke 1858\"},s.CPM={a:6375738.7,rf:334.29,ellipseName:\"Comm. des Poids et Mesures 1799\"},s.delmbr={a:6376428,rf:311.5,ellipseName:\"Delambre 1810 (Belgium)\"},s.engelis={a:6378136.05,rf:298.2566,ellipseName:\"Engelis 1985\"},s.evrst30={a:6377276.345,rf:300.8017,ellipseName:\"Everest 1830\"},s.evrst48={a:6377304.063,rf:300.8017,ellipseName:\"Everest 1948\"},s.evrst56={a:6377301.243,rf:300.8017,ellipseName:\"Everest 1956\"},s.evrst69={a:6377295.664,rf:300.8017,ellipseName:\"Everest 1969\"},s.evrstSS={a:6377298.556,rf:300.8017,ellipseName:\"Everest (Sabah & Sarawak)\"},s.fschr60={a:6378166,rf:298.3,ellipseName:\"Fischer (Mercury Datum) 1960\"},s.fschr60m={a:6378155,rf:298.3,ellipseName:\"Fischer 1960\"},s.fschr68={a:6378150,rf:298.3,ellipseName:\"Fischer 1968\"},s.helmert={a:6378200,rf:298.3,ellipseName:\"Helmert 1906\"},s.hough={a:6378270,rf:297,ellipseName:\"Hough\"},s.intl={a:6378388,rf:297,ellipseName:\"International 1909 (Hayford)\"},s.kaula={a:6378163,rf:298.24,ellipseName:\"Kaula 1961\"},s.lerch={a:6378139,rf:298.257,ellipseName:\"Lerch 1979\"},s.mprts={a:6397300,rf:191,ellipseName:\"Maupertius 1738\"},s.new_intl={a:6378157.5,b:6356772.2,ellipseName:\"New International 1967\"},s.plessis={a:6376523,rf:6355863,ellipseName:\"Plessis 1817 (France)\"},s.krass={a:6378245,rf:298.3,ellipseName:\"Krassovsky, 1942\"},s.SEasia={a:6378155,b:6356773.3205,ellipseName:\"Southeast Asia\"},s.walbeck={a:6376896,b:6355834.8467,ellipseName:\"Walbeck\"},s.WGS60={a:6378165,rf:298.3,ellipseName:\"WGS 60\"},s.WGS66={a:6378145,rf:298.25,ellipseName:\"WGS 66\"},s.WGS7={a:6378135,rf:298.26,ellipseName:\"WGS 72\"},l.WGS84=s.WGS84={a:6378137,rf:298.257223563,ellipseName:\"WGS 84\"},s.sphere={a:6370997,b:6370997,ellipseName:\"Normal Sphere (r=6370997)\"}},\n",
       "      function _(e,a,s){Object.defineProperty(s,\"__esModule\",{value:!0});var t={};s.default=t,t.wgs84={towgs84:\"0,0,0\",ellipse:\"WGS84\",datumName:\"WGS84\"},t.ch1903={towgs84:\"674.374,15.056,405.346\",ellipse:\"bessel\",datumName:\"swiss\"},t.ggrs87={towgs84:\"-199.87,74.79,246.62\",ellipse:\"GRS80\",datumName:\"Greek_Geodetic_Reference_System_1987\"},t.nad83={towgs84:\"0,0,0\",ellipse:\"GRS80\",datumName:\"North_American_Datum_1983\"},t.nad27={nadgrids:\"@conus,@alaska,@ntv2_0.gsb,@ntv1_can.dat\",ellipse:\"clrk66\",datumName:\"North_American_Datum_1927\"},t.potsdam={towgs84:\"606.0,23.0,413.0\",ellipse:\"bessel\",datumName:\"Potsdam Rauenberg 1950 DHDN\"},t.carthage={towgs84:\"-263.0,6.0,431.0\",ellipse:\"clark80\",datumName:\"Carthage 1934 Tunisia\"},t.hermannskogel={towgs84:\"653.0,-212.0,449.0\",ellipse:\"bessel\",datumName:\"Hermannskogel\"},t.osni52={towgs84:\"482.530,-130.596,564.557,-1.042,-0.214,-0.631,8.15\",ellipse:\"airy\",datumName:\"Irish National\"},t.ire65={towgs84:\"482.530,-130.596,564.557,-1.042,-0.214,-0.631,8.15\",ellipse:\"mod_airy\",datumName:\"Ireland 1965\"},t.rassadiran={towgs84:\"-133.63,-157.5,-158.62\",ellipse:\"intl\",datumName:\"Rassadiran\"},t.nzgd49={towgs84:\"59.47,-5.04,187.44,0.47,-0.1,1.024,-4.5993\",ellipse:\"intl\",datumName:\"New Zealand Geodetic Datum 1949\"},t.osgb36={towgs84:\"446.448,-125.157,542.060,0.1502,0.2470,0.8421,-20.4894\",ellipse:\"airy\",datumName:\"Airy 1830\"},t.s_jtsk={towgs84:\"589,76,480\",ellipse:\"bessel\",datumName:\"S-JTSK (Ferro)\"},t.beduaram={towgs84:\"-106,-87,188\",ellipse:\"clrk80\",datumName:\"Beduaram\"},t.gunung_segara={towgs84:\"-403,684,41\",ellipse:\"bessel\",datumName:\"Gunung Segara Jakarta\"},t.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,_){Object.defineProperty(_,\"__esModule\",{value:!0});const t=a(37);_.default=function(a,m,_,u,d,p){var r={};return r.datum_type=void 0===a||\"none\"===a?t.PJD_NODATUM:t.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=t.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=t.PJD_7PARAM,r.datum_params[3]*=t.SEC_TO_RAD,r.datum_params[4]*=t.SEC_TO_RAD,r.datum_params[5]*=t.SEC_TO_RAD,r.datum_params[6]=r.datum_params[6]/1e6+1))),r.a=_,r.b=u,r.es=d,r.ep2=p,r}},\n",
       "      function _(t,e,a){Object.defineProperty(a,\"__esModule\",{value:!0});const r=t(1),u=t(37),m=r.__importDefault(t(58)),_=r.__importDefault(t(60)),o=r.__importDefault(t(32)),d=r.__importDefault(t(61)),f=r.__importDefault(t(62));a.default=function t(e,a,r){var n;return Array.isArray(r)&&(r=d.default(r)),f.default(r),e.datum&&a.datum&&function(t,e){return(t.datum.datum_type===u.PJD_3PARAM||t.datum.datum_type===u.PJD_7PARAM)&&\"WGS84\"!==e.datumCode||(e.datum.datum_type===u.PJD_3PARAM||e.datum.datum_type===u.PJD_7PARAM)&&\"WGS84\"!==t.datumCode}(e,a)&&(r=t(e,n=new o.default(\"WGS84\"),r),e=n),\"enu\"!==e.axis&&(r=_.default(e,!1,r)),\"longlat\"===e.projName?r={x:r.x*u.D2R,y:r.y*u.D2R,z:r.z||0}:(e.to_meter&&(r={x:r.x*e.to_meter,y:r.y*e.to_meter,z:r.z||0}),r=e.inverse(r)),e.from_greenwich&&(r.x+=e.from_greenwich),r=m.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*u.R2D,y:r.y*u.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?_.default(a,!0,r):r}},\n",
       "      function _(e,t,a){Object.defineProperty(a,\"__esModule\",{value:!0});const u=e(37),o=e(59);function _(e){return e===u.PJD_3PARAM||e===u.PJD_7PARAM}a.default=function(e,t,a){return o.compareDatums(e,t)||e.datum_type===u.PJD_NODATUM||t.datum_type===u.PJD_NODATUM?a:e.es!==t.es||e.a!==t.a||_(e.datum_type)||_(t.datum_type)?(a=o.geodeticToGeocentric(a,e.es,e.a),_(e.datum_type)&&(a=o.geocentricToWgs84(a,e.datum_type,e.datum_params)),_(t.datum_type)&&(a=o.geocentricFromWgs84(a,t.datum_type,t.datum_params)),o.geocentricToGeodetic(a,t.es,t.a,t.b)):a}},\n",
       "      function _(a,t,r){Object.defineProperty(r,\"__esModule\",{value:!0});const e=a(37);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===e.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!==e.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,u,s,_,n=a.x,d=a.y,i=a.z?a.z:0;if(d<-e.HALF_PI&&d>-1.001*e.HALF_PI)d=-e.HALF_PI;else if(d>e.HALF_PI&&d<1.001*e.HALF_PI)d=e.HALF_PI;else{if(d<-e.HALF_PI)return{x:-1/0,y:-1/0,z:a.z};if(d>e.HALF_PI)return{x:1/0,y:1/0,z:a.z}}return n>Math.PI&&(n-=2*Math.PI),u=Math.sin(d),_=Math.cos(d),s=u*u,{x:((m=r/Math.sqrt(1-t*s))+i)*_*Math.cos(n),y:(m+i)*_*Math.sin(n),z:(m*(1-t)+i)*u}},r.geocentricToGeodetic=function(a,t,r,m){var u,s,_,n,d,i,p,P,o,y,M,z,c,A,x,f=a.x,h=a.y,I=a.z?a.z:0;if(u=Math.sqrt(f*f+h*h),s=Math.sqrt(f*f+h*h+I*I),u/r<1e-12){if(A=0,s/r<1e-12)return e.HALF_PI,x=-m,{x:a.x,y:a.y,z:a.z}}else A=Math.atan2(h,f);_=I/s,P=(n=u/s)*(1-t)*(d=1/Math.sqrt(1-t*(2-t)*n*n)),o=_*d,c=0;do{c++,i=t*(p=r/Math.sqrt(1-t*o*o))/(p+(x=u*P+I*o-p*(1-t*o*o))),z=(M=_*(d=1/Math.sqrt(1-i*(2-i)*n*n)))*P-(y=n*(1-i)*d)*o,P=y,o=M}while(z*z>1e-24&&c<30);return{x:A,y:Math.atan(M/Math.abs(y)),z:x}},r.geocentricToWgs84=function(a,t,r){if(t===e.PJD_3PARAM)return{x:a.x+r[0],y:a.y+r[1],z:a.z+r[2]};if(t===e.PJD_7PARAM){var m=r[0],u=r[1],s=r[2],_=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-_*a.z)+u,z:i*(-n*a.x+_*a.y+a.z)+s}}},r.geocentricFromWgs84=function(a,t,r){if(t===e.PJD_3PARAM)return{x:a.x-r[0],y:a.y-r[1],z:a.z-r[2]};if(t===e.PJD_7PARAM){var m=r[0],u=r[1],s=r[2],_=r[3],n=r[4],d=r[5],i=r[6],p=(a.x-m)/i,P=(a.y-u)/i,o=(a.z-s)/i;return{x:p+d*P-n*o,y:-d*p+P+_*o,z:n*p-_*P+o}}}},\n",
       "      function _(e,a,r){Object.defineProperty(r,\"__esModule\",{value:!0}),r.default=function(e,a,r){var c,s,u,i=r.x,n=r.y,t=r.z||0,d={};for(u=0;u<3;u++)if(!a||2!==u||void 0!==r.z)switch(0===u?(c=i,s=\"x\"):1===u?(c=n,s=\"y\"):(c=t,s=\"z\"),e.axis[u]){case\"e\":d[s]=c;break;case\"w\":d[s]=-c;break;case\"n\":d[s]=c;break;case\"s\":d[s]=-c;break;case\"u\":void 0!==r[s]&&(d.z=c);break;case\"d\":void 0!==r[s]&&(d.z=-c);break;default:return null}return d}},\n",
       "      function _(e,n,t){Object.defineProperty(t,\"__esModule\",{value:!0}),t.default=function(e){var n={x:e[0],y:e[1]};return e.length>2&&(n.z=e[2]),e.length>3&&(n.m=e[3]),n}},\n",
       "      function _(e,i,n){function t(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\")}Object.defineProperty(n,\"__esModule\",{value:!0}),n.default=function(e){t(e.x),t(e.y)}},\n",
       "      function _(e,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const r=e(1),n=e(64),s=r.__importStar(e(68)),_=r.__importStar(e(19)),l=e(69);class o extends n.DOMView{initialize(){super.initialize(),this.visuals=new s.Visuals(this.model),this._has_finished=!0}get plot_view(){return this.parent}get plot_model(){return this.parent.model}request_render(){this.plot_view.request_render()}map_to_screen(e,t){return this.plot_view.map_to_screen(e,t,this.model.x_range_name,this.model.y_range_name)}get needs_clip(){return!1}notify_finished(){this.plot_view.notify_finished()}get has_webgl(){return!1}}i.RendererView=o,o.__name__=\"RendererView\";class d extends l.Model{constructor(e){super(e)}static init_Renderer(){this.define({level:[_.RenderLevel],visible:[_.Boolean,!0]})}}i.Renderer=d,d.__name__=\"Renderer\",d.init_Renderer()},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=e(1),r=e(65),n=i.__importStar(e(66)),_=e(67);class a extends r.View{initialize(){super.initialize(),this._has_finished=!1,this.el=this._createElement()}remove(){n.removeElement(this.el),super.remove()}css_classes(){return[]}cursor(e,t){return null}render(){}renderTo(e){e.appendChild(this.el),this.render()}has_finished(){return this._has_finished}get _root_element(){return n.parent(this.el,`.${_.bk_root}`)||document.body}get is_idle(){return this.has_finished()}_createElement(){return n.createElement(this.tagName,{class:this.css_classes()})}}s.DOMView=a,a.__name__=\"DOMView\",a.prototype.tagName=\"div\"},\n",
       "      function _(t,e,i){Object.defineProperty(i,\"__esModule\",{value:!0});const r=t(14),n=t(8),o=t(25);class s{constructor(t){if(this.removed=new r.Signal0(this,\"removed\"),this._ready=Promise.resolve(void 0),null==t.model)throw new Error(\"model of a view wasn't configured\");this.model=t.model,this._parent=t.parent,this.id=t.id||o.uniqueId()}get ready(){return this._ready}connect(t,e){return t.connect((t,i)=>{const r=Promise.resolve(e.call(this,t,i));this._ready=this._ready.then(()=>r)},this)}disconnect(t,e){return t.disconnect(e,this)}initialize(){}async lazy_initialize(){}remove(){this._parent=void 0,this.disconnect_signals(),this.removed.emit()}toString(){return`${this.model.type}View(${this.id})`}serializable_state(){return{type:this.model.type}}get parent(){if(void 0!==this._parent)return this._parent;throw new Error(\"parent of a view wasn't configured\")}get is_root(){return null===this.parent}get root(){return this.is_root?this:this.parent.root}assert_root(){if(!this.is_root)throw new Error(`${this.toString()} is not a root layout`)}connect_signals(){}disconnect_signals(){r.Signal.disconnectReceiver(this)}on_change(t,e){for(const i of n.isArray(t)?t:[t])this.connect(i.change,e)}}i.View=s,s.__name__=\"View\"},\n",
       "      function _(t,e,n){Object.defineProperty(n,\"__esModule\",{value:!0});const i=t(8),s=t=>(e={},...n)=>{const s=document.createElement(t);s.classList.add(\"bk\");for(const t in e){let n=e[t];if(null!=n&&(!i.isBoolean(n)||n))if(\"class\"===t&&(i.isString(n)&&(n=n.split(/\\s+/)),i.isArray(n)))for(const t of n)null!=t&&s.classList.add(t);else if(\"style\"===t&&i.isPlainObject(n))for(const t in n)s.style[t]=n[t];else if(\"data\"===t&&i.isPlainObject(n))for(const t in n)s.dataset[t]=n[t];else s.setAttribute(t,n)}function o(t){if(t instanceof HTMLElement)s.appendChild(t);else if(i.isString(t))s.appendChild(document.createTextNode(t));else if(null!=t&&!1!==t)throw new Error(`expected an HTMLElement, string, false or null, got ${JSON.stringify(t)}`)}for(const t of n)if(i.isArray(t))for(const e of t)o(e);else o(t);return s};function o(t){const e=t.parentNode;null!=e&&e.removeChild(t)}function l(t,...e){const n=t.firstChild;for(const i of e)t.insertBefore(i,n)}function r(t,e){const n=Element.prototype;return(n.matches||n.webkitMatchesSelector||n.mozMatchesSelector||n.msMatchesSelector).call(t,e)}function c(t){return parseFloat(t)||0}function a(t){const e=getComputedStyle(t);return{border:{top:c(e.borderTopWidth),bottom:c(e.borderBottomWidth),left:c(e.borderLeftWidth),right:c(e.borderRightWidth)},margin:{top:c(e.marginTop),bottom:c(e.marginBottom),left:c(e.marginLeft),right:c(e.marginRight)},padding:{top:c(e.paddingTop),bottom:c(e.paddingBottom),left:c(e.paddingLeft),right:c(e.paddingRight)}}}function h(t){const e=t.getBoundingClientRect();return{width:Math.ceil(e.width),height:Math.ceil(e.height)}}n.createElement=function(t,e,...n){return s(t)(e,...n)},n.div=s(\"div\"),n.span=s(\"span\"),n.canvas=s(\"canvas\"),n.link=s(\"link\"),n.style=s(\"style\"),n.a=s(\"a\"),n.p=s(\"p\"),n.i=s(\"i\"),n.pre=s(\"pre\"),n.button=s(\"button\"),n.label=s(\"label\"),n.input=s(\"input\"),n.select=s(\"select\"),n.option=s(\"option\"),n.optgroup=s(\"optgroup\"),n.textarea=s(\"textarea\"),n.nbsp=function(){return document.createTextNode(\" \")},n.append=function(t,...e){for(const n of e)t.appendChild(n)},n.remove=o,n.removeElement=o,n.replaceWith=function(t,e){const n=t.parentNode;null!=n&&n.replaceChild(e,t)},n.prepend=l,n.empty=function(t){let e;for(;e=t.firstChild;)t.removeChild(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=r,n.parent=function(t,e){let n=t;for(;n=n.parentElement;)if(r(n,e))return n;return null},n.extents=a,n.size=h,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:s}}=a(t),{width:o,height:l}=h(t);return{width:Math.ceil(o+e+n),height:Math.ceil(l+i+s)}},n.content_size=function(t){const{left:e,top:n}=t.getBoundingClientRect(),{padding:i}=a(t);let s=0,o=0;for(const l of t.children){const t=l.getBoundingClientRect();s=Math.max(s,Math.ceil(t.left-e-i.left+t.width)),o=Math.max(o,Math.ceil(t.top-n-i.top+t.height))}return{width:s,height:o}},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:s,left:o}=n;i.margin=`${t}px ${e}px ${s}px ${o}px`}},n.children=function(t){return Array.from(t.children)};class d{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 p;function u(t,e,n){const{width:i,height:s,position:o,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=o,t.style.display=l,t.style.width=i,t.style.height=s}}n.ClassList=d,d.__name__=\"ClassList\",n.classes=function(t){return new d(t)},(p=n.Keys||(n.Keys={}))[p.Backspace=8]=\"Backspace\",p[p.Tab=9]=\"Tab\",p[p.Enter=13]=\"Enter\",p[p.Esc=27]=\"Esc\",p[p.PageUp=33]=\"PageUp\",p[p.PageDown=34]=\"PageDown\",p[p.Left=37]=\"Left\",p[p.Up=38]=\"Up\",p[p.Right=39]=\"Right\",p[p.Down=40]=\"Down\",p[p.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 u(t,{},e)},n.sized=u;class f{constructor(){this.style=n.style({type:\"text/css\"}),l(document.head,this.style)}append(t){this.style.appendChild(document.createTextNode(t))}}n.StyleSheet=f,f.__name__=\"StyleSheet\",n.styles=new f},\n",
       "      function _(n,o,e){Object.defineProperty(e,\"__esModule\",{value:!0}),n(1).__importStar(n(66)).styles.append(\".bk-root {\\n  position: relative;\\n  width: auto;\\n  height: auto;\\n  z-index: 0;\\n  box-sizing: border-box;\\n  font-family: Helvetica, Arial, sans-serif;\\n  font-size: 10pt;\\n}\\n.bk-root .bk,\\n.bk-root .bk:before,\\n.bk-root .bk:after {\\n  box-sizing: inherit;\\n  margin: 0;\\n  border: 0;\\n  padding: 0;\\n  background-image: none;\\n  font-family: inherit;\\n  font-size: 100%;\\n  line-height: 1.42857143;\\n}\\n.bk-root pre.bk {\\n  font-family: Courier, monospace;\\n}\\n\"),e.bk_root=\"bk-root\"},\n",
       "      function _(e,t,a){Object.defineProperty(a,\"__esModule\",{value:!0});const s=e(1).__importStar(e(18)),l=e(21);function c(e,t,a){e.moveTo(0,a+.5),e.lineTo(t,a+.5),e.stroke()}function i(e,t,a){e.moveTo(a+.5,0),e.lineTo(a+.5,t),e.stroke()}function h(e,t){e.moveTo(0,t),e.lineTo(t,0),e.stroke(),e.moveTo(0,0),e.lineTo(t,t),e.stroke()}function o(e,t,a,s){const l=a,o=l/2,n=o/2,r=function(e){const t=document.createElement(\"canvas\");return t.width=e,t.height=e,t}(a),_=r.getContext(\"2d\");switch(_.strokeStyle=t,_.lineCap=\"square\",_.fillStyle=t,_.lineWidth=s,e){case\" \":case\"blank\":break;case\".\":case\"dot\":_.arc(o,o,o/2,0,2*Math.PI,!0),_.fill();break;case\"o\":case\"ring\":_.arc(o,o,o/2,0,2*Math.PI,!0),_.stroke();break;case\"-\":case\"horizontal_line\":c(_,l,o);break;case\"|\":case\"vertical_line\":i(_,l,o);break;case\"+\":case\"cross\":c(_,l,o),i(_,l,o);break;case'\"':case\"horizontal_dash\":c(_,o,o);break;case\":\":case\"vertical_dash\":i(_,o,o);break;case\"@\":case\"spiral\":const e=l/30;_.moveTo(o,o);for(let t=0;t<360;t++){const a=.1*t,s=o+e*a*Math.cos(a),l=o+e*a*Math.sin(a);_.lineTo(s,l)}_.stroke();break;case\"/\":case\"right_diagonal_line\":_.moveTo(.5-n,l),_.lineTo(n+.5,0),_.stroke(),_.moveTo(n+.5,l),_.lineTo(3*n+.5,0),_.stroke(),_.moveTo(3*n+.5,l),_.lineTo(5*n+.5,0),_.stroke(),_.stroke();break;case\"\\\\\":case\"left_diagonal_line\":_.moveTo(n+.5,l),_.lineTo(.5-n,0),_.stroke(),_.moveTo(3*n+.5,l),_.lineTo(n+.5,0),_.stroke(),_.moveTo(5*n+.5,l),_.lineTo(3*n+.5,0),_.stroke(),_.stroke();break;case\"x\":case\"diagonal_cross\":h(_,l);break;case\",\":case\"right_diagonal_dash\":_.moveTo(n+.5,3*n+.5),_.lineTo(3*n+.5,n+.5),_.stroke();break;case\"`\":case\"left_diagonal_dash\":_.moveTo(n+.5,n+.5),_.lineTo(3*n+.5,3*n+.5),_.stroke();break;case\"v\":case\"horizontal_wave\":_.moveTo(0,n),_.lineTo(o,3*n),_.lineTo(l,n),_.stroke();break;case\">\":case\"vertical_wave\":_.moveTo(n,0),_.lineTo(3*n,o),_.lineTo(n,l),_.stroke();break;case\"*\":case\"criss_cross\":h(_,l),c(_,l,o),i(_,l,o)}return r}class n{constructor(e,t=\"\"){this.obj=e,this.prefix=t,this.cache={};for(const a of this.attrs)this[a]=e.properties[t+a]}warm_cache(e){for(const t of this.attrs){const a=this.obj.properties[this.prefix+t];if(void 0!==a.spec.value)this.cache[t]=a.spec.value;else{if(null==e)throw new Error(\"source is required with a vectorized visual property\");this.cache[t+\"_array\"]=a.array(e)}}}cache_select(e,t){const a=this.obj.properties[this.prefix+e];let s;return void 0!==a.spec.value?this.cache[e]=s=a.spec.value:this.cache[e]=s=this.cache[e+\"_array\"][t],s}set_vectorize(e,t){null!=this.all_indices?this._set_vectorize(e,this.all_indices[t]):this._set_vectorize(e,t)}}a.ContextProperties=n,n.__name__=\"ContextProperties\";class r extends n{set_value(e){e.strokeStyle=this.line_color.value(),e.globalAlpha=this.line_alpha.value(),e.lineWidth=this.line_width.value(),e.lineJoin=this.line_join.value(),e.lineCap=this.line_cap.value(),e.setLineDash(this.line_dash.value()),e.setLineDashOffset(this.line_dash_offset.value())}get doit(){return!(null===this.line_color.spec.value||0==this.line_alpha.spec.value||0==this.line_width.spec.value)}_set_vectorize(e,t){this.cache_select(\"line_color\",t),e.strokeStyle!==this.cache.line_color&&(e.strokeStyle=this.cache.line_color),this.cache_select(\"line_alpha\",t),e.globalAlpha!==this.cache.line_alpha&&(e.globalAlpha=this.cache.line_alpha),this.cache_select(\"line_width\",t),e.lineWidth!==this.cache.line_width&&(e.lineWidth=this.cache.line_width),this.cache_select(\"line_join\",t),e.lineJoin!==this.cache.line_join&&(e.lineJoin=this.cache.line_join),this.cache_select(\"line_cap\",t),e.lineCap!==this.cache.line_cap&&(e.lineCap=this.cache.line_cap),this.cache_select(\"line_dash\",t),e.getLineDash()!==this.cache.line_dash&&e.setLineDash(this.cache.line_dash),this.cache_select(\"line_dash_offset\",t),e.getLineDashOffset()!==this.cache.line_dash_offset&&e.setLineDashOffset(this.cache.line_dash_offset)}color_value(){const[e,t,a,s]=l.color2rgba(this.line_color.value(),this.line_alpha.value());return`rgba(${255*e},${255*t},${255*a},${s})`}}a.Line=r,r.__name__=\"Line\",r.prototype.attrs=Object.keys(s.line());class _ extends n{set_value(e){e.fillStyle=this.fill_color.value(),e.globalAlpha=this.fill_alpha.value()}get doit(){return!(null===this.fill_color.spec.value||0==this.fill_alpha.spec.value)}_set_vectorize(e,t){this.cache_select(\"fill_color\",t),e.fillStyle!==this.cache.fill_color&&(e.fillStyle=this.cache.fill_color),this.cache_select(\"fill_alpha\",t),e.globalAlpha!==this.cache.fill_alpha&&(e.globalAlpha=this.cache.fill_alpha)}color_value(){const[e,t,a,s]=l.color2rgba(this.fill_color.value(),this.fill_alpha.value());return`rgba(${255*e},${255*t},${255*a},${s})`}}a.Fill=_,_.__name__=\"Fill\",_.prototype.attrs=Object.keys(s.fill());class p extends n{cache_select(e,t){let a;if(\"pattern\"==e){this.cache_select(\"hatch_color\",t),this.cache_select(\"hatch_scale\",t),this.cache_select(\"hatch_pattern\",t),this.cache_select(\"hatch_weight\",t);const{hatch_color:e,hatch_scale:a,hatch_pattern:s,hatch_weight:l,hatch_extra:c}=this.cache;if(null!=c&&c.hasOwnProperty(s)){const t=c[s];this.cache.pattern=t.get_pattern(e,a,l)}else this.cache.pattern=t=>{const c=o(s,e,a,l);return t.createPattern(c,\"repeat\")}}else a=super.cache_select(e,t);return a}_try_defer(e){const{hatch_pattern:t,hatch_extra:a}=this.cache;if(null!=a&&a.hasOwnProperty(t)){a[t].onload(e)}}get doit(){return!(null===this.hatch_color.spec.value||0==this.hatch_alpha.spec.value||\" \"==this.hatch_pattern.spec.value||\"blank\"==this.hatch_pattern.spec.value||null===this.hatch_pattern.spec.value)}doit2(e,t,a,s){if(!this.doit)return;this.cache_select(\"pattern\",t),null==this.cache.pattern(e)?this._try_defer(s):(this.set_vectorize(e,t),a())}_set_vectorize(e,t){this.cache_select(\"pattern\",t),e.fillStyle=this.cache.pattern(e),this.cache_select(\"hatch_alpha\",t),e.globalAlpha!==this.cache.hatch_alpha&&(e.globalAlpha=this.cache.hatch_alpha)}color_value(){const[e,t,a,s]=l.color2rgba(this.hatch_color.value(),this.hatch_alpha.value());return`rgba(${255*e},${255*t},${255*a},${s})`}}a.Hatch=p,p.__name__=\"Hatch\",p.prototype.attrs=Object.keys(s.hatch());class u extends n{cache_select(e,t){let a;if(\"font\"==e){super.cache_select(\"text_font_style\",t),super.cache_select(\"text_font_size\",t),super.cache_select(\"text_font\",t);const{text_font_style:e,text_font_size:s,text_font:l}=this.cache;this.cache.font=a=`${e} ${s} ${l}`}else a=super.cache_select(e,t);return a}font_value(){const e=this.text_font.value(),t=this.text_font_size.value();return this.text_font_style.value()+\" \"+t+\" \"+e}color_value(){const[e,t,a,s]=l.color2rgba(this.text_color.value(),this.text_alpha.value());return`rgba(${255*e},${255*t},${255*a},${s})`}set_value(e){e.font=this.font_value(),e.fillStyle=this.text_color.value(),e.globalAlpha=this.text_alpha.value(),e.textAlign=this.text_align.value(),e.textBaseline=this.text_baseline.value()}get doit(){return!(null===this.text_color.spec.value||0==this.text_alpha.spec.value)}_set_vectorize(e,t){this.cache_select(\"font\",t),e.font!==this.cache.font&&(e.font=this.cache.font),this.cache_select(\"text_color\",t),e.fillStyle!==this.cache.text_color&&(e.fillStyle=this.cache.text_color),this.cache_select(\"text_alpha\",t),e.globalAlpha!==this.cache.text_alpha&&(e.globalAlpha=this.cache.text_alpha),this.cache_select(\"text_align\",t),e.textAlign!==this.cache.text_align&&(e.textAlign=this.cache.text_align),this.cache_select(\"text_baseline\",t),e.textBaseline!==this.cache.text_baseline&&(e.textBaseline=this.cache.text_baseline)}}a.Text=u,u.__name__=\"Text\",u.prototype.attrs=Object.keys(s.text());class f{constructor(e){for(const t of e.mixins){const[a,s=\"\"]=t.split(\":\");let l;switch(a){case\"line\":l=r;break;case\"fill\":l=_;break;case\"hatch\":l=p;break;case\"text\":l=u;break;default:throw new Error(`unknown visual: ${a}`)}this[s+a]=new l(e,s)}}warm_cache(e){for(const t in this)if(this.hasOwnProperty(t)){const a=this[t];a instanceof n&&a.warm_cache(e)}}set_all_indices(e){for(const t in this)if(this.hasOwnProperty(t)){const a=this[t];a instanceof n&&(a.all_indices=e)}}}a.Visuals=f,f.__name__=\"Visuals\"},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});const n=e(1),c=e(13),r=n.__importStar(e(19)),a=e(8),i=e(23),o=e(70);class _ extends c.HasProps{constructor(e){super(e)}static init_Model(){this.define({tags:[r.Array,[]],name:[r.String],js_property_callbacks:[r.Any,{}],js_event_callbacks:[r.Any,{}],subscribed_events:[r.Array,[]]})}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){for(const t of this.js_event_callbacks[e.event_name]||[])t.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.id):o.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 in this._js_callbacks){const s=this._js_callbacks[t],n=e(t);for(const e of s)this.disconnect(n,e)}this._js_callbacks={};for(const t in this.js_property_callbacks){const s=this.js_property_callbacks[t].map(e=>()=>e.execute(this));this._js_callbacks[t]=s;const n=e(t);for(const e of s)this.connect(n,e)}}_doc_attached(){i.isEmpty(this.js_event_callbacks)&&i.isEmpty(this.subscribed_events)||this._update_event_callbacks()}select(e){if(a.isString(e))return this.references().filter(t=>t instanceof _&&t.name===e);if(e.prototype instanceof c.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=_,_.__name__=\"Model\",_.init_Model()},\n",
       "      function _(e,l,o){Object.defineProperty(o,\"__esModule\",{value:!0});const n=e(8),t={};class s{constructor(e,l){this.name=e,this.level=l}}o.LogLevel=s,s.__name__=\"LogLevel\";class g{constructor(e,l=g.INFO){this._name=e,this.set_level(l)}static get levels(){return Object.keys(g.log_levels)}static get(e,l=g.INFO){if(e.length>0){let o=t[e];return null==o&&(t[e]=o=new g(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 s)this._log_level=e;else{if(!n.isString(e)||null==g.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=g.log_levels[e]}const l=`[${this._name}]`;for(const e in g.log_levels){g.log_levels[e].level<this._log_level.level||this._log_level.level===g.OFF.level?this[e]=function(){}:this[e]=r(e,l)}}trace(...e){}debug(...e){}info(...e){}warn(...e){}error(...e){}}function r(e,l){return null!=console[e]?console[e].bind(console,l):null!=console.log?console.log.bind(console,l):function(){}}function i(e){const l=o.logger.level;return n.isString(e)&&null==g.log_levels[e]?(console.log(`[bokeh] unrecognized logging level '${e}' passed to Bokeh.set_log_level(), ignoring`),console.log(`[bokeh] valid log levels are: ${g.levels.join(\", \")}`)):(console.log(`[bokeh] setting log level to: '${n.isString(e)?e:e.level}'`),o.logger.set_level(e)),l}o.Logger=g,g.__name__=\"Logger\",g.TRACE=new s(\"trace\",0),g.DEBUG=new s(\"debug\",1),g.INFO=new s(\"info\",2),g.WARN=new s(\"warn\",6),g.ERROR=new s(\"error\",7),g.FATAL=new s(\"fatal\",8),g.OFF=new s(\"off\",9),g.log_levels={trace:g.TRACE,debug:g.DEBUG,info:g.INFO,warn:g.WARN,error:g.ERROR,fatal:g.FATAL,off:g.OFF},o.logger=g.get(\"bokeh\"),o.set_log_level=i,o.with_log_level=function(e,l){const o=i(e);try{l()}finally{i(o)}}},\n",
       "      function _(t,e,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=t(1),a=t(29),n=t(72),r=t(73),o=i.__importStar(t(19)),_=t(10);class l extends a.AnnotationView{initialize(){super.initialize(),null==this.model.source&&(this.model.source=new r.ColumnDataSource),this.set_data(this.model.source)}connect_signals(){super.connect_signals(),this.connect(this.model.change,()=>this.set_data(this.model.source)),this.connect(this.model.source.streaming,()=>this.set_data(this.model.source)),this.connect(this.model.source.patching,()=>this.set_data(this.model.source))}set_data(t){super.set_data(t),this.visuals.warm_cache(t),this.plot_view.request_render()}_map_data(){const{frame:t}=this.plot_view;let e,s,i,a;return\"data\"==this.model.start_units?(e=t.xscales[this.model.x_range_name].v_compute(this._x_start),s=t.yscales[this.model.y_range_name].v_compute(this._y_start)):(e=t.xview.v_compute(this._x_start),s=t.yview.v_compute(this._y_start)),\"data\"==this.model.end_units?(i=t.xscales[this.model.x_range_name].v_compute(this._x_end),a=t.yscales[this.model.y_range_name].v_compute(this._y_end)):(i=t.xview.v_compute(this._x_end),a=t.yview.v_compute(this._y_end)),[[e,s],[i,a]]}render(){if(!this.model.visible)return;const{ctx:t}=this.plot_view.canvas_view;t.save();const[e,s]=this._map_data();null!=this.model.end&&this._arrow_head(t,\"render\",this.model.end,e,s),null!=this.model.start&&this._arrow_head(t,\"render\",this.model.start,s,e),t.beginPath();const{x:i,y:a,width:n,height:r}=this.plot_view.frame.bbox;t.rect(i,a,n,r),null!=this.model.end&&this._arrow_head(t,\"clip\",this.model.end,e,s),null!=this.model.start&&this._arrow_head(t,\"clip\",this.model.start,s,e),t.closePath(),t.clip(),this._arrow_body(t,e,s),t.restore()}_arrow_head(t,e,s,i,a){for(let n=0,r=this._x_start.length;n<r;n++){const r=Math.PI/2+_.atan2([i[0][n],i[1][n]],[a[0][n],a[1][n]]);t.save(),t.translate(a[0][n],a[1][n]),t.rotate(r),\"render\"==e?s.render(t,n):\"clip\"==e&&s.clip(t,n),t.restore()}}_arrow_body(t,e,s){if(this.visuals.line.doit)for(let i=0,a=this._x_start.length;i<a;i++)this.visuals.line.set_vectorize(t,i),t.beginPath(),t.moveTo(e[0][i],e[1][i]),t.lineTo(s[0][i],s[1][i]),t.stroke()}}s.ArrowView=l,l.__name__=\"ArrowView\";class h extends a.Annotation{constructor(t){super(t)}static init_Arrow(){this.prototype.default_view=l,this.mixins([\"line\"]),this.define({x_start:[o.NumberSpec],y_start:[o.NumberSpec],start_units:[o.SpatialUnits,\"data\"],start:[o.Instance,null],x_end:[o.NumberSpec],y_end:[o.NumberSpec],end_units:[o.SpatialUnits,\"data\"],end:[o.Instance,()=>new n.OpenHead({})],source:[o.Instance],x_range_name:[o.String,\"default\"],y_range_name:[o.String,\"default\"]})}}s.Arrow=h,h.__name__=\"Arrow\",h.init_Arrow()},\n",
       "      function _(i,e,s){Object.defineProperty(s,\"__esModule\",{value:!0});const t=i(1),l=i(29),n=i(68),o=t.__importStar(i(19));class h extends l.Annotation{constructor(i){super(i)}static init_ArrowHead(){this.define({size:[o.Number,25]})}initialize(){super.initialize(),this.visuals=new n.Visuals(this)}}s.ArrowHead=h,h.__name__=\"ArrowHead\",h.init_ArrowHead();class a extends h{constructor(i){super(i)}static init_OpenHead(){this.mixins([\"line\"])}clip(i,e){this.visuals.line.set_vectorize(i,e),i.moveTo(.5*this.size,this.size),i.lineTo(.5*this.size,-2),i.lineTo(-.5*this.size,-2),i.lineTo(-.5*this.size,this.size),i.lineTo(0,0),i.lineTo(.5*this.size,this.size)}render(i,e){this.visuals.line.doit&&(this.visuals.line.set_vectorize(i,e),i.beginPath(),i.moveTo(.5*this.size,this.size),i.lineTo(0,0),i.lineTo(-.5*this.size,this.size),i.stroke())}}s.OpenHead=a,a.__name__=\"OpenHead\",a.init_OpenHead();class r extends h{constructor(i){super(i)}static init_NormalHead(){this.mixins([\"line\",\"fill\"]),this.override({fill_color:\"black\"})}clip(i,e){this.visuals.line.set_vectorize(i,e),i.moveTo(.5*this.size,this.size),i.lineTo(.5*this.size,-2),i.lineTo(-.5*this.size,-2),i.lineTo(-.5*this.size,this.size),i.lineTo(.5*this.size,this.size)}render(i,e){this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(i,e),this._normal(i,e),i.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(i,e),this._normal(i,e),i.stroke())}_normal(i,e){i.beginPath(),i.moveTo(.5*this.size,this.size),i.lineTo(0,0),i.lineTo(-.5*this.size,this.size),i.closePath()}}s.NormalHead=r,r.__name__=\"NormalHead\",r.init_NormalHead();class z extends h{constructor(i){super(i)}static init_VeeHead(){this.mixins([\"line\",\"fill\"]),this.override({fill_color:\"black\"})}clip(i,e){this.visuals.line.set_vectorize(i,e),i.moveTo(.5*this.size,this.size),i.lineTo(.5*this.size,-2),i.lineTo(-.5*this.size,-2),i.lineTo(-.5*this.size,this.size),i.lineTo(0,.5*this.size),i.lineTo(.5*this.size,this.size)}render(i,e){this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(i,e),this._vee(i,e),i.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(i,e),this._vee(i,e),i.stroke())}_vee(i,e){i.beginPath(),i.moveTo(.5*this.size,this.size),i.lineTo(0,0),i.lineTo(-.5*this.size,this.size),i.lineTo(0,.5*this.size),i.closePath()}}s.VeeHead=z,z.__name__=\"VeeHead\",z.init_VeeHead();class _ extends h{constructor(i){super(i)}static init_TeeHead(){this.mixins([\"line\"])}render(i,e){this.visuals.line.doit&&(this.visuals.line.set_vectorize(i,e),i.beginPath(),i.moveTo(.5*this.size,0),i.lineTo(-.5*this.size,0),i.stroke())}clip(i,e){}}s.TeeHead=_,_.__name__=\"TeeHead\",_.init_TeeHead()},\n",
       "      function _(t,e,n){Object.defineProperty(n,\"__esModule\",{value:!0});const s=t(1),a=t(74),o=t(13),i=s.__importStar(t(19)),r=t(15),l=t(100),u=t(8),c=s.__importStar(t(102)),_=t(23),h=t(103);function d(t,e,n){if(u.isArray(t)){const s=t.concat(e);return null!=n&&s.length>n?s.slice(-n):s}if(u.isTypedArray(t)){const s=t.length+e.length;if(null!=n&&s>n){const a=s-n,o=t.length;let i;t.length<n?(i=new t.constructor(n),i.set(t,0)):i=t;for(let t=a,e=o;t<e;t++)i[t-a]=i[t];for(let t=0,n=e.length;t<n;t++)i[t+(o-a)]=e[t];return i}{const n=new t.constructor(e);return c.concat(t,n)}}throw new Error(\"unsupported array types\")}function m(t,e){let n,s,a;return u.isNumber(t)?(n=t,a=t+1,s=1):(n=null!=t.start?t.start:0,a=null!=t.stop?t.stop:e,s=null!=t.step?t.step:1),[n,a,s]}function f(t,e,n){const s=new r.Set;let a=!1;for(const[o,i]of e){let e,r,l,c;if(u.isArray(o)){const[a]=o;s.add(a),r=n[a],e=t[a],c=i,2===o.length?(r=[1,r[0]],l=[o[0],0,o[1]]):l=o}else u.isNumber(o)?(c=[i],s.add(o)):(c=i,a=!0),l=[0,0,o],r=[1,t.length],e=t;let _=0;const[h,d,f]=m(l[1],r[0]),[p,g,y]=m(l[2],r[1]);for(let t=h;t<d;t+=f)for(let n=p;n<g;n+=y)a&&s.add(n),e[t*r[1]+n]=c[_],_++}return s}n.stream_to_column=d,n.slice=m,n.patch_to_column=f;class p extends a.ColumnarDataSource{constructor(t){super(t)}static init_ColumnDataSource(){this.define({data:[i.Any,{}]})}initialize(){super.initialize(),[this.data,this._shapes]=l.decode_column_data(this.data)}attributes_as_json(t=!0,e=p._value_to_json){const n={},s=this.serializable_attributes();for(const e of _.keys(s)){let a=s[e];\"data\"===e&&(a=l.encode_column_data(a,this._shapes)),(t||e in this._set_after_defaults)&&(n[e]=a)}return e(\"attributes\",n,this)}static _value_to_json(t,e,n){return u.isPlainObject(e)&&\"data\"===t?l.encode_column_data(e,n._shapes):o.HasProps._value_to_json(t,e,n)}stream(t,e,n){const{data:s}=this;for(const n in t)s[n]=d(s[n],t[n],e);if(this.setv({data:s},{silent:!0}),this.streaming.emit(),null!=this.document){const s=new h.ColumnsStreamedEvent(this.document,this.ref(),t,e);this.document._notify_change(this,\"data\",null,null,{setter_id:n,hint:s})}}patch(t,e){const{data:n}=this;let s=new r.Set;for(const e in t){const a=t[e];s=s.union(f(n[e],a,this._shapes[e]))}if(this.setv({data:n},{silent:!0}),this.patching.emit(s.values),null!=this.document){const n=new h.ColumnsPatchedEvent(this.document,this.ref(),t);this.document._notify_change(this,\"data\",null,null,{setter_id:e,hint:n})}}}n.ColumnDataSource=p,p.__name__=\"ColumnDataSource\",p.init_ColumnDataSource()},\n",
       "      function _(t,n,e){Object.defineProperty(e,\"__esModule\",{value:!0});const a=t(1),s=t(75),i=t(14),r=t(70),c=t(77),l=a.__importStar(t(19)),o=t(8),u=t(9),h=t(23),g=t(76),_=t(99);class d extends s.DataSource{constructor(t){super(t)}get_array(t){let n=this.data[t];return null==n?this.data[t]=n=[]:o.isArray(n)||(this.data[t]=n=Array.from(n)),n}static init_ColumnarDataSource(){this.define({selection_policy:[l.Instance,()=>new _.UnionRenderers]}),this.internal({selection_manager:[l.Instance,t=>new c.SelectionManager({source:t})],inspected:[l.Instance,()=>new g.Selection],_shapes:[l.Any,{}]})}initialize(){super.initialize(),this._select=new i.Signal0(this,\"select\"),this.inspect=new i.Signal(this,\"inspect\"),this.streaming=new i.Signal0(this,\"streaming\"),this.patching=new i.Signal(this,\"patching\")}get_column(t){const n=this.data[t];return null!=n?n:null}columns(){return h.keys(this.data)}get_length(t=!0){const n=u.uniq(h.values(this.data).map(t=>t.length));switch(n.length){case 0:return null;case 1:return n[0];default:{const e=\"data source has columns of inconsistent lengths\";if(t)return r.logger.warn(e),n.sort()[0];throw new Error(e)}}}get_indices(){const t=this.get_length();return u.range(0,null!=t?t:1)}clear(){const t={};for(const n of this.columns())t[n]=new this.data[n].constructor(0);this.data=t}}e.ColumnarDataSource=d,d.__name__=\"ColumnarDataSource\",d.init_ColumnarDataSource()},\n",
       "      function _(e,t,a){Object.defineProperty(a,\"__esModule\",{value:!0});const c=e(1),n=e(69),o=e(76),i=c.__importStar(e(19));class r extends n.Model{constructor(e){super(e)}static init_DataSource(){this.define({selected:[i.Instance,()=>new o.Selection]})}}a.DataSource=r,r.__name__=\"DataSource\",r.init_DataSource()},\n",
       "      function _(i,e,s){Object.defineProperty(s,\"__esModule\",{value:!0});const t=i(1),n=i(69),l=t.__importStar(i(19)),_=i(9),h=i(23);class c extends n.Model{constructor(i){super(i)}static init_Selection(){this.define({indices:[l.Array,[]],line_indices:[l.Array,[]],multiline_indices:[l.Any,{}]}),this.internal({final:[l.Boolean],selected_glyphs:[l.Array,[]],get_view:[l.Any],image_indices:[l.Array,[]]})}initialize(){super.initialize(),this.get_view=()=>null}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,s){this.final=e,s?this.update_through_union(i):(this.indices=i.indices,this.line_indices=i.line_indices,this.selected_glyphs=i.selected_glyphs,this.get_view=i.get_view,this.multiline_indices=i.multiline_indices,this.image_indices=i.image_indices)}clear(){this.final=!0,this.indices=[],this.line_indices=[],this.multiline_indices={},this.get_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=_.union(i.indices,this.indices),this.selected_glyphs=_.union(i.selected_glyphs,this.selected_glyphs),this.line_indices=_.union(i.line_indices,this.line_indices),this.get_view()||(this.get_view=i.get_view),this.multiline_indices=h.merge(i.multiline_indices,this.multiline_indices)}update_through_intersection(i){this.indices=_.intersection(i.indices,this.indices),this.selected_glyphs=_.union(i.selected_glyphs,this.selected_glyphs),this.line_indices=_.union(i.line_indices,this.line_indices),this.get_view()||(this.get_view=i.get_view),this.multiline_indices=h.merge(i.multiline_indices,this.multiline_indices)}}s.Selection=c,c.__name__=\"Selection\",c.init_Selection()},\n",
       "      function _(e,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const s=e(1),n=e(13),o=e(76),c=e(78),r=e(97),l=s.__importStar(e(19));class _ extends n.HasProps{constructor(e){super(e),this.inspectors={}}static init_SelectionManager(){this.internal({source:[l.Any]})}select(e,t,i,s=!1){const n=[],o=[];for(const t of e)t instanceof c.GlyphRendererView?n.push(t):t instanceof r.GraphRendererView&&o.push(t);let l=!1;for(const e of o){const n=e.model.selection_policy.hit_test(t,e);l=l||e.model.selection_policy.do_selection(n,e.model,i,s)}if(n.length>0){const e=this.source.selection_policy.hit_test(t,n);l=l||this.source.selection_policy.do_selection(e,this.source,i,s)}return l}inspect(e,t){let i=!1;if(e instanceof c.GlyphRendererView){const s=e.hit_test(t);if(null!=s){i=!s.is_empty();const n=this.get_or_create_inspector(e.model);n.update(s,!0,!1),this.source.setv({inspected:n},{silent:!0}),this.source.inspect.emit([e,{geometry:t}])}}else if(e instanceof r.GraphRendererView){const s=e.model.inspection_policy.hit_test(t,e);i=i||e.model.inspection_policy.do_inspection(s,t,e,!1,!1)}return i}clear(e){this.source.selected.clear(),null!=e&&this.get_or_create_inspector(e.model).clear()}get_or_create_inspector(e){return null==this.inspectors[e.id]&&(this.inspectors[e.id]=new o.Selection),this.inspectors[e.id]}}i.SelectionManager=_,_.__name__=\"SelectionManager\",_.init_SelectionManager()},\n",
       "      function _(e,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const s=e(1),l=e(79),n=e(80),h=e(91),o=e(92),a=e(94),r=e(95),_=e(70),d=s.__importStar(e(19)),c=e(12),g=e(9),p=e(23),y=e(96),u=e(88),m={fill:{},line:{}},v={fill:{fill_alpha:.3,fill_color:\"grey\"},line:{line_alpha:.3,line_color:\"grey\"}},f={fill:{fill_alpha:.2},line:{}};class w extends l.DataRendererView{async lazy_initialize(){await super.lazy_initialize();const e=this.model.glyph,t=g.includes(e.mixins,\"fill\"),i=g.includes(e.mixins,\"line\"),s=p.clone(e.attributes);function l(l){const n=p.clone(s);return t&&p.extend(n,l.fill),i&&p.extend(n,l.line),new e.constructor(n)}delete s.id,this.glyph=await this.build_glyph_view(e);let{selection_glyph:n}=this.model;null==n?n=l({fill:{},line:{}}):\"auto\"===n&&(n=l(m)),this.selection_glyph=await this.build_glyph_view(n);let{nonselection_glyph:h}=this.model;null==h?h=l({fill:{},line:{}}):\"auto\"===h&&(h=l(f)),this.nonselection_glyph=await this.build_glyph_view(h);const{hover_glyph:o}=this.model;null!=o&&(this.hover_glyph=await this.build_glyph_view(o));const{muted_glyph:a}=this.model;null!=a&&(this.muted_glyph=await this.build_glyph_view(a));const r=l(v);this.decimated_glyph=await this.build_glyph_view(r),this.xscale=this.plot_view.frame.xscales[this.model.x_range_name],this.yscale=this.plot_view.frame.yscales[this.model.y_range_name],this.set_data(!1)}async build_glyph_view(e){return y.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(),this.connect(this.model.change,()=>this.request_render()),this.connect(this.model.glyph.change,()=>this.set_data()),this.connect(this.model.data_source.change,()=>this.set_data()),this.connect(this.model.data_source.streaming,()=>this.set_data()),this.connect(this.model.data_source.patching,e=>this.set_data(!0,e)),this.connect(this.model.data_source.selected.change,()=>this.request_render()),this.connect(this.model.data_source._select,()=>this.request_render()),null!=this.hover_glyph&&this.connect(this.model.data_source.inspect,()=>this.request_render()),this.connect(this.model.properties.view.change,()=>this.set_data()),this.connect(this.model.view.change,()=>this.set_data()),this.connect(this.model.properties.visible.change,()=>this.plot_view.update_dataranges());const{x_ranges:e,y_ranges:t}=this.plot_view.frame;for(const t in e){const i=e[t];i instanceof u.FactorRange&&this.connect(i.change,()=>this.set_data())}for(const e in t){const i=t[e];i instanceof u.FactorRange&&this.connect(i.change,()=>this.set_data())}this.connect(this.model.glyph.transformchange,()=>this.set_data())}have_selection_glyphs(){return null!=this.selection_glyph&&null!=this.nonselection_glyph}set_data(e=!0,t=null){const i=Date.now(),s=this.model.data_source;this.all_indices=this.model.view.indices,this.glyph.model.setv({x_range_name:this.model.x_range_name,y_range_name:this.model.y_range_name},{silent:!0}),this.glyph.set_data(s,this.all_indices,t),this.glyph.set_visuals(s),this.decimated_glyph.set_visuals(s),this.have_selection_glyphs()&&(this.selection_glyph.set_visuals(s),this.nonselection_glyph.set_visuals(s)),null!=this.hover_glyph&&this.hover_glyph.set_visuals(s),null!=this.muted_glyph&&this.muted_glyph.set_visuals(s);const{lod_factor:l}=this.plot_model;this.decimated=[];for(let e=0,t=Math.floor(this.all_indices.length/l);e<t;e++)this.decimated.push(e*l);const n=Date.now()-i;_.logger.debug(`${this.glyph.model.type} GlyphRenderer (${this.model.id}): set_data finished in ${n}ms`),this.set_data_timestamp=Date.now(),e&&this.request_render()}get has_webgl(){return this.glyph.has_webgl}render(){if(!this.model.visible)return;const e=Date.now(),t=this.has_webgl;this.glyph.map_data();const i=Date.now()-e,s=Date.now();let l=this.glyph.mask_data(this.all_indices);l.length===this.all_indices.length&&(l=g.range(0,this.all_indices.length));const r=Date.now()-s,{ctx:d}=this.plot_view.canvas_view;d.save();const{selected:p}=this.model.data_source;let y;y=!p||p.is_empty()?[]:this.glyph instanceof n.LineView&&p.selected_glyph===this.glyph.model?this.model.view.convert_indices_from_subset(l):p.indices;const{inspected:u}=this.model.data_source,m=new Set((()=>!u||u.is_empty()?[]:u.selected_glyph?this.model.view.convert_indices_from_subset(l):u.indices.length>0?u.indices:c.map(Object.keys(u.multiline_indices),e=>parseInt(e)))()),v=c.filter(l,e=>m.has(this.all_indices[e])),{lod_threshold:f}=this.plot_model;let w,b,x;null!=this.model.document&&this.model.document.interactive_duration()>0&&!t&&null!=f&&this.all_indices.length>f?(l=this.decimated,w=this.decimated_glyph,b=this.decimated_glyph,x=this.selection_glyph):(w=this.model.muted&&null!=this.muted_glyph?this.muted_glyph:this.glyph,b=this.nonselection_glyph,x=this.selection_glyph),null!=this.hover_glyph&&v.length&&(l=g.difference(l,v));let D,R=null;if(y.length&&this.have_selection_glyphs()){const e=Date.now(),t={};for(const e of y)t[e]=!0;const i=new Array,s=new Array;if(this.glyph instanceof n.LineView)for(const e of this.all_indices)null!=t[e]?i.push(e):s.push(e);else for(const e of l)null!=t[this.all_indices[e]]?i.push(e):s.push(e);R=Date.now()-e,D=Date.now(),b.render(d,s,this.glyph),x.render(d,i,this.glyph),null!=this.hover_glyph&&(this.glyph instanceof n.LineView?this.hover_glyph.render(d,this.model.view.convert_indices_from_subset(v),this.glyph):this.hover_glyph.render(d,v,this.glyph))}else if(D=Date.now(),this.glyph instanceof n.LineView)this.hover_glyph&&v.length?this.hover_glyph.render(d,this.model.view.convert_indices_from_subset(v),this.glyph):w.render(d,this.all_indices,this.glyph);else if(this.glyph instanceof h.PatchView||this.glyph instanceof o.HAreaView||this.glyph instanceof a.VAreaView)if(0==u.selected_glyphs.length||null==this.hover_glyph)w.render(d,this.all_indices,this.glyph);else for(const e of u.selected_glyphs)e.id==this.glyph.model.id&&this.hover_glyph.render(d,this.all_indices,this.glyph);else w.render(d,l,this.glyph),this.hover_glyph&&v.length&&this.hover_glyph.render(d,v,this.glyph);const V=Date.now()-D;this.last_dtrender=V;const $=Date.now()-e;_.logger.debug(`${this.glyph.model.type} GlyphRenderer (${this.model.id}): render finished in ${$}ms`),_.logger.trace(` - map_data finished in       : ${i}ms`),_.logger.trace(` - mask_data finished in      : ${r}ms`),null!=R&&_.logger.trace(` - selection mask finished in : ${R}ms`),_.logger.trace(` - glyph renders finished in  : ${V}ms`),d.restore()}draw_legend(e,t,i,s,l,n,h,o){null==o&&(o=this.model.get_reference_point(n,h)),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=w,w.__name__=\"GlyphRendererView\";class b extends l.DataRenderer{constructor(e){super(e)}static init_GlyphRenderer(){this.prototype.default_view=w,this.define({data_source:[d.Instance],view:[d.Instance,()=>new r.CDSView],glyph:[d.Instance],hover_glyph:[d.Instance],nonselection_glyph:[d.Any,\"auto\"],selection_glyph:[d.Any,\"auto\"],muted_glyph:[d.Instance],muted:[d.Boolean,!1]})}initialize(){super.initialize(),null==this.view.source&&(this.view.source=this.data_source,this.view.compute_indices())}get_reference_point(e,t){let i=0;if(null!=e){const s=this.data_source.get_column(e);if(null!=s){const e=c.indexOf(s,t);-1!=e&&(i=e)}}return i}get_selection_manager(){return this.data_source.selection_manager}}i.GlyphRenderer=b,b.__name__=\"GlyphRenderer\",b.init_GlyphRenderer()},\n",
       "      function _(e,r,n){Object.defineProperty(n,\"__esModule\",{value:!0});const t=e(1),a=e(63),_=t.__importStar(e(19));class i extends a.RendererView{}n.DataRendererView=i,i.__name__=\"DataRendererView\";class d extends a.Renderer{constructor(e){super(e)}static init_DataRenderer(){this.define({x_range_name:[_.String,\"default\"],y_range_name:[_.String,\"default\"]}),this.override({level:\"glyph\"})}}n.DataRenderer=d,d.__name__=\"DataRenderer\",d.init_DataRenderer()},\n",
       "      function _(e,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const s=e(1),n=e(81),_=e(90),l=s.__importStar(e(87));class r extends n.XYGlyphView{_render(e,t,{sx:i,sy:s}){let n=!1,_=null;this.visuals.line.set_value(e);for(const l of t){if(n){if(!isFinite(i[l]+s[l])){e.stroke(),e.beginPath(),n=!1,_=l;continue}null!=_&&l-_>1&&(e.stroke(),n=!1)}n?e.lineTo(i[l],s[l]):(e.beginPath(),e.moveTo(i[l],s[l]),n=!0),_=l}n&&e.stroke()}_hit_point(e){const t=l.create_empty_hit_test_result(),i={x:e.sx,y:e.sy};let s=9999;const n=Math.max(2,this.visuals.line.line_width.value()/2);for(let e=0,_=this.sx.length-1;e<_;e++){const _={x:this.sx[e],y:this.sy[e]},r={x:this.sx[e+1],y:this.sy[e+1]},h=l.dist_to_segment(i,_,r);h<n&&h<s&&(s=h,t.add_to_selected_glyphs(this.model),t.get_view=()=>this,t.line_indices=[e])}return t}_hit_span(e){const{sx:t,sy:i}=e,s=l.create_empty_hit_test_result();let n,_;\"v\"==e.direction?(n=this.renderer.yscale.invert(i),_=this._y):(n=this.renderer.xscale.invert(t),_=this._x);for(let e=0,t=_.length-1;e<t;e++)(_[e]<=n&&n<=_[e+1]||_[e+1]<=n&&n<=_[e])&&(s.add_to_selected_glyphs(this.model),s.get_view=()=>this,s.line_indices.push(e));return s}get_interpolation_hit(e,t){const[i,s,n,l]=[this._x[e],this._y[e],this._x[e+1],this._y[e+1]];return _.line_interpolation(this.renderer,t,i,s,n,l)}draw_legend_for_index(e,t,i){_.generic_line_legend(this.visuals,e,t,i)}}i.LineView=r,r.__name__=\"LineView\";class h extends n.XYGlyph{constructor(e){super(e)}static init_Line(){this.prototype.default_view=r,this.mixins([\"line\"])}}i.Line=h,h.__name__=\"Line\",h.init_Line()},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=e(82),n=e(86);class _ extends n.GlyphView{_index_data(){const e=[];for(let t=0,s=this._x.length;t<s;t++){const s=this._x[t],i=this._y[t];!isNaN(s+i)&&isFinite(s+i)&&e.push({x0:s,y0:i,x1:s,y1:i,i:t})}return new i.SpatialIndex(e)}scenterx(e){return this.sx[e]}scentery(e){return this.sy[e]}}s.XYGlyphView=_,_.__name__=\"XYGlyphView\";class h extends n.Glyph{constructor(e){super(e)}static init_XYGlyph(){this.coords([[\"x\",\"y\"]])}}s.XYGlyph=h,h.__name__=\"XYGlyph\",h.init_XYGlyph()},\n",
       "      function _(n,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const e=n(1).__importDefault(n(83)),s=n(85);class r{constructor(n){if(this.points=n,this.index=null,n.length>0){this.index=new e.default(n.length);for(const t of n){const{x0:n,y0:i,x1:e,y1:s}=t;this.index.add(n,i,e,s)}this.index.finish()}}_normalize(n){let{x0:t,y0:i,x1:e,y1:s}=n;return t>e&&([t,e]=[e,t]),i>s&&([i,s]=[s,i]),{x0:t,y0:i,x1:e,y1:s}}get bbox(){if(null==this.index)return s.empty();{const{minX:n,minY:t,maxX:i,maxY:e}=this.index;return{x0:n,y0:t,x1:i,y1:e}}}search(n){if(null==this.index)return[];{const{x0:t,y0:i,x1:e,y1:s}=this._normalize(n);return this.index.search(t,i,e,s).map(n=>this.points[n])}}indices(n){return this.search(n).map(({i:n})=>n)}}i.SpatialIndex=r,r.__name__=\"SpatialIndex\"},\n",
       "      function _(t,s,i){Object.defineProperty(i,\"__esModule\",{value:!0});const e=t(1).__importDefault(t(84)),h=[Int8Array,Uint8Array,Uint8ClampedArray,Int16Array,Uint16Array,Int32Array,Uint32Array,Float32Array,Float64Array];class n{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),[o]=new Uint32Array(t,4,1);return new n(o,e,h[15&i],t)}constructor(t,s=16,i=Float64Array,n){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 o=t,r=o;this._levelBounds=[4*o];do{o=Math.ceil(o/this.nodeSize),r+=o,this._levelBounds.push(4*r)}while(1!==o);this.ArrayType=i||Float64Array,this.IndexArrayType=r<16384?Uint16Array:Uint32Array;const a=h.indexOf(this.ArrayType),_=4*r*this.ArrayType.BYTES_PER_ELEMENT;if(a<0)throw new Error(`Unexpected typed array class: ${i}.`);n&&n instanceof ArrayBuffer?(this.data=n,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 e.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}.`);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++],d=Math.floor(65535*((n+r)/2-this.minX)/t),l=Math.floor(65535*((o+a)/2-this.minY)/s);i[e]=_(d,l)}!function t(s,i,e,h,n){if(h>=n)return;const o=s[h+n>>1];let r=h-1,_=n+1;for(;;){do{r++}while(s[r]<o);do{_--}while(s[_]>o);if(r>=_)break;a(s,i,e,r,_)}t(s,i,e,h,_),t(s,i,e,_+1,n)}(i,this._boxes,this._indices,0,this.numItems-1);for(let t=0,s=0;t<this._levelBounds.length-1;t++){const i=this._levelBounds[t];for(;s<i;){let t=1/0,e=1/0,h=-1/0,n=-1/0;const o=s;for(let o=0;o<this.nodeSize&&s<i;o++){const i=this._boxes[s++],o=this._boxes[s++],r=this._boxes[s++],a=this._boxes[s++];i<t&&(t=i),o<e&&(e=o),r>h&&(h=r),a>n&&(n=a)}this._indices[this._pos>>2]=o,this._boxes[this._pos++]=t,this._boxes[this._pos++]=e,this._boxes[this._pos++]=h,this._boxes[this._pos++]=n}}}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,o=this._levelBounds.length-1;const r=[],a=[];for(;void 0!==n;){const _=Math.min(n+4*this.nodeSize,this._levelBounds[o]);for(let d=n;d<_;d+=4){const _=0|this._indices[d>>2];i<this._boxes[d]||(e<this._boxes[d+1]||t>this._boxes[d+2]||s>this._boxes[d+3]||(n<4*this.numItems?(void 0===h||h(_))&&a.push(_):(r.push(_),r.push(o-1))))}o=r.pop(),n=r.pop()}return a}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 a=this._queue,_=[],d=e*e;for(;void 0!==n;){const e=Math.min(n+4*this.nodeSize,r(n,this._levelBounds));for(let i=n;i<e;i+=4){const e=0|this._indices[i>>2],r=o(t,this._boxes[i],this._boxes[i+2]),_=o(s,this._boxes[i+1],this._boxes[i+3]),d=r*r+_*_;n<4*this.numItems?(void 0===h||h(e))&&a.push(-e-1,d):a.push(e,d)}for(;a.length&&a.peek()<0;){if(a.peekValue()>d)return a.clear(),_;if(_.push(-a.pop()-1),_.length===i)return a.clear(),_}n=a.pop()}return a.clear(),_}}function o(t,s,i){return t<s?s-t:t<=i?0:t-i}function r(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 a(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],d=s[o+2],l=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]=d,s[r+3]=l;const u=i[e];i[e]=i[h],i[h]=u}function _(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 d=t^s,l=e|65535^(d|i);return d=16711935&(d|d<<8),d=252645135&(d|d<<4),d=858993459&(d|d<<2),d=1431655765&(d|d<<1),l=16711935&(l|l<<8),l=252645135&(l|l<<4),l=858993459&(l|l<<2),l=1431655765&(l|l<<1),(l<<1|d)>>>0}i.default=n},\n",
       "      function _(s,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});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,e=this.values[s];if(t>=e)break;this.ids[i]=this.ids[s],this.values[i]=e,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 e=0;for(;e<i;){let s=1+(e<<1);const i=s+1;let h=this.ids[s],l=this.values[s];const n=this.values[i];if(i<this.length&&n<l&&(s=i,h=this.ids[i],l=n),l>=t)break;this.ids[e]=h,this.values[e]=l,e=s}this.ids[e]=s,this.values[e]=t}return s}peek(){return this.ids[0]}peekValue(){return this.values[0]}}},\n",
       "      function _(t,i,e){Object.defineProperty(e,\"__esModule\",{value:!0});const{min:h,max:r}=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:h(t.x0,i.x0),x1:r(t.x1,i.x1),y0:h(t.y0,i.y0),y1:r(t.y1,i.y1)}};class s{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}}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 rect(){return{x0:this.x0,y0:this.y0,x1:this.x1,y1:this.y1}}get box(){return{x:this.x,y:this.y,width:this.width,height:this.height}}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}contains(t,i){return t>=this.x0&&t<=this.x1&&i>=this.y0&&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]}union(t){return new s({x0:h(this.x0,t.x0),y0:h(this.y0,t.y0),x1:r(this.x1,t.x1),y1:r(this.y1,t.y1)})}equals(t){return this.x0==t.x0&&this.y0==t.y0&&this.x1==t.x1&&this.y1==t.y1}get xview(){return{compute:t=>this.left+t,v_compute:t=>{const i=new Float64Array(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 Float64Array(t.length),e=this.bottom;for(let h=0;h<t.length;h++)i[h]=e-t[h];return i}}}}e.BBox=s,s.__name__=\"BBox\"},\n",
       "      function _(t,e,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=t(1),n=i.__importStar(t(87)),r=i.__importStar(t(19)),a=i.__importStar(t(85)),_=i.__importStar(t(30)),l=i.__importStar(t(68)),o=t(65),h=t(69),c=t(70),d=t(12),p=t(23),y=t(8),u=t(80),g=t(88);class m extends o.View{constructor(){super(...arguments),this._nohit_warned=new Set}get renderer(){return this.parent}get has_webgl(){return null!=this.glglyph}initialize(){super.initialize(),this.visuals=new l.Visuals(this.model)}async lazy_initialize(){await super.lazy_initialize();const{webgl:e}=this.renderer.plot_view.canvas_view;if(null!=e){let s=null;try{s=await Promise.resolve().then(()=>i.__importStar(t(358)))}catch(t){if(\"MODULE_NOT_FOUND\"!==t.code)throw t;c.logger.warn(\"WebGL was requested and is supported, but bokeh-gl(.min).js is not available, falling back to 2D rendering.\")}if(null!=s){const t=s[this.model.type+\"GLGlyph\"];null!=t&&(this.glglyph=new t(e.gl,this))}}}set_visuals(t){this.visuals.warm_cache(t),null!=this.glglyph&&this.glglyph.set_visuals_changed()}render(t,e,s){t.beginPath(),null!=this.glglyph&&this.glglyph.render(t,e,s)||this._render(t,e,s)}has_finished(){return!0}notify_finished(){this.renderer.notify_finished()}_bounds(t){return t}bounds(){return this._bounds(this.index.bbox)}log_bounds(){const t=a.empty(),e=this.index.search(a.positive_x());for(const s of e)s.x0<t.x0&&(t.x0=s.x0),s.x1>t.x1&&(t.x1=s.x1);const s=this.index.search(a.positive_y());for(const e of s)e.y0<t.y0&&(t.y0=e.y0),e.y1>t.y1&&(t.y1=e.y1);return this._bounds(t)}get_anchor_point(t,e,[s,i]){switch(t){case\"center\":return{x:this.scenterx(e,s,i),y:this.scentery(e,s,i)};default:return null}}sdist(t,e,s,i=\"edge\",n=!1){let r,a;const _=e.length;if(\"center\"==i){const t=d.map(s,t=>t/2);r=new Float64Array(_);for(let s=0;s<_;s++)r[s]=e[s]-t[s];a=new Float64Array(_);for(let s=0;s<_;s++)a[s]=e[s]+t[s]}else{r=e,a=new Float64Array(_);for(let t=0;t<_;t++)a[t]=r[t]+s[t]}const l=t.v_compute(r),o=t.v_compute(a);return n?d.map(l,(t,e)=>Math.ceil(Math.abs(o[e]-l[e]))):d.map(l,(t,e)=>Math.abs(o[e]-l[e]))}draw_legend_for_index(t,e,s){}hit_test(t){switch(t.type){case\"point\":if(null!=this._hit_point)return this._hit_point(t);break;case\"span\":if(null!=this._hit_span)return this._hit_span(t);break;case\"rect\":if(null!=this._hit_rect)return this._hit_rect(t);break;case\"poly\":if(null!=this._hit_poly)return this._hit_poly(t)}return this._nohit_warned.has(t.type)||(c.logger.debug(`'${t.type}' selection not available for ${this.model.type}`),this._nohit_warned.add(t.type)),null}_hit_rect_against_index(t){const{sx0:e,sx1:s,sy0:i,sy1:r}=t,[a,_]=this.renderer.xscale.r_invert(e,s),[l,o]=this.renderer.yscale.r_invert(i,r),h=n.create_empty_hit_test_result();return h.indices=this.index.indices({x0:a,x1:_,y0:l,y1:o}),h}set_data(t,e,s){let i=this.model.materialize_dataspecs(t);if(this.visuals.set_all_indices(e),e&&!(this instanceof u.LineView)){const t={};for(const s in i){const n=i[s];\"_\"===s.charAt(0)?t[s]=e.map(t=>n[t]):t[s]=n}i=t}const n=this;if(p.extend(n,i),this.renderer.plot_view.model.use_map&&(null!=n._x&&([n._x,n._y]=_.project_xy(n._x,n._y)),null!=n._xs&&([n._xs,n._ys]=_.project_xsys(n._xs,n._ys)),null!=n._x0&&([n._x0,n._y0]=_.project_xy(n._x0,n._y0)),null!=n._x1&&([n._x1,n._y1]=_.project_xy(n._x1,n._y1))),null!=this.renderer.plot_view.frame.x_ranges){const t=this.renderer.plot_view.frame.x_ranges[this.model.x_range_name],e=this.renderer.plot_view.frame.y_ranges[this.model.y_range_name];for(let[s,i]of this.model._coords)s=`_${s}`,i=`_${i}`,null!=n._xs?(t instanceof g.FactorRange&&(n[s]=d.map(n[s],e=>t.v_synthetic(e))),e instanceof g.FactorRange&&(n[i]=d.map(n[i],t=>e.v_synthetic(t)))):(t instanceof g.FactorRange&&(n[s]=t.v_synthetic(n[s])),e instanceof g.FactorRange&&(n[i]=e.v_synthetic(n[i])))}null!=this.glglyph&&this.glglyph.set_data_changed(n._x.length),this._set_data(s),this.index_data()}_set_data(t){}index_data(){this.index=this._index_data()}mask_data(t){return null!=this.glglyph||null==this._mask_data?t:this._mask_data()}map_data(){const t=this;for(let[e,s]of this.model._coords){const i=`s${e}`,n=`s${s}`;if(e=`_${e}`,s=`_${s}`,null!=t[e]&&(y.isArray(t[e][0])||y.isTypedArray(t[e][0]))){const r=t[e].length;t[i]=new Array(r),t[n]=new Array(r);for(let a=0;a<r;a++){const[r,_]=this.map_to_screen(t[e][a],t[s][a]);t[i][a]=r,t[n][a]=_}}else[t[i],t[n]]=this.map_to_screen(t[e],t[s])}this._map_data()}_map_data(){}map_to_screen(t,e){return this.renderer.plot_view.map_to_screen(t,e,this.model.x_range_name,this.model.y_range_name)}}s.GlyphView=m,m.__name__=\"GlyphView\";class x extends h.Model{constructor(t){super(t)}static init_Glyph(){this.prototype._coords=[],this.internal({x_range_name:[r.String,\"default\"],y_range_name:[r.String,\"default\"]})}static coords(t){const e=this.prototype._coords.concat(t);this.prototype._coords=e;const s={};for(const[e,i]of t)s[e]=[r.CoordinateSpec],s[i]=[r.CoordinateSpec];this.define(s)}}s.Glyph=x,x.__name__=\"Glyph\",x.init_Glyph()},\n",
       "      function _(t,n,e){Object.defineProperty(e,\"__esModule\",{value:!0});const i=t(9),r=t(76);function s(t){return t*t}function o(t,n){return s(t.x-n.x)+s(t.y-n.y)}function c(t,n,e){const i=o(n,e);if(0==i)return o(t,n);const r=((t.x-n.x)*(e.x-n.x)+(t.y-n.y)*(e.y-n.y))/i;return o(t,r<0?n:r>1?e:{x:n.x+r*(e.x-n.x),y:n.y+r*(e.y-n.y)})}e.point_in_poly=function(t,n,e,i){let r=!1,s=e[e.length-1],o=i[i.length-1];for(let c=0;c<e.length;c++){const u=e[c],_=i[c];o<n!=_<n&&s+(n-o)/(_-o)*(u-s)<t&&(r=!r),s=u,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.create_empty_hit_test_result=function(){return new r.Selection},e.create_hit_test_result_from_hits=function(t){const n=new r.Selection;return n.indices=i.sort_by(t,([t,n])=>n).map(([t,n])=>t),n},e.dist_2_pts=o,e.dist_to_segment_squared=c,e.dist_to_segment=function(t,n,e){return Math.sqrt(c(t,n,e))},e.check_2_segments_intersect=function(t,n,e,i,r,s,o,c){const u=(c-s)*(e-t)-(o-r)*(i-n);if(0==u)return{hit:!1,x:null,y:null};{let _=n-s,l=t-r;const h=(e-t)*_-(i-n)*l;return _=((o-r)*_-(c-s)*l)/u,l=h/u,{hit:_>0&&_<1&&l>0&&l<1,x:t+_*(e-t),y:n+_*(i-n)}}}},\n",
       "      function _(t,n,e){Object.defineProperty(e,\"__esModule\",{value:!0});const i=t(1),s=t(89),r=i.__importStar(t(19)),a=t(12),o=t(9),p=t(8),h=t(11);function g(t,n,e=0){const i={};for(let s=0;s<t.length;s++){const r=t[s];if(r in i)throw new Error(`duplicate factor or subfactor: ${r}`);i[r]={value:.5+s*(1+n)+e}}return[i,(t.length-1)*n]}function c(t,n,e,i=0){const s={},r={},a=[];for(const[n,e]of t)n in r||(r[n]=[],a.push(n)),r[n].push(e);let p=i,h=0;for(const t of a){const i=r[t].length,[a,c]=g(r[t],e,p);h+=c;const u=o.sum(r[t].map(t=>a[t].value));s[t]={value:u/i,mapping:a},p+=i+n+c}return[s,a,(a.length-1)*n+h]}function u(t,n,e,i,s=0){const r={},a={},p=[];for(const[n,e,i]of t)n in a||(a[n]=[],p.push(n)),a[n].push([e,i]);const h=[];let g=s,u=0;for(const t of p){const s=a[t].length,[p,l,_]=c(a[t],e,i,g);for(const n of l)h.push([t,n]);u+=_;const d=o.sum(a[t].map(([t])=>p[t].value));r[t]={value:d/s,mapping:p},g+=s+n+_}return[r,p,h,(p.length-1)*n+u]}e.map_one_level=g,e.map_two_levels=c,e.map_three_levels=u;class l extends s.Range{constructor(t){super(t)}static init_FactorRange(){this.define({factors:[r.Array,[]],factor_padding:[r.Number,0],subgroup_padding:[r.Number,.8],group_padding:[r.Number,1.4],range_padding:[r.Number,0],range_padding_units:[r.PaddingUnits,\"percent\"],start:[r.Number],end:[r.Number]}),this.internal({levels:[r.Number],mids:[r.Array],tops:[r.Array],tops_groups:[r.Array]})}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){if(1==t.length){const n=this._mapping;return n.hasOwnProperty(t[0])?n[t[0]].value:NaN}if(2==t.length){const n=this._mapping;return n.hasOwnProperty(t[0])&&n[t[0]].mapping.hasOwnProperty(t[1])?n[t[0]].mapping[t[1]].value:NaN}if(3==t.length){const n=this._mapping;return n.hasOwnProperty(t[0])&&n[t[0]].mapping.hasOwnProperty(t[1])&&n[t[0]].mapping[t[1]].mapping.hasOwnProperty(t[2])?n[t[0]].mapping[t[1]].mapping[t[2]].value:NaN}h.unreachable()}synthetic(t){if(p.isNumber(t))return t;if(p.isString(t))return this._lookup([t]);let n=0;const e=t[t.length-1];return p.isNumber(e)&&(n=e,t=t.slice(0,-1)),this._lookup(t)+n}v_synthetic(t){return a.map(t,t=>this.synthetic(t))}_init(t){let n,e;if(o.every(this.factors,p.isString))n=1,[this._mapping,e]=g(this.factors,this.factor_padding);else if(o.every(this.factors,t=>p.isArray(t)&&2==t.length&&p.isString(t[0])&&p.isString(t[1])))n=2,[this._mapping,this.tops,e]=c(this.factors,this.group_padding,this.factor_padding);else{if(!o.every(this.factors,t=>p.isArray(t)&&3==t.length&&p.isString(t[0])&&p.isString(t[1])&&p.isString(t[2])))throw new Error(\"???\");n=3,[this._mapping,this.tops,this.mids,e]=u(this.factors,this.group_padding,this.subgroup_padding,this.factor_padding)}let i=0,s=this.factors.length+e;if(\"percent\"==this.range_padding_units){const t=(s-i)*this.range_padding/2;i-=t,s+=t}else i-=this.range_padding,s+=this.range_padding;this.setv({start:i,end:s,levels:n},{silent:t}),\"auto\"==this.bounds&&this.setv({bounds:[i,s]},{silent:!0})}}e.FactorRange=l,l.__name__=\"FactorRange\",l.init_FactorRange()},\n",
       "      function _(e,t,n){Object.defineProperty(n,\"__esModule\",{value:!0});const i=e(1),a=e(69),r=i.__importStar(e(19));class s extends a.Model{constructor(e){super(e),this.have_updated_interactively=!1}static init_Range(){this.define({bounds:[r.Any],min_interval:[r.Any],max_interval:[r.Any]}),this.internal({plots:[r.Array,[]]})}get is_reversed(){return this.start>this.end}}n.Range=s,s.__name__=\"Range\",s.init_Range()},\n",
       "      function _(e,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const n=e(1).__importStar(e(87));i.generic_line_legend=function(e,t,{x0:i,x1:n,y0:c,y1:o},r){t.save(),t.beginPath(),t.moveTo(i,(c+o)/2),t.lineTo(n,(c+o)/2),e.line.doit&&(e.line.set_vectorize(t,r),t.stroke()),t.restore()},i.generic_area_legend=function(e,t,{x0:i,x1:n,y0:c,y1:o},r){const l=.1*Math.abs(n-i),a=.1*Math.abs(o-c),s=i+l,_=n-l,h=c+a,v=o-a;e.fill.doit&&(e.fill.set_vectorize(t,r),t.fillRect(s,h,_-s,v-h)),null!=e.hatch&&e.hatch.doit&&(e.hatch.set_vectorize(t,r),t.fillRect(s,h,_-s,v-h)),e.line&&e.line.doit&&(t.beginPath(),t.rect(s,h,_-s,v-h),e.line.set_vectorize(t,r),t.stroke())},i.line_interpolation=function(e,t,i,c,o,r){const{sx:l,sy:a}=t;let s,_,h,v;\"point\"==t.type?([h,v]=e.yscale.r_invert(a-1,a+1),[s,_]=e.xscale.r_invert(l-1,l+1)):\"v\"==t.direction?([h,v]=e.yscale.r_invert(a,a),[s,_]=[Math.min(i-1,o-1),Math.max(i+1,o+1)]):([s,_]=e.xscale.r_invert(l,l),[h,v]=[Math.min(c-1,r-1),Math.max(c+1,r+1)]);const{x:x,y:y}=n.check_2_segments_intersect(s,h,_,v,i,c,o,r);return[x,y]}},\n",
       "      function _(e,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const s=e(1),l=e(81),_=e(90),n=s.__importStar(e(87));class a extends l.XYGlyphView{_inner_loop(e,t,i,s,l){for(const _ of t)0!=_?isNaN(i[_]+s[_])?(e.closePath(),l.apply(e),e.beginPath()):e.lineTo(i[_],s[_]):(e.beginPath(),e.moveTo(i[_],s[_]));e.closePath(),l.call(e)}_render(e,t,{sx:i,sy:s}){this.visuals.fill.doit&&(this.visuals.fill.set_value(e),this._inner_loop(e,t,i,s,e.fill)),this.visuals.hatch.doit2(e,0,()=>this._inner_loop(e,t,i,s,e.fill),()=>this.renderer.request_render()),this.visuals.line.doit&&(this.visuals.line.set_value(e),this._inner_loop(e,t,i,s,e.stroke))}draw_legend_for_index(e,t,i){_.generic_area_legend(this.visuals,e,t,i)}_hit_point(e){const t=n.create_empty_hit_test_result();return n.point_in_poly(e.sx,e.sy,this.sx,this.sy)&&(t.add_to_selected_glyphs(this.model),t.get_view=()=>this),t}}i.PatchView=a,a.__name__=\"PatchView\";class o extends l.XYGlyph{constructor(e){super(e)}static init_Patch(){this.prototype.default_view=a,this.mixins([\"line\",\"fill\",\"hatch\"])}}i.Patch=o,o.__name__=\"Patch\",o.init_Patch()},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=e(1),r=e(93),n=e(82),_=i.__importStar(e(87)),a=i.__importStar(e(19));class h extends r.AreaView{_index_data(){const e=[];for(let t=0,s=this._x1.length;t<s;t++){const s=this._x1[t],i=this._x2[t],r=this._y[t];!isNaN(s+i+r)&&isFinite(s+i+r)&&e.push({x0:Math.min(s,i),y0:r,x1:Math.max(s,i),y1:r,i:t})}return new n.SpatialIndex(e)}_inner(e,t,s,i,r){e.beginPath();for(let s=0,r=t.length;s<r;s++)e.lineTo(t[s],i[s]);for(let t=s.length-1;t>=0;t--)e.lineTo(s[t],i[t]);e.closePath(),r.call(e)}_render(e,t,{sx1:s,sx2:i,sy:r}){this.visuals.fill.doit&&(this.visuals.fill.set_value(e),this._inner(e,s,i,r,e.fill)),this.visuals.hatch.doit2(e,0,()=>this._inner(e,s,i,r,e.fill),()=>this.renderer.request_render())}_hit_point(e){const t=_.create_empty_hit_test_result(),s=this.sy.length,i=new Float64Array(2*s),r=new Float64Array(2*s);for(let e=0,t=s;e<t;e++)i[e]=this.sx1[e],r[e]=this.sy[e],i[s+e]=this.sx2[s-e-1],r[s+e]=this.sy[s-e-1];return _.point_in_poly(e.sx,e.sy,i,r)&&(t.add_to_selected_glyphs(this.model),t.get_view=()=>this),t}scenterx(e){return(this.sx1[e]+this.sx2[e])/2}scentery(e){return this.sy[e]}_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=h,h.__name__=\"HAreaView\";class l extends r.Area{constructor(e){super(e)}static init_HArea(){this.prototype.default_view=h,this.define({x1:[a.CoordinateSpec],x2:[a.CoordinateSpec],y:[a.CoordinateSpec]})}}s.HArea=l,l.__name__=\"HArea\",l.init_HArea()},\n",
       "      function _(e,i,_){Object.defineProperty(_,\"__esModule\",{value:!0});const a=e(86),n=e(90);class s extends a.GlyphView{draw_legend_for_index(e,i,_){n.generic_area_legend(this.visuals,e,i,_)}}_.AreaView=s,s.__name__=\"AreaView\";class r extends a.Glyph{constructor(e){super(e)}static init_Area(){this.mixins([\"fill\",\"hatch\"])}}_.Area=r,r.__name__=\"Area\",r.init_Area()},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=e(1),r=e(93),n=e(82),_=i.__importStar(e(87)),a=i.__importStar(e(19));class h extends r.AreaView{_index_data(){const e=[];for(let t=0,s=this._x.length;t<s;t++){const s=this._x[t],i=this._y1[t],r=this._y2[t];!isNaN(s+i+r)&&isFinite(s+i+r)&&e.push({x0:s,y0:Math.min(i,r),x1:s,y1:Math.max(i,r),i:t})}return new n.SpatialIndex(e)}_inner(e,t,s,i,r){e.beginPath();for(let i=0,r=s.length;i<r;i++)e.lineTo(t[i],s[i]);for(let s=i.length-1;s>=0;s--)e.lineTo(t[s],i[s]);e.closePath(),r.call(e)}_render(e,t,{sx:s,sy1:i,sy2:r}){this.visuals.fill.doit&&(this.visuals.fill.set_value(e),this._inner(e,s,i,r,e.fill)),this.visuals.hatch.doit2(e,0,()=>this._inner(e,s,i,r,e.fill),()=>this.renderer.request_render())}scenterx(e){return this.sx[e]}scentery(e){return(this.sy1[e]+this.sy2[e])/2}_hit_point(e){const t=_.create_empty_hit_test_result(),s=this.sx.length,i=new Float64Array(2*s),r=new Float64Array(2*s);for(let e=0,t=s;e<t;e++)i[e]=this.sx[e],r[e]=this.sy1[e],i[s+e]=this.sx[s-e-1],r[s+e]=this.sy2[s-e-1];return _.point_in_poly(e.sx,e.sy,i,r)&&(t.add_to_selected_glyphs(this.model),t.get_view=()=>this),t}_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=h,h.__name__=\"VAreaView\";class l extends r.Area{constructor(e){super(e)}static init_VArea(){this.prototype.default_view=h,this.define({x:[a.CoordinateSpec],y1:[a.CoordinateSpec],y2:[a.CoordinateSpec]})}}s.VArea=l,l.__name__=\"VArea\",l.init_VArea()},\n",
       "      function _(i,e,s){Object.defineProperty(s,\"__esModule\",{value:!0});const t=i(1),n=i(69),c=t.__importStar(i(19)),o=i(76),r=i(9),_=i(74);class h extends n.Model{constructor(i){super(i)}static init_CDSView(){this.define({filters:[c.Array,[]],source:[c.Instance]}),this.internal({indices:[c.Array,[]],indices_map:[c.Any,{}]})}initialize(){super.initialize(),this.compute_indices()}connect_signals(){super.connect_signals(),this.connect(this.properties.filters.change,()=>{this.compute_indices(),this.change.emit()});const i=()=>{const i=()=>this.compute_indices();null!=this.source&&(this.connect(this.source.change,i),this.source instanceof _.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(){const i=this.filters.map(i=>i.compute_indices(this.source)).filter(i=>null!=i);i.length>0?this.indices=r.intersection.apply(this,i):this.source instanceof _.ColumnarDataSource&&(this.indices=this.source.get_indices()),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=new o.Selection;e.update_through_union(i);const s=i.indices.map(i=>this.indices[i]);return e.indices=s,e.image_indices=i.image_indices,e}convert_selection_to_subset(i){const e=new o.Selection;e.update_through_union(i);const s=i.indices.map(i=>this.indices_map[i]);return e.indices=s,e.image_indices=i.image_indices,e}convert_indices_from_subset(i){return i.map(i=>this.indices[i])}}s.CDSView=h,h.__name__=\"CDSView\",h.init_CDSView()},\n",
       "      function _(e,n,t){Object.defineProperty(t,\"__esModule\",{value:!0});const i=e(9);async function o(e,n,t){const i=new e(Object.assign(Object.assign({},t),{model:n}));return i.initialize(),await i.lazy_initialize(),i}t.build_view=async function(e,n={parent:null},t=(e=>e.default_view)){const i=await o(t(e),e,n);return i.connect_signals(),i},t.build_views=async function(e,n,t={parent:null},c=(e=>e.default_view)){const s=i.difference(Object.keys(e),n.map(e=>e.id));for(const n of s)e[n].remove(),delete e[n];const a=[],l=n.filter(n=>null==e[n.id]);for(const n of l){const i=await o(c(n),n,t);e[n.id]=i,a.push(i)}for(const e of a)e.connect_signals();return a},t.remove_views=function(e){for(const n in e)e[n].remove(),delete e[n]}},\n",
       "      function _(e,t,n){Object.defineProperty(n,\"__esModule\",{value:!0});const s=e(1),r=e(79),a=e(98),i=s.__importStar(e(19)),d=e(96);class _ extends r.DataRendererView{initialize(){super.initialize(),this.xscale=this.plot_view.frame.xscales.default,this.yscale=this.plot_view.frame.yscales.default,this._renderer_views={}}async lazy_initialize(){[this.node_view,this.edge_view]=await d.build_views(this._renderer_views,[this.model.node_renderer,this.model.edge_renderer],{parent:this.parent}),this.set_data()}connect_signals(){super.connect_signals(),this.connect(this.model.layout_provider.change,()=>this.set_data()),this.connect(this.model.node_renderer.data_source._select,()=>this.set_data()),this.connect(this.model.node_renderer.data_source.inspect,()=>this.set_data()),this.connect(this.model.node_renderer.data_source.change,()=>this.set_data()),this.connect(this.model.edge_renderer.data_source._select,()=>this.set_data()),this.connect(this.model.edge_renderer.data_source.inspect,()=>this.set_data()),this.connect(this.model.edge_renderer.data_source.change,()=>this.set_data());const{x_ranges:e,y_ranges:t}=this.plot_view.frame;for(const t in e){const n=e[t];this.connect(n.change,()=>this.set_data())}for(const e in t){const n=t[e];this.connect(n.change,()=>this.set_data())}}set_data(e=!0){this.node_view.glyph.model.setv({x_range_name:this.model.x_range_name,y_range_name:this.model.y_range_name},{silent:!0}),this.edge_view.glyph.model.setv({x_range_name:this.model.x_range_name,y_range_name:this.model.y_range_name},{silent:!0});const t=this.node_view.glyph;[t._x,t._y]=this.model.layout_provider.get_node_coordinates(this.model.node_renderer.data_source);const n=this.edge_view.glyph;[n._xs,n._ys]=this.model.layout_provider.get_edge_coordinates(this.model.edge_renderer.data_source),t.index_data(),n.index_data(),e&&this.request_render()}render(){this.edge_view.render(),this.node_view.render()}}n.GraphRendererView=_,_.__name__=\"GraphRendererView\";class o extends r.DataRenderer{constructor(e){super(e)}static init_GraphRenderer(){this.prototype.default_view=_,this.define({layout_provider:[i.Instance],node_renderer:[i.Instance],edge_renderer:[i.Instance],selection_policy:[i.Instance,()=>new a.NodesOnly],inspection_policy:[i.Instance,()=>new a.NodesOnly]})}get_selection_manager(){return this.node_renderer.data_source.selection_manager}}n.GraphRenderer=o,o.__name__=\"GraphRenderer\",o.init_GraphRenderer()},\n",
       "      function _(e,t,d){Object.defineProperty(d,\"__esModule\",{value:!0});const n=e(69),s=e(12),o=e(9),_=e(87);class i extends n.Model{constructor(e){super(e)}_hit_test_nodes(e,t){if(!t.model.visible)return null;const d=t.node_view.glyph.hit_test(e);return null==d?null:t.node_view.model.view.convert_selection_from_subset(d)}_hit_test_edges(e,t){if(!t.model.visible)return null;const d=t.edge_view.glyph.hit_test(e);return null==d?null:t.edge_view.model.view.convert_selection_from_subset(d)}}d.GraphHitTestPolicy=i,i.__name__=\"GraphHitTestPolicy\";class r extends i{constructor(e){super(e)}hit_test(e,t){return this._hit_test_nodes(e,t)}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 o=d.model.get_selection_manager().get_or_create_inspector(d.node_view.model);return o.update(e,n,s),d.node_view.model.data_source.setv({inspected:o},{silent:!0}),d.node_view.model.data_source.inspect.emit([d.node_view,{geometry:t}]),!o.is_empty()}}d.NodesOnly=r,r.__name__=\"NodesOnly\";class c extends i{constructor(e){super(e)}hit_test(e,t){return this._hit_test_nodes(e,t)}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++)(o.contains(n,t.data.start[e])||o.contains(n,t.data.end[e]))&&s.push(e);const i=_.create_empty_hit_test_result();for(const e of s)i.multiline_indices[e]=[0];return i.indices=s,i}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,_=this.get_linked_edges(t.node_renderer.data_source,t.edge_renderer.data_source,\"selection\");return o.update(_,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 _=d.edge_view.model.data_source.selection_manager.get_or_create_inspector(d.edge_view.model),i=this.get_linked_edges(d.node_view.model.data_source,d.edge_view.model.data_source,\"inspection\");return _.update(i,n,s),d.edge_view.model.data_source.setv({inspected:_},{silent:!0}),d.node_view.model.data_source.inspect.emit([d.node_view,{geometry:t}]),!o.is_empty()}}d.NodesAndLinkedEdges=c,c.__name__=\"NodesAndLinkedEdges\";class a extends i{constructor(e){super(e)}hit_test(e,t){return this._hit_test_edges(e,t)}get_linked_nodes(e,t,d){let n=[];\"selection\"==d?n=t.selected.indices:\"inspection\"==d&&(n=t.inspected.indices);const i=[];for(const e of n)i.push(t.data.start[e]),i.push(t.data.end[e]);const r=o.uniq(i).map(t=>s.indexOf(e.data.index,t)),c=_.create_empty_hit_test_result();return c.indices=r,c}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,_=this.get_linked_nodes(t.node_renderer.data_source,t.edge_renderer.data_source,\"selection\");return o.update(_,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 _=d.node_view.model.data_source.selection_manager.get_or_create_inspector(d.node_view.model),i=this.get_linked_nodes(d.node_view.model.data_source,d.edge_view.model.data_source,\"inspection\");return _.update(i,n,s),d.node_view.model.data_source.setv({inspected:_},{silent:!0}),d.edge_view.model.data_source.inspect.emit([d.edge_view,{geometry:t}]),!o.is_empty()}}d.EdgesAndLinkedNodes=a,a.__name__=\"EdgesAndLinkedNodes\"},\n",
       "      function _(e,t,n){Object.defineProperty(n,\"__esModule\",{value:!0});const s=e(69);class o extends s.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=o,o.__name__=\"SelectionPolicy\";class r extends o{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=r,r.__name__=\"IntersectRenderers\";class c extends o{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=c,c.__name__=\"UnionRenderers\"},\n",
       "      function _(r,n,t){Object.defineProperty(t,\"__esModule\",{value:!0});const e=r(8),a=r(101);function o(r){const n=new Uint8Array(r.buffer,r.byteOffset,2*r.length);for(let r=0,t=n.length;r<t;r+=2){const t=n[r];n[r]=n[r+1],n[r+1]=t}}function i(r){const n=new Uint8Array(r.buffer,r.byteOffset,4*r.length);for(let r=0,t=n.length;r<t;r+=4){let t=n[r];n[r]=n[r+3],n[r+3]=t,t=n[r+1],n[r+1]=n[r+2],n[r+2]=t}}function s(r){const n=new Uint8Array(r.buffer,r.byteOffset,8*r.length);for(let r=0,t=n.length;r<t;r+=8){let t=n[r];n[r]=n[r+7],n[r+7]=t,t=n[r+1],n[r+1]=n[r+6],n[r+6]=t,t=n[r+2],n[r+2]=n[r+5],n[r+5]=t,t=n[r+3],n[r+3]=n[r+4],n[r+4]=t}}function c(r,n){const e=r.order!==t.BYTE_ORDER,{shape:a}=r;let c=null;for(const t of n){if(JSON.parse(t[0]).id===r.__buffer__){c=t[1];break}}const f=new t.ARRAY_TYPES[r.dtype](c);return e&&(2===f.BYTES_PER_ELEMENT?o(f):4===f.BYTES_PER_ELEMENT?i(f):8===f.BYTES_PER_ELEMENT&&s(f)),[f,a]}function f(r,n){return e.isObject(r)&&\"__ndarray__\"in r?A(r):e.isObject(r)&&\"__buffer__\"in r?c(r,n):e.isArray(r)||e.isTypedArray(r)?[r,[]]:void 0}function u(r){const n=new Uint8Array(r),t=Array.from(n).map(r=>String.fromCharCode(r));return btoa(t.join(\"\"))}function y(r){const n=atob(r),t=n.length,e=new Uint8Array(t);for(let r=0,a=t;r<a;r++)e[r]=n.charCodeAt(r);return e.buffer}function A(r){const n=y(r.__ndarray__),e=r.dtype,a=r.shape;let o;if(!(e in t.ARRAY_TYPES))throw new Error(`unknown dtype: ${e}`);return o=new t.ARRAY_TYPES[e](n),[o,a]}function l(r,n){const e=u(r.buffer),a=function(r){if(\"name\"in r.constructor)return r.constructor.name;switch(!0){case r instanceof Uint8Array:return\"Uint8Array\";case r instanceof Int8Array:return\"Int8Array\";case r instanceof Uint16Array:return\"Uint16Array\";case r instanceof Int16Array:return\"Int16Array\";case r instanceof Uint32Array:return\"Uint32Array\";case r instanceof Int32Array:return\"Int32Array\";case r instanceof Float32Array:return\"Float32Array\";case r instanceof Float64Array:return\"Float64Array\";default:throw new Error(\"unsupported typed array\")}}(r);let o;if(!(a in t.DTYPES))throw new Error(`unknown array type: ${a}`);return o=t.DTYPES[a],{__ndarray__:e,shape:n,dtype:o}}function _(r,n){if(0==r.length||!e.isObject(r[0])&&!e.isArray(r[0]))return[r,[]];const t=[],a=[];for(const o of r){const[r,i]=e.isArray(o)?_(o,n):f(o,n);t.push(r),a.push(i)}return[t,a.map(r=>r.filter(r=>0!=r.length))]}function d(r,n){const t=[];for(let a=0,o=r.length;a<o;a++){const o=r[a];if(e.isTypedArray(o)){const r=n[a]?n[a]:void 0;t.push(l(o,r))}else e.isArray(o)?t.push(d(o,n?n[a]:[])):t.push(o)}return t}t.ARRAY_TYPES={uint8:Uint8Array,int8:Int8Array,uint16:Uint16Array,int16:Int16Array,uint32:Uint32Array,int32:Int32Array,float32:Float32Array,float64:Float64Array},t.DTYPES={Uint8Array:\"uint8\",Int8Array:\"int8\",Uint16Array:\"uint16\",Int16Array:\"int16\",Uint32Array:\"uint32\",Int32Array:\"int32\",Float32Array:\"float32\",Float64Array:\"float64\"},t.BYTE_ORDER=a.is_little_endian?\"little\":\"big\",t.swap16=o,t.swap32=i,t.swap64=s,t.process_buffer=c,t.process_array=f,t.arrayBufferToBase64=u,t.base64ToArrayBuffer=y,t.decode_base64=A,t.encode_base64=l,t.decode_column_data=function(r,n=[]){const t={},a={};for(const o in r){const i=r[o];if(e.isArray(i)){if(0==i.length||!e.isObject(i[0])&&!e.isArray(i[0])){t[o]=i;continue}const[r,s]=_(i,n);t[o]=r,a[o]=s}else{const[r,e]=f(i,n);t[o]=r,a[o]=e}}return[t,a]},t.encode_column_data=function(r,n){const t={};for(const a in r){const o=r[a],i=null!=n?n[a]:void 0;let s;s=e.isTypedArray(o)?l(o,i):e.isArray(o)?d(o,i||[]):o,t[a]=s}return t}},\n",
       "      function _(e,n,i){Object.defineProperty(i,\"__esModule\",{value:!0}),i.is_ie=(()=>{const e=\"undefined\"!=typeof navigator?navigator.userAgent:\"\";return e.indexOf(\"MSIE\")>=0||e.indexOf(\"Trident\")>0||e.indexOf(\"Edge\")>0})(),i.is_mobile=\"undefined\"!=typeof window&&(\"ontouchstart\"in window||navigator.maxTouchPoints>0),i.is_little_endian=(()=>{const e=new ArrayBuffer(4),n=new Uint8Array(e);new Uint32Array(e)[1]=168496141;let i=!0;return 10==n[4]&&11==n[5]&&12==n[6]&&13==n[7]&&(i=!1),i})()},\n",
       "      function _(t,e,n){Object.defineProperty(n,\"__esModule\",{value:!0}),n.concat=function(t,...e){let n=t.length;for(const t of e)n+=t.length;const o=new t.constructor(n);o.set(t,0);let c=t.length;for(const t of e)o.set(t,c),c+=t.length;return o}},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});const n=e(13);class o{constructor(e){this.document=e}}s.DocumentChangedEvent=o,o.__name__=\"DocumentChangedEvent\";class r extends o{constructor(e,t,s){super(e),this.msg_type=t,this.msg_data=s}json(e){const t=this.msg_data,s=n.HasProps._value_to_json(\"\",t,null);return n.HasProps._value_record_references(t,{},!0),{kind:\"MessageSent\",msg_type:this.msg_type,msg_data:s}}}s.MessageSentEvent=r,r.__name__=\"MessageSentEvent\";class d extends o{constructor(e,t,s,n,o,r,d){super(e),this.model=t,this.attr=s,this.old=n,this.new_=o,this.setter_id=r,this.hint=d}json(e){if(\"id\"===this.attr)throw new Error(\"'id' field should never change, whatever code just set it is wrong\");if(null!=this.hint)return this.hint.json(e);const t=this.new_,s=n.HasProps._value_to_json(this.attr,t,this.model),o={};n.HasProps._value_record_references(t,o,!0),this.model.id in o&&this.model!==t&&delete o[this.model.id];for(const t in o)e[t]=o[t];return{kind:\"ModelChanged\",model:this.model.ref(),attr:this.attr,new:s}}}s.ModelChangedEvent=d,d.__name__=\"ModelChangedEvent\";class i extends o{constructor(e,t,s){super(e),this.column_source=t,this.patches=s}json(e){return{kind:\"ColumnsPatched\",column_source:this.column_source,patches:this.patches}}}s.ColumnsPatchedEvent=i,i.__name__=\"ColumnsPatchedEvent\";class _ extends o{constructor(e,t,s,n){super(e),this.column_source=t,this.data=s,this.rollover=n}json(e){return{kind:\"ColumnsStreamed\",column_source:this.column_source,data:this.data,rollover:this.rollover}}}s.ColumnsStreamedEvent=_,_.__name__=\"ColumnsStreamedEvent\";class a extends o{constructor(e,t,s){super(e),this.title=t,this.setter_id=s}json(e){return{kind:\"TitleChanged\",title:this.title}}}s.TitleChangedEvent=a,a.__name__=\"TitleChangedEvent\";class l extends o{constructor(e,t,s){super(e),this.model=t,this.setter_id=s}json(e){return n.HasProps._value_record_references(this.model,e,!0),{kind:\"RootAdded\",model:this.model.ref()}}}s.RootAddedEvent=l,l.__name__=\"RootAddedEvent\";class h extends o{constructor(e,t,s){super(e),this.model=t,this.setter_id=s}json(e){return{kind:\"RootRemoved\",model:this.model.ref()}}}s.RootRemovedEvent=h,h.__name__=\"RootRemovedEvent\"},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=e(1),_=e(29),o=e(73),l=i.__importStar(e(19));class a extends _.AnnotationView{initialize(){super.initialize(),this.set_data(this.model.source)}connect_signals(){super.connect_signals(),this.connect(this.model.source.streaming,()=>this.set_data(this.model.source)),this.connect(this.model.source.patching,()=>this.set_data(this.model.source)),this.connect(this.model.source.change,()=>this.set_data(this.model.source))}set_data(e){super.set_data(e),this.visuals.warm_cache(e),this.plot_view.request_render()}_map_data(){const{frame:e}=this.plot_view,t=this.model.dimension,s=e.xscales[this.model.x_range_name],i=e.yscales[this.model.y_range_name],_=\"height\"==t?i:s,o=\"height\"==t?s:i,l=\"height\"==t?e.yview:e.xview,a=\"height\"==t?e.xview:e.yview;let n,h,r;n=\"data\"==this.model.properties.lower.units?_.v_compute(this._lower):l.v_compute(this._lower),h=\"data\"==this.model.properties.upper.units?_.v_compute(this._upper):l.v_compute(this._upper),r=\"data\"==this.model.properties.base.units?o.v_compute(this._base):a.v_compute(this._base);const[c,p]=\"height\"==t?[1,0]:[0,1],u=[n,r],d=[h,r];this._lower_sx=u[c],this._lower_sy=u[p],this._upper_sx=d[c],this._upper_sy=d[p]}render(){if(!this.model.visible)return;this._map_data();const{ctx:e}=this.plot_view.canvas_view;e.beginPath(),e.moveTo(this._lower_sx[0],this._lower_sy[0]);for(let t=0,s=this._lower_sx.length;t<s;t++)e.lineTo(this._lower_sx[t],this._lower_sy[t]);for(let t=this._upper_sx.length-1;t>=0;t--)e.lineTo(this._upper_sx[t],this._upper_sy[t]);e.closePath(),this.visuals.fill.doit&&(this.visuals.fill.set_value(e),e.fill()),e.beginPath(),e.moveTo(this._lower_sx[0],this._lower_sy[0]);for(let t=0,s=this._lower_sx.length;t<s;t++)e.lineTo(this._lower_sx[t],this._lower_sy[t]);this.visuals.line.doit&&(this.visuals.line.set_value(e),e.stroke()),e.beginPath(),e.moveTo(this._upper_sx[0],this._upper_sy[0]);for(let t=0,s=this._upper_sx.length;t<s;t++)e.lineTo(this._upper_sx[t],this._upper_sy[t]);this.visuals.line.doit&&(this.visuals.line.set_value(e),e.stroke())}}s.BandView=a,a.__name__=\"BandView\";class n extends _.Annotation{constructor(e){super(e)}static init_Band(){this.prototype.default_view=a,this.mixins([\"line\",\"fill\"]),this.define({lower:[l.DistanceSpec],upper:[l.DistanceSpec],base:[l.DistanceSpec],dimension:[l.Dimension,\"height\"],source:[l.Instance,()=>new o.ColumnDataSource],x_range_name:[l.String,\"default\"],y_range_name:[l.String,\"default\"]}),this.override({fill_color:\"#fff9ba\",fill_alpha:.4,line_color:\"#cccccc\",line_alpha:.3})}}s.Band=n,n.__name__=\"Band\",n.init_Band()},\n",
       "      function _(t,e,i){Object.defineProperty(i,\"__esModule\",{value:!0});const s=t(1),l=t(29),o=t(14),n=t(66),a=s.__importStar(t(19)),h=t(85),r=t(106);i.EDGE_TOLERANCE=2.5;class d extends l.AnnotationView{initialize(){super.initialize(),this.plot_view.canvas_view.add_overlay(this.el),this.el.classList.add(r.bk_shading),n.undisplay(this.el)}connect_signals(){super.connect_signals(),\"css\"==this.model.render_mode?(this.connect(this.model.change,()=>this.render()),this.connect(this.model.data_update,()=>this.render())):(this.connect(this.model.change,()=>this.plot_view.request_render()),this.connect(this.model.data_update,()=>this.plot_view.request_render()))}render(){if(this.model.visible||\"css\"!=this.model.render_mode||n.undisplay(this.el),!this.model.visible)return;if(null==this.model.left&&null==this.model.right&&null==this.model.top&&null==this.model.bottom)return void n.undisplay(this.el);const{frame:t}=this.plot_view,e=t.xscales[this.model.x_range_name],i=t.yscales[this.model.y_range_name],s=(t,e,i,s,l)=>{let o;return o=null!=t?this.model.screen?t:\"data\"==e?i.compute(t):s.compute(t):l,o};this.sleft=s(this.model.left,this.model.left_units,e,t.xview,t._left.value),this.sright=s(this.model.right,this.model.right_units,e,t.xview,t._right.value),this.stop=s(this.model.top,this.model.top_units,i,t.yview,t._top.value),this.sbottom=s(this.model.bottom,this.model.bottom_units,i,t.yview,t._bottom.value),(\"css\"==this.model.render_mode?this._css_box.bind(this):this._canvas_box.bind(this))(this.sleft,this.sright,this.sbottom,this.stop)}_css_box(t,e,i,s){const l=this.model.properties.line_width.value(),o=Math.floor(e-t)-l,a=Math.floor(i-s)-l;this.el.style.left=`${t}px`,this.el.style.width=`${o}px`,this.el.style.top=`${s}px`,this.el.style.height=`${a}px`,this.el.style.borderWidth=`${l}px`,this.el.style.borderColor=this.model.properties.line_color.value(),this.el.style.backgroundColor=this.model.properties.fill_color.value(),this.el.style.opacity=this.model.properties.fill_alpha.value();const h=this.model.properties.line_dash.value().length<2?\"solid\":\"dashed\";this.el.style.borderStyle=h,n.display(this.el)}_canvas_box(t,e,i,s){const{ctx:l}=this.plot_view.canvas_view;l.save(),l.beginPath(),l.rect(t,s,e-t,i-s),this.visuals.fill.set_value(l),l.fill(),this.visuals.line.set_value(l),l.stroke(),l.restore()}interactive_bbox(){const t=this.model.properties.line_width.value()+i.EDGE_TOLERANCE;return new h.BBox({x0:this.sleft-t,y0:this.stop-t,x1:this.sright+t,y1:this.sbottom+t})}interactive_hit(t,e){if(null==this.model.in_cursor)return!1;return this.interactive_bbox().contains(t,e)}cursor(t,e){return Math.abs(t-this.sleft)<3||Math.abs(t-this.sright)<3?this.model.ew_cursor:Math.abs(e-this.sbottom)<3||Math.abs(e-this.stop)<3?this.model.ns_cursor:t>this.sleft&&t<this.sright&&e>this.stop&&e<this.sbottom?this.model.in_cursor:null}}i.BoxAnnotationView=d,d.__name__=\"BoxAnnotationView\";class _ extends l.Annotation{constructor(t){super(t)}static init_BoxAnnotation(){this.prototype.default_view=d,this.mixins([\"line\",\"fill\"]),this.define({render_mode:[a.RenderMode,\"canvas\"],x_range_name:[a.String,\"default\"],y_range_name:[a.String,\"default\"],top:[a.Number,null],top_units:[a.SpatialUnits,\"data\"],bottom:[a.Number,null],bottom_units:[a.SpatialUnits,\"data\"],left:[a.Number,null],left_units:[a.SpatialUnits,\"data\"],right:[a.Number,null],right_units:[a.SpatialUnits,\"data\"]}),this.internal({screen:[a.Boolean,!1],ew_cursor:[a.String,null],ns_cursor:[a.String,null],in_cursor:[a.String,null]}),this.override({fill_color:\"#fff9ba\",fill_alpha:.4,line_color:\"#cccccc\",line_alpha:.3})}initialize(){super.initialize(),this.data_update=new o.Signal0(this,\"data_update\")}update({left:t,right:e,top:i,bottom:s}){this.setv({left:t,right:e,top:i,bottom:s,screen:!0},{silent:!0}),this.data_update.emit()}}i.BoxAnnotation=_,_.__name__=\"BoxAnnotation\",_.init_BoxAnnotation()},\n",
       "      function _(n,o,t){Object.defineProperty(t,\"__esModule\",{value:!0});const a=n(1);n(67),a.__importStar(n(66)).styles.append(\".bk-root .bk-shading {\\n  position: absolute;\\n  display: block;\\n  border: 1px dashed green;\\n}\\n\"),t.bk_annotation=\"bk-annotation\",t.bk_shading=\"bk-shading\",t.bk_annotation_child=\"bk-annotation-child\"},\n",
       "      function _(t,e,i){Object.defineProperty(i,\"__esModule\",{value:!0});const o=t(1),s=t(29),a=t(108),l=t(112),r=t(114),n=t(119),_=t(129),h=t(130),m=o.__importStar(t(19)),d=o.__importStar(t(131)),c=t(9),u=t(12),p=t(23),g=t(8),f=t(11);class b extends s.AnnotationView{initialize(){super.initialize(),this._set_canvas_image()}connect_signals(){super.connect_signals(),this.connect(this.model.properties.visible.change,()=>this.plot_view.request_render()),this.connect(this.model.ticker.change,()=>this.plot_view.request_render()),this.connect(this.model.formatter.change,()=>this.plot_view.request_render()),null!=this.model.color_mapper&&this.connect(this.model.color_mapper.change,()=>{this._set_canvas_image(),this.plot_view.request_render()})}_get_size(){if(null==this.model.color_mapper)return{width:0,height:0};{const{width:t,height:e}=this.compute_legend_dimensions();return{width:t,height:e}}}_set_canvas_image(){if(null==this.model.color_mapper)return;let t,e,{palette:i}=this.model.color_mapper;switch(\"vertical\"==this.model.orientation&&(i=c.reversed(i)),this.model.orientation){case\"vertical\":[t,e]=[1,i.length];break;case\"horizontal\":[t,e]=[i.length,1]}const o=document.createElement(\"canvas\");o.width=t,o.height=e;const s=o.getContext(\"2d\"),a=s.getImageData(0,0,t,e),l=new r.LinearColorMapper({palette:i}).rgba_mapper.v_compute(c.range(0,i.length));a.data.set(l),s.putImageData(a,0,0),this.image=o}compute_legend_dimensions(){const t=this._computed_image_dimensions(),[e,i]=[t.height,t.width],o=this._get_label_extent(),s=this._title_extent(),a=this._tick_extent(),{padding:l}=this.model;let r,n;switch(this.model.orientation){case\"vertical\":r=e+s+2*l,n=i+a+o+2*l;break;case\"horizontal\":r=e+s+a+o+2*l,n=i+2*l}return{width:n,height:r}}compute_legend_location(){const t=this.compute_legend_dimensions(),[e,i]=[t.height,t.width],o=this.model.margin,s=null!=this.panel?this.panel:this.plot_view.frame,[a,l]=s.bbox.ranges,{location:r}=this.model;let n,_;if(g.isString(r))switch(r){case\"top_left\":n=a.start+o,_=l.start+o;break;case\"top_center\":n=(a.end+a.start)/2-i/2,_=l.start+o;break;case\"top_right\":n=a.end-o-i,_=l.start+o;break;case\"bottom_right\":n=a.end-o-i,_=l.end-o-e;break;case\"bottom_center\":n=(a.end+a.start)/2-i/2,_=l.end-o-e;break;case\"bottom_left\":n=a.start+o,_=l.end-o-e;break;case\"center_left\":n=a.start+o,_=(l.end+l.start)/2-e/2;break;case\"center\":n=(a.end+a.start)/2-i/2,_=(l.end+l.start)/2-e/2;break;case\"center_right\":n=a.end-o-i,_=(l.end+l.start)/2-e/2}else if(g.isArray(r)&&2==r.length){const[t,i]=r;n=s.xview.compute(t),_=s.yview.compute(i)-e}else f.unreachable();return{sx:n,sy:_}}render(){if(!this.model.visible||null==this.model.color_mapper)return;const{ctx:t}=this.plot_view.canvas_view;t.save();const{sx:e,sy:i}=this.compute_legend_location();t.translate(e,i),this._draw_bbox(t);const o=this._get_image_offset();if(t.translate(o.x,o.y),this._draw_image(t),null!=this.model.color_mapper.low&&null!=this.model.color_mapper.high){const e=this.tick_info();this._draw_major_ticks(t,e),this._draw_minor_ticks(t,e),this._draw_major_labels(t,e)}this.model.title&&this._draw_title(t),t.restore()}_draw_bbox(t){const e=this.compute_legend_dimensions();t.save(),this.visuals.background_fill.doit&&(this.visuals.background_fill.set_value(t),t.fillRect(0,0,e.width,e.height)),this.visuals.border_line.doit&&(this.visuals.border_line.set_value(t),t.strokeRect(0,0,e.width,e.height)),t.restore()}_draw_image(t){const e=this._computed_image_dimensions();t.save(),t.setImageSmoothingEnabled(!1),t.globalAlpha=this.model.scale_alpha,t.drawImage(this.image,0,0,e.width,e.height),this.visuals.bar_line.doit&&(this.visuals.bar_line.set_value(t),t.strokeRect(0,0,e.width,e.height)),t.restore()}_draw_major_ticks(t,e){if(!this.visuals.major_tick_line.doit)return;const[i,o]=this._normals(),s=this._computed_image_dimensions(),[a,l]=[s.width*i,s.height*o],[r,n]=e.coords.major,_=this.model.major_tick_in,h=this.model.major_tick_out;t.save(),t.translate(a,l),this.visuals.major_tick_line.set_value(t);for(let e=0,s=r.length;e<s;e++)t.beginPath(),t.moveTo(Math.round(r[e]+i*h),Math.round(n[e]+o*h)),t.lineTo(Math.round(r[e]-i*_),Math.round(n[e]-o*_)),t.stroke();t.restore()}_draw_minor_ticks(t,e){if(!this.visuals.minor_tick_line.doit)return;const[i,o]=this._normals(),s=this._computed_image_dimensions(),[a,l]=[s.width*i,s.height*o],[r,n]=e.coords.minor,_=this.model.minor_tick_in,h=this.model.minor_tick_out;t.save(),t.translate(a,l),this.visuals.minor_tick_line.set_value(t);for(let e=0,s=r.length;e<s;e++)t.beginPath(),t.moveTo(Math.round(r[e]+i*h),Math.round(n[e]+o*h)),t.lineTo(Math.round(r[e]-i*_),Math.round(n[e]-o*_)),t.stroke();t.restore()}_draw_major_labels(t,e){if(!this.visuals.major_label_text.doit)return;const[i,o]=this._normals(),s=this._computed_image_dimensions(),[a,l]=[s.width*i,s.height*o],r=this.model.label_standoff+this._tick_extent(),[n,_]=[r*i,r*o],[h,m]=e.coords.major,d=e.labels.major;this.visuals.major_label_text.set_value(t),t.save(),t.translate(a+n,l+_);for(let e=0,s=h.length;e<s;e++)t.fillText(d[e],Math.round(h[e]+i*this.model.label_standoff),Math.round(m[e]+o*this.model.label_standoff));t.restore()}_draw_title(t){this.visuals.title_text.doit&&(t.save(),this.visuals.title_text.set_value(t),t.fillText(this.model.title,0,-this.model.title_standoff),t.restore())}_get_label_extent(){const t=this.tick_info().labels.major;let e;if(null==this.model.color_mapper.low||null==this.model.color_mapper.high||p.isEmpty(t))e=0;else{const{ctx:i}=this.plot_view.canvas_view;switch(i.save(),this.visuals.major_label_text.set_value(i),this.model.orientation){case\"vertical\":e=c.max(t.map(t=>i.measureText(t.toString()).width));break;case\"horizontal\":e=d.measure_font(this.visuals.major_label_text.font_value()).height}e+=this.model.label_standoff,i.restore()}return e}_get_image_offset(){return{x:this.model.padding,y:this.model.padding+this._title_extent()}}_normals(){return\"vertical\"==this.model.orientation?[1,0]:[0,1]}_title_extent(){const t=this.model.title_text_font+\" \"+this.model.title_text_font_size+\" \"+this.model.title_text_font_style;return this.model.title?d.measure_font(t).height+this.model.title_standoff:0}_tick_extent(){return null!=this.model.color_mapper.low&&null!=this.model.color_mapper.high?c.max([this.model.major_tick_out,this.model.minor_tick_out]):0}_computed_image_dimensions(){const t=this.plot_view.frame._height.value,e=this.plot_view.frame._width.value,i=this._title_extent();let o,s;switch(this.model.orientation){case\"vertical\":\"auto\"==this.model.height?null!=this.panel?o=t-2*this.model.padding-i:(o=c.max([25*this.model.color_mapper.palette.length,.3*t]),o=c.min([o,.8*t-2*this.model.padding-i])):o=this.model.height,s=\"auto\"==this.model.width?25:this.model.width;break;case\"horizontal\":o=\"auto\"==this.model.height?25:this.model.height,\"auto\"==this.model.width?null!=this.panel?s=e-2*this.model.padding:(s=c.max([25*this.model.color_mapper.palette.length,.3*e]),s=c.min([s,.8*e-2*this.model.padding])):s=this.model.width}return{width:s,height:o}}_tick_coordinate_scale(t){const e={source_range:new h.Range1d({start:this.model.color_mapper.low,end:this.model.color_mapper.high}),target_range:new h.Range1d({start:0,end:t})};switch(this.model.color_mapper.type){case\"LinearColorMapper\":return new n.LinearScale(e);case\"LogColorMapper\":return new _.LogScale(e);default:f.unreachable()}}_format_major_labels(t,e){const i=this.model.formatter.doFormat(t,null);for(let t=0,o=e.length;t<o;t++)e[t]in this.model.major_label_overrides&&(i[t]=this.model.major_label_overrides[e[t]]);return i}tick_info(){const t=this._computed_image_dimensions();let e;switch(this.model.orientation){case\"vertical\":e=t.height;break;case\"horizontal\":e=t.width}const i=this._tick_coordinate_scale(e),[o,s]=this._normals(),[a,l]=[this.model.color_mapper.low,this.model.color_mapper.high],r=this.model.ticker.get_ticks(a,l,null,null,this.model.ticker.desired_num_ticks),n=r.major,_=r.minor,h=[[],[]],m=[[],[]];for(let t=0,e=n.length;t<e;t++)n[t]<a||n[t]>l||(h[o].push(n[t]),h[s].push(0));for(let t=0,e=_.length;t<e;t++)_[t]<a||_[t]>l||(m[o].push(_[t]),m[s].push(0));const d={major:this._format_major_labels(h[o],n)},c={major:[[],[]],minor:[[],[]]};return c.major[o]=i.v_compute(h[o]),c.minor[o]=i.v_compute(m[o]),c.major[s]=h[s],c.minor[s]=m[s],\"vertical\"==this.model.orientation&&(c.major[o]=u.map(c.major[o],t=>e-t),c.minor[o]=u.map(c.minor[o],t=>e-t)),{coords:c,labels:d}}}i.ColorBarView=b,b.__name__=\"ColorBarView\";class v extends s.Annotation{constructor(t){super(t)}static init_ColorBar(){this.prototype.default_view=b,this.mixins([\"text:major_label_\",\"text:title_\",\"line:major_tick_\",\"line:minor_tick_\",\"line:border_\",\"line:bar_\",\"fill:background_\"]),this.define({location:[m.Any,\"top_right\"],orientation:[m.Orientation,\"vertical\"],title:[m.String],title_standoff:[m.Number,2],width:[m.Any,\"auto\"],height:[m.Any,\"auto\"],scale_alpha:[m.Number,1],ticker:[m.Instance,()=>new a.BasicTicker],formatter:[m.Instance,()=>new l.BasicTickFormatter],major_label_overrides:[m.Any,{}],color_mapper:[m.Instance],label_standoff:[m.Number,5],margin:[m.Number,30],padding:[m.Number,10],major_tick_in:[m.Number,5],major_tick_out:[m.Number,0],minor_tick_in:[m.Number,0],minor_tick_out:[m.Number,0]}),this.override({background_fill_color:\"#ffffff\",background_fill_alpha:.95,bar_line_color:null,border_line_color:null,major_label_text_align:\"center\",major_label_text_baseline:\"middle\",major_label_text_font_size:\"8pt\",major_tick_line_color:\"#ffffff\",minor_tick_line_color:null,title_text_font_size:\"10pt\",title_text_font_style:\"italic\"})}}i.ColorBar=v,v.__name__=\"ColorBar\",v.init_ColorBar()},\n",
       "      function _(e,c,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=e(109);class r extends i.AdaptiveTicker{constructor(e){super(e)}}s.BasicTicker=r,r.__name__=\"BasicTicker\"},\n",
       "      function _(t,i,a){Object.defineProperty(a,\"__esModule\",{value:!0});const e=t(1),s=t(110),n=t(9),r=e.__importStar(t(19));class _ extends s.ContinuousTicker{constructor(t){super(t)}static init_AdaptiveTicker(){this.define({base:[r.Number,10],mantissas:[r.Array,[1,2,5]],min_interval:[r.Number,0],max_interval:[r.Number]})}initialize(){super.initialize();const t=n.nth(this.mantissas,-1)/this.base,i=n.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),r=Math.floor(function(t,i=Math.E){return Math.log(t)/Math.log(i)}(s/this.base_factor,this.base)),_=Math.pow(this.base,r)*this.base_factor,h=this.extended_mantissas,m=h.map(t=>Math.abs(a-e/(t*_))),o=h[n.argmin(m)];return c=o*_,l=this.get_min_interval(),u=this.get_max_interval(),Math.max(l,Math.min(u,c));var c,l,u}}a.AdaptiveTicker=_,_.__name__=\"AdaptiveTicker\",_.init_AdaptiveTicker()},\n",
       "      function _(t,i,e){Object.defineProperty(e,\"__esModule\",{value:!0});const n=t(1),r=t(111),s=n.__importStar(t(19)),o=t(9),_=t(8);class c extends r.Ticker{constructor(t){super(t)}static init_ContinuousTicker(){this.define({num_minor_ticks:[s.Number,5],desired_num_ticks:[s.Number,6]})}get_ticks(t,i,e,n,r){return this.get_ticks_no_defaults(t,i,n,this.desired_num_ticks)}get_ticks_no_defaults(t,i,e,n){const r=this.get_interval(t,i,n),s=Math.floor(t/r),c=Math.ceil(i/r);let u;u=_.isStrictNaN(s)||_.isStrictNaN(c)?[]:o.range(s,c+1);const a=u.map(t=>t*r).filter(e=>t<=e&&e<=i),l=this.num_minor_ticks,m=[];if(l>0&&a.length>0){const e=r/l,n=o.range(0,l).map(t=>t*e);for(const e of n.slice(1)){const n=a[0]-e;t<=n&&n<=i&&m.push(n)}for(const e of a)for(const r of n){const n=e+r;t<=n&&n<=i&&m.push(n)}}return{major:a,minor:m}}get_min_interval(){return this.min_interval}get_max_interval(){return null!=this.max_interval?this.max_interval:1/0}get_ideal_interval(t,i,e){return(i-t)/e}}e.ContinuousTicker=c,c.__name__=\"ContinuousTicker\",c.init_ContinuousTicker()},\n",
       "      function _(e,c,n){Object.defineProperty(n,\"__esModule\",{value:!0});const o=e(69);class r extends o.Model{constructor(e){super(e)}}n.Ticker=r,r.__name__=\"Ticker\"},\n",
       "      function _(i,t,e){Object.defineProperty(e,\"__esModule\",{value:!0});const r=i(1),o=i(113),s=r.__importStar(i(19));class n extends o.TickFormatter{constructor(i){super(i),this.last_precision=3}static init_BasicTickFormatter(){this.define({precision:[s.Any,\"auto\"],use_scientific:[s.Boolean,!0],power_limit_high:[s.Number,5],power_limit_low:[s.Number,-3]})}get scientific_limit_low(){return Math.pow(10,this.power_limit_low)}get scientific_limit_high(){return Math.pow(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,r=i.length<2?0:Math.abs(i[1]-i[0])/1e4;for(const o of i){const i=Math.abs(o);if(!(i<=r)&&(i>=t||i<=e))return!0}return!1}_format_with_precision(i,t,e){const r=new Array(i.length);if(t)for(let t=0,o=i.length;t<o;t++)r[t]=i[t].toExponential(e);else for(let t=0,o=i.length;t<o;t++)r[t]=i[t].toFixed(e).replace(/(\\.[0-9]*?)0+$/,\"$1\").replace(/\\.$/,\"\");return r}_auto_precision(i,t){const e=new Array(i.length),r=this.last_precision<=15;i:for(let o=this.last_precision;r?o<=15:o>=1;r?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]=i[0].toFixed(o).replace(/(\\.[0-9]*?)0+$/,\"$1\").replace(/\\.$/,\"\");for(let t=1;t<i.length;t++)if(e[t]=i[t].toFixed(o).replace(/(\\.[0-9]*?)0+$/,\"$1\").replace(/\\.$/,\"\"),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),r=\"auto\"==this.precision?this._auto_precision(i,e):this.precision;return this._format_with_precision(i,e,r)}}e.BasicTickFormatter=n,n.__name__=\"BasicTickFormatter\",n.init_BasicTickFormatter()},\n",
       "      function _(e,t,o){Object.defineProperty(o,\"__esModule\",{value:!0});const r=e(69);class c extends r.Model{constructor(e){super(e)}}o.TickFormatter=c,c.__name__=\"TickFormatter\"},\n",
       "      function _(o,n,l){Object.defineProperty(l,\"__esModule\",{value:!0});const e=o(115),t=o(12);class i extends e.ContinuousColorMapper{constructor(o){super(o)}_v_compute(o,n,l,e){const{nan_color:i,low_color:r,high_color:s}=e,c=null!=this.low?this.low:t.min(o),h=null!=this.high?this.high:t.max(o),u=l.length-1,a=1/(h-c),_=1/l.length;for(let e=0,t=o.length;e<t;e++){const t=o[e];if(isNaN(t)){n[e]=i;continue}if(t==h){n[e]=l[u];continue}const p=(t-c)*a,f=Math.floor(p/_);n[e]=f<0?null!=r?r:l[0]:f>u?null!=s?s:l[u]:l[f]}}}l.LinearColorMapper=i,i.__name__=\"LinearColorMapper\"},\n",
       "      function _(o,r,l){Object.defineProperty(l,\"__esModule\",{value:!0});const i=o(1),t=o(116),e=i.__importStar(o(19));class s extends t.ColorMapper{constructor(o){super(o)}static init_ContinuousColorMapper(){this.define({high:[e.Number],low:[e.Number],high_color:[e.Color],low_color:[e.Color]})}_colors(o){return Object.assign(Object.assign({},super._colors(o)),{low_color:null!=this.low_color?o(this.low_color):void 0,high_color:null!=this.high_color?o(this.high_color):void 0})}}l.ContinuousColorMapper=s,s.__name__=\"ContinuousColorMapper\",s.init_ContinuousColorMapper()},\n",
       "      function _(t,e,r){Object.defineProperty(r,\"__esModule\",{value:!0});const n=t(1),o=t(117),_=n.__importStar(t(19)),i=t(8),l=t(21),c=t(101);function a(t){return i.isNumber(t)?t:(\"#\"!=t[0]&&(t=l.color2hex(t)),9!=t.length&&(t+=\"ff\"),parseInt(t.slice(1),16))}function s(t){const e=new Uint32Array(t.length);for(let r=0,n=t.length;r<n;r++)e[r]=a(t[r]);return e}function p(t){if(c.is_little_endian){const e=new DataView(t.buffer);for(let r=0,n=t.length;r<n;r++)e.setUint32(4*r,t[r])}return new Uint8Array(t.buffer)}r._convert_color=a,r._convert_palette=s,r._uint32_to_rgba=p;class u extends o.Mapper{constructor(t){super(t)}static init_ColorMapper(){this.define({palette:[_.Any],nan_color:[_.Color,\"gray\"]})}v_compute(t){const e=new Array(t.length);return this._v_compute(t,e,this.palette,this._colors(t=>t)),e}get rgba_mapper(){const t=this,e=s(this.palette),r=this._colors(a);return{v_compute(n){const o=new Uint32Array(n.length);return t._v_compute(n,o,e,r),p(o)}}}_colors(t){return{nan_color:t(this.nan_color)}}}r.ColorMapper=u,u.__name__=\"ColorMapper\",u.init_ColorMapper()},\n",
       "      function _(e,r,n){Object.defineProperty(n,\"__esModule\",{value:!0});const o=e(118);class s extends o.Transform{constructor(e){super(e)}compute(e){throw new Error(\"mapping single values is not supported\")}}n.Mapper=s,s.__name__=\"Mapper\"},\n",
       "      function _(e,n,o){Object.defineProperty(o,\"__esModule\",{value:!0});const r=e(69);class s extends r.Model{constructor(e){super(e)}}o.Transform=s,s.__name__=\"Transform\"},\n",
       "      function _(e,t,n){Object.defineProperty(n,\"__esModule\",{value:!0});const r=e(120);class _ extends r.ContinuousScale{constructor(e){super(e)}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=_,_.__name__=\"LinearScale\"},\n",
       "      function _(e,n,o){Object.defineProperty(o,\"__esModule\",{value:!0});const c=e(121);class s extends c.Scale{constructor(e){super(e)}}o.ContinuousScale=s,s.__name__=\"ContinuousScale\"},\n",
       "      function _(t,e,r){Object.defineProperty(r,\"__esModule\",{value:!0});const n=t(1),_=t(122),s=n.__importStar(t(19));class i extends _.Transform{constructor(t){super(t)}static init_Scale(){this.internal({source_range:[s.Any],target_range:[s.Any]})}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 Float64Array(t.length);for(let _=0;_<t.length;_++)n[_]=e*t[_]+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 _=0;_<t.length;_++)n[_]=(t[_]-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=i,i.__name__=\"Scale\",i.init_Scale()},\n",
       "      function _(r,o,t){Object.defineProperty(t,\"__esModule\",{value:!0});var e=r(123);t.CustomJSTransform=e.CustomJSTransform;var a=r(124);t.Dodge=a.Dodge;var n=r(125);t.Interpolator=n.Interpolator;var p=r(126);t.Jitter=p.Jitter;var l=r(127);t.LinearInterpolator=l.LinearInterpolator;var v=r(128);t.StepInterpolator=v.StepInterpolator;var s=r(118);t.Transform=s.Transform},\n",
       "      function _(t,r,s){Object.defineProperty(s,\"__esModule\",{value:!0});const n=t(1),e=t(118),a=n.__importStar(t(19)),o=t(23),u=t(25);class i extends e.Transform{constructor(t){super(t)}static init_CustomJSTransform(){this.define({args:[a.Any,{}],func:[a.String,\"\"],v_func:[a.String,\"\"]})}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=i,i.__name__=\"CustomJSTransform\",i.init_CustomJSTransform()},\n",
       "      function _(e,t,r){Object.defineProperty(r,\"__esModule\",{value:!0});const n=e(1),o=e(118),i=e(88),s=n.__importStar(e(19)),a=e(8);class c extends o.Transform{constructor(e){super(e)}static init_Dodge(){this.define({value:[s.Number,0],range:[s.Instance]})}v_compute(e){let t;if(this.range instanceof i.FactorRange)t=this.range.v_synthetic(e);else{if(!a.isArrayableOf(e,a.isNumber))throw new Error(\"unexpected\");t=e}const r=new Float64Array(t.length);for(let e=0;e<t.length;e++){const n=t[e];r[e]=this._compute(n)}return r}compute(e){if(this.range instanceof i.FactorRange)return this._compute(this.range.synthetic(e));if(a.isNumber(e))return this._compute(e);throw new Error(\"unexpected\")}_compute(e){return e+this.value}}r.Dodge=c,c.__name__=\"Dodge\",c.init_Dodge()},\n",
       "      function _(t,e,r){Object.defineProperty(r,\"__esModule\",{value:!0});const s=t(1),o=t(118),n=s.__importStar(t(19)),i=t(9),a=t(8);class h extends o.Transform{constructor(t){super(t),this._sorted_dirty=!0}static init_Interpolator(){this.define({x:[n.Any],y:[n.Any],data:[n.Any],clip:[n.Boolean,!0]})}connect_signals(){super.connect_signals(),this.connect(this.change,()=>this._sorted_dirty=!0)}v_compute(t){const e=new Float64Array(t.length);for(let r=0;r<t.length;r++){const s=t[r];e[r]=this.compute(s)}return e}sort(t=!1){if(!this._sorted_dirty)return;let e,r;if(a.isString(this.x)&&a.isString(this.y)&&null!=this.data){const t=this.data.columns();if(!i.includes(t,this.x))throw new Error(\"The x parameter does not correspond to a valid column name defined in the data parameter\");if(!i.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(!a.isArray(this.x)||!a.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 s=[];for(const t in e)s.push({x:e[t],y:r[t]});t?s.sort((t,e)=>t.x>e.x?-1:t.x==e.x?0:1):s.sort((t,e)=>t.x<e.x?-1:t.x==e.x?0:1),this._x_sorted=[],this._y_sorted=[];for(const{x:t,y:e}of s)this._x_sorted.push(t),this._y_sorted.push(e);this._sorted_dirty=!1}}r.Interpolator=h,h.__name__=\"Interpolator\",h.init_Interpolator()},\n",
       "      function _(t,e,r){Object.defineProperty(r,\"__esModule\",{value:!0});const i=t(1),n=t(118),s=t(88),o=t(8),u=i.__importStar(t(19)),a=i.__importStar(t(10));class h extends n.Transform{constructor(t){super(t)}static init_Jitter(){this.define({mean:[u.Number,0],width:[u.Number,1],distribution:[u.Distribution,\"uniform\"],range:[u.Instance]}),this.internal({previous_values:[u.Array]})}v_compute(t){if(null!=this.previous_values&&this.previous_values.length==t.length)return this.previous_values;let e;if(this.range instanceof s.FactorRange)e=this.range.v_synthetic(t);else{if(!o.isArrayableOf(t,o.isNumber))throw new Error(\"unexpected\");e=t}const r=new Float64Array(e.length);for(let t=0;t<e.length;t++){const i=e[t];r[t]=this._compute(i)}return this.previous_values=r,r}compute(t){if(this.range instanceof s.FactorRange)return this._compute(this.range.synthetic(t));if(o.isNumber(t))return this._compute(t);throw new Error(\"unexpected\")}_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)}}}r.Jitter=h,h.__name__=\"Jitter\",h.init_Jitter()},\n",
       "      function _(t,s,e){Object.defineProperty(e,\"__esModule\",{value:!0});const _=t(9),r=t(125);class o extends r.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=_.find_last_index(this._x_sorted,s=>s<t),e=this._x_sorted[s],r=this._x_sorted[s+1],o=this._y_sorted[s],i=this._y_sorted[s+1];return o+(t-e)/(r-e)*(i-o)}}e.LinearInterpolator=o,o.__name__=\"LinearInterpolator\"},\n",
       "      function _(t,e,r){Object.defineProperty(r,\"__esModule\",{value:!0});const s=t(1),o=t(125),_=s.__importStar(t(19)),i=t(9);class n extends o.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=i.find_last_index(this._x_sorted,e=>t>=e);break;case\"before\":e=i.find_index(this._x_sorted,e=>t<=e);break;case\"center\":{const r=this._x_sorted.map(e=>Math.abs(e-t)),s=i.min(r);e=i.find_index(r,t=>s===t);break}default:throw new Error(`unknown mode: ${this.mode}`)}return-1!=e?this._y_sorted[e]:NaN}}r.StepInterpolator=n,n.__name__=\"StepInterpolator\",n.init_StepInterpolator()},\n",
       "      function _(t,e,o){Object.defineProperty(o,\"__esModule\",{value:!0});const a=t(120);class s extends a.ContinuousScale{constructor(t){super(t)}compute(t){const[e,o,a,s]=this._compute_state();let n;if(0==a)n=0;else{const r=(Math.log(t)-s)/a;n=isFinite(r)?r*e+o:NaN}return n}v_compute(t){const[e,o,a,s]=this._compute_state(),n=new Float64Array(t.length);if(0==a)for(let e=0;e<t.length;e++)n[e]=0;else for(let r=0;r<t.length;r++){const l=(Math.log(t[r])-s)/a;let c;c=isFinite(l)?l*e+o:NaN,n[r]=c}return n}invert(t){const[e,o,a,s]=this._compute_state(),n=(t-o)/e;return Math.exp(a*n+s)}v_invert(t){const[e,o,a,s]=this._compute_state(),n=new Float64Array(t.length);for(let r=0;r<t.length;r++){const l=(t[r]-o)/e;n[r]=Math.exp(a*l+s)}return n}_get_safe_factor(t,e){let o=t<0?0:t,a=e<0?0:e;if(o==a)if(0==o)[o,a]=[1,10];else{const t=Math.log(o)/Math.log(10);o=Math.pow(10,Math.floor(t)),a=Math.ceil(t)!=Math.floor(t)?Math.pow(10,Math.ceil(t)):Math.pow(10,Math.ceil(t)+1)}return[o,a]}_compute_state(){const t=this.source_range.start,e=this.source_range.end,o=this.target_range.start,a=this.target_range.end-o,[s,n]=this._get_safe_factor(t,e);let r,l;return 0==s?(r=Math.log(n),l=0):(r=Math.log(n)-Math.log(s),l=Math.log(s)),[a,o,r,l]}}o.LogScale=s,s.__name__=\"LogScale\"},\n",
       "      function _(t,e,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=t(1),n=t(89),r=i.__importStar(t(19));class a extends n.Range{constructor(t){super(t)}static init_Range1d(){this.define({start:[r.Number,0],end:[r.Number,1],reset_start:[r.Number],reset_end:[r.Number]})}_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(),null==this.reset_start&&(this.reset_start=this.start),null==this.reset_end&&(this.reset_end=this.end),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(),this.start!=this.reset_start||this.end!=this.reset_end?this.setv({start:this.reset_start,end:this.reset_end}):this.change.emit()}}s.Range1d=a,a.__name__=\"Range1d\",a.init_Range1d()},\n",
       "      function _(t,e,n){Object.defineProperty(n,\"__esModule\",{value:!0});const o=t(66),i={};n.measure_font=function(t){if(null!=i[t])return i[t];const e=o.span({style:{font:t}},\"Hg\"),n=o.div({style:{display:\"inline-block\",width:\"1px\",height:\"0px\"}}),l=o.div({},e,n);document.body.appendChild(l);try{n.style.verticalAlign=\"baseline\";const s=o.offset(n).top-o.offset(e).top;n.style.verticalAlign=\"bottom\";const d=o.offset(n).top-o.offset(e).top,c={height:d,ascent:s,descent:d-s};return i[t]=c,c}finally{document.body.removeChild(l)}};const l={};n.measure_text=function(t,e){const n=l[e];if(null!=n){const e=n[t];if(null!=e)return e}else l[e]={};const i=o.div({style:{display:\"inline-block\",\"white-space\":\"nowrap\",font:e}},t);document.body.appendChild(i);try{const{width:n,height:o}=i.getBoundingClientRect();return l[e][t]={width:n,height:o},{width:n,height:o}}finally{document.body.removeChild(i)}}},\n",
       "      function _(e,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const s=e(1),a=e(133),l=e(66),n=s.__importStar(e(19));class o extends a.TextAnnotationView{initialize(){super.initialize(),this.visuals.warm_cache()}_get_size(){const{ctx:e}=this.plot_view.canvas_view;this.visuals.text.set_value(e);const{width:t,ascent:i}=e.measureText(this.model.text);return{width:t,height:i}}render(){if(this.model.visible||\"css\"!=this.model.render_mode||l.undisplay(this.el),!this.model.visible)return;let e;switch(this.model.angle_units){case\"rad\":e=-this.model.angle;break;case\"deg\":e=-this.model.angle*Math.PI/180}const t=null!=this.panel?this.panel:this.plot_view.frame,i=this.plot_view.frame.xscales[this.model.x_range_name],s=this.plot_view.frame.yscales[this.model.y_range_name];let a=\"data\"==this.model.x_units?i.compute(this.model.x):t.xview.compute(this.model.x),n=\"data\"==this.model.y_units?s.compute(this.model.y):t.yview.compute(this.model.y);a+=this.model.x_offset,n-=this.model.y_offset,(\"canvas\"==this.model.render_mode?this._canvas_text.bind(this):this._css_text.bind(this))(this.plot_view.canvas_view.ctx,this.model.text,a,n,e)}}i.LabelView=o,o.__name__=\"LabelView\";class _ extends a.TextAnnotation{constructor(e){super(e)}static init_Label(){this.prototype.default_view=o,this.mixins([\"text\",\"line:border_\",\"fill:background_\"]),this.define({x:[n.Number],x_units:[n.SpatialUnits,\"data\"],y:[n.Number],y_units:[n.SpatialUnits,\"data\"],text:[n.String],angle:[n.Angle,0],angle_units:[n.AngleUnits,\"rad\"],x_offset:[n.Number,0],y_offset:[n.Number,0],x_range_name:[n.String,\"default\"],y_range_name:[n.String,\"default\"]}),this.override({background_fill_color:null,border_line_color:null})}}i.Label=_,_.__name__=\"Label\",_.init_Label()},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=e(1),l=e(29),a=e(66),n=i.__importStar(e(19)),o=e(131),r=e(106),_=e(11);class h extends l.AnnotationView{constructor(){super(...arguments),this.rotate=!0}initialize(){super.initialize(),\"css\"==this.model.render_mode&&(this.el.classList.add(r.bk_annotation),this.plot_view.canvas_view.add_overlay(this.el))}connect_signals(){super.connect_signals(),\"css\"==this.model.render_mode?this.connect(this.model.change,()=>this.render()):this.connect(this.model.change,()=>this.plot_view.request_render())}_calculate_text_dimensions(e,t){const{width:s}=e.measureText(t),{height:i}=o.measure_font(this.visuals.text.font_value());return[s,i]}_calculate_bounding_box_dimensions(e,t){const[s,i]=this._calculate_text_dimensions(e,t);let l,a;switch(e.textAlign){case\"left\":l=0;break;case\"center\":l=-s/2;break;case\"right\":l=-s;break;default:_.unreachable()}switch(e.textBaseline){case\"top\":a=0;break;case\"middle\":a=-.5*i;break;case\"bottom\":a=-1*i;break;case\"alphabetic\":a=-.8*i;break;case\"hanging\":a=-.17*i;break;case\"ideographic\":a=-.83*i;break;default:_.unreachable()}return[l,a,s,i]}_canvas_text(e,t,s,i,l){this.visuals.text.set_value(e);const a=this._calculate_bounding_box_dimensions(e,t);e.save(),e.beginPath(),e.translate(s,i),l&&e.rotate(l),e.rect(a[0],a[1],a[2],a[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,l){a.undisplay(this.el),this.visuals.text.set_value(e);const n=this._calculate_bounding_box_dimensions(e,t),o=this.visuals.border_line.line_dash.value().length<2?\"solid\":\"dashed\";this.visuals.border_line.set_value(e),this.visuals.background_fill.set_value(e),this.el.style.position=\"absolute\",this.el.style.left=`${s+n[0]}px`,this.el.style.top=`${i+n[1]}px`,this.el.style.color=`${this.visuals.text.text_color.value()}`,this.el.style.opacity=`${this.visuals.text.text_alpha.value()}`,this.el.style.font=`${this.visuals.text.font_value()}`,this.el.style.lineHeight=\"normal\",l&&(this.el.style.transform=`rotate(${l}rad)`),this.visuals.background_fill.doit&&(this.el.style.backgroundColor=`${this.visuals.background_fill.color_value()}`),this.visuals.border_line.doit&&(this.el.style.borderStyle=`${o}`,this.el.style.borderWidth=`${this.visuals.border_line.line_width.value()}px`,this.el.style.borderColor=`${this.visuals.border_line.color_value()}`),this.el.textContent=t,a.display(this.el)}}s.TextAnnotationView=h,h.__name__=\"TextAnnotationView\";class c extends l.Annotation{constructor(e){super(e)}static init_TextAnnotation(){this.define({render_mode:[n.RenderMode,\"canvas\"]})}}s.TextAnnotation=c,c.__name__=\"TextAnnotation\",c.init_TextAnnotation()},\n",
       "      function _(t,e,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=t(1),l=t(133),o=t(73),a=t(66),n=i.__importStar(t(19)),r=t(106);class _ extends l.TextAnnotationView{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=a.div({class:r.bk_annotation_child,style:{display:\"none\"}});this.el.appendChild(t)}}connect_signals(){super.connect_signals(),\"css\"==this.model.render_mode?(this.connect(this.model.change,()=>{this.set_data(this.model.source),this.render()}),this.connect(this.model.source.streaming,()=>{this.set_data(this.model.source),this.render()}),this.connect(this.model.source.patching,()=>{this.set_data(this.model.source),this.render()}),this.connect(this.model.source.change,()=>{this.set_data(this.model.source),this.render()})):(this.connect(this.model.change,()=>{this.set_data(this.model.source),this.plot_view.request_render()}),this.connect(this.model.source.streaming,()=>{this.set_data(this.model.source),this.plot_view.request_render()}),this.connect(this.model.source.patching,()=>{this.set_data(this.model.source),this.plot_view.request_render()}),this.connect(this.model.source.change,()=>{this.set_data(this.model.source),this.plot_view.request_render()}))}set_data(t){super.set_data(t),this.visuals.warm_cache(t)}_map_data(){const t=this.plot_view.frame.xscales[this.model.x_range_name],e=this.plot_view.frame.yscales[this.model.y_range_name],s=null!=this.panel?this.panel:this.plot_view.frame;return[\"data\"==this.model.x_units?t.v_compute(this._x):s.xview.v_compute(this._x),\"data\"==this.model.y_units?e.v_compute(this._y):s.yview.v_compute(this._y)]}render(){if(this.model.visible||\"css\"!=this.model.render_mode||a.undisplay(this.el),!this.model.visible)return;const t=\"canvas\"==this.model.render_mode?this._v_canvas_text.bind(this):this._v_css_text.bind(this),{ctx:e}=this.plot_view.canvas_view,[s,i]=this._map_data();for(let l=0,o=this._text.length;l<o;l++)t(e,l,this._text[l],s[l]+this._x_offset[l],i[l]-this._y_offset[l],this._angle[l])}_get_size(){const{ctx:t}=this.plot_view.canvas_view;this.visuals.text.set_value(t);const{width:e,ascent:s}=t.measureText(this._text[0]);return{width:e,height:s}}_v_canvas_text(t,e,s,i,l,o){this.visuals.text.set_vectorize(t,e);const a=this._calculate_bounding_box_dimensions(t,s);t.save(),t.beginPath(),t.translate(i,l),t.rotate(o),t.rect(a[0],a[1],a[2],a[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,l,o){const n=this.el.children[e];n.textContent=s,this.visuals.text.set_vectorize(t,e);const r=this._calculate_bounding_box_dimensions(t,s),_=this.visuals.border_line.line_dash.value().length<2?\"solid\":\"dashed\";this.visuals.border_line.set_vectorize(t,e),this.visuals.background_fill.set_vectorize(t,e),n.style.position=\"absolute\",n.style.left=`${i+r[0]}px`,n.style.top=`${l+r[1]}px`,n.style.color=`${this.visuals.text.text_color.value()}`,n.style.opacity=`${this.visuals.text.text_alpha.value()}`,n.style.font=`${this.visuals.text.font_value()}`,n.style.lineHeight=\"normal\",o&&(n.style.transform=`rotate(${o}rad)`),this.visuals.background_fill.doit&&(n.style.backgroundColor=`${this.visuals.background_fill.color_value()}`),this.visuals.border_line.doit&&(n.style.borderStyle=`${_}`,n.style.borderWidth=`${this.visuals.border_line.line_width.value()}px`,n.style.borderColor=`${this.visuals.border_line.color_value()}`),a.display(n)}}s.LabelSetView=_,_.__name__=\"LabelSetView\";class h extends l.TextAnnotation{constructor(t){super(t)}static init_LabelSet(){this.prototype.default_view=_,this.mixins([\"text\",\"line:border_\",\"fill:background_\"]),this.define({x:[n.NumberSpec],y:[n.NumberSpec],x_units:[n.SpatialUnits,\"data\"],y_units:[n.SpatialUnits,\"data\"],text:[n.StringSpec,{field:\"text\"}],angle:[n.AngleSpec,0],x_offset:[n.NumberSpec,{value:0}],y_offset:[n.NumberSpec,{value:0}],source:[n.Instance,()=>new o.ColumnDataSource],x_range_name:[n.String,\"default\"],y_range_name:[n.String,\"default\"]}),this.override({background_fill_color:null,border_line_color:null})}}s.LabelSet=h,h.__name__=\"LabelSet\",h.init_LabelSet()},\n",
       "      function _(t,e,i){Object.defineProperty(i,\"__esModule\",{value:!0});const s=t(1),l=t(29),n=s.__importStar(t(19)),h=t(14),a=t(131),_=t(85),o=t(9),r=t(23),d=t(8),c=t(11);class m extends l.AnnotationView{cursor(t,e){return\"none\"==this.model.click_policy?null:\"pointer\"}get legend_padding(){return null!=this.visuals.border_line.line_color.value()?this.model.padding:0}connect_signals(){super.connect_signals(),this.connect(this.model.change,()=>this.plot_view.request_render()),this.connect(this.model.item_change,()=>this.plot_view.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=o.max([a.measure_font(this.visuals.label_text.font_value()).height,s,e]);const{ctx:n}=this.plot_view.canvas_view;n.save(),this.visuals.label_text.set_value(n),this.text_widths={};for(const e of t)this.text_widths[e]=o.max([n.measureText(e).width,l]);this.visuals.title_text.set_value(n),this.title_height=this.model.title?a.measure_font(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(o.max(r.values(this.text_widths)),0),m=this.model.margin,{legend_padding:g}=this,b=this.model.spacing,{label_standoff:f}=this.model;let u,x;if(\"vertical\"==this.model.orientation)u=t.length*this.max_label_height+Math.max(t.length-1,0)*b+2*g+this.title_height,x=o.max([h+i+f+2*g,this.title_width+2*g]);else{let e=2*g+Math.max(t.length-1,0)*b;for(const t in this.text_widths){const s=this.text_widths[t];e+=o.max([s,l])+i+f}x=o.max([this.title_width+2*g,e]),u=this.max_label_height+this.title_height+2*g}const p=null!=this.panel?this.panel:this.plot_view.frame,[v,w]=p.bbox.ranges,{location:y}=this.model;let k,N;if(d.isString(y))switch(y){case\"top_left\":k=v.start+m,N=w.start+m;break;case\"top_center\":k=(v.end+v.start)/2-x/2,N=w.start+m;break;case\"top_right\":k=v.end-m-x,N=w.start+m;break;case\"bottom_right\":k=v.end-m-x,N=w.end-m-u;break;case\"bottom_center\":k=(v.end+v.start)/2-x/2,N=w.end-m-u;break;case\"bottom_left\":k=v.start+m,N=w.end-m-u;break;case\"center_left\":k=v.start+m,N=(w.end+w.start)/2-u/2;break;case\"center\":k=(v.end+v.start)/2-x/2,N=(w.end+w.start)/2-u/2;break;case\"center_right\":k=v.end-m-x,N=(w.end+w.start)/2-u/2}else if(d.isArray(y)&&2==y.length){const[t,e]=y;k=p.xview.compute(t),N=p.yview.compute(e)-u}else c.unreachable();return new _.BBox({left:k,top:N,width:x,height:u})}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 a=i=l;const o=this.compute_legend_bbox(),r=\"vertical\"==this.model.orientation;for(const d of this.model.items){const c=d.get_labels_list_from_label_prop();for(const m of c){const c=o.x+a,g=o.y+i+this.title_height;let b,f;if([b,f]=r?[o.width-2*l,this.max_label_height]:[this.text_widths[m]+s+h,this.max_label_height],new _.BBox({left:c,top:g,width:b,height:f}).contains(t,e)){switch(this.model.click_policy){case\"hide\":for(const t of d.renderers)t.visible=!t.visible;break;case\"mute\":for(const t of d.renderers)t.muted=!t.muted}return!0}r?i+=this.max_label_height+n:a+=this.text_widths[m]+s+h+n}}return!1}render(){if(!this.model.visible)return;if(0==this.model.items.length)return;for(const t of this.model.items)t.legend=this.model;const{ctx:t}=this.plot_view.canvas_view,e=this.compute_legend_bbox();t.save(),this._draw_legend_box(t,e),this._draw_legend_items(t,e),this.model.title&&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 a=l,_=l;const r=\"vertical\"==this.model.orientation;for(const d of this.model.items){const c=d.get_labels_list_from_label_prop(),m=d.get_field_from_label_prop();if(0==c.length)continue;const g=(()=>{switch(this.model.click_policy){case\"none\":return!0;case\"hide\":return o.every(d.renderers,t=>t.visible);case\"mute\":return o.every(d.renderers,t=>!t.muted)}})();for(const o of c){const c=e.x+a,b=e.y+_+this.title_height,f=c+i,u=b+s;r?_+=this.max_label_height+n:a+=this.text_widths[o]+i+h+n,this.visuals.label_text.set_value(t),t.fillText(o,f+h,b+this.max_label_height/2);for(const e of d.renderers){this.plot_view.renderer_views[e.id].draw_legend(t,c,f,b,u,m,o,d.index)}if(!g){let s,n;[s,n]=r?[e.width-2*l,this.max_label_height]:[this.text_widths[o]+i+h,this.max_label_height],t.beginPath(),t.rect(c,b,s,n),this.visuals.inactive_fill.set_value(t),t.fill()}}}}_draw_title(t,e){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(this.model.title,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=m,m.__name__=\"LegendView\";class g extends l.Annotation{constructor(t){super(t)}initialize(){super.initialize(),this.item_change=new h.Signal0(this,\"item_change\")}static init_Legend(){this.prototype.default_view=m,this.mixins([\"text:label_\",\"text:title_\",\"fill:inactive_\",\"line:border_\",\"fill:background_\"]),this.define({orientation:[n.Orientation,\"vertical\"],location:[n.Any,\"top_right\"],title:[n.String],title_standoff:[n.Number,5],label_standoff:[n.Number,5],glyph_height:[n.Number,20],glyph_width:[n.Number,20],label_height:[n.Number,20],label_width:[n.Number,20],margin:[n.Number,10],padding:[n.Number,10],spacing:[n.Number,3],items:[n.Array,[]],click_policy:[n.Any,\"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:\"10pt\",label_text_baseline:\"middle\",title_text_font_size:\"10pt\",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=g,g.__name__=\"Legend\",g.init_Legend()},\n",
       "      function _(e,r,n){Object.defineProperty(n,\"__esModule\",{value:!0});const t=e(1),l=e(69),i=e(74),s=e(137),_=t.__importStar(e(19)),o=e(70),a=e(9);class u extends l.Model{constructor(e){super(e)}static init_LegendItem(){this.define({label:[_.StringSpec,null],renderers:[_.Array,[]],index:[_.Number,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&&!a.includes(r.columns(),e))return!1}return!0}initialize(){super.initialize(),this.legend=null,this.connect(this.change,()=>{null!=this.legend&&this.legend.item_change.emit()}),this._check_data_sources_on_renderers()||o.logger.error(\"Non matching data sources on legend item renderers\"),this._check_field_label_on_data_source()||o.logger.error(`Bad column name on label: ${this.label}`)}get_field_from_label_prop(){const{label:e}=this;return s.isField(e)?e.field:null}get_labels_list_from_label_prop(){if(s.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 i.ColumnarDataSource){const n=r.get_column(e);return null!=n?a.uniq(Array.from(n)):[\"Invalid field\"]}}return[]}}n.LegendItem=u,u.__name__=\"LegendItem\",u.init_LegendItem()},\n",
       "      function _(e,i,n){Object.defineProperty(n,\"__esModule\",{value:!0});const t=e(8);n.isValue=function(e){return t.isPlainObject(e)&&\"value\"in e},n.isField=function(e){return t.isPlainObject(e)&&\"field\"in e}},\n",
       "      function _(t,e,i){Object.defineProperty(i,\"__esModule\",{value:!0});const n=t(1),s=t(29),l=t(14),o=n.__importStar(t(19));class a extends s.AnnotationView{connect_signals(){super.connect_signals(),this.connect(this.model.change,()=>this.plot_view.request_render()),this.connect(this.model.data_update,()=>this.plot_view.request_render())}render(){if(!this.model.visible)return;const{xs:t,ys:e}=this.model;if(t.length!=e.length)return;if(t.length<3||e.length<3)return;const{frame:i}=this.plot_view,{ctx:n}=this.plot_view.canvas_view;for(let s=0,l=t.length;s<l;s++){let l,o;if(\"screen\"!=this.model.xs_units)throw new Error(\"not implemented\");if(l=this.model.screen?t[s]:i.xview.compute(t[s]),\"screen\"!=this.model.ys_units)throw new Error(\"not implemented\");o=this.model.screen?e[s]:i.yview.compute(e[s]),0==s?(n.beginPath(),n.moveTo(l,o)):n.lineTo(l,o)}n.closePath(),this.visuals.line.doit&&(this.visuals.line.set_value(n),n.stroke()),this.visuals.fill.doit&&(this.visuals.fill.set_value(n),n.fill())}}i.PolyAnnotationView=a,a.__name__=\"PolyAnnotationView\";class r extends s.Annotation{constructor(t){super(t)}static init_PolyAnnotation(){this.prototype.default_view=a,this.mixins([\"line\",\"fill\"]),this.define({xs:[o.Array,[]],xs_units:[o.SpatialUnits,\"data\"],ys:[o.Array,[]],ys_units:[o.SpatialUnits,\"data\"],x_range_name:[o.String,\"default\"],y_range_name:[o.String,\"default\"]}),this.internal({screen:[o.Boolean,!1]}),this.override({fill_color:\"#fff9ba\",fill_alpha:.4,line_color:\"#cccccc\",line_alpha:.3})}initialize(){super.initialize(),this.data_update=new l.Signal0(this,\"data_update\")}update({xs:t,ys:e}){this.setv({xs:t,ys:e,screen:!0},{silent:!0}),this.data_update.emit()}}i.PolyAnnotation=r,r.__name__=\"PolyAnnotation\",r.init_PolyAnnotation()},\n",
       "      function _(e,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const n=e(1),s=e(29),l=n.__importStar(e(19));class o extends s.AnnotationView{initialize(){super.initialize()}connect_signals(){super.connect_signals(),this.connect(this.model.change,()=>this.plot_view.request_render())}render(){this.model.visible&&this._draw_slope()}_draw_slope(){const e=this.model.gradient,t=this.model.y_intercept;if(null==e||null==t)return;const{frame:i}=this.plot_view,n=i.xscales[this.model.x_range_name],s=i.yscales[this.model.y_range_name],l=i._top.value,o=l+i._height.value,a=(s.invert(l)-t)/e,_=(s.invert(o)-t)/e,r=n.compute(a),c=n.compute(_),{ctx:u}=this.plot_view.canvas_view;u.save(),u.beginPath(),this.visuals.line.set_value(u),u.moveTo(r,l),u.lineTo(c,o),u.stroke(),u.restore()}}i.SlopeView=o,o.__name__=\"SlopeView\";class a extends s.Annotation{constructor(e){super(e)}static init_Slope(){this.prototype.default_view=o,this.mixins([\"line\"]),this.define({gradient:[l.Number,null],y_intercept:[l.Number,null],x_range_name:[l.String,\"default\"],y_range_name:[l.String,\"default\"]}),this.override({line_color:\"black\"})}}i.Slope=a,a.__name__=\"Slope\",a.init_Slope()},\n",
       "      function _(e,i,t){Object.defineProperty(t,\"__esModule\",{value:!0});const s=e(1),o=e(29),n=e(66),l=s.__importStar(e(19));class a extends o.AnnotationView{initialize(){super.initialize(),this.plot_view.canvas_view.add_overlay(this.el),this.el.style.position=\"absolute\",n.undisplay(this.el)}connect_signals(){super.connect_signals(),this.model.for_hover?this.connect(this.model.properties.computed_location.change,()=>this._draw_span()):\"canvas\"==this.model.render_mode?(this.connect(this.model.change,()=>this.plot_view.request_render()),this.connect(this.model.properties.location.change,()=>this.plot_view.request_render())):(this.connect(this.model.change,()=>this.render()),this.connect(this.model.properties.location.change,()=>this._draw_span()))}render(){this.model.visible||\"css\"!=this.model.render_mode||n.undisplay(this.el),this.model.visible&&this._draw_span()}_draw_span(){const e=this.model.for_hover?this.model.computed_location:this.model.location;if(null==e)return void n.undisplay(this.el);const{frame:i}=this.plot_view,t=i.xscales[this.model.x_range_name],s=i.yscales[this.model.y_range_name],o=(i,t)=>this.model.for_hover?this.model.computed_location:\"data\"==this.model.location_units?i.compute(e):t.compute(e);let l,a,h,d;if(\"width\"==this.model.dimension?(h=o(s,i.yview),a=i._left.value,d=i._width.value,l=this.model.properties.line_width.value()):(h=i._top.value,a=o(t,i.xview),d=this.model.properties.line_width.value(),l=i._height.value),\"css\"==this.model.render_mode)this.el.style.top=`${h}px`,this.el.style.left=`${a}px`,this.el.style.width=`${d}px`,this.el.style.height=`${l}px`,this.el.style.backgroundColor=this.model.properties.line_color.value(),this.el.style.opacity=this.model.properties.line_alpha.value(),n.display(this.el);else if(\"canvas\"==this.model.render_mode){const{ctx:e}=this.plot_view.canvas_view;e.save(),e.beginPath(),this.visuals.line.set_value(e),e.moveTo(a,h),\"width\"==this.model.dimension?e.lineTo(a+d,h):e.lineTo(a,h+l),e.stroke(),e.restore()}}}t.SpanView=a,a.__name__=\"SpanView\";class h extends o.Annotation{constructor(e){super(e)}static init_Span(){this.prototype.default_view=a,this.mixins([\"line\"]),this.define({render_mode:[l.RenderMode,\"canvas\"],x_range_name:[l.String,\"default\"],y_range_name:[l.String,\"default\"],location:[l.Number,null],location_units:[l.SpatialUnits,\"data\"],dimension:[l.Dimension,\"width\"]}),this.override({line_color:\"black\"}),this.internal({for_hover:[l.Boolean,!1],computed_location:[l.Number,null]})}}t.Span=h,h.__name__=\"Span\",h.init_Span()},\n",
       "      function _(e,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const l=e(1),a=e(133),s=e(66),n=e(68),o=l.__importStar(e(19));class r extends a.TextAnnotationView{initialize(){super.initialize(),this.visuals.text=new n.Text(this.model)}_get_location(){const e=this.panel,t=this.model.offset;let i,l;switch(e.side){case\"above\":case\"below\":switch(this.model.vertical_align){case\"top\":l=e._top.value+5;break;case\"middle\":l=e._vcenter.value;break;case\"bottom\":l=e._bottom.value-5}switch(this.model.align){case\"left\":i=e._left.value+t;break;case\"center\":i=e._hcenter.value;break;case\"right\":i=e._right.value-t}break;case\"left\":switch(this.model.vertical_align){case\"top\":i=e._left.value-5;break;case\"middle\":i=e._hcenter.value;break;case\"bottom\":i=e._right.value+5}switch(this.model.align){case\"left\":l=e._bottom.value-t;break;case\"center\":l=e._vcenter.value;break;case\"right\":l=e._top.value+t}break;case\"right\":switch(this.model.vertical_align){case\"top\":i=e._right.value-5;break;case\"middle\":i=e._hcenter.value;break;case\"bottom\":i=e._left.value+5}switch(this.model.align){case\"left\":l=e._top.value+t;break;case\"center\":l=e._vcenter.value;break;case\"right\":l=e._bottom.value-t}}return[i,l]}render(){if(!this.model.visible)return void(\"css\"==this.model.render_mode&&s.undisplay(this.el));const{text:e}=this.model;if(null==e||0==e.length)return;this.model.text_baseline=this.model.vertical_align,this.model.text_align=this.model.align;const[t,i]=this._get_location(),l=this.panel.get_label_angle_heuristic(\"parallel\");(\"canvas\"==this.model.render_mode?this._canvas_text.bind(this):this._css_text.bind(this))(this.plot_view.canvas_view.ctx,e,t,i,l)}_get_size(){const{text:e}=this.model;if(null==e||0==e.length)return{width:0,height:0};{this.visuals.text.set_value(this.ctx);const{width:t,ascent:i}=this.ctx.measureText(e);return{width:t,height:i*this.visuals.text.text_line_height.value()+10}}}}i.TitleView=r,r.__name__=\"TitleView\";class c extends a.TextAnnotation{constructor(e){super(e)}static init_Title(){this.prototype.default_view=r,this.mixins([\"line:border_\",\"fill:background_\"]),this.define({text:[o.String],text_font:[o.Font,\"helvetica\"],text_font_size:[o.FontSizeSpec,\"10pt\"],text_font_style:[o.FontStyle,\"bold\"],text_color:[o.ColorSpec,\"#444444\"],text_alpha:[o.NumberSpec,1],text_line_height:[o.Number,1],vertical_align:[o.VerticalAlign,\"bottom\"],align:[o.TextAlign,\"left\"],offset:[o.Number,0]}),this.override({background_fill_color:null,border_line_color:null}),this.internal({text_align:[o.TextAlign,\"left\"],text_baseline:[o.TextBaseline,\"bottom\"]})}}i.Title=c,c.__name__=\"Title\",c.init_Title()},\n",
       "      function _(e,i,t){Object.defineProperty(t,\"__esModule\",{value:!0});const o=e(1),l=e(29),s=e(96),a=e(66),n=o.__importStar(e(19));class r extends l.AnnotationView{constructor(){super(...arguments),this.rotate=!0}initialize(){super.initialize(),this.plot_view.canvas_view.add_event(this.el)}async lazy_initialize(){this._toolbar_view=await s.build_view(this.model.toolbar,{parent:this}),this.plot_view.visibility_callbacks.push(e=>this._toolbar_view.set_visibility(e))}remove(){this._toolbar_view.remove(),super.remove()}render(){super.render(),this.model.visible?(this.el.style.position=\"absolute\",this.el.style.overflow=\"hidden\",a.position(this.el,this.panel.bbox),this._toolbar_view.render(),a.empty(this.el),this.el.appendChild(this._toolbar_view.el),a.display(this.el)):a.undisplay(this.el)}_get_size(){const{tools:e,logo:i}=this.model.toolbar;return{width:30*e.length+(null!=i?25:0),height:30}}}t.ToolbarPanelView=r,r.__name__=\"ToolbarPanelView\";class _ extends l.Annotation{constructor(e){super(e)}static init_ToolbarPanel(){this.prototype.default_view=r,this.define({toolbar:[n.Instance]})}}t.ToolbarPanel=_,_.__name__=\"ToolbarPanel\",_.init_ToolbarPanel()},\n",
       "      function _(t,e,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=t(1),l=t(29),o=t(66),a=i.__importStar(t(19)),h=t(144),n=t(145);function c(t,e,s,i,l){switch(t){case\"horizontal\":return e<i?\"right\":\"left\";case\"vertical\":return s<l?\"below\":\"above\";default:return t}}s.compute_side=c;class r extends l.AnnotationView{initialize(){super.initialize(),this.plot_view.canvas_view.add_overlay(this.el),o.undisplay(this.el)}connect_signals(){super.connect_signals(),this.connect(this.model.properties.data.change,()=>this._draw_tips())}css_classes(){return super.css_classes().concat(h.bk_tooltip)}render(){this.model.visible&&this._draw_tips()}_draw_tips(){const{data:t}=this.model;if(o.empty(this.el),o.undisplay(this.el),this.model.custom?this.el.classList.add(h.bk_tooltip_custom):this.el.classList.remove(h.bk_tooltip_custom),0==t.length)return;const{frame:e}=this.plot_view;for(const[s,i,l]of t){if(this.model.inner_only&&!e.bbox.contains(s,i))continue;const t=o.div({},l);this.el.appendChild(t)}const[s,i]=t[t.length-1],l=c(this.model.attachment,s,i,e._hcenter.value,e._vcenter.value);this.el.classList.remove(n.bk_right),this.el.classList.remove(n.bk_left),this.el.classList.remove(n.bk_above),this.el.classList.remove(n.bk_below);let a;o.display(this.el);let r=0,d=0;switch(l){case\"right\":this.el.classList.add(n.bk_left),r=s+(this.el.offsetWidth-this.el.clientWidth)+10,a=i-this.el.offsetHeight/2;break;case\"left\":this.el.classList.add(n.bk_right),d=this.plot_view.layout.bbox.width-s+10,a=i-this.el.offsetHeight/2;break;case\"below\":this.el.classList.add(n.bk_above),a=i+(this.el.offsetHeight-this.el.clientHeight)+10,r=Math.round(s-this.el.offsetWidth/2);break;case\"above\":this.el.classList.add(n.bk_below),a=i-this.el.offsetHeight-10,r=Math.round(s-this.el.offsetWidth/2)}this.model.show_arrow&&this.el.classList.add(h.bk_tooltip_arrow),this.el.childNodes.length>0?(this.el.style.top=`${a}px`,this.el.style.left=r?`${r}px`:\"auto\",this.el.style.right=d?`${d}px`:\"auto\"):o.undisplay(this.el)}}s.TooltipView=r,r.__name__=\"TooltipView\";class d extends l.Annotation{constructor(t){super(t)}static init_Tooltip(){this.prototype.default_view=r,this.define({attachment:[a.TooltipAttachment,\"horizontal\"],inner_only:[a.Boolean,!0],show_arrow:[a.Boolean,!0]}),this.override({level:\"overlay\"}),this.internal({data:[a.Any,[]],custom:[a.Any]})}clear(){this.data=[]}add(t,e,s){this.data=this.data.concat([[t,e,s]])}}s.Tooltip=d,d.__name__=\"Tooltip\",d.init_Tooltip()},\n",
       "      function _(o,t,n){Object.defineProperty(n,\"__esModule\",{value:!0});const r=o(1);o(67),r.__importStar(o(66)).styles.append('.bk-root {\\n  /* Same border color used everywhere */\\n  /* Gray of icons */\\n}\\n.bk-root .bk-tooltip {\\n  font-weight: 300;\\n  font-size: 12px;\\n  position: absolute;\\n  padding: 5px;\\n  border: 1px solid #e5e5e5;\\n  color: #2f2f2f;\\n  background-color: white;\\n  pointer-events: none;\\n  opacity: 0.95;\\n  z-index: 100;\\n}\\n.bk-root .bk-tooltip > div:not(:first-child) {\\n  /* gives space when multiple elements are being hovered over */\\n  margin-top: 5px;\\n  border-top: #e5e5e5 1px dashed;\\n}\\n.bk-root .bk-tooltip.bk-left.bk-tooltip-arrow::before {\\n  position: absolute;\\n  margin: -7px 0 0 0;\\n  top: 50%;\\n  width: 0;\\n  height: 0;\\n  border-style: solid;\\n  border-width: 7px 0 7px 0;\\n  border-color: transparent;\\n  content: \" \";\\n  display: block;\\n  left: -10px;\\n  border-right-width: 10px;\\n  border-right-color: #909599;\\n}\\n.bk-root .bk-tooltip.bk-left::before {\\n  left: -10px;\\n  border-right-width: 10px;\\n  border-right-color: #909599;\\n}\\n.bk-root .bk-tooltip.bk-right.bk-tooltip-arrow::after {\\n  position: absolute;\\n  margin: -7px 0 0 0;\\n  top: 50%;\\n  width: 0;\\n  height: 0;\\n  border-style: solid;\\n  border-width: 7px 0 7px 0;\\n  border-color: transparent;\\n  content: \" \";\\n  display: block;\\n  right: -10px;\\n  border-left-width: 10px;\\n  border-left-color: #909599;\\n}\\n.bk-root .bk-tooltip.bk-right::after {\\n  right: -10px;\\n  border-left-width: 10px;\\n  border-left-color: #909599;\\n}\\n.bk-root .bk-tooltip.bk-above::before {\\n  position: absolute;\\n  margin: 0 0 0 -7px;\\n  left: 50%;\\n  width: 0;\\n  height: 0;\\n  border-style: solid;\\n  border-width: 0 7px 0 7px;\\n  border-color: transparent;\\n  content: \" \";\\n  display: block;\\n  top: -10px;\\n  border-bottom-width: 10px;\\n  border-bottom-color: #909599;\\n}\\n.bk-root .bk-tooltip.bk-below::after {\\n  position: absolute;\\n  margin: 0 0 0 -7px;\\n  left: 50%;\\n  width: 0;\\n  height: 0;\\n  border-style: solid;\\n  border-width: 0 7px 0 7px;\\n  border-color: transparent;\\n  content: \" \";\\n  display: block;\\n  bottom: -10px;\\n  border-top-width: 10px;\\n  border-top-color: #909599;\\n}\\n.bk-root .bk-tooltip-row-label {\\n  text-align: right;\\n  color: #26aae1;\\n  /* blue from toolbar highlighting */\\n}\\n.bk-root .bk-tooltip-row-value {\\n  color: default;\\n  /* seems to be necessary for notebook */\\n}\\n.bk-root .bk-tooltip-color-block {\\n  width: 12px;\\n  height: 12px;\\n  margin-left: 5px;\\n  margin-right: 5px;\\n  outline: #dddddd solid 1px;\\n  display: inline-block;\\n}\\n'),n.bk_tooltip=\"bk-tooltip\",n.bk_tooltip_arrow=\"bk-tooltip-arrow\",n.bk_tooltip_custom=\"bk-tooltip-custom\",n.bk_tooltip_row_label=\"bk-tooltip-row-label\",n.bk_tooltip_row_value=\"bk-tooltip-row-value\",n.bk_tooltip_color_block=\"bk-tooltip-color-block\"},\n",
       "      function _(e,b,t){Object.defineProperty(t,\"__esModule\",{value:!0}),e(1).__importStar(e(66)).styles.append(\"\"),t.bk_active=\"bk-active\",t.bk_inline=\"bk-inline\",t.bk_left=\"bk-left\",t.bk_right=\"bk-right\",t.bk_above=\"bk-above\",t.bk_below=\"bk-below\",t.bk_up=\"bk-up\",t.bk_down=\"bk-down\",t.bk_side=function(e){switch(e){case\"above\":return t.bk_above;case\"below\":return t.bk_below;case\"left\":return t.bk_left;case\"right\":return t.bk_right}}},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=e(1),r=e(29),o=e(73),a=e(72),n=i.__importStar(e(19));class h extends r.AnnotationView{initialize(){super.initialize(),this.set_data(this.model.source)}connect_signals(){super.connect_signals(),this.connect(this.model.source.streaming,()=>this.set_data(this.model.source)),this.connect(this.model.source.patching,()=>this.set_data(this.model.source)),this.connect(this.model.source.change,()=>this.set_data(this.model.source))}set_data(e){super.set_data(e),this.visuals.warm_cache(e),this.plot_view.request_render()}_map_data(){const{frame:e}=this.plot_view,t=this.model.dimension,s=e.xscales[this.model.x_range_name],i=e.yscales[this.model.y_range_name],r=\"height\"==t?i:s,o=\"height\"==t?s:i,a=\"height\"==t?e.yview:e.xview,n=\"height\"==t?e.xview:e.yview;let h,_,l;h=\"data\"==this.model.properties.lower.units?r.v_compute(this._lower):a.v_compute(this._lower),_=\"data\"==this.model.properties.upper.units?r.v_compute(this._upper):a.v_compute(this._upper),l=\"data\"==this.model.properties.base.units?o.v_compute(this._base):n.v_compute(this._base);const[d,p]=\"height\"==t?[1,0]:[0,1],c=[h,l],u=[_,l];this._lower_sx=c[d],this._lower_sy=c[p],this._upper_sx=u[d],this._upper_sy=u[p]}render(){if(!this.model.visible)return;this._map_data();const{ctx:e}=this.plot_view.canvas_view;if(this.visuals.line.doit)for(let t=0,s=this._lower_sx.length;t<s;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.model.lower_head)for(let s=0,i=this._lower_sx.length;s<i;s++)e.save(),e.translate(this._lower_sx[s],this._lower_sy[s]),e.rotate(t+Math.PI),this.model.lower_head.render(e,s),e.restore();if(null!=this.model.upper_head)for(let s=0,i=this._upper_sx.length;s<i;s++)e.save(),e.translate(this._upper_sx[s],this._upper_sy[s]),e.rotate(t),this.model.upper_head.render(e,s),e.restore()}}s.WhiskerView=h,h.__name__=\"WhiskerView\";class _ extends r.Annotation{constructor(e){super(e)}static init_Whisker(){this.prototype.default_view=h,this.mixins([\"line\"]),this.define({lower:[n.DistanceSpec],lower_head:[n.Instance,()=>new a.TeeHead({level:\"underlay\",size:10})],upper:[n.DistanceSpec],upper_head:[n.Instance,()=>new a.TeeHead({level:\"underlay\",size:10})],base:[n.DistanceSpec],dimension:[n.Dimension,\"height\"],source:[n.Instance,()=>new o.ColumnDataSource],x_range_name:[n.String,\"default\"],y_range_name:[n.String,\"default\"]}),this.override({level:\"underlay\"})}}s.Whisker=_,_.__name__=\"Whisker\",_.init_Whisker()},\n",
       "      function _(i,a,e){Object.defineProperty(e,\"__esModule\",{value:!0});var r=i(148);e.Axis=r.Axis;var s=i(150);e.CategoricalAxis=s.CategoricalAxis;var x=i(153);e.ContinuousAxis=x.ContinuousAxis;var A=i(154);e.DatetimeAxis=A.DatetimeAxis;var o=i(155);e.LinearAxis=o.LinearAxis;var t=i(168);e.LogAxis=t.LogAxis;var n=i(171);e.MercatorAxis=n.MercatorAxis},\n",
       "      function _(e,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const s=e(1),a=e(149),l=s.__importStar(e(19)),n=e(9),o=e(8),r=e(88),{abs:_,min:h,max:c}=Math;class m extends a.GuideRendererView{constructor(){super(...arguments),this.rotate=!0}get panel(){return this.layout}render(){if(!this.model.visible)return;const e={tick:this._tick_extent(),tick_label:this._tick_label_extents(),axis_label:this._axis_label_extent()},t=this.tick_coords,i=this.plot_view.canvas_view.ctx;i.save(),this._draw_rule(i,e),this._draw_major_ticks(i,e,t),this._draw_minor_ticks(i,e,t),this._draw_major_labels(i,e,t),this._draw_axis_label(i,e,t),null!=this._render&&this._render(i,e,t),i.restore()}connect_signals(){super.connect_signals(),this.connect(this.model.change,()=>this.plot_view.request_paint());const e=this.model.properties;this.on_change(e.visible,()=>this.plot_view.request_layout())}get_size(){if(this.model.visible&&null==this.model.fixed_location){const e=this._get_size();return{width:0,height:Math.round(e)}}return{width:0,height:0}}_get_size(){return this._tick_extent()+this._tick_label_extent()+this._axis_label_extent()}get needs_clip(){return null!=this.model.fixed_location}_draw_rule(e,t){if(!this.visuals.axis_line.doit)return;const[i,s]=this.rule_coords,[a,l]=this.plot_view.map_to_screen(i,s,this.model.x_range_name,this.model.y_range_name),[n,o]=this.normals,[r,_]=this.offsets;this.visuals.axis_line.set_value(e),e.beginPath(),e.moveTo(Math.round(a[0]+n*r),Math.round(l[0]+o*_));for(let t=1;t<a.length;t++){const i=Math.round(a[t]+n*r),s=Math.round(l[t]+o*_);e.lineTo(i,s)}e.stroke()}_draw_major_ticks(e,t,i){const s=this.model.major_tick_in,a=this.model.major_tick_out,l=this.visuals.major_tick_line;this._draw_ticks(e,i.major,s,a,l)}_draw_minor_ticks(e,t,i){const s=this.model.minor_tick_in,a=this.model.minor_tick_out,l=this.visuals.minor_tick_line;this._draw_ticks(e,i.minor,s,a,l)}_draw_major_labels(e,t,i){const s=i.major,a=this.compute_labels(s[this.dimension]),l=this.model.major_label_orientation,n=t.tick+this.model.major_label_standoff,o=this.visuals.major_label_text;this._draw_oriented_labels(e,a,s,l,this.panel.side,n,o)}_draw_axis_label(e,t,i){if(null==this.model.axis_label||0==this.model.axis_label.length||null!=this.model.fixed_location)return;let s,a;switch(this.panel.side){case\"above\":s=this.panel._hcenter.value,a=this.panel._bottom.value;break;case\"below\":s=this.panel._hcenter.value,a=this.panel._top.value;break;case\"left\":s=this.panel._right.value,a=this.panel._vcenter.value;break;case\"right\":s=this.panel._left.value,a=this.panel._vcenter.value;break;default:throw new Error(`unknown side: ${this.panel.side}`)}const l=[[s],[a]],o=t.tick+n.sum(t.tick_label)+this.model.axis_label_standoff,r=this.visuals.axis_label_text;this._draw_oriented_labels(e,[this.model.axis_label],l,\"parallel\",this.panel.side,o,r,\"screen\")}_draw_ticks(e,t,i,s,a){if(!a.doit)return;const[l,n]=t,[o,r]=this.plot_view.map_to_screen(l,n,this.model.x_range_name,this.model.y_range_name),[_,h]=this.normals,[c,m]=this.offsets,[d,u]=[_*(c-i),h*(m-i)],[b,x]=[_*(c+s),h*(m+s)];a.set_value(e);for(let t=0;t<o.length;t++){const i=Math.round(o[t]+b),s=Math.round(r[t]+x),a=Math.round(o[t]+d),l=Math.round(r[t]+u);e.beginPath(),e.moveTo(i,s),e.lineTo(a,l),e.stroke()}}_draw_oriented_labels(e,t,i,s,a,l,n,r=\"data\"){if(!n.doit||0==t.length)return;let _,h,c,m;if(\"screen\"==r)[_,h]=i,[c,m]=[0,0];else{const[e,t]=i;[_,h]=this.plot_view.map_to_screen(e,t,this.model.x_range_name,this.model.y_range_name),[c,m]=this.offsets}const[d,u]=this.normals,b=d*(c+l),x=u*(m+l);let p;n.set_value(e),this.panel.apply_label_text_heuristics(e,s),p=o.isString(s)?this.panel.get_label_angle_heuristic(s):-s;for(let i=0;i<_.length;i++){const s=Math.round(_[i]+b),a=Math.round(h[i]+x);e.translate(s,a),e.rotate(p),e.fillText(t[i],0,0),e.rotate(-p),e.translate(-s,-a)}}_axis_label_extent(){if(null==this.model.axis_label||\"\"==this.model.axis_label)return 0;const e=this.model.axis_label_standoff,t=this.visuals.axis_label_text;return this._oriented_labels_extent([this.model.axis_label],\"parallel\",this.panel.side,e,t)}_tick_extent(){return this.model.major_tick_out}_tick_label_extent(){return n.sum(this._tick_label_extents())}_tick_label_extents(){const e=this.tick_coords.major,t=this.compute_labels(e[this.dimension]),i=this.model.major_label_orientation,s=this.model.major_label_standoff,a=this.visuals.major_label_text;return[this._oriented_labels_extent(t,i,this.panel.side,s,a)]}_oriented_labels_extent(e,t,i,s,a){if(0==e.length)return 0;const l=this.plot_view.canvas_view.ctx;let n,r;a.set_value(l),o.isString(t)?(n=1,r=this.panel.get_label_angle_heuristic(t)):(n=2,r=-t),r=Math.abs(r);const _=Math.cos(r),h=Math.sin(r);let c=0;for(let t=0;t<e.length;t++){const s=1.1*l.measureText(e[t]).width,a=.9*l.measureText(e[t]).ascent;let o;o=\"above\"==i||\"below\"==i?s*h+a/n*_:s*_+a/n*h,o>c&&(c=o)}return c>0&&(c+=s),c}get normals(){return this.panel.normals}get dimension(){return this.panel.dimension}compute_labels(e){const t=this.model.formatter.doFormat(e,this);for(let i=0;i<e.length;i++)e[i]in this.model.major_label_overrides&&(t[i]=this.model.major_label_overrides[e[i]]);return t}get offsets(){if(null!=this.model.fixed_location)return[0,0];const{frame:e}=this.plot_view;let[t,i]=[0,0];switch(this.panel.side){case\"below\":i=_(this.panel._top.value-e._bottom.value);break;case\"above\":i=_(this.panel._bottom.value-e._top.value);break;case\"right\":t=_(this.panel._left.value-e._right.value);break;case\"left\":t=_(this.panel._right.value-e._left.value)}return[t,i]}get ranges(){const e=this.dimension,t=(e+1)%2,{frame:i}=this.plot_view,s=[i.x_ranges[this.model.x_range_name],i.y_ranges[this.model.y_range_name]];return[s[e],s[t]]}get computed_bounds(){const[e]=this.ranges,t=this.model.bounds,i=[e.min,e.max];if(\"auto\"==t)return[e.min,e.max];if(o.isArray(t)){let e,s;const[a,l]=t,[n,o]=i;return _(a-l)>_(n-o)?(e=c(h(a,l),n),s=h(c(a,l),o)):(e=h(a,l),s=c(a,l)),[e,s]}throw new Error(`user bounds '${t}' not understood`)}get rule_coords(){const e=this.dimension,t=(e+1)%2,[i]=this.ranges,[s,a]=this.computed_bounds,l=[new Array(2),new Array(2)];return l[e][0]=Math.max(s,i.min),l[e][1]=Math.min(a,i.max),l[e][0]>l[e][1]&&(l[e][0]=l[e][1]=NaN),l[t][0]=this.loc,l[t][1]=this.loc,l}get tick_coords(){const e=this.dimension,t=(e+1)%2,[i]=this.ranges,[s,a]=this.computed_bounds,l=this.model.ticker.get_ticks(s,a,i,this.loc,{}),n=l.major,o=l.minor,r=[[],[]],_=[[],[]],[h,c]=[i.min,i.max];for(let i=0;i<n.length;i++)n[i]<h||n[i]>c||(r[e].push(n[i]),r[t].push(this.loc));for(let i=0;i<o.length;i++)o[i]<h||o[i]>c||(_[e].push(o[i]),_[t].push(this.loc));return{major:r,minor:_}}get loc(){const{fixed_location:e}=this.model;if(null!=e){if(o.isNumber(e))return e;const[,t]=this.ranges;if(t instanceof r.FactorRange)return t.synthetic(e);throw new Error(\"unexpected\")}const[,t]=this.ranges;switch(this.panel.side){case\"left\":case\"below\":return t.start;case\"right\":case\"above\":return t.end}}serializable_state(){return Object.assign(Object.assign({},super.serializable_state()),{bbox:this.layout.bbox.box})}}i.AxisView=m,m.__name__=\"AxisView\";class d extends a.GuideRenderer{constructor(e){super(e)}static init_Axis(){this.prototype.default_view=m,this.mixins([\"line:axis_\",\"line:major_tick_\",\"line:minor_tick_\",\"text:major_label_\",\"text:axis_label_\"]),this.define({bounds:[l.Any,\"auto\"],ticker:[l.Instance],formatter:[l.Instance],x_range_name:[l.String,\"default\"],y_range_name:[l.String,\"default\"],axis_label:[l.String,\"\"],axis_label_standoff:[l.Int,5],major_label_standoff:[l.Int,5],major_label_orientation:[l.Any,\"horizontal\"],major_label_overrides:[l.Any,{}],major_tick_in:[l.Number,2],major_tick_out:[l.Number,6],minor_tick_in:[l.Number,0],minor_tick_out:[l.Number,4],fixed_location:[l.Any,null]}),this.override({axis_line_color:\"black\",major_tick_line_color:\"black\",minor_tick_line_color:\"black\",major_label_text_font_size:\"8pt\",major_label_text_align:\"center\",major_label_text_baseline:\"alphabetic\",axis_label_text_font_size:\"10pt\",axis_label_text_font_style:\"italic\"})}}i.Axis=d,d.__name__=\"Axis\",d.init_Axis()},\n",
       "      function _(e,r,d){Object.defineProperty(d,\"__esModule\",{value:!0});const n=e(63);class i extends n.RendererView{}d.GuideRendererView=i,i.__name__=\"GuideRendererView\";class t extends n.Renderer{constructor(e){super(e)}static init_GuideRenderer(){this.override({level:\"overlay\"})}}d.GuideRenderer=t,t.__name__=\"GuideRenderer\",t.init_GuideRenderer()},\n",
       "      function _(t,s,o){Object.defineProperty(o,\"__esModule\",{value:!0});const e=t(1),i=t(148),r=t(151),a=t(152),l=e.__importStar(t(19));class _ extends i.AxisView{_render(t,s,o){this._draw_group_separators(t,s,o)}_draw_group_separators(t,s,o){const[e]=this.ranges,[i,r]=this.computed_bounds;if(!e.tops||e.tops.length<2||!this.visuals.separator_line.doit)return;const a=this.dimension,l=(a+1)%2,_=[[],[]];let n=0;for(let t=0;t<e.tops.length-1;t++){let s,o;for(let i=n;i<e.factors.length;i++)if(e.factors[i][0]==e.tops[t+1]){[s,o]=[e.factors[i-1],e.factors[i]],n=i;break}const h=(e.synthetic(s)+e.synthetic(o))/2;h>i&&h<r&&(_[a].push(h),_[l].push(this.loc))}const h=this._tick_label_extent();this._draw_ticks(t,_,-3,h-6,this.visuals.separator_line)}_draw_major_labels(t,s,o){const e=this._get_factor_info();let i=s.tick+this.model.major_label_standoff;for(let o=0;o<e.length;o++){const[r,a,l,_]=e[o];this._draw_oriented_labels(t,r,a,l,this.panel.side,i,_),i+=s.tick_label[o]}}_tick_label_extents(){const t=this._get_factor_info(),s=[];for(const[o,,e,i]of t){const t=this._oriented_labels_extent(o,e,this.panel.side,this.model.major_label_standoff,i);s.push(t)}return s}_get_factor_info(){const[t]=this.ranges,[s,o]=this.computed_bounds,e=this.loc,i=this.model.ticker.get_ticks(s,o,t,e,{}),r=this.tick_coords,a=[];if(1==t.levels){const t=i.major,s=this.model.formatter.doFormat(t,this);a.push([s,r.major,this.model.major_label_orientation,this.visuals.major_label_text])}else if(2==t.levels){const t=i.major.map(t=>t[1]),s=this.model.formatter.doFormat(t,this);a.push([s,r.major,this.model.major_label_orientation,this.visuals.major_label_text]),a.push([i.tops,r.tops,this.model.group_label_orientation,this.visuals.group_text])}else if(3==t.levels){const t=i.major.map(t=>t[2]),s=this.model.formatter.doFormat(t,this),o=i.mids.map(t=>t[1]);a.push([s,r.major,this.model.major_label_orientation,this.visuals.major_label_text]),a.push([o,r.mids,this.model.subgroup_label_orientation,this.visuals.subgroup_text]),a.push([i.tops,r.tops,this.model.group_label_orientation,this.visuals.group_text])}return a}get tick_coords(){const t=this.dimension,s=(t+1)%2,[o]=this.ranges,[e,i]=this.computed_bounds,r=this.model.ticker.get_ticks(e,i,o,this.loc,{}),a={major:[[],[]],mids:[[],[]],tops:[[],[]],minor:[[],[]]};return a.major[t]=r.major,a.major[s]=r.major.map(t=>this.loc),3==o.levels&&(a.mids[t]=r.mids,a.mids[s]=r.mids.map(t=>this.loc)),o.levels>1&&(a.tops[t]=r.tops,a.tops[s]=r.tops.map(t=>this.loc)),a}}o.CategoricalAxisView=_,_.__name__=\"CategoricalAxisView\";class n extends i.Axis{constructor(t){super(t)}static init_CategoricalAxis(){this.prototype.default_view=_,this.mixins([\"line:separator_\",\"text:group_\",\"text:subgroup_\"]),this.define({group_label_orientation:[l.Any,\"parallel\"],subgroup_label_orientation:[l.Any,\"parallel\"]}),this.override({ticker:()=>new r.CategoricalTicker,formatter:()=>new a.CategoricalTickFormatter,separator_line_color:\"lightgrey\",separator_line_width:2,group_text_font_style:\"bold\",group_text_font_size:\"8pt\",group_text_color:\"grey\",subgroup_text_font_style:\"bold\",subgroup_text_font_size:\"8pt\"})}}o.CategoricalAxis=n,n.__name__=\"CategoricalAxis\",n.init_CategoricalAxis()},\n",
       "      function _(t,c,e){Object.defineProperty(e,\"__esModule\",{value:!0});const o=t(111);class s extends o.Ticker{constructor(t){super(t)}get_ticks(t,c,e,o,s){return{major:this._collect(e.factors,e,t,c),minor:[],tops:this._collect(e.tops||[],e,t,c),mids:this._collect(e.mids||[],e,t,c)}}_collect(t,c,e,o){const s=[];for(const r of t){const t=c.synthetic(r);t>e&&t<o&&s.push(r)}return s}}e.CategoricalTicker=s,s.__name__=\"CategoricalTicker\"},\n",
       "      function _(e,t,r){Object.defineProperty(r,\"__esModule\",{value:!0});const o=e(113),c=e(9);class a extends o.TickFormatter{constructor(e){super(e)}doFormat(e,t){return c.copy(e)}}r.CategoricalTickFormatter=a,a.__name__=\"CategoricalTickFormatter\"},\n",
       "      function _(s,e,n){Object.defineProperty(n,\"__esModule\",{value:!0});const o=s(148);class t extends o.Axis{constructor(s){super(s)}}n.ContinuousAxis=t,t.__name__=\"ContinuousAxis\"},\n",
       "      function _(e,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const s=e(155),a=e(156),r=e(161);class n extends s.LinearAxisView{}i.DatetimeAxisView=n,n.__name__=\"DatetimeAxisView\";class _ extends s.LinearAxis{constructor(e){super(e)}static init_DatetimeAxis(){this.prototype.default_view=n,this.override({ticker:()=>new r.DatetimeTicker,formatter:()=>new a.DatetimeTickFormatter})}}i.DatetimeAxis=_,_.__name__=\"DatetimeAxis\",_.init_DatetimeAxis()},\n",
       "      function _(e,i,s){Object.defineProperty(s,\"__esModule\",{value:!0});const t=e(148),n=e(153),r=e(112),a=e(108);class _ extends t.AxisView{}s.LinearAxisView=_,_.__name__=\"LinearAxisView\";class c extends n.ContinuousAxis{constructor(e){super(e)}static init_LinearAxis(){this.prototype.default_view=_,this.override({ticker:()=>new a.BasicTicker,formatter:()=>new r.BasicTickFormatter})}}s.LinearAxis=c,c.__name__=\"LinearAxis\",c.init_LinearAxis()},\n",
       "      function _(t,s,e){Object.defineProperty(e,\"__esModule\",{value:!0});const r=t(1),i=r.__importDefault(t(157)),n=t(113),o=t(70),a=r.__importStar(t(19)),c=t(158),m=t(9),u=t(8);function h(t){return i.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:i.default(t,s)}}const l=[\"microseconds\",\"milliseconds\",\"seconds\",\"minsec\",\"minutes\",\"hourmin\",\"hours\",\"days\",\"months\",\"years\"];class _ extends n.TickFormatter{constructor(t){super(t),this.strip_leading_zeros=!0}static init_DatetimeTickFormatter(){this.define({microseconds:[a.Array,[\"%fus\"]],milliseconds:[a.Array,[\"%3Nms\",\"%S.%3Ns\"]],seconds:[a.Array,[\"%Ss\"]],minsec:[a.Array,[\":%M:%S\"]],minutes:[a.Array,[\":%M\",\"%Mm\"]],hourmin:[a.Array,[\"%H:%M\"]],hours:[a.Array,[\"%Hh\",\"%H:%M\"]],days:[a.Array,[\"%m/%d\",\"%a%d\"]],months:[a.Array,[\"%m/%Y\",\"%b %Y\"]],years:[a.Array,[\"%Y\"]]})}initialize(){super.initialize(),this._update_width_formats()}_update_width_formats(){const t=+i.default(new Date),s=function(s){const e=s.map(s=>d(t,s).length),r=m.sort_by(m.zip(e,s),([t])=>t);return m.unzip(r)};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,r=e/(t.length-1),i=this._get_resolution_str(r,e),[,[n]]=this._width_formats[i],a=[],c=l.indexOf(i),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,n)}catch(t){o.logger.warn(`unable to format tick for timestamp value ${s}`),o.logger.warn(` - ${t}`),a.push(\"ERR\");continue}let r=!1,u=c;for(;0==e[m[l[u]]];){let n;if(u+=1,u==l.length)break;if((\"minsec\"==i||\"hourmin\"==i)&&!r){if(\"minsec\"==i&&0==e[4]&&0!=e[5]||\"hourmin\"==i&&0==e[3]&&0!=e[4]){n=this._width_formats[l[c-1]][1][0],t=d(s,n);break}r=!0}n=this._width_formats[l[u]][1][0],t=d(s,n)}if(this.strip_leading_zeros){let s=t.replace(/^0+/g,\"\");s!=t&&isNaN(parseInt(s))&&(s=`0${s}`),a.push(s)}else a.push(t)}return a}}e.DatetimeTickFormatter=_,_.__name__=\"DatetimeTickFormatter\",_.init_DatetimeTickFormatter()},\n",
       "      function _(e,t,n){!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,n,e){Object.defineProperty(e,\"__esModule\",{value:!0});const t=r(1),i=t.__importStar(r(159)),u=r(160),a=t.__importDefault(r(157)),f=r(25),o=r(8);function l(r,...n){return u.sprintf(r,...n)}function s(r,n,e){if(o.isNumber(r)){return l((()=>{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 c(r,n,t){if(null==n)return s;if(null!=t&&r in t){const n=t[r];if(o.isString(n)){if(n in e.DEFAULT_FORMATTERS)return e.DEFAULT_FORMATTERS[n];throw new Error(`Unknown tooltip field formatter type '${n}'`)}return function(r,e,t){return n.format(r,e,t)}}return e.DEFAULT_FORMATTERS.numeral}function m(r,n,e,t){if(\"$\"==r[0]){return function(r,n){if(r in n)return n[r];throw new Error(`Unknown special variable '$${r}'`)}(r.substring(1),t)}return function(r,n,e){const t=n.get_column(r);if(null==t)return null;if(o.isNumber(e))return t[e];const i=t[e.index];if(o.isTypedArray(i)||o.isArray(i)){if(o.isArray(i[0])){return i[e.dim2][e.dim1]}return i[e.flat_index]}return i}(r.substring(1).replace(/[{}]/g,\"\"),n,e)}e.DEFAULT_FORMATTERS={numeral:(r,n,e)=>i.format(r,n),datetime:(r,n,e)=>a.default(r,n),printf:(r,n,e)=>l(n,r)},e.sprintf=l,e.basic_formatter=s,e.get_formatter=c,e.get_value=m,e.replace_placeholders=function(r,n,e,t,i={}){return r=(r=r.replace(/@\\$name/g,r=>`@{${i.name}}`)).replace(/((?:\\$\\w+)|(?:@\\w+)|(?:@{(?:[^{}]+)}))(?:{([^{}]+)})?/g,(r,u,a)=>{const o=m(u,n,e,i);if(null==o)return`${f.escape(\"???\")}`;if(\"safe\"==a)return`${o}`;const l=c(u,a,t);return`${f.escape(l(o,a,i))}`})}},\n",
FAGES Francois's avatar
FAGES Francois committed
909
910
911
912
913
914
915
916
       "      function _(e,n,t){\n",
       "      /*!\n",
       "           * numbro.js\n",
       "           * version : 1.6.2\n",
       "           * author : Företagsplatsen AB\n",
       "           * license : MIT\n",
       "           * http://www.foretagsplatsen.se\n",
       "           */\n",
917
918
919
920
921
922
923
924
925
926
927
928
929
930
931
932
933
934
935
936
937
938
939
940
941
942
943
944
945
946
947
948
949
950
951
952
953
954
955
956
957
958
959
960
961
962
963
964
965
966
967
968
969
970
971
972
973
974
975
976
977
978
979
980
981
982
983
984
985
986
987
988
989
990
991
992
993
994
995
996
997
998
999
1000
1001
1002
1003
1004
1005
1006
1007
1008
1009
1010
1011
1012
1013
1014
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041
1042
1043
1044
1045
1046
1047
1048
1049
1050
1051
1052
1053
1054
       "      var r,i={},a=i,o=\"en-US\",l=null,u=\"0,0\";void 0!==n&&n.exports;function c(e){this._value=e}function s(e){var n,t=\"\";for(n=0;n<e;n++)t+=\"0\";return t}function f(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]||\"\")+s(i-r.length),n>0&&(a+=\".\"+s(n)),a}(e,n):(t(e*o)/o).toFixed(n),r&&(i=new RegExp(\"0{1,\"+r+\"}$\"),a=a.replace(i,\"\")),a}function d(e,n,t){return n.indexOf(\"$\")>-1?function(e,n,t){var r,a,l=n,u=l.indexOf(\"$\"),c=l.indexOf(\"(\"),s=l.indexOf(\"+\"),f=l.indexOf(\"-\"),d=\"\",p=\"\";-1===l.indexOf(\"$\")?\"infix\"===i[o].currency.position?(p=i[o].currency.symbol,i[o].currency.spaceSeparated&&(p=\" \"+p+\" \")):i[o].currency.spaceSeparated&&(d=\" \"):l.indexOf(\" $\")>-1?(d=\" \",l=l.replace(\" $\",\"\")):l.indexOf(\"$ \")>-1?(d=\" \",l=l.replace(\"$ \",\"\")):l=l.replace(\"$\",\"\");if(a=h(e,l,t,p),-1===n.indexOf(\"$\"))switch(i[o].currency.position){case\"postfix\":a.indexOf(\")\")>-1?((a=a.split(\"\")).splice(-1,0,d+i[o].currency.symbol),a=a.join(\"\")):a=a+d+i[o].currency.symbol;break;case\"infix\":break;case\"prefix\":a.indexOf(\"(\")>-1||a.indexOf(\"-\")>-1?(a=a.split(\"\"),r=Math.max(c,f)+1,a.splice(r,0,i[o].currency.symbol+d),a=a.join(\"\")):a=i[o].currency.symbol+d+a;break;default:throw Error('Currency position should be among [\"prefix\", \"infix\", \"postfix\"]')}else u<=1?a.indexOf(\"(\")>-1||a.indexOf(\"+\")>-1||a.indexOf(\"-\")>-1?(a=a.split(\"\"),r=1,(u<c||u<s||u<f)&&(r=0),a.splice(r,0,i[o].currency.symbol+d),a=a.join(\"\")):a=i[o].currency.symbol+d+a:a.indexOf(\")\")>-1?((a=a.split(\"\")).splice(-1,0,d+i[o].currency.symbol),a=a.join(\"\")):a=a+d+i[o].currency.symbol;return a}(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=h(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):h(e,n,t)}function h(e,n,t,r){var a,u,c,s,d,h,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!==l)return l;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=(d=Math.floor(Math.log(T)/Math.LN10)+1)%3)?3:p,g&&0!==T&&(h=Math.floor(Math.log(T)/Math.LN10)+1-g,m=3*~~((Math.min(g,d)-p)/3),T/=Math.pow(10,m),-1===n.indexOf(\".\")&&g>3))for(n+=\"[.]\",M=(M=0===h?0:3*~~(h/3)-h)<0?M+3:M,a=0;a<M;a++)n+=\"0\";Math.floor(Math.log(Math.abs(e))/Math.LN10)+1!==g&&(T>=Math.pow(10,12)&&!D||j?(k+=i[o].abbreviations.trillion,e/=Math.pow(10,12)):T<Math.pow(10,12)&&T>=Math.pow(10,9)&&!D||S?(k+=i[o].abbreviations.billion,e/=Math.pow(10,9)):T<Math.pow(10,9)&&T>=Math.pow(10,6)&&!D||N?(k+=i[o].abbreviations.million,e/=Math.pow(10,6)):(T<Math.pow(10,6)&&T>=Math.pow(10,3)&&!D||U)&&(k+=i[o].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(u=Math.pow(1024,s),c=Math.pow(1024,s+1),e>=u&&e<c){C+=K[s],u>0&&(e/=u);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(u=Math.pow(1e3,s),c=Math.pow(1e3,s+1),e>=u&&e<c){C+=G[s],u>0&&(e/=u);break}if(n.indexOf(\"o\")>-1&&(n.indexOf(\" o\")>-1?(L=\" \",n=n.replace(\" o\",\"\")):n=n.replace(\"o\",\"\"),i[o].ordinal&&(L+=i[o].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(\"*\")?f(e,e.toString().split(\".\")[1].length,t):O.indexOf(\"[\")>-1?f(e,(O=(O=O.replace(\"]\",\"\")).split(\"[\"))[0].length+O[1].length,t,O[1].length):f(e,O.length,t)).split(\".\")[0],I.split(\".\")[1].length)I=(r?k+r:i[o].delimiters.decimal)+I.split(\".\")[1];else I=\"\";F&&0===Number(I.slice(1))&&(I=\"\")}else x=f(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\"+i[o].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 p(e,n){i[e]=n}function m(e){o=e;var n=i[e].defaults;n&&n.format&&r.defaultFormat(n.format),n&&n.currencyFormat&&r.defaultCurrencyFormat(n.currencyFormat)}(r=function(e){return r.isNumbro(e)?e=e.value():0===e||void 0===e?e=0:Number(e)||(e=r.fn.unformat(e)),new c(Number(e))}).version=\"1.6.2\",r.isNumbro=function(e){return e instanceof c},r.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;a[t]||(Object.keys(a).forEach((function(e){i||e.split(\"-\")[0]!==r||(i=e)})),t=i||n||\"en-US\"),m(t)},r.setCulture=function(e,n){var t=e,r=e.split(\"-\")[1],a=null;i[t]||(r&&Object.keys(i).forEach((function(e){a||e.split(\"-\")[1]!==r||(a=e)})),t=a||n||\"en-US\"),m(t)},r.language=function(e,n){if(console.warn(\"`language` is deprecated since version 1.6.0. Use `culture` instead\"),!e)return o;if(e&&!n){if(!a[e])throw new Error(\"Unknown language : \"+e);m(e)}return!n&&a[e]||p(e,n),r},r.culture=function(e,n){if(!e)return o;if(e&&!n){if(!i[e])throw new Error(\"Unknown culture : \"+e);m(e)}return!n&&i[e]||p(e,n),r},r.languageData=function(e){if(console.warn(\"`languageData` is deprecated since version 1.6.0. Use `cultureData` instead\"),!e)return a[o];if(!a[e])throw new Error(\"Unknown language : \"+e);return a[e]},r.cultureData=function(e){if(!e)return i[o];if(!i[e])throw new Error(\"Unknown culture : \"+e);return i[e]},r.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\"}}),r.languages=function(){return console.warn(\"`languages` is deprecated since version 1.6.0. Use `cultures` instead\"),a},r.cultures=function(){return i},r.zeroFormat=function(e){l=\"string\"==typeof e?e:null},r.defaultFormat=function(e){u=\"string\"==typeof e?e:\"0.0\"},r.defaultCurrencyFormat=function(e){\"string\"==typeof e?e:\"0$\"},r.validate=function(e,n){var t,i,a,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=r.cultureData(n)}catch(e){c=r.cultureData(r.culture())}return a=c.currency.symbol,l=c.abbreviations,t=c.delimiters.decimal,i=\".\"===c.delimiters.thousands?\"\\\\.\":c.delimiters.thousands,(null===(s=e.match(/^[^\\d]+/))||(e=e.substr(1),s[0]===a))&&((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(i+\"{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,i){return null!=t&&t!==r.culture()&&r.setCulture(t),d(Number(e),null!=n?n:u,null==i?Math.round:i)}}},\n",
       "      function _(e,n,t){!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){Object.defineProperty(n,\"__esModule\",{value:!0});const t=e(9),a=e(109),s=e(162),r=e(163),c=e(166),_=e(167),m=e(165);class k extends s.CompositeTicker{constructor(e){super(e)}static init_DatetimeTicker(){this.override({num_minor_ticks:0,tickers:()=>[new a.AdaptiveTicker({mantissas:[1,2,5],base:10,min_interval:0,max_interval:500*m.ONE_MILLI,num_minor_ticks:0}),new a.AdaptiveTicker({mantissas:[1,2,5,10,15,20,30],base:60,min_interval:m.ONE_SECOND,max_interval:30*m.ONE_MINUTE,num_minor_ticks:0}),new a.AdaptiveTicker({mantissas:[1,2,4,6,8,12],base:24,min_interval:m.ONE_HOUR,max_interval:12*m.ONE_HOUR,num_minor_ticks:0}),new r.DaysTicker({days:t.range(1,32)}),new r.DaysTicker({days:t.range(1,31,3)}),new r.DaysTicker({days:[1,8,15,22]}),new r.DaysTicker({days:[1,15]}),new c.MonthsTicker({months:t.range(0,12,1)}),new c.MonthsTicker({months:t.range(0,12,2)}),new c.MonthsTicker({months:t.range(0,12,4)}),new c.MonthsTicker({months:t.range(0,12,6)}),new _.YearsTicker({})]})}}n.DatetimeTicker=k,k.__name__=\"DatetimeTicker\",k.init_DatetimeTicker()},\n",
       "      function _(t,e,i){Object.defineProperty(i,\"__esModule\",{value:!0});const r=t(1),s=t(110),n=r.__importStar(t(19)),_=t(9),a=t(23);class c extends s.ContinuousTicker{constructor(t){super(t)}static init_CompositeTicker(){this.define({tickers:[n.Array,[]]})}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 r=e-t,s=this.get_ideal_interval(t,e,i),n=[_.sorted_index(this.min_intervals,s)-1,_.sorted_index(this.max_intervals,s)],c=[this.min_intervals[n[0]],this.max_intervals[n[1]]].map(t=>Math.abs(i-r/t));let l;if(a.isEmpty(c.filter(t=>!isNaN(t))))l=this.tickers[0];else{const t=n[_.argmin(c)];l=this.tickers[t]}return l}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,r){return this.get_best_ticker(t,e,r).get_ticks_no_defaults(t,e,i,r)}}i.CompositeTicker=c,c.__name__=\"CompositeTicker\",c.init_CompositeTicker()},\n",
       "      function _(t,e,n){Object.defineProperty(n,\"__esModule\",{value:!0});const i=t(1),s=t(164),a=t(165),o=i.__importStar(t(19)),r=t(9);class _ extends s.SingleIntervalTicker{constructor(t){super(t)}static init_DaysTicker(){this.define({days:[o.Array,[]]}),this.override({num_minor_ticks:0})}initialize(){super.initialize();const t=this.days;t.length>1?this.interval=(t[1]-t[0])*a.ONE_DAY:this.interval=31*a.ONE_DAY}get_ticks_no_defaults(t,e,n,i){const s=function(t,e){const n=a.last_month_no_later_than(new Date(t)),i=a.last_month_no_later_than(new Date(e));i.setUTCMonth(i.getUTCMonth()+1);const s=[],o=n;for(;s.push(a.copy_date(o)),o.setUTCMonth(o.getUTCMonth()+1),!(o>i););return s}(t,e),o=this.days,_=this.interval;return{major:r.concat(s.map(t=>((t,e)=>{const n=t.getUTCMonth(),i=[];for(const s of o){const o=a.copy_date(t);o.setUTCDate(s),new Date(o.getTime()+e/2).getUTCMonth()==n&&i.push(o)}return i})(t,_))).map(t=>t.getTime()).filter(n=>t<=n&&n<=e),minor:[]}}}n.DaysTicker=_,_.__name__=\"DaysTicker\",_.init_DaysTicker()},\n",
       "      function _(e,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const n=e(1),r=e(110),l=n.__importStar(e(19));class a extends r.ContinuousTicker{constructor(e){super(e)}static init_SingleIntervalTicker(){this.define({interval:[l.Number]})}get_interval(e,t,i){return this.interval}get min_interval(){return this.interval}get max_interval(){return this.interval}}i.SingleIntervalTicker=a,a.__name__=\"SingleIntervalTicker\",a.init_SingleIntervalTicker()},\n",
       "      function _(t,e,n){function _(t){return new Date(t.getTime())}function O(t){const e=_(t);return e.setUTCDate(1),e.setUTCHours(0),e.setUTCMinutes(0),e.setUTCSeconds(0),e.setUTCMilliseconds(0),e}Object.defineProperty(n,\"__esModule\",{value:!0}),n.ONE_MILLI=1,n.ONE_SECOND=1e3,n.ONE_MINUTE=60*n.ONE_SECOND,n.ONE_HOUR=60*n.ONE_MINUTE,n.ONE_DAY=24*n.ONE_HOUR,n.ONE_MONTH=30*n.ONE_DAY,n.ONE_YEAR=365*n.ONE_DAY,n.copy_date=_,n.last_month_no_later_than=O,n.last_year_no_later_than=function(t){const e=O(t);return e.setUTCMonth(0),e}},\n",
       "      function _(t,e,n){Object.defineProperty(n,\"__esModule\",{value:!0});const r=t(1),i=t(164),s=t(165),a=r.__importStar(t(19)),o=t(9);class _ extends i.SingleIntervalTicker{constructor(t){super(t)}static init_MonthsTicker(){this.define({months:[a.Array,[]]})}initialize(){super.initialize();const t=this.months;t.length>1?this.interval=(t[1]-t[0])*s.ONE_MONTH:this.interval=12*s.ONE_MONTH}get_ticks_no_defaults(t,e,n,r){const i=function(t,e){const n=s.last_year_no_later_than(new Date(t)),r=s.last_year_no_later_than(new Date(e));r.setUTCFullYear(r.getUTCFullYear()+1);const i=[],a=n;for(;i.push(s.copy_date(a)),a.setUTCFullYear(a.getUTCFullYear()+1),!(a>r););return i}(t,e),a=this.months;return{major:o.concat(i.map(t=>a.map(e=>{const n=s.copy_date(t);return n.setUTCMonth(e),n}))).map(t=>t.getTime()).filter(n=>t<=n&&n<=e),minor:[]}}}n.MonthsTicker=_,_.__name__=\"MonthsTicker\",_.init_MonthsTicker()},\n",
       "      function _(e,t,a){Object.defineProperty(a,\"__esModule\",{value:!0});const i=e(108),r=e(164),n=e(165);class _ extends r.SingleIntervalTicker{constructor(e){super(e)}initialize(){super.initialize(),this.interval=n.ONE_YEAR,this.basic_ticker=new i.BasicTicker({num_minor_ticks:0})}get_ticks_no_defaults(e,t,a,i){const r=n.last_year_no_later_than(new Date(e)).getUTCFullYear(),_=n.last_year_no_later_than(new Date(t)).getUTCFullYear();return{major:this.basic_ticker.get_ticks_no_defaults(r,_,a,i).major.map(e=>Date.UTC(e,0,1)).filter(a=>e<=a&&a<=t),minor:[]}}}a.YearsTicker=_,_.__name__=\"YearsTicker\"},\n",
       "      function _(e,i,t){Object.defineProperty(t,\"__esModule\",{value:!0});const s=e(148),o=e(153),n=e(169),r=e(170);class _ extends s.AxisView{}t.LogAxisView=_,_.__name__=\"LogAxisView\";class c extends o.ContinuousAxis{constructor(e){super(e)}static init_LogAxis(){this.prototype.default_view=_,this.override({ticker:()=>new r.LogTicker,formatter:()=>new n.LogTickFormatter})}}t.LogAxis=c,c.__name__=\"LogAxis\",c.init_LogAxis()},\n",
       "      function _(t,e,r){Object.defineProperty(r,\"__esModule\",{value:!0});const i=t(1),o=t(113),a=t(112),n=i.__importStar(t(19));class c extends o.TickFormatter{constructor(t){super(t)}static init_LogTickFormatter(){this.define({ticker:[n.Instance,null]})}initialize(){super.initialize(),this.basic_formatter=new a.BasicTickFormatter}doFormat(t,e){if(0==t.length)return[];const r=null!=this.ticker?this.ticker.base:10;let i=!1;const o=new Array(t.length);for(let e=0,a=t.length;e<a;e++)if(o[e]=`${r}^${Math.round(Math.log(t[e])/Math.log(r))}`,e>0&&o[e]==o[e-1]){i=!0;break}return i?this.basic_formatter.doFormat(t,e):o}}r.LogTickFormatter=c,c.__name__=\"LogTickFormatter\",c.init_LogTickFormatter()},\n",
       "      function _(t,o,e){Object.defineProperty(e,\"__esModule\",{value:!0});const i=t(109),s=t(9);class n extends i.AdaptiveTicker{constructor(t){super(t)}static init_LogTicker(){this.override({mantissas:[1,5]})}get_ticks_no_defaults(t,o,e,i){const n=this.num_minor_ticks,r=[],a=this.base,c=Math.log(t)/Math.log(a),f=Math.log(o)/Math.log(a),l=f-c;let h;if(isFinite(l))if(l<2){const e=this.get_interval(t,o,i),a=Math.floor(t/e),c=Math.ceil(o/e);if(h=s.range(a,c+1).filter(t=>0!=t).map(t=>t*e).filter(e=>t<=e&&e<=o),n>0&&h.length>0){const t=e/n,o=s.range(0,n).map(o=>o*t);for(const t of o.slice(1))r.push(h[0]-t);for(const t of h)for(const e of o)r.push(t+e)}}else{const t=Math.ceil(.999999*c),o=Math.floor(1.000001*f),e=Math.ceil((o-t)/9);if(h=s.range(t-1,o+1,e).map(t=>Math.pow(a,t)),n>0&&h.length>0){const t=Math.pow(a,e)/n,o=s.range(1,n+1).map(o=>o*t);for(const t of o)r.push(h[0]/t);r.push(h[0]);for(const t of h)for(const e of o)r.push(t*e)}}else h=[];return{major:h.filter(e=>t<=e&&e<=o),minor:r.filter(e=>t<=e&&e<=o)}}}e.LogTicker=n,n.__name__=\"LogTicker\",n.init_LogTicker()},\n",
       "      function _(e,t,r){Object.defineProperty(r,\"__esModule\",{value:!0});const i=e(148),s=e(155),o=e(172),a=e(173);class c extends i.AxisView{}r.MercatorAxisView=c,c.__name__=\"MercatorAxisView\";class n extends s.LinearAxis{constructor(e){super(e)}static init_MercatorAxis(){this.prototype.default_view=c,this.override({ticker:()=>new a.MercatorTicker({dimension:\"lat\"}),formatter:()=>new o.MercatorTickFormatter({dimension:\"lat\"})})}}r.MercatorAxis=n,n.__name__=\"MercatorAxis\",n.init_MercatorAxis()},\n",
       "      function _(r,t,e){Object.defineProperty(e,\"__esModule\",{value:!0});const o=r(1),n=r(112),i=o.__importStar(r(19)),c=r(30);class s extends n.BasicTickFormatter{constructor(r){super(r)}static init_MercatorTickFormatter(){this.define({dimension:[i.LatLon]})}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]=c.wgs84_mercator.inverse([r[n],t.loc]);o[n]=e}else for(let n=0;n<e;n++){const[,e]=c.wgs84_mercator.inverse([t.loc,r[n]]);o[n]=e}return super.doFormat(o,t)}}e.MercatorTickFormatter=s,s.__name__=\"MercatorTickFormatter\",s.init_MercatorTickFormatter()},\n",
       "      function _(r,o,e){Object.defineProperty(e,\"__esModule\",{value:!0});const n=r(1),s=r(108),i=n.__importStar(r(19)),t=r(30);class c extends s.BasicTicker{constructor(r){super(r)}static init_MercatorTicker(){this.define({dimension:[i.LatLon]})}get_ticks_no_defaults(r,o,e,n){if(null==this.dimension)throw new Error(\"MercatorTicker.dimension not configured\");let s,i,c;[r,o]=t.clip_mercator(r,o,this.dimension),\"lon\"===this.dimension?([s,c]=t.wgs84_mercator.inverse([r,e]),[i,c]=t.wgs84_mercator.inverse([o,e])):([c,s]=t.wgs84_mercator.inverse([e,r]),[c,i]=t.wgs84_mercator.inverse([e,o]));const a=super.get_ticks_no_defaults(s,i,e,n),_=[],f=[];if(\"lon\"===this.dimension){for(const r of a.major)if(t.in_bounds(r,\"lon\")){const[o]=t.wgs84_mercator.forward([r,c]);_.push(o)}for(const r of a.minor)if(t.in_bounds(r,\"lon\")){const[o]=t.wgs84_mercator.forward([r,c]);f.push(o)}}else{for(const r of a.major)if(t.in_bounds(r,\"lat\")){const[,o]=t.wgs84_mercator.forward([c,r]);_.push(o)}for(const r of a.minor)if(t.in_bounds(r,\"lat\")){const[,o]=t.wgs84_mercator.forward([c,r]);f.push(o)}}return{major:_,minor:f}}}e.MercatorTicker=c,c.__name__=\"MercatorTicker\",c.init_MercatorTicker()},\n",
       "      function _(e,n,o){Object.defineProperty(o,\"__esModule\",{value:!0});var t=e(175);o.CustomJS=t.CustomJS;var u=e(177);o.OpenURL=u.OpenURL},\n",
       "      function _(t,e,s){Object.defineProperty(s,\"__esModule\",{value:!0});const n=t(1),u=t(176),c=n.__importStar(t(19)),r=t(23),a=t(25);class i extends u.Callback{constructor(t){super(t)}static init_CustomJS(){this.define({args:[c.Any,{}],code:[c.String,\"\"]})}get names(){return r.keys(this.args)}get values(){return r.values(this.args)}get func(){const t=a.use_strict(this.code);return new Function(...this.names,\"cb_obj\",\"cb_data\",t)}execute(t,e={}){return this.func.apply(t,this.values.concat(t,e))}}s.CustomJS=i,i.__name__=\"CustomJS\",i.init_CustomJS()},\n",
       "      function _(e,c,l){Object.defineProperty(l,\"__esModule\",{value:!0});const a=e(69);class n extends a.Model{constructor(e){super(e)}}l.Callback=n,n.__name__=\"Callback\"},\n",
       "      function _(e,t,n){Object.defineProperty(n,\"__esModule\",{value:!0});const o=e(1),s=e(176),i=e(158),c=o.__importStar(e(19));class r extends s.Callback{constructor(e){super(e)}static init_OpenURL(){this.define({url:[c.String,\"http://\"],same_tab:[c.Boolean,!1]})}execute(e,{source:t}){const n=e=>{const n=i.replace_placeholders(this.url,t,e);this.same_tab?window.location.href=n:window.open(n)},{selected:o}=t;for(const e of o.indices)n(e);for(const e of o.line_indices)n(e)}}n.OpenURL=r,r.__name__=\"OpenURL\",r.init_OpenURL()},\n",
       "      function _(a,e,r){Object.defineProperty(r,\"__esModule\",{value:!0});var n=a(179);r.Canvas=n.Canvas;var s=a(183);r.CartesianFrame=s.CartesianFrame},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});const a=e(1),i=e(13),n=e(64),l=e(70),o=a.__importStar(e(19)),c=e(66),d=e(85),h=e(180),_=e(181),r=(()=>{const e=document.createElement(\"canvas\"),t=e.getContext(\"webgl\",{premultipliedAlpha:!0});return null!=t?{canvas:e,gl:t}:void l.logger.trace(\"WebGL is not supported\")})(),v=a.__importDefault(e(182));class p extends n.DOMView{get ctx(){return this._ctx}initialize(){super.initialize();const e={position:\"absolute\",top:\"0\",left:\"0\",width:\"100%\",height:\"100%\"};switch(this.model.output_backend){case\"webgl\":this.webgl=r;case\"canvas\":{this.canvas_el=c.canvas({class:_.bk_canvas,style:e});const t=this.canvas_el.getContext(\"2d\");if(null==t)throw new Error(\"unable to obtain 2D rendering context\");this._ctx=t;break}case\"svg\":{const e=new v.default;this._ctx=e,this.canvas_el=e.getSvg();break}}this.underlays_el=c.div({class:_.bk_canvas_underlays,style:e}),this.overlays_el=c.div({class:_.bk_canvas_overlays,style:e}),this.events_el=c.div({class:_.bk_canvas_events,style:e}),c.append(this.el,this.underlays_el,this.canvas_el,this.overlays_el,this.events_el),h.fixup_ctx(this._ctx),l.logger.debug(\"CanvasView initialized\")}add_underlay(e){this.underlays_el.appendChild(e)}add_overlay(e){this.overlays_el.appendChild(e)}add_event(e){this.events_el.appendChild(e)}prepare_canvas(e,t){this.bbox=new d.BBox({left:0,top:0,width:e,height:t}),this.el.style.width=`${e}px`,this.el.style.height=`${t}px`;const{use_hidpi:s,output_backend:a}=this.model,i=s&&\"svg\"!=a?devicePixelRatio:1;this.model.pixel_ratio=i,this.canvas_el.style.width=`${e}px`,this.canvas_el.style.height=`${t}px`,this.canvas_el.setAttribute(\"width\",`${e*i}`),this.canvas_el.setAttribute(\"height\",`${t*i}`),l.logger.debug(`Rendering CanvasView with width: ${e}, height: ${t}, pixel ratio: ${i}`)}save(e){if(this.canvas_el instanceof HTMLCanvasElement){const t=this.canvas_el;if(null!=t.msToBlob){const s=t.msToBlob();window.navigator.msSaveBlob(s,e)}else{const s=document.createElement(\"a\");s.href=t.toDataURL(\"image/png\"),s.download=e+\".png\",s.target=\"_blank\",s.dispatchEvent(new MouseEvent(\"click\"))}}else{const t=this._ctx.getSerializedSvg(!0),s=new Blob([t],{type:\"text/plain\"}),a=document.createElement(\"a\");a.download=e+\".svg\",a.innerHTML=\"Download svg\",a.href=window.URL.createObjectURL(s),a.onclick=e=>document.body.removeChild(e.target),a.style.display=\"none\",document.body.appendChild(a),a.click()}}}s.CanvasView=p,p.__name__=\"CanvasView\";class u extends i.HasProps{constructor(e){super(e)}static init_Canvas(){this.prototype.default_view=p,this.internal({use_hidpi:[o.Boolean,!0],pixel_ratio:[o.Number,1],output_backend:[o.OutputBackend,\"canvas\"]})}}s.Canvas=u,u.__name__=\"Canvas\",u.init_Canvas()},\n",
       "      function _(e,t,n){Object.defineProperty(n,\"__esModule\",{value:!0}),n.fixup_ctx=function(e){!function(e){e.setLineDash||(e.setLineDash=t=>{e.mozDash=t,e.webkitLineDash=t}),e.getLineDash||(e.getLineDash=()=>e.mozDash)}(e),function(e){e.setLineDashOffset=t=>{e.lineDashOffset=t,e.mozDashOffset=t,e.webkitLineDashOffset=t},e.getLineDashOffset=()=>e.mozDashOffset}(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.measureText&&null==e.html5MeasureText&&(e.html5MeasureText=e.measureText,e.measureText=t=>{const n=e.html5MeasureText(t);return n.ascent=1.6*e.html5MeasureText(\"m\").width,n})}(e),function(e){e.ellipse||(e.ellipse=function(t,n,a,o,s,i,m,h=!1){const l=.551784;e.translate(t,n),e.rotate(s);let u=a,r=o;h&&(u=-a,r=-o),e.moveTo(-u,0),e.bezierCurveTo(-u,r*l,-u*l,r,0,r),e.bezierCurveTo(u*l,r,u,r*l,u,0),e.bezierCurveTo(u,-r*l,u*l,-r,0,-r),e.bezierCurveTo(-u*l,-r,-u,-r*l,-u,0),e.rotate(-s),e.translate(-t,-n)})}(e)}},\n",
       "      function _(a,e,n){Object.defineProperty(n,\"__esModule\",{value:!0}),a(67),n.bk_canvas=\"bk-canvas\",n.bk_canvas_underlays=\"bk-canvas-underlays\",n.bk_canvas_overlays=\"bk-canvas-overlays\",n.bk_canvas_events=\"bk-canvas-events\"},\n",
       "      function _(t,e,r){var i,n,s,a,o;function h(t,e){var r,i=Object.keys(e);for(r=0;r<i.length;r++)t=t.replace(new RegExp(\"\\\\{\"+i[r]+\"\\\\}\",\"gi\"),e[i[r]]);return t}function l(t){var e,r,i;if(!t)throw new Error(\"cannot create a random attribute name for an undefined object\");e=\"ABCDEFGHIJKLMNOPQRSTUVWXTZabcdefghiklmnopqrstuvwxyz\",r=\"\";do{for(r=\"\",i=0;i<12;i++)r+=e[Math.floor(Math.random()*e.length)]}while(t[r]);return r}function c(t){var e={alphabetic:\"alphabetic\",hanging:\"hanging\",top:\"text-before-edge\",bottom:\"text-after-edge\",middle:\"central\"};return e[t]||e.alphabetic}\n",
       "      /*!!\n",
       "           *  Canvas 2 Svg v1.0.21\n",
       "           *  A low level canvas to SVG converter. Uses a mock canvas context to build an SVG document.\n",
       "           *\n",
       "           *  Licensed under the MIT license:\n",
       "           *  http://www.opensource.org/licenses/mit-license.php\n",
       "           *\n",
       "           *  Author:\n",
       "           *  Kerry Liu\n",
       "           *\n",
       "           *  Copyright (c) 2014 Gliffy Inc.\n",
       "           */\n",
       "      Object.defineProperty(r,\"__esModule\",{value:!0}),o=function(t,e){var r,i,n,s={};for(t=t.split(\",\"),e=e||10,r=0;r<t.length;r+=2)i=\"&\"+t[r+1]+\";\",n=parseInt(t[r],e),s[i]=\"&#\"+n+\";\";return s[\"\\\\xa0\"]=\"&#160;\",s}(\"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),i={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\"}},(s=function(t,e){this.__root=t,this.__ctx=e}).prototype.addColorStop=function(t,e){var r,i=this.__ctx.__createElement(\"stop\");i.setAttribute(\"offset\",t),-1!==e.indexOf(\"rgba\")?(r=/rgba\\(\\s*(\\d+)\\s*,\\s*(\\d+)\\s*,\\s*(\\d+)\\s*,\\s*(\\d?\\.?\\d*)\\s*\\)/gi.exec(e),i.setAttribute(\"stop-color\",h(\"rgb({r},{g},{b})\",{r:r[1],g:r[2],b:r[3]})),i.setAttribute(\"stop-opacity\",r[4])):i.setAttribute(\"stop-color\",e),this.__root.appendChild(i)},a=function(t,e){this.__root=t,this.__ctx=e},(n=function(t){var e,r={width:500,height:500,enableMirroring:!1};if(arguments.length>1?((e=r).width=arguments[0],e.height=arguments[1]):e=t||r,!(this instanceof n))return new n(e);this.width=e.width||r.width,this.height=e.height||r.height,this.enableMirroring=void 0!==e.enableMirroring?e.enableMirroring:r.enableMirroring,this.canvas=this,this.__document=e.document||document,e.ctx?this.__ctx=e.ctx:(this.__canvas=this.__document.createElement(\"canvas\"),this.__ctx=this.__canvas.getContext(\"2d\")),this.__setDefaultStyles(),this.__stack=[this.__getStyleState()],this.__groupStack=[],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.__root.setAttribute(\"width\",this.width),this.__root.setAttribute(\"height\",this.height),this.__ids={},this.__defs=this.__document.createElementNS(\"http://www.w3.org/2000/svg\",\"defs\"),this.__root.appendChild(this.__defs),this.__currentElement=this.__document.createElementNS(\"http://www.w3.org/2000/svg\",\"g\"),this.__root.appendChild(this.__currentElement)}).prototype.__createElement=function(t,e,r){void 0===e&&(e={});var i,n,s=this.__document.createElementNS(\"http://www.w3.org/2000/svg\",t),a=Object.keys(e);for(r&&(s.setAttribute(\"fill\",\"none\"),s.setAttribute(\"stroke\",\"none\")),i=0;i<a.length;i++)n=a[i],s.setAttribute(n,e[n]);return s},n.prototype.__setDefaultStyles=function(){var t,e,r=Object.keys(i);for(t=0;t<r.length;t++)this[e=r[t]]=i[e].canvas},n.prototype.__applyStyleState=function(t){var e,r,i=Object.keys(t);for(e=0;e<i.length;e++)this[r=i[e]]=t[r]},n.prototype.__getStyleState=function(){var t,e,r={},n=Object.keys(i);for(t=0;t<n.length;t++)r[e=n[t]]=this[e];return r},n.prototype.__applyStyleToCurrentElement=function(t){var e=this.__currentElement,r=this.__currentElementsToStyle;r&&(e.setAttribute(t,\"\"),e=r.element,r.children.forEach((function(e){e.setAttribute(t,\"\")})));var n,o,l,c,p,_=Object.keys(i);for(n=0;n<_.length;n++)if(o=i[_[n]],l=this[_[n]],o.apply)if(l instanceof a){if(l.__ctx)for(;l.__ctx.__defs.childNodes.length;)c=l.__ctx.__defs.childNodes[0].getAttribute(\"id\"),this.__ids[c]=c,this.__defs.appendChild(l.__ctx.__defs.childNodes[0]);e.setAttribute(o.apply,h(\"url(#{id})\",{id:l.__root.getAttribute(\"id\")}))}else if(l instanceof s)e.setAttribute(o.apply,h(\"url(#{id})\",{id:l.__root.getAttribute(\"id\")}));else if(-1!==o.apply.indexOf(t)&&o.svg!==l)if(\"stroke\"!==o.svgAttr&&\"fill\"!==o.svgAttr||-1===l.indexOf(\"rgba\")){var u=o.svgAttr;if(\"globalAlpha\"===_[n]&&(u=t+\"-\"+o.svgAttr,e.getAttribute(u)))continue;e.setAttribute(u,l)}else{p=/rgba\\(\\s*(\\d+)\\s*,\\s*(\\d+)\\s*,\\s*(\\d+)\\s*,\\s*(\\d?\\.?\\d*)\\s*\\)/gi.exec(l),e.setAttribute(o.svgAttr,h(\"rgb({r},{g},{b})\",{r:p[1],g:p[2],b:p[3]}));var d=p[4],g=this.globalAlpha;null!=g&&(d*=g),e.setAttribute(o.svgAttr+\"-opacity\",d)}},n.prototype.__closestGroupOrSvg=function(t){return\"g\"===(t=t||this.__currentElement).nodeName||\"svg\"===t.nodeName?t:this.__closestGroupOrSvg(t.parentNode)},n.prototype.getSerializedSvg=function(t){var e,r,i,n,s,a=(new XMLSerializer).serializeToString(this.__root);if(/xmlns=\"http:\\/\\/www\\.w3\\.org\\/2000\\/svg\".+xmlns=\"http:\\/\\/www\\.w3\\.org\\/2000\\/svg/gi.test(a)&&(a=a.replace('xmlns=\"http://www.w3.org/2000/svg','xmlns:xlink=\"http://www.w3.org/1999/xlink')),t)for(e=Object.keys(o),r=0;r<e.length;r++)i=e[r],n=o[i],(s=new RegExp(i,\"gi\")).test(a)&&(a=a.replace(s,n));return a},n.prototype.getSvg=function(){return this.__root},n.prototype.save=function(){var t=this.__createElement(\"g\"),e=this.__closestGroupOrSvg();this.__groupStack.push(e),e.appendChild(t),this.__currentElement=t,this.__stack.push(this.__getStyleState())},n.prototype.restore=function(){this.__currentElement=this.__groupStack.pop(),this.__currentElementsToStyle=null,this.__currentElement||(this.__currentElement=this.__root.childNodes[1]);var t=this.__stack.pop();this.__applyStyleState(t)},n.prototype.__addTransform=function(t){var e=this.__closestGroupOrSvg();if(e.childNodes.length>0){\"path\"===this.__currentElement.nodeName&&(this.__currentElementsToStyle||(this.__currentElementsToStyle={element:e,children:[]}),this.__currentElementsToStyle.children.push(this.__currentElement),this.__applyCurrentDefaultPath());var r=this.__createElement(\"g\");e.appendChild(r),this.__currentElement=r}var i=this.__currentElement.getAttribute(\"transform\");i?i+=\" \":i=\"\",i+=t,this.__currentElement.setAttribute(\"transform\",i)},n.prototype.scale=function(t,e){void 0===e&&(e=t),this.__addTransform(h(\"scale({x},{y})\",{x:t,y:e}))},n.prototype.rotate=function(t){var e=180*t/Math.PI;this.__addTransform(h(\"rotate({angle},{cx},{cy})\",{angle:e,cx:0,cy:0}))},n.prototype.translate=function(t,e){this.__addTransform(h(\"translate({x},{y})\",{x:t,y:e}))},n.prototype.transform=function(t,e,r,i,n,s){this.__addTransform(h(\"matrix({a},{b},{c},{d},{e},{f})\",{a:t,b:e,c:r,d:i,e:n,f:s}))},n.prototype.beginPath=function(){var t;this.__currentDefaultPath=\"\",this.__currentPosition={},t=this.__createElement(\"path\",{},!0),this.__closestGroupOrSvg().appendChild(t),this.__currentElement=t},n.prototype.__applyCurrentDefaultPath=function(){var t=this.__currentElement;\"path\"===t.nodeName?t.setAttribute(\"d\",this.__currentDefaultPath):console.error(\"Attempted to apply path command to node\",t.nodeName)},n.prototype.__addPathCommand=function(t){this.__currentDefaultPath+=\" \",this.__currentDefaultPath+=t},n.prototype.moveTo=function(t,e){\"path\"!==this.__currentElement.nodeName&&this.beginPath(),this.__currentPosition={x:t,y:e},this.__addPathCommand(h(\"M {x} {y}\",{x:t,y:e}))},n.prototype.closePath=function(){this.__currentDefaultPath&&this.__addPathCommand(\"Z\")},n.prototype.lineTo=function(t,e){this.__currentPosition={x:t,y:e},this.__currentDefaultPath.indexOf(\"M\")>-1?this.__addPathCommand(h(\"L {x} {y}\",{x:t,y:e})):this.__addPathCommand(h(\"M {x} {y}\",{x:t,y:e}))},n.prototype.bezierCurveTo=function(t,e,r,i,n,s){this.__currentPosition={x:n,y:s},this.__addPathCommand(h(\"C {cp1x} {cp1y} {cp2x} {cp2y} {x} {y}\",{cp1x:t,cp1y:e,cp2x:r,cp2y:i,x:n,y:s}))},n.prototype.quadraticCurveTo=function(t,e,r,i){this.__currentPosition={x:r,y:i},this.__addPathCommand(h(\"Q {cpx} {cpy} {x} {y}\",{cpx:t,cpy:e,x:r,y:i}))};var p=function(t){var e=Math.sqrt(t[0]*t[0]+t[1]*t[1]);return[t[0]/e,t[1]/e]};n.prototype.arcTo=function(t,e,r,i,n){var s=this.__currentPosition&&this.__currentPosition.x,a=this.__currentPosition&&this.__currentPosition.y;if(void 0!==s&&void 0!==a){if(n<0)throw new Error(\"IndexSizeError: The radius provided (\"+n+\") is negative.\");if(s===t&&a===e||t===r&&e===i||0===n)this.lineTo(t,e);else{var o=p([s-t,a-e]),h=p([r-t,i-e]);if(o[0]*h[1]!=o[1]*h[0]){var l=o[0]*h[0]+o[1]*h[1],c=Math.acos(Math.abs(l)),_=p([o[0]+h[0],o[1]+h[1]]),u=n/Math.sin(c/2),d=t+u*_[0],g=e+u*_[1],m=[-o[1],o[0]],f=[h[1],-h[0]],y=function(t){var e=t[0];return t[1]>=0?Math.acos(e):-Math.acos(e)},v=y(m),b=y(f);this.lineTo(d+m[0]*n,g+m[1]*n),this.arc(d,g,n,v,b)}else this.lineTo(t,e)}}},n.prototype.stroke=function(){\"path\"===this.__currentElement.nodeName&&this.__currentElement.setAttribute(\"paint-order\",\"fill stroke markers\"),this.__applyCurrentDefaultPath(),this.__applyStyleToCurrentElement(\"stroke\")},n.prototype.fill=function(){\"path\"===this.__currentElement.nodeName&&this.__currentElement.setAttribute(\"paint-order\",\"stroke fill markers\"),this.__applyCurrentDefaultPath(),this.__applyStyleToCurrentElement(\"fill\")},n.prototype.rect=function(t,e,r,i){\"path\"!==this.__currentElement.nodeName&&this.beginPath(),this.moveTo(t,e),this.lineTo(t+r,e),this.lineTo(t+r,e+i),this.lineTo(t,e+i),this.lineTo(t,e),this.closePath()},n.prototype.fillRect=function(t,e,r,i){var n;n=this.__createElement(\"rect\",{x:t,y:e,width:r,height:i},!0),this.__closestGroupOrSvg().appendChild(n),this.__currentElement=n,this.__applyStyleToCurrentElement(\"fill\")},n.prototype.strokeRect=function(t,e,r,i){var n;n=this.__createElement(\"rect\",{x:t,y:e,width:r,height:i},!0),this.__closestGroupOrSvg().appendChild(n),this.__currentElement=n,this.__applyStyleToCurrentElement(\"stroke\")},n.prototype.__clearCanvas=function(){for(var t=this.__closestGroupOrSvg().getAttribute(\"transform\"),e=this.__root.childNodes[1],r=e.childNodes,i=r.length-1;i>=0;i--)r[i]&&e.removeChild(r[i]);this.__currentElement=e,this.__groupStack=[],t&&this.__addTransform(t)},n.prototype.clearRect=function(t,e,r,i){if(0!==t||0!==e||r!==this.width||i!==this.height){var n,s=this.__closestGroupOrSvg();n=this.__createElement(\"rect\",{x:t,y:e,width:r,height:i,fill:\"#FFFFFF\"},!0),s.appendChild(n)}else this.__clearCanvas()},n.prototype.createLinearGradient=function(t,e,r,i){var n=this.__createElement(\"linearGradient\",{id:l(this.__ids),x1:t+\"px\",x2:r+\"px\",y1:e+\"px\",y2:i+\"px\",gradientUnits:\"userSpaceOnUse\"},!1);return this.__defs.appendChild(n),new s(n,this)},n.prototype.createRadialGradient=function(t,e,r,i,n,a){var o=this.__createElement(\"radialGradient\",{id:l(this.__ids),cx:i+\"px\",cy:n+\"px\",r:a+\"px\",fx:t+\"px\",fy:e+\"px\",gradientUnits:\"userSpaceOnUse\"},!1);return this.__defs.appendChild(o),new s(o,this)},n.prototype.__parseFont=function(){var t=/^\\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),e={style:t[1]||\"normal\",size:t[4]||\"10px\",family:t[6]||\"sans-serif\",weight:t[3]||\"normal\",decoration:t[2]||\"normal\",href:null};return\"underline\"===this.__fontUnderline&&(e.decoration=\"underline\"),this.__fontHref&&(e.href=this.__fontHref),e},n.prototype.__wrapTextLink=function(t,e){if(t.href){var r=this.__createElement(\"a\");return r.setAttributeNS(\"http://www.w3.org/1999/xlink\",\"xlink:href\",t.href),r.appendChild(e),r}return e},n.prototype.__applyText=function(t,e,r,i){var n,s,a=this.__parseFont(),o=this.__closestGroupOrSvg(),h=this.__createElement(\"text\",{\"font-family\":a.family,\"font-size\":a.size,\"font-style\":a.style,\"font-weight\":a.weight,\"text-decoration\":a.decoration,x:e,y:r,\"text-anchor\":(n=this.textAlign,s={left:\"start\",right:\"end\",center:\"middle\",start:\"start\",end:\"end\"},s[n]||s.start),\"dominant-baseline\":c(this.textBaseline)},!0);h.appendChild(this.__document.createTextNode(t)),this.__currentElement=h,this.__applyStyleToCurrentElement(i),o.appendChild(this.__wrapTextLink(a,h))},n.prototype.fillText=function(t,e,r){this.__applyText(t,e,r,\"fill\")},n.prototype.strokeText=function(t,e,r){this.__applyText(t,e,r,\"stroke\")},n.prototype.measureText=function(t){return this.__ctx.font=this.font,this.__ctx.measureText(t)},n.prototype.arc=function(t,e,r,i,n,s){if(i!==n){(i%=2*Math.PI)===(n%=2*Math.PI)&&(n=(n+2*Math.PI-.001*(s?-1:1))%(2*Math.PI));var a=t+r*Math.cos(n),o=e+r*Math.sin(n),l=t+r*Math.cos(i),c=e+r*Math.sin(i),p=s?0:1,_=0,u=n-i;u<0&&(u+=2*Math.PI),_=s?u>Math.PI?0:1:u>Math.PI?1:0,this.lineTo(l,c),this.__addPathCommand(h(\"A {rx} {ry} {xAxisRotation} {largeArcFlag} {sweepFlag} {endX} {endY}\",{rx:r,ry:r,xAxisRotation:0,largeArcFlag:_,sweepFlag:p,endX:a,endY:o})),this.__currentPosition={x:a,y:o}}},n.prototype.clip=function(){var t=this.__closestGroupOrSvg(),e=this.__createElement(\"clipPath\"),r=l(this.__ids),i=this.__createElement(\"g\");this.__applyCurrentDefaultPath(),t.removeChild(this.__currentElement),e.setAttribute(\"id\",r),e.appendChild(this.__currentElement),this.__defs.appendChild(e),t.setAttribute(\"clip-path\",h(\"url(#{id})\",{id:r})),t.appendChild(i),this.__currentElement=i},n.prototype.drawImage=function(){var t,e,r,i,s,a,o,h,l,c,p,_,u,d,g=Array.prototype.slice.call(arguments),m=g[0],f=0,y=0;if(3===g.length)t=g[1],e=g[2],r=s=m.width,i=a=m.height;else if(5===g.length)t=g[1],e=g[2],r=g[3],i=g[4],s=m.width,a=m.height;else{if(9!==g.length)throw new Error(\"Inavlid number of arguments passed to drawImage: \"+arguments.length);f=g[1],y=g[2],s=g[3],a=g[4],t=g[5],e=g[6],r=g[7],i=g[8]}o=this.__closestGroupOrSvg(),this.__currentElement;var v=\"translate(\"+t+\", \"+e+\")\";if(m instanceof n){if((h=m.getSvg().cloneNode(!0)).childNodes&&h.childNodes.length>1){for(l=h.childNodes[0];l.childNodes.length;)d=l.childNodes[0].getAttribute(\"id\"),this.__ids[d]=d,this.__defs.appendChild(l.childNodes[0]);if(c=h.childNodes[1]){var b,x=c.getAttribute(\"transform\");b=x?x+\" \"+v:v,c.setAttribute(\"transform\",b),o.appendChild(c)}}}else\"IMG\"===m.nodeName?((p=this.__createElement(\"image\")).setAttribute(\"width\",r),p.setAttribute(\"height\",i),p.setAttribute(\"preserveAspectRatio\",\"none\"),(f||y||s!==m.width||a!==m.height)&&((_=this.__document.createElement(\"canvas\")).width=r,_.height=i,(u=_.getContext(\"2d\")).drawImage(m,f,y,s,a,0,0,r,i),m=_),p.setAttribute(\"transform\",v),p.setAttributeNS(\"http://www.w3.org/1999/xlink\",\"xlink:href\",\"CANVAS\"===m.nodeName?m.toDataURL():m.getAttribute(\"src\")),o.appendChild(p)):\"CANVAS\"===m.nodeName&&((p=this.__createElement(\"image\")).setAttribute(\"width\",r),p.setAttribute(\"height\",i),p.setAttribute(\"preserveAspectRatio\",\"none\"),(_=this.__document.createElement(\"canvas\")).width=r,_.height=i,(u=_.getContext(\"2d\")).imageSmoothingEnabled=!1,u.mozImageSmoothingEnabled=!1,u.oImageSmoothingEnabled=!1,u.webkitImageSmoothingEnabled=!1,u.drawImage(m,f,y,s,a,0,0,r,i),m=_,p.setAttribute(\"transform\",v),p.setAttributeNS(\"http://www.w3.org/1999/xlink\",\"xlink:href\",m.toDataURL()),o.appendChild(p))},n.prototype.createPattern=function(t,e){var r,i=this.__document.createElementNS(\"http://www.w3.org/2000/svg\",\"pattern\"),s=l(this.__ids);return i.setAttribute(\"id\",s),i.setAttribute(\"width\",t.width),i.setAttribute(\"height\",t.height),\"CANVAS\"===t.nodeName||\"IMG\"===t.nodeName?((r=this.__document.createElementNS(\"http://www.w3.org/2000/svg\",\"image\")).setAttribute(\"width\",t.width),r.setAttribute(\"height\",t.height),r.setAttributeNS(\"http://www.w3.org/1999/xlink\",\"xlink:href\",\"CANVAS\"===t.nodeName?t.toDataURL():t.getAttribute(\"src\")),i.appendChild(r),this.__defs.appendChild(i)):t instanceof n&&(i.appendChild(t.__root.childNodes[1]),this.__defs.appendChild(i)),new a(i,this)},n.prototype.setLineDash=function(t){t&&t.length>0?this.lineDash=t.join(\",\"):this.lineDash=null},n.prototype.drawFocusRing=function(){},n.prototype.createImageData=function(){},n.prototype.getImageData=function(){},n.prototype.putImageData=function(){},n.prototype.globalCompositeOperation=function(){},n.prototype.setTransform=function(){},r.default=n},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});const a=e(184),_=e(120),n=e(129),r=e(130),i=e(185),g=e(88),c=e(187);class h extends c.LayoutItem{constructor(e,t,s,a,_={},n={}){super(),this.x_scale=e,this.y_scale=t,this.x_range=s,this.y_range=a,this.extra_x_ranges=_,this.extra_y_ranges=n,this._configure_scales()}map_to_screen(e,t,s=\"default\",a=\"default\"){return[this.xscales[s].v_compute(e),this.yscales[a].v_compute(t)]}_get_ranges(e,t){return Object.assign(Object.assign({},t),{default:e})}_get_scales(e,t,s){const c={};for(const h in t){const o=t[h];if((o instanceof i.DataRange1d||o instanceof r.Range1d)&&!(e instanceof _.ContinuousScale))throw new Error(`Range ${o.type} is incompatible is Scale ${e.type}`);if(o instanceof g.FactorRange&&!(e instanceof a.CategoricalScale))throw new Error(`Range ${o.type} is incompatible is Scale ${e.type}`);e instanceof n.LogScale&&o instanceof i.DataRange1d&&(o.scale_hint=\"log\");const l=e.clone();l.setv({source_range:o,target_range:s}),c[h]=l}return c}_configure_frame_ranges(){this._h_target=new r.Range1d({start:this._left.value,end:this._right.value}),this._v_target=new r.Range1d({start:this._bottom.value,end:this._top.value})}_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._xscales=this._get_scales(this.x_scale,this._x_ranges,this._h_target),this._yscales=this._get_scales(this.y_scale,this._y_ranges,this._v_target)}_update_scales(){this._configure_frame_ranges();for(const e in this._xscales){this._xscales[e].target_range=this._h_target}for(const e in this._yscales){this._yscales[e].target_range=this._v_target}}_set_geometry(e,t){super._set_geometry(e,t),this._update_scales()}get x_ranges(){return this._x_ranges}get y_ranges(){return this._y_ranges}get xscales(){return this._xscales}get yscales(){return this._yscales}}s.CartesianFrame=h,h.__name__=\"CartesianFrame\"},\n",
       "      function _(e,r,t){Object.defineProperty(t,\"__esModule\",{value:!0});const n=e(121);class _ extends n.Scale{constructor(e){super(e)}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)}}t.CategoricalScale=_,_.__name__=\"CategoricalScale\"},\n",
       "      function _(t,i,n){Object.defineProperty(n,\"__esModule\",{value:!0});const e=t(1),a=t(186),s=t(78),l=t(70),_=e.__importStar(t(19)),o=e.__importStar(t(85)),r=t(9);class d extends a.DataRange{constructor(t){super(t),this._plot_bounds={},this.have_updated_interactively=!1}static init_DataRange1d(){this.define({start:[_.Number],end:[_.Number],range_padding:[_.Number,.1],range_padding_units:[_.PaddingUnits,\"percent\"],flipped:[_.Boolean,!1],follow:[_.StartEnd],follow_interval:[_.Number],default_span:[_.Number,2],only_visible:[_.Boolean,!1]}),this.internal({scale_hint:[_.String,\"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}get min(){return Math.min(this.start,this.end)}get max(){return Math.max(this.start,this.end)}computed_renderers(){const t=this.names;let i=this.renderers;if(0==i.length)for(const t of this.plots){const n=t.renderers.filter(t=>t instanceof s.GlyphRenderer);i=i.concat(n)}t.length>0&&(i=i.filter(i=>r.includes(t,i.name))),l.logger.debug(`computed ${i.length} renderers for DataRange1d ${this.id}`);for(const t of i)l.logger.trace(` - ${t.type} ${t.id}`);return i}_compute_plot_bounds(t,i){let n=o.empty();for(const e of t)null==i[e.id]||!e.visible&&this.only_visible||(n=o.union(n,i[e.id]));return n}adjust_bounds_for_aspect(t,i){const n=o.empty();let e=t.x1-t.x0;e<=0&&(e=1);let a=t.y1-t.y0;a<=0&&(a=1);const s=.5*(t.x1+t.x0),l=.5*(t.y1+t.y0);return e<i*a?e=i*a:a=e/i,n.x1=s+.5*e,n.x0=s-.5*e,n.y1=l+.5*a,n.y0=l-.5*a,n}_compute_min_max(t,i){let n,e,a=o.empty();for(const i in t){const n=t[i];a=o.union(a,n)}return[n,e]=0==i?[a.x0,a.x1]:[a.y0,a.y1],[n,e]}_compute_range(t,i){const n=this.range_padding;let e,a;if(null!=this._initial_start&&(t=this._initial_start),null!=this._initial_end&&(i=this._initial_end),\"log\"==this.scale_hint){let s,_;if((isNaN(t)||!isFinite(t)||t<=0)&&(t=isNaN(i)||!isFinite(i)||i<=0?.1:i/100,l.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,l.logger.warn(`could not determine maximum data value for log axis, DataRange1d using value ${i}`)),i==t)_=this.default_span+.001,s=Math.log(t)/Math.log(10);else{let e,a;\"percent\"==this.range_padding_units?(e=Math.log(t)/Math.log(10),a=Math.log(i)/Math.log(10),_=(a-e)*(1+n)):(e=Math.log(t-n)/Math.log(10),a=Math.log(i+n)/Math.log(10),_=a-e),s=(e+a)/2}e=Math.pow(10,s-_/2),a=Math.pow(10,s+_/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;e=l-s/2,a=l+s/2}let s=1;this.flipped&&([e,a]=[a,e],s=-1);const _=this.follow_interval;return null!=_&&Math.abs(e-a)>_&&(\"start\"==this.follow?a=e+s*_:\"end\"==this.follow&&(e=a-s*_)),[e,a]}update(t,i,n,e){if(this.have_updated_interactively)return;const a=this.computed_renderers();let s=this._compute_plot_bounds(a,t);null!=e&&(s=this.adjust_bounds_for_aspect(s,e)),this._plot_bounds[n]=s;const[l,_]=this._compute_min_max(this._plot_bounds,i);let[o,r]=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&&(r=this._initial_end):r=this._initial_end);const[d,h]=[this.start,this.end];if(o!=d||r!=h){const t={};o!=d&&(t.start=o),r!=h&&(t.end=r),this.setv(t)}\"auto\"==this.bounds&&this.setv({bounds:[o,r]},{silent:!0}),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=d,d.__name__=\"DataRange1d\",d.init_DataRange1d()},\n",
       "      function _(e,a,t){Object.defineProperty(t,\"__esModule\",{value:!0});const n=e(1),r=e(89),s=n.__importStar(e(19));class _ extends r.Range{constructor(e){super(e)}static init_DataRange(){this.define({names:[s.Array,[]],renderers:[s.Array,[]]})}}t.DataRange=_,_.__name__=\"DataRange\",_.init_DataRange()},\n",
       "      function _(a,o,t){Object.defineProperty(t,\"__esModule\",{value:!0});var e=a(188);t.Sizeable=e.Sizeable;var r=a(189);t.Layoutable=r.Layoutable,t.LayoutItem=r.LayoutItem;var n=a(190);t.HStack=n.HStack,t.VStack=n.VStack,t.AnchorLayout=n.AnchorLayout;var u=a(191);t.Grid=u.Grid,t.Row=u.Row,t.Column=u.Column;var c=a(192);t.ContentBox=c.ContentBox,t.VariadicBox=c.VariadicBox},\n",
       "      function _(h,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const{min:e,max:w}=Math;class d{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 d({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 d({width:h!=1/0?w(this.width,h):this.width,height:t!=1/0?w(this.height,t):this.height})}expand_to({width:h,height:t}){this.width=w(this.width,h),this.height=w(this.height,t)}narrowed_to({width:h,height:t}){return new d({width:e(this.width,h),height:e(this.height,t)})}narrow_to({width:h,height:t}){this.width=e(this.width,h),this.height=e(this.height,t)}grow_by({left:h,right:t,top:i,bottom:e}){const w=this.width+h+t,s=this.height+i+e;return new d({width:w,height:s})}shrink_by({left:h,right:t,top:i,bottom:e}){const s=w(this.width-h-t,0),n=w(this.height-i-e,0);return new d({width:s,height:n})}map(h,t){return new d({width:h(this.width),height:(null!=t?t:h)(this.height)})}}i.Sizeable=d,d.__name__=\"Sizeable\"},\n",
       "      function _(i,t,h){Object.defineProperty(h,\"__esModule\",{value:!0});const e=i(188),s=i(85),{min:n,max:g,round:a}=Math;class r{constructor(){this._bbox=new s.BBox,this._inner_bbox=new s.BBox;const i=this;this._top={get value(){return i.bbox.top}},this._left={get value(){return i.bbox.left}},this._width={get value(){return i.bbox.width}},this._height={get value(){return i.bbox.height}},this._right={get value(){return i.bbox.right}},this._bottom={get value(){return i.bbox.bottom}},this._hcenter={get value(){return i.bbox.hcenter}},this._vcenter={get value(){return i.bbox.vcenter}}}get bbox(){return this._bbox}get inner_bbox(){return this._inner_bbox}get sizing(){return this._sizing}set_sizing(i){const t=i.width_policy||\"fit\",h=i.width,e=null!=i.min_width?i.min_width:0,s=null!=i.max_width?i.max_width:1/0,n=i.height_policy||\"fit\",g=i.height,a=null!=i.min_height?i.min_height:0,r=null!=i.max_height?i.max_height:1/0,l=i.aspect,_=i.margin||{top:0,right:0,bottom:0,left:0},d=!1!==i.visible,o=i.halign||\"start\",u=i.valign||\"start\";this._sizing={width_policy:t,min_width:e,width:h,max_width:s,height_policy:n,min_height:a,height:g,max_height:r,aspect:l,margin:_,visible:d,halign:o,valign:u,size:{width:h,height:g},min_size:{width:e,height:a},max_size:{width:s,height:r}},this._init()}_init(){}_set_geometry(i,t){this._bbox=i,this._inner_bbox=t}set_geometry(i,t){this._set_geometry(i,t||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:s,height_policy:n}=this.sizing,g=(i,t)=>{const h={max:4,fit:3,min:2,fixed:1};return h[i]>h[t]};if(\"fixed\"!=s&&\"fixed\"!=n)if(s==n){const s=t,n=a(t/e),g=a(h*e),r=h;Math.abs(i.width-s)+Math.abs(i.height-n)<=Math.abs(i.width-g)+Math.abs(i.height-r)?(t=s,h=n):(t=g,h=r)}else g(s,n)?h=a(t/e):t=a(h*e);else\"fixed\"==s?h=a(t/e):\"fixed\"==n&&(t=a(h*e))}return{width:t,height:h}}measure(i){if(!this.sizing.visible)return{width:0,height:0};const t=i=>\"fixed\"==this.sizing.width_policy&&null!=this.sizing.width?this.sizing.width:i,h=i=>\"fixed\"==this.sizing.height_policy&&null!=this.sizing.height?this.sizing.height:i,s=new e.Sizeable(i).shrink_by(this.sizing.margin).map(t,h),n=this._measure(s),g=this.clip_size(n),a=t(g.width),r=h(g.height),l=this.apply_aspect(s,{width:a,height:r});return Object.assign(Object.assign({},n),l)}compute(i={}){const t=this.measure({width:null!=i.width&&this.is_width_expanding()?i.width:1/0,height:null!=i.height&&this.is_height_expanding()?i.height:1/0}),{width:h,height:e}=t,n=new s.BBox({left:0,top:0,width:h,height:e});let g=void 0;if(null!=t.inner){const{left:i,top:n,right:a,bottom:r}=t.inner;g=new s.BBox({left:i,top:n,right:h-a,bottom:e-r})}this.set_geometry(n,g)}get xview(){return this.bbox.xview}get yview(){return this.bbox.yview}clip_width(i){return g(this.sizing.min_width,n(i,this.sizing.max_width))}clip_height(i){return g(this.sizing.min_height,n(i,this.sizing.max_height))}clip_size({width:i,height:t}){return{width:this.clip_width(i),height:this.clip_height(t)}}}h.Layoutable=r,r.__name__=\"Layoutable\";class l extends r{_measure(i){const{width_policy:t,height_policy:h}=this.sizing;let e,s;if(i.width==1/0)e=null!=this.sizing.width?this.sizing.width:0;else switch(t){case\"fixed\":e=null!=this.sizing.width?this.sizing.width:0;break;case\"min\":e=null!=this.sizing.width?n(i.width,this.sizing.width):0;break;case\"fit\":e=null!=this.sizing.width?n(i.width,this.sizing.width):i.width;break;case\"max\":e=null!=this.sizing.width?g(i.width,this.sizing.width):i.width}if(i.height==1/0)s=null!=this.sizing.height?this.sizing.height:0;else switch(h){case\"fixed\":s=null!=this.sizing.height?this.sizing.height:0;break;case\"min\":s=null!=this.sizing.height?n(i.height,this.sizing.height):0;break;case\"fit\":s=null!=this.sizing.height?n(i.height,this.sizing.height):i.height;break;case\"max\":s=null!=this.sizing.height?g(i.height,this.sizing.height):i.height}return{width:e,height:s}}}h.LayoutItem=l,l.__name__=\"LayoutItem\";class _ extends r{_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=_,_.__name__=\"ContentLayoutable\"},\n",
       "      function _(t,e,h){Object.defineProperty(h,\"__esModule\",{value:!0});const o=t(189),r=t(85);class i extends o.Layoutable{constructor(){super(...arguments),this.children=[]}}h.Stack=i,i.__name__=\"Stack\";class s extends i{_measure(t){let e=0,h=0;for(const t of this.children){const o=t.measure({width:0,height:0});e+=o.width,h=Math.max(h,o.height)}return{width:e,height:h}}_set_geometry(t,e){super._set_geometry(t,e);const{top:h,bottom:o}=t;let{left:i}=t;for(const t of this.children){const{width:e}=t.measure({width:0,height:0});t.set_geometry(new r.BBox({left:i,width:e,top:h,bottom:o})),i+=e}}}h.HStack=s,s.__name__=\"HStack\";class n extends i{_measure(t){let e=0,h=0;for(const t of this.children){const o=t.measure({width:0,height:0});e=Math.max(e,o.width),h+=o.height}return{width:e,height:h}}_set_geometry(t,e){super._set_geometry(t,e);const{left:h,right:o}=t;let{top:i}=t;for(const t of this.children){const{height:e}=t.measure({width:0,height:0});t.set_geometry(new r.BBox({top:i,height:e,left:h,right:o})),i+=e}}}h.VStack=n,n.__name__=\"VStack\";class c extends o.Layoutable{constructor(){super(...arguments),this.children=[]}_measure(t){let e=0,h=0;for(const{layout:o}of this.children){const r=o.measure(t);e=Math.max(e,r.width),h=Math.max(h,r.height)}return{width:e,height:h}}_set_geometry(t,e){super._set_geometry(t,e);for(const{layout:e,anchor:h,margin:o}of this.children){const{left:i,right:s,top:n,bottom:c,hcenter:a,vcenter:_}=t,{width:g,height:d}=e.measure(t);let m;switch(h){case\"top_left\":m=new r.BBox({left:i+o,top:n+o,width:g,height:d});break;case\"top_center\":m=new r.BBox({hcenter:a,top:n+o,width:g,height:d});break;case\"top_right\":m=new r.BBox({right:s-o,top:n+o,width:g,height:d});break;case\"bottom_right\":m=new r.BBox({right:s-o,bottom:c-o,width:g,height:d});break;case\"bottom_center\":m=new r.BBox({hcenter:a,bottom:c-o,width:g,height:d});break;case\"bottom_left\":m=new r.BBox({left:i+o,bottom:c-o,width:g,height:d});break;case\"center_left\":m=new r.BBox({left:i+o,vcenter:_,width:g,height:d});break;case\"center\":m=new r.BBox({hcenter:a,vcenter:_,width:g,height:d});break;case\"center_right\":m=new r.BBox({right:s-o,vcenter:_,width:g,height:d})}e.set_geometry(m)}}}h.AnchorLayout=c,c.__name__=\"AnchorLayout\"},\n",
       "      function _(t,i,s){Object.defineProperty(s,\"__esModule\",{value:!0});const e=t(188),o=t(189),n=t(8),r=t(85),h=t(9),{max:l,round:c}=Math;class a{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))}}a.__name__=\"DefaultMap\";class g{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=l(this._nrows,s+1),this._ncols=l(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 g;for(const{span:s,data:e}of this._items)i.add(s,t(s,e));return i}}g.__name__=\"Container\";class p extends o.Layoutable{constructor(t=[]){super(),this.items=t,this.rows=\"auto\",this.cols=\"auto\",this.spacing=0,this.absolute=!1}is_width_expanding(){if(super.is_width_expanding())return!0;if(\"fixed\"==this.sizing.width_policy)return!1;const{cols:t}=this._state;return h.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 h.some(t,t=>\"max\"==t.policy)}_init(){super._init();const t=new g;for(const{layout:i,row:s,col:e,row_span:o,col_span:n}of this.items)if(i.sizing.visible){const r=s,h=e,l=s+(null!=o?o:1)-1,c=e+(null!=n?n:1)-1;t.add({r0:r,c0:h,r1:l,c1:c},i)}const{nrows:i,ncols:s}=t,e=new Array(i);for(let s=0;s<i;s++){const i=(()=>{const t=n.isPlainObject(this.rows)?this.rows[s]||this.rows[\"*\"]:this.rows;return null==t?{policy:\"auto\"}:n.isNumber(t)?{policy:\"fixed\",height:t}:n.isString(t)?{policy:t}:t})(),o=i.align||\"auto\";if(\"fixed\"==i.policy)e[s]={policy:\"fixed\",height:i.height,align:o};else if(\"min\"==i.policy)e[s]={policy:\"min\",align:o};else if(\"fit\"==i.policy||\"max\"==i.policy)e[s]={policy:i.policy,flex:i.flex||1,align:o};else{if(\"auto\"!=i.policy)throw new Error(\"unrechable\");h.some(t.row(s),t=>t.is_height_expanding())?e[s]={policy:\"max\",flex:1,align:o}:e[s]={policy:\"min\",align:o}}}const o=new Array(s);for(let i=0;i<s;i++){const s=(()=>{const t=n.isPlainObject(this.cols)?this.cols[i]||this.cols[\"*\"]:this.cols;return null==t?{policy:\"auto\"}:n.isNumber(t)?{policy:\"fixed\",width:t}:n.isString(t)?{policy:t}:t})(),e=s.align||\"auto\";if(\"fixed\"==s.policy)o[i]={policy:\"fixed\",width:s.width,align:e};else if(\"min\"==s.policy)o[i]={policy:\"min\",align:e};else if(\"fit\"==s.policy||\"max\"==s.policy)o[i]={policy:s.policy,flex:s.flex||1,align:e};else{if(\"auto\"!=s.policy)throw new Error(\"unrechable\");h.some(t.col(i),t=>t.is_width_expanding())?o[i]={policy:\"max\",flex:1,align:e}:o[i]={policy:\"min\",align:e}}}const[r,l]=n.isNumber(this.spacing)?[this.spacing,this.spacing]:this.spacing;this._state={items:t,nrows:i,ncols:s,rows:e,cols:o,rspacing:r,cspacing:l}}_measure_totals(t,i){const{nrows:s,ncols:e,rspacing:o,cspacing:n}=this._state;return{height:h.sum(t)+(s-1)*o,width:h.sum(i)+(e-1)*n}}_measure_cells(t){const{items:i,nrows:s,ncols:o,rows:n,cols:r,rspacing:h,cspacing:a}=this._state,p=new Array(s);for(let t=0;t<s;t++){const i=n[t];p[t]=\"fixed\"==i.policy?i.height:0}const _=new Array(o);for(let t=0;t<o;t++){const i=r[t];_[t]=\"fixed\"==i.policy?i.width:0}const f=new g;return i.foreach((i,s)=>{const{r0:o,c0:g,r1:d,c1:w}=i,u=(d-o)*h,m=(w-g)*a;let y=0;for(let i=o;i<=d;i++)y+=t(i,g).height;y+=u;let x=0;for(let i=g;i<=w;i++)x+=t(o,i).width;x+=m;const b=s.measure({width:x,height:y});f.add(i,{layout:s,size_hint:b});const z=new e.Sizeable(b).grow_by(s.sizing.margin);z.height-=u,z.width-=m;const j=[];for(let t=o;t<=d;t++){const i=n[t];\"fixed\"==i.policy?z.height-=i.height:j.push(t)}if(z.height>0){const t=c(z.height/j.length);for(const i of j)p[i]=l(p[i],t)}const O=[];for(let t=g;t<=w;t++){const i=r[t];\"fixed\"==i.policy?z.width-=i.width:O.push(t)}if(z.width>0){const t=c(z.width/O.length);for(const i of O)_[i]=l(_[i],t)}}),{size:this._measure_totals(p,_),row_heights:p,col_widths:_,size_hints:f}}_measure_grid(t){const{nrows:i,ncols:s,rows:e,cols:o,rspacing:n,cspacing:r}=this._state,h=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}});let a;a=\"fixed\"==this.sizing.height_policy&&null!=this.sizing.height?this.sizing.height:t.height!=1/0&&this.is_height_expanding()?t.height:h.size.height;let g,p=0;for(let t=0;t<i;t++){const i=e[t];\"fit\"==i.policy||\"max\"==i.policy?p+=i.flex:a-=h.row_heights[t]}if(a-=(i-1)*n,0!=p&&a>0)for(let t=0;t<i;t++){const i=e[t];if(\"fit\"==i.policy||\"max\"==i.policy){const s=c(a*(i.flex/p));a-=s,h.row_heights[t]=s,p-=i.flex}}else if(a<0){let t=0;for(let s=0;s<i;s++){\"fixed\"!=e[s].policy&&t++}let s=-a;for(let o=0;o<i;o++){if(\"fixed\"!=e[o].policy){const i=h.row_heights[o],e=c(s/t);h.row_heights[o]=l(i-e,0),s-=e>i?i:e,t--}}}g=\"fixed\"==this.sizing.width_policy&&null!=this.sizing.width?this.sizing.width:t.width!=1/0&&this.is_width_expanding()?t.width:h.size.width;let _=0;for(let t=0;t<s;t++){const i=o[t];\"fit\"==i.policy||\"max\"==i.policy?_+=i.flex:g-=h.col_widths[t]}if(g-=(s-1)*r,0!=_&&g>0)for(let t=0;t<s;t++){const i=o[t];if(\"fit\"==i.policy||\"max\"==i.policy){const s=c(g*(i.flex/_));g-=s,h.col_widths[t]=s,_-=i.flex}}else if(g<0){let t=0;for(let i=0;i<s;i++){\"fixed\"!=o[i].policy&&t++}let i=-g;for(let e=0;e<s;e++){if(\"fixed\"!=o[e].policy){const s=h.col_widths[e],o=c(i/t);h.col_widths[e]=l(s-o,0),i-=o>s?s:o,t--}}}const{row_heights:f,col_widths:d,size_hints:w}=this._measure_cells((t,i)=>({width:h.col_widths[i],height:h.row_heights[t]}));return{size:this._measure_totals(f,d),row_heights:f,col_widths:d,size_hints:w}}_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:h,col_widths:g,size_hints:p}=this._measure_grid(t),_=this._state.rows.map((t,i)=>Object.assign(Object.assign({},t),{top:0,height:h[i],get bottom(){return this.top+this.height}})),f=this._state.cols.map((t,i)=>Object.assign(Object.assign({},t),{left:0,width:g[i],get right(){return this.left+this.width}})),d=p.map((t,i)=>Object.assign(Object.assign({},i),{outer:new r.BBox,inner:new r.BBox}));for(let i=0,e=this.absolute?t.top:0;i<s;i++){const t=_[i];t.top=e,e+=t.height+o}for(let i=0,s=this.absolute?t.left:0;i<e;i++){const t=f[i];t.left=s,s+=t.width+n}d.foreach(({r0:t,c0:i,r1:s,c1:e},h)=>{const{layout:l,size_hint:a}=h,{sizing:g}=l,{width:p,height:d}=a,w=function(t,i){let s=(i-t)*n;for(let e=t;e<=i;e++)s+=f[e].width;return s}(i,e),u=function(t,i){let s=(i-t)*o;for(let e=t;e<=i;e++)s+=_[e].height;return s}(t,s),m=i==e&&\"auto\"!=f[i].align?f[i].align:g.halign,y=t==s&&\"auto\"!=_[t].align?_[t].align:g.valign;let x=f[i].left;\"start\"==m?x+=g.margin.left:\"center\"==m?x+=c((w-p)/2):\"end\"==m&&(x+=w-g.margin.right-p);let b=_[t].top;\"start\"==y?b+=g.margin.top:\"center\"==y?b+=c((u-d)/2):\"end\"==y&&(b+=u-g.margin.bottom-d),h.outer=new r.BBox({left:x,top:b,width:p,height:d})});const w=_.map(()=>({start:new a(()=>0),end:new a(()=>0)})),u=f.map(()=>({start:new a(()=>0),end:new a(()=>0)}));d.foreach(({r0:t,c0:i,r1:s,c1:e},{size_hint:o,outer:n})=>{const{inner:r}=o;null!=r&&(w[t].start.apply(n.top,t=>l(t,r.top)),w[s].end.apply(_[s].bottom-n.bottom,t=>l(t,r.bottom)),u[i].start.apply(n.left,t=>l(t,r.left)),u[e].end.apply(f[e].right-n.right,t=>l(t,r.right)))}),d.foreach(({r0:t,c0:i,r1:s,c1:e},o)=>{const{size_hint:n,outer:h}=o;function l({left:t,right:i,top:s,bottom:e}){const o=h.width-t-i,n=h.height-s-e;return new r.BBox({left:t,top:s,width:o,height:n})}if(null!=n.inner){let r=l(n.inner);if(!1!==n.align){const o=w[t].start.get(h.top),n=w[s].end.get(_[s].bottom-h.bottom),c=u[i].start.get(h.left),a=u[e].end.get(f[e].right-h.right);try{r=l({top:o,bottom:n,left:c,right:a})}catch(t){}}o.inner=r}else o.inner=h}),d.foreach((t,{layout:i,outer:s,inner:e})=>{i.set_geometry(s,e)})}}s.Grid=p,p.__name__=\"Grid\";class _ extends p{constructor(t){super(),this.items=t.map((t,i)=>({layout:t,row:0,col:i})),this.rows=\"fit\"}}s.Row=_,_.__name__=\"Row\";class f extends p{constructor(t){super(),this.items=t.map((t,i)=>({layout:t,row:i,col:0})),this.cols=\"fit\"}}s.Column=f,f.__name__=\"Column\"},\n",
       "      function _(e,t,n){Object.defineProperty(n,\"__esModule\",{value:!0});const s=e(189),i=e(188),o=e(66);class r extends s.ContentLayoutable{constructor(e){super(),this.content_size=o.unsized(e,()=>new i.Sizeable(o.size(e)))}_content_size(){return this.content_size}}n.ContentBox=r,r.__name__=\"ContentBox\";class a extends s.Layoutable{constructor(e){super(),this.el=e}_measure(e){const t=new i.Sizeable(e).bounded_to(this.sizing.size);return o.sized(this.el,t,()=>{const e=new i.Sizeable(o.content_size(this.el)),{border:t,padding:n}=o.extents(this.el);return e.grow_by(t).grow_by(n).map(Math.ceil)})}}n.VariadicBox=a,a.__name__=\"VariadicBox\"},\n",
       "      function _(e,r,u){Object.defineProperty(u,\"__esModule\",{value:!0});var a=e(194);u.Expression=a.Expression;var n=e(195);u.Stack=n.Stack;var o=e(196);u.CumSum=o.CumSum},\n",
       "      function _(e,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const s=e(69);class n extends s.Model{constructor(e){super(e),this._connected={},this._result={}}initialize(){super.initialize(),this._connected={},this._result={}}v_compute(e){null==this._connected[e.id]&&(this.connect(e.change,()=>delete this._result[e.id]),this.connect(e.patching,()=>delete this._result[e.id]),this.connect(e.streaming,()=>delete this._result[e.id]),this._connected[e.id]=!0);let t=this._result[e.id];return null==t&&(this._result[e.id]=t=this._v_compute(e)),t}}i.Expression=n,n.__name__=\"Expression\"},\n",
       "      function _(t,e,n){Object.defineProperty(n,\"__esModule\",{value:!0});const i=t(1),o=t(194),r=i.__importStar(t(19));class s extends o.Expression{constructor(t){super(t)}static init_Stack(){this.define({fields:[r.Array,[]]})}_v_compute(t){var e;const n=null!==(e=t.get_length())&&void 0!==e?e:0,i=new Float64Array(n);for(const e of this.fields){const o=t.data[e];if(null!=o)for(let t=0,e=Math.min(n,o.length);t<e;t++)i[t]+=o[t]}return i}}n.Stack=s,s.__name__=\"Stack\",s.init_Stack()},\n",
       "      function _(e,t,n){Object.defineProperty(n,\"__esModule\",{value:!0});const i=e(1),u=e(194),o=i.__importStar(e(19));class r extends u.Expression{constructor(e){super(e)}static init_CumSum(){this.define({field:[o.String],include_zero:[o.Boolean,!1]})}_v_compute(e){const t=new Float64Array(e.get_length()||0),n=e.data[this.field],i=this.include_zero?1:0;t[0]=this.include_zero?0:n[0];for(let e=1;e<t.length;e++)t[e]=t[e-1]+n[e-i];return t}}n.CumSum=r,r.__name__=\"CumSum\",r.init_CumSum()},\n",
       "      function _(e,r,t){Object.defineProperty(t,\"__esModule\",{value:!0});var l=e(198);t.BooleanFilter=l.BooleanFilter;var i=e(200);t.CustomJSFilter=i.CustomJSFilter;var o=e(199);t.Filter=o.Filter;var F=e(201);t.GroupFilter=F.GroupFilter;var a=e(202);t.IndexFilter=a.IndexFilter},\n",
       "      function _(e,o,l){Object.defineProperty(l,\"__esModule\",{value:!0});const n=e(1),t=e(199),i=n.__importStar(e(19)),r=e(70),a=e(9),s=e(8);class g extends t.Filter{constructor(e){super(e)}static init_BooleanFilter(){this.define({booleans:[i.Array,null]})}compute_indices(e){const o=this.booleans;return null!=o&&o.length>0?a.every(o,s.isBoolean)?(o.length!==e.get_length()&&r.logger.warn(`BooleanFilter ${this.id}: length of booleans doesn't match data source`),a.range(0,o.length).filter(e=>!0===o[e])):(r.logger.warn(`BooleanFilter ${this.id}: booleans should be array of booleans, defaulting to no filtering`),null):(null!=o&&0==o.length?r.logger.warn(`BooleanFilter ${this.id}: booleans is empty, defaulting to no filtering`):r.logger.warn(`BooleanFilter ${this.id}: booleans was not set, defaulting to no filtering`),null)}}l.BooleanFilter=g,g.__name__=\"BooleanFilter\",g.init_BooleanFilter()},\n",
       "      function _(e,t,r){Object.defineProperty(r,\"__esModule\",{value:!0});const i=e(1),l=e(69),n=i.__importStar(e(19)),o=e(8),s=e(9),a=e(70);class f extends l.Model{constructor(e){super(e)}static init_Filter(){this.define({filter:[n.Array,null]})}compute_indices(e){const t=this.filter;return null!=t&&t.length>=0?o.isArrayOf(t,o.isBoolean)?s.range(0,t.length).filter(e=>!0===t[e]):o.isArrayOf(t,o.isInteger)?t:(a.logger.warn(`Filter ${this.id}: filter should either be array of only booleans or only integers, defaulting to no filtering`),null):(a.logger.warn(`Filter ${this.id}: filter was not set to be an array, defaulting to no filtering`),null)}}r.Filter=f,f.__name__=\"Filter\",f.init_Filter()},\n",
       "      function _(t,e,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=t(1),r=t(199),n=i.__importStar(t(19)),u=t(23),c=t(25);class o extends r.Filter{constructor(t){super(t)}static init_CustomJSFilter(){this.define({args:[n.Any,{}],code:[n.String,\"\"]})}get names(){return u.keys(this.args)}get values(){return u.values(this.args)}get func(){const t=c.use_strict(this.code);return new Function(...this.names,\"source\",t)}compute_indices(t){return this.filter=this.func(...this.values,t),super.compute_indices(t)}}s.CustomJSFilter=o,o.__name__=\"CustomJSFilter\",o.init_CustomJSFilter()},\n",
       "      function _(t,n,i){Object.defineProperty(i,\"__esModule\",{value:!0});const e=t(1),r=t(199),o=e.__importStar(t(19)),u=t(70),l=t(9);class s extends r.Filter{constructor(t){super(t),this.indices=null}static init_GroupFilter(){this.define({column_name:[o.String],group:[o.String]})}compute_indices(t){const n=t.get_column(this.column_name);return null==n?(u.logger.warn(\"group filter: groupby column not found in data source\"),null):(this.indices=l.range(0,t.get_length()||0).filter(t=>n[t]===this.group),0===this.indices.length&&u.logger.warn(`group filter: group '${this.group}' did not match any values in column '${this.column_name}'`),this.indices)}}i.GroupFilter=s,s.__name__=\"GroupFilter\",s.init_GroupFilter()},\n",
       "      function _(e,i,n){Object.defineProperty(n,\"__esModule\",{value:!0});const t=e(1),r=e(199),s=t.__importStar(e(19)),l=e(70),d=e(8),o=e(9);class c extends r.Filter{constructor(e){super(e)}static init_IndexFilter(){this.define({indices:[s.Array,null]})}compute_indices(e){return null!=this.indices&&this.indices.length>=0?o.every(this.indices,d.isInteger)?this.indices:(l.logger.warn(`IndexFilter ${this.id}: indices should be array of integers, defaulting to no filtering`),null):(l.logger.warn(`IndexFilter ${this.id}: indices was not set, defaulting to no filtering`),null)}}n.IndexFilter=c,c.__name__=\"IndexFilter\",c.init_IndexFilter()},\n",
       "      function _(r,t,a){Object.defineProperty(a,\"__esModule\",{value:!0});var e=r(112);a.BasicTickFormatter=e.BasicTickFormatter;var c=r(152);a.CategoricalTickFormatter=c.CategoricalTickFormatter;var i=r(156);a.DatetimeTickFormatter=i.DatetimeTickFormatter;var o=r(204);a.FuncTickFormatter=o.FuncTickFormatter;var m=r(169);a.LogTickFormatter=m.LogTickFormatter;var F=r(172);a.MercatorTickFormatter=F.MercatorTickFormatter;var k=r(205);a.NumeralTickFormatter=k.NumeralTickFormatter;var T=r(206);a.PrintfTickFormatter=T.PrintfTickFormatter;var v=r(113);a.TickFormatter=v.TickFormatter},\n",
       "      function _(t,e,n){Object.defineProperty(n,\"__esModule\",{value:!0});const r=t(1),s=t(113),i=r.__importStar(t(19)),c=t(23),a=t(25);class u extends s.TickFormatter{constructor(t){super(t)}static init_FuncTickFormatter(){this.define({args:[i.Any,{}],code:[i.String,\"\"]})}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,e){const n=this._make_func().bind({});return t.map((t,e,r)=>n(t,e,r,...this.values))}}n.FuncTickFormatter=u,u.__name__=\"FuncTickFormatter\",u.init_FuncTickFormatter()},\n",
       "      function _(r,t,n){Object.defineProperty(n,\"__esModule\",{value:!0});const e=r(1),o=e.__importStar(r(159)),a=r(113),i=e.__importStar(r(19));class u extends a.TickFormatter{constructor(r){super(r)}static init_NumeralTickFormatter(){this.define({format:[i.String,\"0,0\"],language:[i.String,\"en\"],rounding:[i.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=u,u.__name__=\"NumeralTickFormatter\",u.init_NumeralTickFormatter()},\n",
       "      function _(t,r,i){Object.defineProperty(i,\"__esModule\",{value:!0});const e=t(1),n=t(113),o=t(158),a=e.__importStar(t(19));class c extends n.TickFormatter{constructor(t){super(t)}static init_PrintfTickFormatter(){this.define({format:[a.String,\"%s\"]})}doFormat(t,r){return t.map(t=>o.sprintf(this.format,t))}}i.PrintfTickFormatter=c,c.__name__=\"PrintfTickFormatter\",c.init_PrintfTickFormatter()},\n",
       "      function _(a,e,r){Object.defineProperty(r,\"__esModule\",{value:!0});var v=a(208);r.AnnularWedge=v.AnnularWedge;var l=a(209);r.Annulus=l.Annulus;var t=a(210);r.Arc=t.Arc;var i=a(211);r.Bezier=i.Bezier;var n=a(212);r.Circle=n.Circle;var u=a(213);r.CenterRotatable=u.CenterRotatable;var c=a(214);r.Ellipse=c.Ellipse;var g=a(215);r.EllipseOval=g.EllipseOval;var A=a(86);r.Glyph=A.Glyph;var p=a(92);r.HArea=p.HArea;var s=a(216);r.HBar=s.HBar;var d=a(218);r.HexTile=d.HexTile;var R=a(219);r.Image=R.Image;var o=a(221);r.ImageRGBA=o.ImageRGBA;var y=a(222);r.ImageURL=y.ImageURL;var h=a(80);r.Line=h.Line;var m=a(224);r.MultiLine=m.MultiLine;var B=a(225);r.MultiPolygons=B.MultiPolygons;var P=a(226);r.Oval=P.Oval;var G=a(91);r.Patch=G.Patch;var H=a(227);r.Patches=H.Patches;var I=a(228);r.Quad=I.Quad;var L=a(229);r.Quadratic=L.Quadratic;var M=a(230);r.Ray=M.Ray;var O=a(231);r.Rect=O.Rect;var x=a(232);r.Segment=x.Segment;var C=a(233);r.Step=C.Step;var E=a(234);r.Text=E.Text;var Q=a(94);r.VArea=Q.VArea;var S=a(235);r.VBar=S.VBar;var T=a(236);r.Wedge=T.Wedge;var V=a(81);r.XYGlyph=V.XYGlyph},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=e(1),r=e(81),n=e(90),a=i.__importStar(e(87)),_=i.__importStar(e(19)),o=e(10);class h extends r.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=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=this._outer_radius,this._angle=new Float32Array(this._start_angle.length);for(let e=0,t=this._start_angle.length;e<t;e++)this._angle[e]=this._end_angle[e]-this._start_angle[e]}_render(e,t,{sx:s,sy:i,_start_angle:r,_angle:n,sinner_radius:a,souter_radius:_}){const o=this.model.properties.direction.value();for(const h of t)isNaN(s[h]+i[h]+a[h]+_[h]+r[h]+n[h])||(e.translate(s[h],i[h]),e.rotate(r[h]),e.moveTo(_[h],0),e.beginPath(),e.arc(0,0,_[h],0,n[h],o),e.rotate(n[h]),e.lineTo(a[h],0),e.arc(0,0,a[h],0,-n[h],!o),e.closePath(),e.rotate(-n[h]-r[h]),e.translate(-s[h],-i[h]),this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(e,h),e.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(e,h),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,_,h,u;if(\"data\"==this.model.properties.outer_radius.units)n=i-this.max_outer_radius,h=i+this.max_outer_radius,_=r-this.max_outer_radius,u=r+this.max_outer_radius;else{const e=t-this.max_outer_radius,i=t+this.max_outer_radius;[n,h]=this.renderer.xscale.r_invert(e,i);const r=s-this.max_outer_radius,a=s+this.max_outer_radius;[_,u]=this.renderer.yscale.r_invert(r,a)}const l=[];for(const e of this.index.indices({x0:n,x1:h,y0:_,y1:u})){const t=Math.pow(this.souter_radius[e],2),s=Math.pow(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]),h=Math.pow(n-a,2)+Math.pow(_-o,2);h<=t&&h>=s&&l.push([e,h])}const d=this.model.properties.direction.value(),c=[];for(const[e,i]of l){const r=Math.atan2(s-this.sy[e],t-this.sx[e]);o.angle_between(-r,-this._start_angle[e],-this._end_angle[e],d)&&c.push([e,i])}return a.create_hit_test_result_from_hits(c)}draw_legend_for_index(e,t,s){n.generic_area_legend(this.visuals,e,t,s)}_scenterxy(e){const t=(this.sinner_radius[e]+this.souter_radius[e])/2,s=(this._start_angle[e]+this._end_angle[e])/2;return{x:this.sx[e]+t*Math.cos(s),y:this.sy[e]+t*Math.sin(s)}}scenterx(e){return this._scenterxy(e).x}scentery(e){return this._scenterxy(e).y}}s.AnnularWedgeView=h,h.__name__=\"AnnularWedgeView\";class u extends r.XYGlyph{constructor(e){super(e)}static init_AnnularWedge(){this.prototype.default_view=h,this.mixins([\"line\",\"fill\"]),this.define({direction:[_.Direction,\"anticlock\"],inner_radius:[_.DistanceSpec],outer_radius:[_.DistanceSpec],start_angle:[_.AngleSpec],end_angle:[_.AngleSpec]})}}s.AnnularWedge=u,u.__name__=\"AnnularWedge\",u.init_AnnularWedge()},\n",
       "      function _(s,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const e=s(1),r=s(81),a=e.__importStar(s(87)),n=e.__importStar(s(19)),_=s(101);class u extends r.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=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=this._outer_radius}_render(s,t,{sx:i,sy:e,sinner_radius:r,souter_radius:a}){for(const n of t)if(!isNaN(i[n]+e[n]+r[n]+a[n])){if(this.visuals.fill.doit){if(this.visuals.fill.set_vectorize(s,n),s.beginPath(),_.is_ie)for(const t of[!1,!0])s.arc(i[n],e[n],r[n],0,Math.PI,t),s.arc(i[n],e[n],a[n],Math.PI,0,!t);else s.arc(i[n],e[n],r[n],0,2*Math.PI,!0),s.arc(i[n],e[n],a[n],2*Math.PI,0,!1);s.fill()}this.visuals.line.doit&&(this.visuals.line.set_vectorize(s,n),s.beginPath(),s.arc(i[n],e[n],r[n],0,2*Math.PI),s.moveTo(i[n]+a[n],e[n]),s.arc(i[n],e[n],a[n],0,2*Math.PI),s.stroke())}}_hit_point(s){const{sx:t,sy:i}=s,e=this.renderer.xscale.invert(t),r=this.renderer.yscale.invert(i);let n,_,u,o;if(\"data\"==this.model.properties.outer_radius.units)n=e-this.max_outer_radius,u=e+this.max_outer_radius,_=r-this.max_outer_radius,o=r+this.max_outer_radius;else{const s=t-this.max_outer_radius,e=t+this.max_outer_radius;[n,u]=this.renderer.xscale.r_invert(s,e);const r=i-this.max_outer_radius,a=i+this.max_outer_radius;[_,o]=this.renderer.yscale.r_invert(r,a)}const h=[];for(const s of this.index.indices({x0:n,x1:u,y0:_,y1:o})){const t=Math.pow(this.souter_radius[s],2),i=Math.pow(this.sinner_radius[s],2),[a,n]=this.renderer.xscale.r_compute(e,this._x[s]),[_,u]=this.renderer.yscale.r_compute(r,this._y[s]),o=Math.pow(a-n,2)+Math.pow(_-u,2);o<=t&&o>=i&&h.push([s,o])}return a.create_hit_test_result_from_hits(h)}draw_legend_for_index(s,{x0:t,y0:i,x1:e,y1:r},a){const n=a+1,_=new Array(n);_[a]=(t+e)/2;const u=new Array(n);u[a]=(i+r)/2;const o=.5*Math.min(Math.abs(e-t),Math.abs(r-i)),h=new Array(n);h[a]=.4*o;const d=new Array(n);d[a]=.8*o,this._render(s,[a],{sx:_,sy:u,sinner_radius:h,souter_radius:d})}}i.AnnulusView=u,u.__name__=\"AnnulusView\";class o extends r.XYGlyph{constructor(s){super(s)}static init_Annulus(){this.prototype.default_view=u,this.mixins([\"line\",\"fill\"]),this.define({inner_radius:[n.DistanceSpec],outer_radius:[n.DistanceSpec]})}}i.Annulus=o,o.__name__=\"Annulus\",o.init_Annulus()},\n",
       "      function _(e,i,s){Object.defineProperty(s,\"__esModule\",{value:!0});const t=e(1),r=e(81),n=e(90),a=t.__importStar(e(19));class _ extends r.XYGlyphView{_map_data(){\"data\"==this.model.properties.radius.units?this.sradius=this.sdist(this.renderer.xscale,this._x,this._radius):this.sradius=this._radius}_render(e,i,{sx:s,sy:t,sradius:r,_start_angle:n,_end_angle:a}){if(this.visuals.line.doit){const _=this.model.properties.direction.value();for(const c of i)isNaN(s[c]+t[c]+r[c]+n[c]+a[c])||(e.beginPath(),e.arc(s[c],t[c],r[c],n[c],a[c],_),this.visuals.line.set_vectorize(e,c),e.stroke())}}draw_legend_for_index(e,i,s){n.generic_line_legend(this.visuals,e,i,s)}}s.ArcView=_,_.__name__=\"ArcView\";class c extends r.XYGlyph{constructor(e){super(e)}static init_Arc(){this.prototype.default_view=_,this.mixins([\"line\"]),this.define({direction:[a.Direction,\"anticlock\"],radius:[a.DistanceSpec],start_angle:[a.AngleSpec],end_angle:[a.AngleSpec]})}}s.Arc=c,c.__name__=\"Arc\",c.init_Arc()},\n",
       "      function _(t,e,i){Object.defineProperty(i,\"__esModule\",{value:!0});const s=t(82),n=t(86),c=t(90);function o(t,e,i,s,n,c,o,h){const r=[],_=[[],[]];for(let _=0;_<=2;_++){let a,x,l;if(0===_?(x=6*t-12*i+6*n,a=-3*t+9*i-9*n+3*o,l=3*i-3*t):(x=6*e-12*s+6*c,a=-3*e+9*s-9*c+3*h,l=3*s-3*e),Math.abs(a)<1e-12){if(Math.abs(x)<1e-12)continue;const t=-l/x;0<t&&t<1&&r.push(t);continue}const y=x*x-4*l*a,u=Math.sqrt(y);if(y<0)continue;const d=(-x+u)/(2*a);0<d&&d<1&&r.push(d);const f=(-x-u)/(2*a);0<f&&f<1&&r.push(f)}let a=r.length;const x=a;for(;a--;){const x=r[a],l=1-x,y=l*l*l*t+3*l*l*x*i+3*l*x*x*n+x*x*x*o;_[0][a]=y;const u=l*l*l*e+3*l*l*x*s+3*l*x*x*c+x*x*x*h;_[1][a]=u}return _[0][x]=t,_[1][x]=e,_[0][x+1]=o,_[1][x+1]=h,[Math.min(..._[0]),Math.max(..._[1]),Math.max(..._[0]),Math.min(..._[1])]}class h extends n.GlyphView{_index_data(){const t=[];for(let e=0,i=this._x0.length;e<i;e++){if(isNaN(this._x0[e]+this._x1[e]+this._y0[e]+this._y1[e]+this._cx0[e]+this._cy0[e]+this._cx1[e]+this._cy1[e]))continue;const[i,s,n,c]=o(this._x0[e],this._y0[e],this._x1[e],this._y1[e],this._cx0[e],this._cy0[e],this._cx1[e],this._cy1[e]);t.push({x0:i,y0:s,x1:n,y1:c,i:e})}return new s.SpatialIndex(t)}_render(t,e,{sx0:i,sy0:s,sx1:n,sy1:c,scx0:o,scy0:h,scx1:r,scy1:_}){if(this.visuals.line.doit)for(const a of e)isNaN(i[a]+s[a]+n[a]+c[a]+o[a]+h[a]+r[a]+_[a])||(t.beginPath(),t.moveTo(i[a],s[a]),t.bezierCurveTo(o[a],h[a],r[a],_[a],n[a],c[a]),this.visuals.line.set_vectorize(t,a),t.stroke())}draw_legend_for_index(t,e,i){c.generic_line_legend(this.visuals,t,e,i)}scenterx(){throw new Error(\"not implemented\")}scentery(){throw new Error(\"not implemented\")}}i.BezierView=h,h.__name__=\"BezierView\";class r extends n.Glyph{constructor(t){super(t)}static init_Bezier(){this.prototype.default_view=h,this.coords([[\"x0\",\"y0\"],[\"x1\",\"y1\"],[\"cx0\",\"cy0\"],[\"cx1\",\"cy1\"]]),this.mixins([\"line\"])}}i.Bezier=r,r.__name__=\"Bezier\",r.init_Bezier()},\n",
       "      function _(s,i,e){Object.defineProperty(e,\"__esModule\",{value:!0});const t=s(1),r=s(81),a=t.__importStar(s(87)),n=t.__importStar(s(19)),h=s(9),d=s(12);class _ extends r.XYGlyphView{_map_data(){if(null!=this._radius)if(\"data\"==this.model.properties.radius.spec.units){switch(this.model.properties.radius_dimension.spec.value){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=d.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=d.map(s,(s,e)=>Math.min(s,i[e]));break}}}else this.sradius=this._radius,this.max_size=2*this.max_radius;else this.sradius=d.map(this._size,s=>s/2)}_mask_data(){const[s,i]=this.renderer.plot_view.frame.bbox.ranges;let e,t,r,a;if(null!=this._radius&&\"data\"==this.model.properties.radius.units){const n=s.start,h=s.end;[e,r]=this.renderer.xscale.r_invert(n,h),e-=this.max_radius,r+=this.max_radius;const d=i.start,_=i.end;[t,a]=this.renderer.yscale.r_invert(d,_),t-=this.max_radius,a+=this.max_radius}else{const n=s.start-this.max_size,h=s.end+this.max_size;[e,r]=this.renderer.xscale.r_invert(n,h);const d=i.start-this.max_size,_=i.end+this.max_size;[t,a]=this.renderer.yscale.r_invert(d,_)}return this.index.indices({x0:e,x1:r,y0:t,y1:a})}_render(s,i,{sx:e,sy:t,sradius:r}){for(const a of i)isNaN(e[a]+t[a]+r[a])||(s.beginPath(),s.arc(e[a],t[a],r[a],0,2*Math.PI,!1),this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(s,a),s.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(s,a),s.stroke()))}_hit_point(s){const{sx:i,sy:e}=s,t=this.renderer.xscale.invert(i),r=this.renderer.yscale.invert(e);let n,h,d,_;if(null!=this._radius&&\"data\"==this.model.properties.radius.units)n=t-this.max_radius,h=t+this.max_radius,d=r-this.max_radius,_=r+this.max_radius;else{const s=i-this.max_size,t=i+this.max_size;[n,h]=this.renderer.xscale.r_invert(s,t);const r=e-this.max_size,a=e+this.max_size;[d,_]=this.renderer.yscale.r_invert(r,a)}const l=this.index.indices({x0:n,x1:h,y0:d,y1:_}),c=[];if(null!=this._radius&&\"data\"==this.model.properties.radius.units)for(const s of l){const i=Math.pow(this.sradius[s],2),[e,a]=this.renderer.xscale.r_compute(t,this._x[s]),[n,h]=this.renderer.yscale.r_compute(r,this._y[s]),d=Math.pow(e-a,2)+Math.pow(n-h,2);d<=i&&c.push([s,d])}else for(const s of l){const t=Math.pow(this.sradius[s],2),r=Math.pow(this.sx[s]-i,2)+Math.pow(this.sy[s]-e,2);r<=t&&c.push([s,r])}return a.create_hit_test_result_from_hits(c)}_hit_span(s){const{sx:i,sy:e}=s,t=this.bounds(),r=a.create_empty_hit_test_result();let n,h,d,_;if(\"h\"==s.direction){let s,e;if(d=t.y0,_=t.y1,null!=this._radius&&\"data\"==this.model.properties.radius.units)s=i-this.max_radius,e=i+this.max_radius,[n,h]=this.renderer.xscale.r_invert(s,e);else{const t=this.max_size/2;s=i-t,e=i+t,[n,h]=this.renderer.xscale.r_invert(s,e)}}else{let s,i;if(n=t.x0,h=t.x1,null!=this._radius&&\"data\"==this.model.properties.radius.units)s=e-this.max_radius,i=e+this.max_radius,[d,_]=this.renderer.yscale.r_invert(s,i);else{const t=this.max_size/2;s=e-t,i=e+t,[d,_]=this.renderer.yscale.r_invert(s,i)}}const l=this.index.indices({x0:n,x1:h,y0:d,y1:_});return r.indices=l,r}_hit_rect(s){const{sx0:i,sx1:e,sy0:t,sy1:r}=s,[n,h]=this.renderer.xscale.r_invert(i,e),[d,_]=this.renderer.yscale.r_invert(t,r),l=a.create_empty_hit_test_result();return l.indices=this.index.indices({x0:n,x1:h,y0:d,y1:_}),l}_hit_poly(s){const{sx:i,sy:e}=s,t=h.range(0,this.sx.length),r=[];for(let s=0,n=t.length;s<n;s++){const n=t[s];a.point_in_poly(this.sx[s],this.sy[s],i,e)&&r.push(n)}const n=a.create_empty_hit_test_result();return n.indices=r,n}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 _=new Array(n);_[a]=.2*Math.min(Math.abs(t-i),Math.abs(r-e)),this._render(s,[a],{sx:h,sy:d,sradius:_})}}e.CircleView=_,_.__name__=\"CircleView\";class l extends r.XYGlyph{constructor(s){super(s)}static init_Circle(){this.prototype.default_view=_,this.mixins([\"line\",\"fill\"]),this.define({angle:[n.AngleSpec,0],size:[n.DistanceSpec,{units:\"screen\",value:4}],radius:[n.DistanceSpec],radius_dimension:[n.RadiusDimension,\"x\"]})}initialize(){super.initialize(),this.properties.radius.optional=!0}}e.Circle=l,l.__name__=\"Circle\",l.init_Circle()},\n",
       "      function _(e,t,n){Object.defineProperty(n,\"__esModule\",{value:!0});const a=e(1),i=e(81),l=a.__importStar(e(19));class s extends i.XYGlyphView{}n.CenterRotatableView=s,s.__name__=\"CenterRotatableView\";class _ extends i.XYGlyph{constructor(e){super(e)}static init_CenterRotatable(){this.mixins([\"line\",\"fill\"]),this.define({angle:[l.AngleSpec,0],width:[l.DistanceSpec],height:[l.DistanceSpec]})}}n.CenterRotatable=_,_.__name__=\"CenterRotatable\",_.init_CenterRotatable()},\n",
       "      function _(e,l,i){Object.defineProperty(i,\"__esModule\",{value:!0});const s=e(215);class t extends s.EllipseOvalView{}i.EllipseView=t,t.__name__=\"EllipseView\";class _ extends s.EllipseOval{constructor(e){super(e)}static init_Ellipse(){this.prototype.default_view=t}}i.Ellipse=_,_.__name__=\"Ellipse\",_.init_Ellipse()},\n",
       "      function _(t,s,e){Object.defineProperty(e,\"__esModule\",{value:!0});const i=t(1),h=t(213),r=i.__importStar(t(87));class a extends h.CenterRotatableView{_set_data(){this.max_w2=0,\"data\"==this.model.properties.width.units&&(this.max_w2=this.max_width/2),this.max_h2=0,\"data\"==this.model.properties.height.units&&(this.max_h2=this.max_height/2)}_map_data(){\"data\"==this.model.properties.width.units?this.sw=this.sdist(this.renderer.xscale,this._x,this._width,\"center\"):this.sw=this._width,\"data\"==this.model.properties.height.units?this.sh=this.sdist(this.renderer.yscale,this._y,this._height,\"center\"):this.sh=this._height}_render(t,s,{sx:e,sy:i,sw:h,sh:r,_angle:a}){for(const _ of s)isNaN(e[_]+i[_]+h[_]+r[_]+a[_])||(t.beginPath(),t.ellipse(e[_],i[_],h[_]/2,r[_]/2,a[_],0,2*Math.PI),this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(t,_),t.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(t,_),t.stroke()))}_hit_point(t){let s,e,i,h,a,_,n,l,d,o;const{sx:x,sy:m}=t,c=this.renderer.xscale.invert(x),w=this.renderer.yscale.invert(m);\"data\"==this.model.properties.width.units?(s=c-this.max_width,e=c+this.max_width):(n=x-this.max_width,l=x+this.max_width,[s,e]=this.renderer.xscale.r_invert(n,l)),\"data\"==this.model.properties.height.units?(i=w-this.max_height,h=w+this.max_height):(d=m-this.max_height,o=m+this.max_height,[i,h]=this.renderer.yscale.r_invert(d,o));const p=this.index.indices({x0:s,x1:e,y0:i,y1:h}),y=[];for(const t of p)a=r.point_in_ellipse(x,m,this._angle[t],this.sh[t]/2,this.sw[t]/2,this.sx[t],this.sy[t]),a&&([n,l]=this.renderer.xscale.r_compute(c,this._x[t]),[d,o]=this.renderer.yscale.r_compute(w,this._y[t]),_=Math.pow(n-l,2)+Math.pow(d-o,2),y.push([t,_]));return r.create_hit_test_result_from_hits(y)}draw_legend_for_index(t,{x0:s,y0:e,x1:i,y1:h},r){const a=r+1,_=new Array(a);_[r]=(s+i)/2;const n=new Array(a);n[r]=(e+h)/2;const l=this.sw[r]/this.sh[r],d=.8*Math.min(Math.abs(i-s),Math.abs(h-e)),o=new Array(a),x=new Array(a);l>1?(o[r]=d,x[r]=d/l):(o[r]=d*l,x[r]=d),this._render(t,[r],{sx:_,sy:n,sw:o,sh:x,_angle:[0]})}_bounds({x0:t,x1:s,y0:e,y1:i}){return{x0:t-this.max_w2,x1:s+this.max_w2,y0:e-this.max_h2,y1:i+this.max_h2}}}e.EllipseOvalView=a,a.__name__=\"EllipseOvalView\";class _ extends h.CenterRotatable{constructor(t){super(t)}}e.EllipseOval=_,_.__name__=\"EllipseOval\"},\n",
       "      function _(t,s,e){Object.defineProperty(e,\"__esModule\",{value:!0});const i=t(1),h=t(217),r=i.__importStar(t(19));class _ extends h.BoxView{scenterx(t){return(this.sleft[t]+this.sright[t])/2}scentery(t){return this.sy[t]}_index_data(){return this._index_box(this._y.length)}_lrtb(t){return[Math.min(this._left[t],this._right[t]),Math.max(this._left[t],this._right[t]),this._y[t]+.5*this._height[t],this._y[t]-.5*this._height[t]]}_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 Float64Array(t),this.sbottom=new Float64Array(t);for(let s=0;s<t;s++)this.stop[s]=this.sy[s]-this.sh[s]/2,this.sbottom[s]=this.sy[s]+this.sh[s]/2;this._clamp_viewport()}}e.HBarView=_,_.__name__=\"HBarView\";class a extends h.Box{constructor(t){super(t)}static init_HBar(){this.prototype.default_view=_,this.coords([[\"left\",\"y\"]]),this.define({height:[r.NumberSpec],right:[r.CoordinateSpec]}),this.override({left:0})}}e.HBar=a,a.__name__=\"HBar\",a.init_HBar()},\n",
       "      function _(t,e,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=t(1),r=t(82),n=t(86),h=t(90),a=i.__importStar(t(87));class o extends n.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]),h=Math.max(this.sbottom[e],this.stop[e]);switch(t){case\"top_left\":return{x:i,y:n};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:h};case\"bottom_center\":return{x:(i+r)/2,y:h};case\"bottom_right\":return{x:r,y:h};case\"center_left\":return{x:i,y:(n+h)/2};case\"center\":return{x:(i+r)/2,y:(n+h)/2};case\"center_right\":return{x:r,y:(n+h)/2};default:return null}}_index_box(t){const e=[];for(let s=0;s<t;s++){const[t,i,r,n]=this._lrtb(s);!isNaN(t+i+r+n)&&isFinite(t+i+r+n)&&e.push({x0:Math.min(t,i),y0:Math.min(r,n),x1:Math.max(i,t),y1:Math.max(r,n),i:s})}return new r.SpatialIndex(e)}_render(t,e,{sleft:s,sright:i,stop:r,sbottom:n}){for(const h of e)isNaN(s[h]+r[h]+i[h]+n[h])||(t.rect(s[h],r[h],i[h]-s[h],n[h]-r[h]),this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(t,h),t.beginPath(),t.rect(s[h],r[h],i[h]-s[h],n[h]-r[h]),t.fill()),this.visuals.hatch.doit2(t,h,()=>{t.beginPath(),t.rect(s[h],r[h],i[h]-s[h],n[h]-r[h]),t.fill()},()=>this.renderer.request_render()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(t,h),t.beginPath(),t.rect(s[h],r[h],i[h]-s[h],n[h]-r[h]),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}),h=a.create_empty_hit_test_result();return h.indices=n,h}_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})}const r=a.create_empty_hit_test_result();return r.indices=i,r}draw_legend_for_index(t,e,s){h.generic_area_legend(this.visuals,t,e,s)}}s.BoxView=o,o.__name__=\"BoxView\";class _ extends n.Glyph{constructor(t){super(t)}static init_Box(){this.mixins([\"line\",\"fill\",\"hatch\"])}}s.Box=_,_.__name__=\"Box\",_.init_Box()},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=e(1),r=e(86),n=i.__importStar(e(87)),a=i.__importStar(e(19)),h=e(82),_=e(90);class l extends r.GlyphView{scenterx(e){return this.sx[e]}scentery(e){return this.sy[e]}_set_data(){const e=this._q.length,t=this.model.size,s=this.model.aspect_scale;if(this._x=new Float64Array(e),this._y=new Float64Array(e),\"pointytop\"==this.model.orientation)for(let i=0;i<e;i++)this._x[i]=t*Math.sqrt(3)*(this._q[i]+this._r[i]/2)/s,this._y[i]=3*-t/2*this._r[i];else for(let i=0;i<e;i++)this._x[i]=3*t/2*this._q[i],this._y[i]=-t*Math.sqrt(3)*(this._r[i]+this._q[i]/2)*s}_index_data(){let e=this.model.size,t=Math.sqrt(3)*e/2;\"flattop\"==this.model.orientation?([t,e]=[e,t],e*=this.model.aspect_scale):t/=this.model.aspect_scale;const s=[];for(let i=0;i<this._x.length;i++){const r=this._x[i],n=this._y[i];!isNaN(r+n)&&isFinite(r+n)&&s.push({x0:r-t,y0:n-e,x1:r+t,y1:n+e,i:i})}return new h.SpatialIndex(s)}map_data(){[this.sx,this.sy]=this.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,a=r/2;return[[0,-n,-n,0,n,n],[r,a,-a,-r,-a,a]]}{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,a=r/2;return[[r,a,-a,-r,-a,a],[0,-n,-n,0,n,n]]}}_render(e,t,{sx:s,sy:i,svx:r,svy:n,_scale:a}){for(const h of t)if(!isNaN(s[h]+i[h]+a[h])){e.translate(s[h],i[h]),e.beginPath();for(let t=0;t<6;t++)e.lineTo(r[t]*a[h],n[t]*a[h]);e.closePath(),e.translate(-s[h],-i[h]),this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(e,h),e.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(e,h),e.stroke())}}_hit_point(e){const{sx:t,sy:s}=e,i=this.renderer.xscale.invert(t),r=this.renderer.yscale.invert(s),a=this.index.indices({x0:i,y0:r,x1:i,y1:r}),h=[];for(const e of a)n.point_in_poly(t-this.sx[e],s-this.sy[e],this.svx,this.svy)&&h.push(e);const _=n.create_empty_hit_test_result();return _.indices=h,_}_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})}const r=n.create_empty_hit_test_result();return r.indices=i,r}_hit_rect(e){const{sx0:t,sx1:s,sy0:i,sy1:r}=e,[a,h]=this.renderer.xscale.r_invert(t,s),[_,l]=this.renderer.yscale.r_invert(i,r),o=n.create_empty_hit_test_result();return o.indices=this.index.indices({x0:a,x1:h,y0:_,y1:l}),o}draw_legend_for_index(e,t,s){_.generic_area_legend(this.visuals,e,t,s)}}s.HexTileView=l,l.__name__=\"HexTileView\";class o extends r.Glyph{constructor(e){super(e)}static init_HexTile(){this.prototype.default_view=l,this.coords([[\"r\",\"q\"]]),this.mixins([\"line\",\"fill\"]),this.define({size:[a.Number,1],aspect_scale:[a.Number,1],scale:[a.NumberSpec,1],orientation:[a.HexTileOrientation,\"pointytop\"]}),this.override({line_color:null})}}s.HexTile=o,o.__name__=\"HexTile\",o.init_HexTile()},\n",
       "      function _(e,t,a){Object.defineProperty(a,\"__esModule\",{value:!0});const i=e(1),s=e(220),_=e(114),n=i.__importStar(e(19)),h=e(9);class o extends s.ImageBaseView{initialize(){super.initialize(),this.connect(this.model.color_mapper.change,()=>this._update_image()),this.connect(this.model.properties.global_alpha.change,()=>this.renderer.request_render())}_update_image(){null!=this.image_data&&(this._set_data(),this.renderer.plot_view.request_render())}_set_data(){this._set_width_heigh_data();const e=this.model.color_mapper.rgba_mapper;for(let t=0,a=this._image.length;t<a;t++){let a;if(null!=this._image_shape&&this._image_shape[t].length>0){a=this._image[t];const e=this._image_shape[t];this._height[t]=e[0],this._width[t]=e[1]}else{const e=this._image[t];a=h.concat(e),this._height[t]=e.length,this._width[t]=e[0].length}const i=e.v_compute(a);this._set_image_data_from_buffer(t,i)}}_render(e,t,{image_data:a,sx:i,sy:s,sw:_,sh:n}){const h=e.getImageSmoothingEnabled();e.setImageSmoothingEnabled(!1),e.globalAlpha=this.model.global_alpha;for(const h of t){if(null==a[h])continue;if(isNaN(i[h]+s[h]+_[h]+n[h]))continue;const t=s[h];e.translate(0,t),e.scale(1,-1),e.translate(0,-t),e.drawImage(a[h],0|i[h],0|s[h],_[h],n[h]),e.translate(0,t),e.scale(1,-1),e.translate(0,-t)}e.setImageSmoothingEnabled(h)}}a.ImageView=o,o.__name__=\"ImageView\";class l extends s.ImageBase{constructor(e){super(e)}static init_Image(){this.prototype.default_view=o,this.define({color_mapper:[n.Instance,()=>new _.LinearColorMapper({palette:[\"#000000\",\"#252525\",\"#525252\",\"#737373\",\"#969696\",\"#bdbdbd\",\"#d9d9d9\",\"#f0f0f0\",\"#ffffff\"]})]})}}a.Image=l,l.__name__=\"Image\",l.init_Image()},\n",
       "      function _(e,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const s=e(1),h=e(81),a=s.__importStar(e(19)),_=s.__importStar(e(87)),r=e(82);class n extends h.XYGlyphView{_render(e,t,i){}_index_data(){const e=[];for(let t=0,i=this._x.length;t<i;t++){const[i,s,h,a]=this._lrtb(t);!isNaN(i+s+h+a)&&isFinite(i+s+h+a)&&e.push({x0:i,y0:a,x1:s,y1:h,i:t})}return new r.SpatialIndex(e)}_lrtb(e){const t=this.renderer.xscale.source_range,i=this._x[e],s=t.is_reversed?i-this._dw[e]:i+this._dw[e],h=this.renderer.yscale.source_range,a=this._y[e],_=h.is_reversed?a-this._dh[e]:a+this._dh[e],[r,n]=i<s?[i,s]:[s,i],[d,g]=a<_?[a,_]:[_,a];return[r,n,g,d]}_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 Array(this._image.length)),null!=this._height&&this._height.length==this._image.length||(this._height=new Array(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\"),h=s.getImageData(0,0,this._width[e],this._height[e]);h.data.set(t),s.putImageData(h,0,0),this.image_data[e]=i}_map_data(){switch(this.model.properties.dw.units){case\"data\":this.sw=this.sdist(this.renderer.xscale,this._x,this._dw,\"edge\",this.model.dilate);break;case\"screen\":this.sw=this._dw}switch(this.model.properties.dh.units){case\"data\":this.sh=this.sdist(this.renderer.yscale,this._y,this._dh,\"edge\",this.model.dilate);break;case\"screen\":this.sh=this._dh}}_image_index(e,t,i){const[s,h,a,_]=this._lrtb(e),r=this._width[e],n=this._height[e],d=(h-s)/r,g=(a-_)/n;let l=Math.floor((t-s)/d),c=Math.floor((i-_)/g);return this.renderer.xscale.source_range.is_reversed&&(l=r-l-1),this.renderer.yscale.source_range.is_reversed&&(c=n-c-1),{index:e,dim1:l,dim2:c,flat_index:c*r+l}}_hit_point(e){const{sx:t,sy:i}=e,s=this.renderer.xscale.invert(t),h=this.renderer.yscale.invert(i),a=this.index.indices({x0:s,x1:s,y0:h,y1:h}),r=_.create_empty_hit_test_result();r.image_indices=[];for(const e of a)t!=1/0&&i!=1/0&&r.image_indices.push(this._image_index(e,s,h));return r}}i.ImageBaseView=n,n.__name__=\"ImageBaseView\";class d extends h.XYGlyph{constructor(e){super(e)}static init_ImageBase(){this.prototype.default_view=n,this.define({image:[a.NumberSpec],dw:[a.DistanceSpec],dh:[a.DistanceSpec],dilate:[a.Boolean,!1],global_alpha:[a.Number,1]})}}i.ImageBase=d,d.__name__=\"ImageBase\",d.init_ImageBase()},\n",
       "      function _(e,t,a){Object.defineProperty(a,\"__esModule\",{value:!0});const i=e(220),s=e(9);class n extends i.ImageBaseView{initialize(){super.initialize(),this.connect(this.model.properties.global_alpha.change,()=>this.renderer.request_render())}_set_data(e){this._set_width_heigh_data();for(let t=0,a=this._image.length;t<a;t++){if(null!=e&&e.indexOf(t)<0)continue;let a;if(null!=this._image_shape&&this._image_shape[t].length>0){a=this._image[t].buffer;const e=this._image_shape[t];this._height[t]=e[0],this._width[t]=e[1]}else{const e=this._image[t],i=s.concat(e);a=new ArrayBuffer(4*i.length);const n=new Uint32Array(a);for(let e=0,t=i.length;e<t;e++)n[e]=i[e];this._height[t]=e.length,this._width[t]=e[0].length}const i=new Uint8Array(a);this._set_image_data_from_buffer(t,i)}}_render(e,t,{image_data:a,sx:i,sy:s,sw:n,sh:h}){const _=e.getImageSmoothingEnabled();e.setImageSmoothingEnabled(!1),e.globalAlpha=this.model.global_alpha;for(const _ of t){if(isNaN(i[_]+s[_]+n[_]+h[_]))continue;const t=s[_];e.translate(0,t),e.scale(1,-1),e.translate(0,-t),e.drawImage(a[_],0|i[_],0|s[_],n[_],h[_]),e.translate(0,t),e.scale(1,-1),e.translate(0,-t)}e.setImageSmoothingEnabled(_)}}a.ImageRGBAView=n,n.__name__=\"ImageRGBAView\";class h extends i.ImageBase{constructor(e){super(e)}static init_ImageRGBA(){this.prototype.default_view=n}}a.ImageRGBA=h,h.__name__=\"ImageRGBA\",h.init_ImageRGBA()},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=e(1),r=e(81),a=i.__importStar(e(19)),n=e(12),h=e(82),l=e(223);class _ extends r.XYGlyphView{constructor(){super(...arguments),this._images_rendered=!1}initialize(){super.initialize(),this.connect(this.model.properties.global_alpha.change,()=>this.renderer.request_render())}_index_data(){return new h.SpatialIndex([])}_set_data(){null!=this.image&&this.image.length==this._url.length||(this.image=n.map(this._url,()=>null));const{retry_attempts:e,retry_timeout:t}=this.model;for(let s=0,i=this._url.length;s<i;s++){const i=this._url[s];null!=i&&\"\"!=i&&new l.ImageLoader(i,{loaded:e=>{this.image[s]=e,this.renderer.request_render()},attempts:e+1,timeout:t})}const s=\"data\"==this.model.properties.w.units,i=\"data\"==this.model.properties.h.units,r=this._x.length,a=new Array(s?2*r:r),h=new Array(i?2*r:r);for(let e=0;e<r;e++)a[e]=this._x[e],h[e]=this._y[e];if(s)for(let e=0;e<r;e++)a[r+e]=this._x[e]+this._w[e];if(i)for(let e=0;e<r;e++)h[r+e]=this._y[e]+this._h[e];const _=n.min(a),o=n.max(a),d=n.min(h),c=n.max(h);this._bounds_rect={x0:_,x1:o,y0:d,y1:c}}has_finished(){return super.has_finished()&&1==this._images_rendered}_map_data(){const e=null!=this.model.w?this._w:n.map(this._x,()=>NaN),t=null!=this.model.h?this._h:n.map(this._x,()=>NaN);switch(this.model.properties.w.units){case\"data\":this.sw=this.sdist(this.renderer.xscale,this._x,e,\"edge\",this.model.dilate);break;case\"screen\":this.sw=e}switch(this.model.properties.h.units){case\"data\":this.sh=this.sdist(this.renderer.yscale,this._y,t,\"edge\",this.model.dilate);break;case\"screen\":this.sh=t}}_render(e,t,{image:s,sx:i,sy:r,sw:a,sh:n,_angle:h}){const{frame:l}=this.renderer.plot_view;e.rect(l._left.value+1,l._top.value+1,l._width.value-2,l._height.value-2),e.clip();let _=!0;for(const l of t){if(isNaN(i[l]+r[l]+h[l]))continue;const t=s[l];null!=t?this._render_image(e,l,t,i,r,a,n,h):_=!1}_&&!this._images_rendered&&(this._images_rendered=!0,this.notify_finished())}_final_sx_sy(e,t,s,i,r){switch(e){case\"top_left\":return[t,s];case\"top_center\":return[t-i/2,s];case\"top_right\":return[t-i,s];case\"center_right\":return[t-i,s-r/2];case\"bottom_right\":return[t-i,s-r];case\"bottom_center\":return[t-i/2,s-r];case\"bottom_left\":return[t,s-r];case\"center_left\":return[t,s-r/2];case\"center\":return[t-i/2,s-r/2]}}_render_image(e,t,s,i,r,a,n,h){isNaN(a[t])&&(a[t]=s.width),isNaN(n[t])&&(n[t]=s.height);const{anchor:l}=this.model,[_,o]=this._final_sx_sy(l,i[t],r[t],a[t],n[t]);e.save(),e.globalAlpha=this.model.global_alpha;const d=a[t]/2,c=n[t]/2;h[t]?(e.translate(_,o),e.translate(d,c),e.rotate(h[t]),e.translate(-d,-c),e.drawImage(s,0,0,a[t],n[t]),e.translate(d,c),e.rotate(-h[t]),e.translate(-d,-c),e.translate(-_,-o)):e.drawImage(s,_,o,a[t],n[t]),e.restore()}bounds(){return this._bounds_rect}}s.ImageURLView=_,_.__name__=\"ImageURLView\";class o extends r.XYGlyph{constructor(e){super(e)}static init_ImageURL(){this.prototype.default_view=_,this.define({url:[a.StringSpec],anchor:[a.Anchor,\"top_left\"],global_alpha:[a.Number,1],angle:[a.AngleSpec,0],w:[a.DistanceSpec],h:[a.DistanceSpec],dilate:[a.Boolean,!1],retry_attempts:[a.Number,0],retry_timeout:[a.Number,0]})}}s.ImageURL=o,o.__name__=\"ImageURL\",o.init_ImageURL()},\n",
       "      function _(i,e,t){Object.defineProperty(t,\"__esModule\",{value:!0});const s=i(70);class a{constructor(i,e={}){this._image=new Image,this._finished=!1;const{attempts:t=1,timeout:a=1}=e;this.promise=new Promise((o,n)=>{this._image.crossOrigin=\"anonymous\";let r=0;this._image.onerror=()=>{if(++r==t){const a=`unable to load ${i} image after ${t} attempts`;if(s.logger.warn(a),null==this._image.crossOrigin)return void(null!=e.failed&&e.failed());s.logger.warn(`attempting to load ${i} without a cross origin policy`),this._image.crossOrigin=null,r=0}setTimeout(()=>this._image.src=i,a)},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(){return this._image}}t.ImageLoader=a,a.__name__=\"ImageLoader\"},\n",
       "      function _(t,e,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=t(1),n=t(82),r=i.__importStar(t(87)),l=t(23),o=t(9),_=t(8),h=t(86),c=t(90);class a extends h.GlyphView{_index_data(){const t=[];for(let e=0,s=this._xs.length;e<s;e++){if(null==this._xs[e]||0===this._xs[e].length)continue;const s=this._xs[e],i=[];for(let t=0,e=s.length;t<e;t++){const e=s[t];_.isStrictNaN(e)||i.push(e)}const n=this._ys[e],r=[];for(let t=0,e=n.length;t<e;t++){const e=n[t];_.isStrictNaN(e)||r.push(e)}const[l,h]=[o.min(i),o.max(i)],[c,a]=[o.min(r),o.max(r)];t.push({x0:l,y0:c,x1:h,y1:a,i:e})}return new n.SpatialIndex(t)}_render(t,e,{sxs:s,sys:i}){for(const n of e){const[e,r]=[s[n],i[n]];this.visuals.line.set_vectorize(t,n);for(let s=0,i=e.length;s<i;s++)0!=s?isNaN(e[s])||isNaN(r[s])?(t.stroke(),t.beginPath()):t.lineTo(e[s],r[s]):(t.beginPath(),t.moveTo(e[s],r[s]));t.stroke()}}_hit_point(t){const e=r.create_empty_hit_test_result(),s={x:t.sx,y:t.sy};let i=9999;const n={};for(let t=0,e=this.sxs.length;t<e;t++){const e=Math.max(2,this.visuals.line.cache_select(\"line_width\",t)/2);let l=null;for(let n=0,o=this.sxs[t].length-1;n<o;n++){const o={x:this.sxs[t][n],y:this.sys[t][n]},_={x:this.sxs[t][n+1],y:this.sys[t][n+1]},h=r.dist_to_segment(s,o,_);h<e&&h<i&&(i=h,l=[n])}l&&(n[t]=l)}return e.indices=l.keys(n).map(t=>parseInt(t,10)),e.multiline_indices=n,e}_hit_span(t){const{sx:e,sy:s}=t,i=r.create_empty_hit_test_result();let n,o;\"v\"===t.direction?(n=this.renderer.yscale.invert(s),o=this._ys):(n=this.renderer.xscale.invert(e),o=this._xs);const _={};for(let t=0,e=o.length;t<e;t++){const e=[];for(let s=0,i=o[t].length-1;s<i;s++)o[t][s]<=n&&n<=o[t][s+1]&&e.push(s);e.length>0&&(_[t]=e)}return i.indices=l.keys(_).map(t=>parseInt(t,10)),i.multiline_indices=_,i}get_interpolation_hit(t,e,s){const[i,n,r,l]=[this._xs[t][e],this._ys[t][e],this._xs[t][e+1],this._ys[t][e+1]];return c.line_interpolation(this.renderer,s,i,n,r,l)}draw_legend_for_index(t,e,s){c.generic_line_legend(this.visuals,t,e,s)}scenterx(){throw new Error(\"not implemented\")}scentery(){throw new Error(\"not implemented\")}}s.MultiLineView=a,a.__name__=\"MultiLineView\";class x extends h.Glyph{constructor(t){super(t)}static init_MultiLine(){this.prototype.default_view=a,this.coords([[\"xs\",\"ys\"]]),this.mixins([\"line\"])}}s.MultiLine=x,x.__name__=\"MultiLine\",x.init_MultiLine()},\n",
       "      function _(t,e,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=t(1),n=t(82),r=t(86),l=t(90),o=t(9),h=t(12),_=i.__importStar(t(87)),a=t(8),c=t(11);class d extends r.GlyphView{_index_data(){const t=[];for(let e=0,s=this._xs.length;e<s;e++)for(let s=0,i=this._xs[e].length;s<i;s++){const i=this._xs[e][s][0],n=this._ys[e][s][0];0!=i.length&&t.push({x0:o.min(i),y0:o.min(n),x1:o.max(i),y1:o.max(n),i:e})}return this.hole_index=this._index_hole_data(),new n.SpatialIndex(t)}_index_hole_data(){const t=[];for(let e=0,s=this._xs.length;e<s;e++)for(let s=0,i=this._xs[e].length;s<i;s++)if(this._xs[e][s].length>1)for(let i=1,n=this._xs[e][s].length;i<n;i++){const n=this._xs[e][s][i],r=this._ys[e][s][i];0!=n.length&&t.push({x0:o.min(n),y0:o.min(r),x1:o.max(n),y1:o.max(r),i:e})}return new n.SpatialIndex(t)}_mask_data(){const t=this.renderer.plot_view.frame.x_ranges.default,[e,s]=[t.min,t.max],i=this.renderer.plot_view.frame.y_ranges.default,[n,r]=[i.min,i.max];return this.index.indices({x0:e,x1:s,y0:n,y1:r}).sort((t,e)=>t-e).filter((t,e,s)=>0===e||t!==s[e-1])}_inner_loop(t,e,s){t.beginPath();for(let i=0,n=e.length;i<n;i++)for(let n=0,r=e[i].length;n<r;n++){const r=e[i][n],l=s[i][n];for(let e=0,s=r.length;e<s;e++)0!=e?t.lineTo(r[e],l[e]):t.moveTo(r[e],l[e]);t.closePath()}}_render(t,e,{sxs:s,sys:i}){if(this.visuals.fill.doit||this.visuals.line.doit)for(const n of e){const[e,r]=[s[n],i[n]];this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(t,n),this._inner_loop(t,e,r),t.fill(\"evenodd\")),this.visuals.hatch.doit2(t,n,()=>{this._inner_loop(t,e,r),t.fill(\"evenodd\")},()=>this.renderer.request_render()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(t,n),this._inner_loop(t,e,r),t.stroke())}}_hit_rect(t){const{sx0:e,sx1:s,sy0:i,sy1:n}=t,r=[e,s,s,e],l=[i,i,n,n],[o,h]=this.renderer.xscale.r_invert(e,s),[a,c]=this.renderer.yscale.r_invert(i,n),d=this.index.indices({x0:o,x1:h,y0:a,y1:c}),x=[];for(let t=0,e=d.length;t<e;t++){const e=d[t],s=this.sxs[e],i=this.sys[e];let n=!0;for(let t=0,e=s.length;t<e;t++){for(let e=0,o=s[t][0].length;e<o;e++){const o=s[t][0][e],h=i[t][0][e];if(!_.point_in_poly(o,h,r,l)){n=!1;break}}if(!n)break}n&&x.push(e)}const y=_.create_empty_hit_test_result();return y.indices=x,y}_hit_point(t){const{sx:e,sy:s}=t,i=this.renderer.xscale.invert(e),n=this.renderer.yscale.invert(s),r=this.index.indices({x0:i,y0:n,x1:i,y1:n}),l=this.hole_index.indices({x0:i,y0:n,x1:i,y1:n}),o=[];for(let t=0,i=r.length;t<i;t++){const i=r[t],n=this.sxs[i],h=this.sys[i];for(let t=0,r=n.length;t<r;t++){const r=n[t].length;if(_.point_in_poly(e,s,n[t][0],h[t][0]))if(1==r)o.push(i);else if(-1==l.indexOf(i))o.push(i);else if(r>1){let l=!1;for(let i=1;i<r;i++){const r=n[t][i],o=h[t][i];if(_.point_in_poly(e,s,r,o)){l=!0;break}}l||o.push(i)}}}const h=_.create_empty_hit_test_result();return h.indices=o,h}_get_snap_coord(t){return h.sum(t)/t.length}scenterx(t,e,s){if(1==this.sxs[t].length)return this._get_snap_coord(this.sxs[t][0][0]);{const i=this.sxs[t],n=this.sys[t];for(let t=0,r=i.length;t<r;t++)if(_.point_in_poly(e,s,i[t][0],n[t][0]))return this._get_snap_coord(i[t][0])}c.unreachable()}scentery(t,e,s){if(1==this.sys[t].length)return this._get_snap_coord(this.sys[t][0][0]);{const i=this.sxs[t],n=this.sys[t];for(let t=0,r=i.length;t<r;t++)if(_.point_in_poly(e,s,i[t][0],n[t][0]))return this._get_snap_coord(n[t][0])}c.unreachable()}map_data(){const t=this;for(let[e,s]of this.model._coords){const i=`s${e}`,n=`s${s}`;if(e=`_${e}`,s=`_${s}`,null!=t[e]&&(a.isArray(t[e][0])||a.isTypedArray(t[e][0]))){const r=t[e].length;t[i]=new Array(r),t[n]=new Array(r);for(let l=0;l<r;l++){const r=t[e][l].length;t[i][l]=new Array(r),t[n][l]=new Array(r);for(let o=0;o<r;o++){const r=t[e][l][o].length;t[i][l][o]=new Array(r),t[n][l][o]=new Array(r);for(let h=0;h<r;h++){const[r,_]=this.map_to_screen(t[e][l][o][h],t[s][l][o][h]);t[i][l][o][h]=r,t[n][l][o][h]=_}}}}}}draw_legend_for_index(t,e,s){l.generic_area_legend(this.visuals,t,e,s)}}s.MultiPolygonsView=d,d.__name__=\"MultiPolygonsView\";class x extends r.Glyph{constructor(t){super(t)}static init_MultiPolygons(){this.prototype.default_view=d,this.coords([[\"xs\",\"ys\"]]),this.mixins([\"line\",\"fill\",\"hatch\"])}}s.MultiPolygons=x,x.__name__=\"MultiPolygons\",x.init_MultiPolygons()},\n",
       "      function _(t,e,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=t(215);class h extends i.EllipseOvalView{_map_data(){let t;const e=this._x.length;this.sw=new Float64Array(e),t=\"data\"==this.model.properties.width.units?this.sdist(this.renderer.xscale,this._x,this._width,\"center\"):this._width;for(let s=0;s<e;s++)this.sw[s]=.75*t[s];\"data\"==this.model.properties.height.units?this.sh=this.sdist(this.renderer.yscale,this._y,this._height,\"center\"):this.sh=this._height}}s.OvalView=h,h.__name__=\"OvalView\";class a extends i.EllipseOval{constructor(t){super(t)}static init_Oval(){this.prototype.default_view=h}}s.Oval=a,a.__name__=\"Oval\",a.init_Oval()},\n",
       "      function _(s,t,e){Object.defineProperty(e,\"__esModule\",{value:!0});const i=s(1),n=s(82),r=s(86),o=s(90),_=s(9),l=s(12),h=s(8),c=i.__importStar(s(87)),a=s(11);class d extends r.GlyphView{_build_discontinuous_object(s){const t=[];for(let e=0,i=s.length;e<i;e++){t[e]=[];let i=_.copy(s[e]);for(;i.length>0;){const s=_.find_last_index(i,s=>h.isStrictNaN(s));let n;s>=0?n=i.splice(s):(n=i,i=[]);const r=n.filter(s=>!h.isStrictNaN(s));t[e].push(r)}}return t}_index_data(){const s=this._build_discontinuous_object(this._xs),t=this._build_discontinuous_object(this._ys),e=[];for(let i=0,n=this._xs.length;i<n;i++)for(let n=0,r=s[i].length;n<r;n++){const r=s[i][n],o=t[i][n];0!=r.length&&e.push({x0:_.min(r),y0:_.min(o),x1:_.max(r),y1:_.max(o),i:i})}return new n.SpatialIndex(e)}_mask_data(){const s=this.renderer.plot_view.frame.x_ranges.default,[t,e]=[s.min,s.max],i=this.renderer.plot_view.frame.y_ranges.default,[n,r]=[i.min,i.max];return this.index.indices({x0:t,x1:e,y0:n,y1:r}).sort((s,t)=>s-t)}_inner_loop(s,t,e,i){for(let n=0,r=t.length;n<r;n++)0!=n?isNaN(t[n]+e[n])?(s.closePath(),i.apply(s),s.beginPath()):s.lineTo(t[n],e[n]):(s.beginPath(),s.moveTo(t[n],e[n]));s.closePath(),i.call(s)}_render(s,t,{sxs:e,sys:i}){this.sxss=this._build_discontinuous_object(e),this.syss=this._build_discontinuous_object(i);for(const n of t){const[t,r]=[e[n],i[n]];this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(s,n),this._inner_loop(s,t,r,s.fill)),this.visuals.hatch.doit2(s,n,()=>this._inner_loop(s,t,r,s.fill),()=>this.renderer.request_render()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(s,n),this._inner_loop(s,t,r,s.stroke))}}_hit_rect(s){const{sx0:t,sx1:e,sy0:i,sy1:n}=s,r=[t,e,e,t],o=[i,i,n,n],[_,l]=this.renderer.xscale.r_invert(t,e),[h,a]=this.renderer.yscale.r_invert(i,n),d=this.index.indices({x0:_,x1:l,y0:h,y1:a}),u=[];for(let s=0,t=d.length;s<t;s++){const t=d[s],e=this.sxs[t],i=this.sys[t];let n=!0;for(let s=0,t=e.length;s<t;s++){const t=e[s],_=i[s];if(!c.point_in_poly(t,_,r,o)){n=!1;break}}n&&u.push(t)}const x=c.create_empty_hit_test_result();return x.indices=u,x}_hit_point(s){const{sx:t,sy:e}=s,i=this.renderer.xscale.invert(t),n=this.renderer.yscale.invert(e),r=this.index.indices({x0:i,y0:n,x1:i,y1:n}),o=[];for(let s=0,i=r.length;s<i;s++){const i=r[s],n=this.sxss[i],_=this.syss[i];for(let s=0,r=n.length;s<r;s++)c.point_in_poly(t,e,n[s],_[s])&&o.push(i)}const _=c.create_empty_hit_test_result();return _.indices=o,_}_get_snap_coord(s){return l.sum(s)/s.length}scenterx(s,t,e){if(1==this.sxss[s].length)return this._get_snap_coord(this.sxs[s]);{const i=this.sxss[s],n=this.syss[s];for(let s=0,r=i.length;s<r;s++)if(c.point_in_poly(t,e,i[s],n[s]))return this._get_snap_coord(i[s])}a.unreachable()}scentery(s,t,e){if(1==this.syss[s].length)return this._get_snap_coord(this.sys[s]);{const i=this.sxss[s],n=this.syss[s];for(let s=0,r=i.length;s<r;s++)if(c.point_in_poly(t,e,i[s],n[s]))return this._get_snap_coord(n[s])}a.unreachable()}draw_legend_for_index(s,t,e){o.generic_area_legend(this.visuals,s,t,e)}}e.PatchesView=d,d.__name__=\"PatchesView\";class u extends r.Glyph{constructor(s){super(s)}static init_Patches(){this.prototype.default_view=d,this.coords([[\"xs\",\"ys\"]]),this.mixins([\"line\",\"fill\",\"hatch\"])}}e.Patches=u,u.__name__=\"Patches\",u.init_Patches()},\n",
       "      function _(t,e,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=t(217);class _ extends i.BoxView{scenterx(t){return(this.sleft[t]+this.sright[t])/2}scentery(t){return(this.stop[t]+this.sbottom[t])/2}_index_data(){return this._index_box(this._right.length)}_lrtb(t){return[this._left[t],this._right[t],this._top[t],this._bottom[t]]}}s.QuadView=_,_.__name__=\"QuadView\";class o extends i.Box{constructor(t){super(t)}static init_Quad(){this.prototype.default_view=_,this.coords([[\"right\",\"bottom\"],[\"left\",\"top\"]])}}s.Quad=o,o.__name__=\"Quad\",o.init_Quad()},\n",
       "      function _(t,i,e){Object.defineProperty(e,\"__esModule\",{value:!0});const s=t(82),n=t(86),r=t(90);function a(t,i,e){if(i==(t+e)/2)return[t,e];{const s=(t-i)/(t-2*i+e),n=t*Math.pow(1-s,2)+2*i*(1-s)*s+e*Math.pow(s,2);return[Math.min(t,e,n),Math.max(t,e,n)]}}class _ extends n.GlyphView{_index_data(){const t=[];for(let i=0,e=this._x0.length;i<e;i++){if(isNaN(this._x0[i]+this._x1[i]+this._y0[i]+this._y1[i]+this._cx[i]+this._cy[i]))continue;const[e,s]=a(this._x0[i],this._cx[i],this._x1[i]),[n,r]=a(this._y0[i],this._cy[i],this._y1[i]);t.push({x0:e,y0:n,x1:s,y1:r,i:i})}return new s.SpatialIndex(t)}_render(t,i,{sx0:e,sy0:s,sx1:n,sy1:r,scx:a,scy:_}){if(this.visuals.line.doit)for(const c of i)isNaN(e[c]+s[c]+n[c]+r[c]+a[c]+_[c])||(t.beginPath(),t.moveTo(e[c],s[c]),t.quadraticCurveTo(a[c],_[c],n[c],r[c]),this.visuals.line.set_vectorize(t,c),t.stroke())}draw_legend_for_index(t,i,e){r.generic_line_legend(this.visuals,t,i,e)}scenterx(){throw new Error(\"not implemented\")}scentery(){throw new Error(\"not implemented\")}}e.QuadraticView=_,_.__name__=\"QuadraticView\";class c extends n.Glyph{constructor(t){super(t)}static init_Quadratic(){this.prototype.default_view=_,this.coords([[\"x0\",\"y0\"],[\"x1\",\"y1\"],[\"cx\",\"cy\"]]),this.mixins([\"line\"])}}e.Quadratic=c,c.__name__=\"Quadratic\",c.init_Quadratic()},\n",
       "      function _(e,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const s=e(1),n=e(81),a=e(90),l=s.__importStar(e(19));class r extends n.XYGlyphView{_map_data(){\"data\"==this.model.properties.length.units?this.slength=this.sdist(this.renderer.xscale,this._x,this._length):this.slength=this._length}_render(e,t,{sx:i,sy:s,slength:n,_angle:a}){if(this.visuals.line.doit){const l=2*(this.renderer.plot_view.frame._width.value+this.renderer.plot_view.frame._height.value);for(let e=0,t=n.length;e<t;e++)0==n[e]&&(n[e]=l);for(const l of t)isNaN(i[l]+s[l]+a[l]+n[l])||(e.translate(i[l],s[l]),e.rotate(a[l]),e.beginPath(),e.moveTo(0,0),e.lineTo(n[l],0),this.visuals.line.set_vectorize(e,l),e.stroke(),e.rotate(-a[l]),e.translate(-i[l],-s[l]))}}draw_legend_for_index(e,t,i){a.generic_line_legend(this.visuals,e,t,i)}}i.RayView=r,r.__name__=\"RayView\";class _ extends n.XYGlyph{constructor(e){super(e)}static init_Ray(){this.prototype.default_view=r,this.mixins([\"line\"]),this.define({length:[l.DistanceSpec],angle:[l.AngleSpec]})}}i.Ray=_,_.__name__=\"Ray\",_.init_Ray()},\n",
       "      function _(t,s,e){Object.defineProperty(e,\"__esModule\",{value:!0});const i=t(1),h=t(213),a=t(90),r=i.__importStar(t(87)),n=i.__importStar(t(19)),_=t(12);class o extends h.CenterRotatableView{_set_data(){this.max_w2=0,\"data\"==this.model.properties.width.units&&(this.max_w2=this.max_width/2),this.max_h2=0,\"data\"==this.model.properties.height.units&&(this.max_h2=this.max_height/2)}_map_data(){if(\"data\"==this.model.properties.width.units)[this.sw,this.sx0]=this._map_dist_corner_for_data_side_length(this._x,this._width,this.renderer.xscale);else{this.sw=this._width;const t=this.sx.length;this.sx0=new Float64Array(t);for(let s=0;s<t;s++)this.sx0[s]=this.sx[s]-this.sw[s]/2}if(\"data\"==this.model.properties.height.units)[this.sh,this.sy1]=this._map_dist_corner_for_data_side_length(this._y,this._height,this.renderer.yscale);else{this.sh=this._height;const t=this.sy.length;this.sy1=new Float64Array(t);for(let s=0;s<t;s++)this.sy1[s]=this.sy[s]-this.sh[s]/2}const t=this.sw.length;this.ssemi_diag=new Float64Array(t);for(let s=0;s<t;s++)this.ssemi_diag[s]=Math.sqrt(this.sw[s]/2*this.sw[s]/2+this.sh[s]/2*this.sh[s]/2)}_render(t,s,{sx:e,sy:i,sx0:h,sy1:a,sw:r,sh:n,_angle:_}){if(this.visuals.fill.doit)for(const o of s)isNaN(e[o]+i[o]+h[o]+a[o]+r[o]+n[o]+_[o])||(this.visuals.fill.set_vectorize(t,o),_[o]?(t.translate(e[o],i[o]),t.rotate(_[o]),t.fillRect(-r[o]/2,-n[o]/2,r[o],n[o]),t.rotate(-_[o]),t.translate(-e[o],-i[o])):t.fillRect(h[o],a[o],r[o],n[o]));if(this.visuals.line.doit){t.beginPath();for(const o of s)isNaN(e[o]+i[o]+h[o]+a[o]+r[o]+n[o]+_[o])||0!=r[o]&&0!=n[o]&&(_[o]?(t.translate(e[o],i[o]),t.rotate(_[o]),t.rect(-r[o]/2,-n[o]/2,r[o],n[o]),t.rotate(-_[o]),t.translate(-e[o],-i[o])):t.rect(h[o],a[o],r[o],n[o]),this.visuals.line.set_vectorize(t,o),t.stroke(),t.beginPath());t.stroke()}}_hit_rect(t){return this._hit_rect_against_index(t)}_hit_point(t){let{sx:s,sy:e}=t;const i=this.renderer.xscale.invert(s),h=this.renderer.yscale.invert(e),a=[];for(let t=0,s=this.sx0.length;t<s;t++)a.push(this.sx0[t]+this.sw[t]/2);const n=[];for(let t=0,s=this.sy1.length;t<s;t++)n.push(this.sy1[t]+this.sh[t]/2);const o=_.max(this._ddist(0,a,this.ssemi_diag)),l=_.max(this._ddist(1,n,this.ssemi_diag)),d=i-o,c=i+o,x=h-l,y=h+l,m=[];for(const t of this.index.indices({x0:d,x1:c,y0:x,y1:y})){let i,h;if(this._angle[t]){const a=Math.sin(-this._angle[t]),r=Math.cos(-this._angle[t]),n=r*(s-this.sx[t])-a*(e-this.sy[t])+this.sx[t],_=a*(s-this.sx[t])+r*(e-this.sy[t])+this.sy[t];s=n,e=_,h=Math.abs(this.sx[t]-s)<=this.sw[t]/2,i=Math.abs(this.sy[t]-e)<=this.sh[t]/2}else h=s-this.sx0[t]<=this.sw[t]&&s-this.sx0[t]>=0,i=e-this.sy1[t]<=this.sh[t]&&e-this.sy1[t]>=0;i&&h&&m.push(t)}const f=r.create_empty_hit_test_result();return f.indices=m,f}_map_dist_corner_for_data_side_length(t,s,e){const i=t.length,h=new Float64Array(i),a=new Float64Array(i);for(let e=0;e<i;e++)h[e]=Number(t[e])-s[e]/2,a[e]=Number(t[e])+s[e]/2;const r=e.v_compute(h),n=e.v_compute(a),_=this.sdist(e,h,s,\"edge\",this.model.dilate);let o=r;for(let t=0,s=r.length;t<s;t++)if(r[t]!=n[t]){o=r[t]<n[t]?r:n;break}return[_,o]}_ddist(t,s,e){const i=0==t?this.renderer.xscale:this.renderer.yscale,h=s,a=h.length,r=new Float64Array(a);for(let t=0;t<a;t++)r[t]=h[t]+e[t];const n=i.v_invert(h),_=i.v_invert(r),o=n.length,l=new Float64Array(o);for(let t=0;t<o;t++)l[t]=Math.abs(_[t]-n[t]);return l}draw_legend_for_index(t,s,e){a.generic_area_legend(this.visuals,t,s,e)}_bounds({x0:t,x1:s,y0:e,y1:i}){return{x0:t-this.max_w2,x1:s+this.max_w2,y0:e-this.max_h2,y1:i+this.max_h2}}}e.RectView=o,o.__name__=\"RectView\";class l extends h.CenterRotatable{constructor(t){super(t)}static init_Rect(){this.prototype.default_view=o,this.define({dilate:[n.Boolean,!1]})}}e.Rect=l,l.__name__=\"Rect\",l.init_Rect()},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=e(1).__importStar(e(87)),n=e(82),r=e(86),h=e(90);class _ extends r.GlyphView{_index_data(){const e=[];for(let t=0,s=this._x0.length;t<s;t++){const s=this._x0[t],i=this._x1[t],n=this._y0[t],r=this._y1[t];isNaN(s+i+n+r)||e.push({x0:Math.min(s,i),y0:Math.min(n,r),x1:Math.max(s,i),y1:Math.max(n,r),i:t})}return new n.SpatialIndex(e)}_render(e,t,{sx0:s,sy0:i,sx1:n,sy1:r}){if(this.visuals.line.doit)for(const h of t)isNaN(s[h]+i[h]+n[h]+r[h])||(e.beginPath(),e.moveTo(s[h],i[h]),e.lineTo(n[h],r[h]),this.visuals.line.set_vectorize(e,h),e.stroke())}_hit_point(e){const{sx:t,sy:s}=e,n={x:t,y:s},r=[],[h,_]=this.renderer.xscale.r_invert(t-2,t+2),[a,c]=this.renderer.yscale.r_invert(s-2,s+2),o=this.index.indices({x0:h,y0:a,x1:_,y1:c});for(const e of o){const t=Math.pow(Math.max(2,this.visuals.line.cache_select(\"line_width\",e)/2),2),s={x:this.sx0[e],y:this.sy0[e]},h={x:this.sx1[e],y:this.sy1[e]};i.dist_to_segment_squared(n,s,h)<t&&r.push(e)}const x=i.create_empty_hit_test_result();return x.indices=r,x}_hit_span(e){const[t,s]=this.renderer.plot_view.frame.bbox.ranges,{sx:n,sy:r}=e;let h,_,a;\"v\"==e.direction?(a=this.renderer.yscale.invert(r),[h,_]=[this._y0,this._y1]):(a=this.renderer.xscale.invert(n),[h,_]=[this._x0,this._x1]);const c=[],[o,x]=this.renderer.xscale.r_invert(t.start,t.end),[l,d]=this.renderer.yscale.r_invert(s.start,s.end),y=this.index.indices({x0:o,y0:l,x1:x,y1:d});for(const t of y){(h[t]<=a&&a<=_[t]||_[t]<=a&&a<=h[t])&&c.push(t);const s=1.5+this.visuals.line.cache_select(\"line_width\",t)/2;h[t]==_[t]&&(\"h\"==e.direction?Math.abs(this.sx0[t]-n)<=s&&c.push(t):Math.abs(this.sy0[t]-r)<=s&&c.push(t))}const u=i.create_empty_hit_test_result();return u.indices=c,u}scenterx(e){return(this.sx0[e]+this.sx1[e])/2}scentery(e){return(this.sy0[e]+this.sy1[e])/2}draw_legend_for_index(e,t,s){h.generic_line_legend(this.visuals,e,t,s)}}s.SegmentView=_,_.__name__=\"SegmentView\";class a extends r.Glyph{constructor(e){super(e)}static init_Segment(){this.prototype.default_view=_,this.coords([[\"x0\",\"y0\"],[\"x1\",\"y1\"]]),this.mixins([\"line\"])}}s.Segment=a,a.__name__=\"Segment\",a.init_Segment()},\n",
       "      function _(e,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const n=e(1),s=e(81),o=e(90),r=n.__importStar(e(19));class l extends s.XYGlyphView{_render(e,t,{sx:i,sy:n}){let s=!1,o=null;this.visuals.line.set_value(e);const r=t.length;if(!(r<2)){e.beginPath(),e.moveTo(i[0],n[0]);for(const r of t){let t,l,a,_;switch(this.model.mode){case\"before\":[t,a]=[i[r-1],n[r]],[l,_]=[i[r],n[r]];break;case\"after\":[t,a]=[i[r],n[r-1]],[l,_]=[i[r],n[r]];break;case\"center\":{const e=(i[r-1]+i[r])/2;[t,a]=[e,n[r-1]],[l,_]=[e,n[r]];break}default:throw new Error(\"unexpected\")}if(s){if(!isFinite(i[r]+n[r])){e.stroke(),e.beginPath(),s=!1,o=r;continue}null!=o&&r-o>1&&(e.stroke(),s=!1)}s?(e.lineTo(t,a),e.lineTo(l,_)):(e.beginPath(),e.moveTo(i[r],n[r]),s=!0),o=r}e.lineTo(i[r-1],n[r-1]),e.stroke()}}draw_legend_for_index(e,t,i){o.generic_line_legend(this.visuals,e,t,i)}}i.StepView=l,l.__name__=\"StepView\";class a extends s.XYGlyph{constructor(e){super(e)}static init_Step(){this.prototype.default_view=l,this.mixins([\"line\"]),this.define({mode:[r.StepMode,\"before\"]})}}i.Step=a,a.__name__=\"Step\",a.init_Step()},\n",
       "      function _(t,s,e){Object.defineProperty(e,\"__esModule\",{value:!0});const i=t(1),_=t(81),n=i.__importStar(t(87)),o=i.__importStar(t(19)),h=t(131);class r extends _.XYGlyphView{_rotate_point(t,s,e,i,_){return[(t-e)*Math.cos(_)-(s-i)*Math.sin(_)+e,(t-e)*Math.sin(_)+(s-i)*Math.cos(_)+i]}_text_bounds(t,s,e,i){return[[t,t+e,t+e,t,t],[s,s,s-i,s-i,s]]}_render(t,s,{sx:e,sy:i,_x_offset:_,_y_offset:n,_angle:o,_text:r}){this._sys=[],this._sxs=[];for(const l of s)if(!isNaN(e[l]+i[l]+_[l]+n[l]+o[l])&&null!=r[l]&&(this._sxs[l]=[],this._sys[l]=[],this.visuals.text.doit)){const s=`${r[l]}`;t.save(),t.translate(e[l]+_[l],i[l]+n[l]),t.rotate(o[l]),this.visuals.text.set_vectorize(t,l);const a=this.visuals.text.cache_select(\"font\",l),{height:x}=h.measure_font(a),c=this.visuals.text.text_line_height.value()*x;if(-1==s.indexOf(\"\\n\")){t.fillText(s,0,0);const o=e[l]+_[l],h=i[l]+n[l],r=t.measureText(s).width,[a,x]=this._text_bounds(o,h,r,c);this._sxs[l].push(a),this._sys[l].push(x)}else{const o=s.split(\"\\n\"),h=c*o.length,r=this.visuals.text.cache_select(\"text_baseline\",l);let a;switch(r){case\"top\":a=0;break;case\"middle\":a=-h/2+c/2;break;case\"bottom\":a=-h+c;break;default:a=0,console.warn(`'${r}' baseline not supported with multi line text`)}for(const s of o){t.fillText(s,0,a);const o=e[l]+_[l],h=a+i[l]+n[l],r=t.measureText(s).width,[x,u]=this._text_bounds(o,h,r,c);this._sxs[l].push(x),this._sys[l].push(u),a+=c}}t.restore()}}_hit_point(t){const{sx:s,sy:e}=t,i=[];for(let t=0;t<this._sxs.length;t++){const _=this._sxs[t],o=this._sys[t],h=_.length;for(let r=0,l=h;r<l;r++){const[l,a]=this._rotate_point(s,e,_[h-1][0],o[h-1][0],-this._angle[t]);n.point_in_poly(l,a,_[r],o[r])&&i.push(t)}}const _=n.create_empty_hit_test_result();return _.indices=i,_}_scenterxy(t){const s=this._sxs[t][0][0],e=this._sys[t][0][0],i=(this._sxs[t][0][2]+s)/2,_=(this._sys[t][0][2]+e)/2,[n,o]=this._rotate_point(i,_,s,e,this._angle[t]);return{x:n,y:o}}scenterx(t){return this._scenterxy(t).x}scentery(t){return this._scenterxy(t).y}}e.TextView=r,r.__name__=\"TextView\";class l extends _.XYGlyph{constructor(t){super(t)}static init_Text(){this.prototype.default_view=r,this.mixins([\"text\"]),this.define({text:[o.NullStringSpec,{field:\"text\"}],angle:[o.AngleSpec,0],x_offset:[o.NumberSpec,0],y_offset:[o.NumberSpec,0]})}}e.Text=l,l.__name__=\"Text\",l.init_Text()},\n",
       "      function _(t,s,e){Object.defineProperty(e,\"__esModule\",{value:!0});const i=t(1),h=t(217),r=i.__importStar(t(19));class o extends h.BoxView{scenterx(t){return this.sx[t]}scentery(t){return(this.stop[t]+this.sbottom[t])/2}_index_data(){return this._index_box(this._x.length)}_lrtb(t){return[this._x[t]-this._width[t]/2,this._x[t]+this._width[t]/2,Math.max(this._top[t],this._bottom[t]),Math.min(this._top[t],this._bottom[t])]}_map_data(){this.sx=this.renderer.xscale.v_compute(this._x),this.sw=this.sdist(this.renderer.xscale,this._x,this._width,\"center\"),this.stop=this.renderer.yscale.v_compute(this._top),this.sbottom=this.renderer.yscale.v_compute(this._bottom);const t=this.sx.length;this.sleft=new Float64Array(t),this.sright=new Float64Array(t);for(let s=0;s<t;s++)this.sleft[s]=this.sx[s]-this.sw[s]/2,this.sright[s]=this.sx[s]+this.sw[s]/2;this._clamp_viewport()}}e.VBarView=o,o.__name__=\"VBarView\";class _ extends h.Box{constructor(t){super(t)}static init_VBar(){this.prototype.default_view=o,this.coords([[\"x\",\"bottom\"]]),this.define({width:[r.NumberSpec],top:[r.CoordinateSpec]}),this.override({bottom:0})}}e.VBar=_,_.__name__=\"VBar\",_.init_VBar()},\n",
       "      function _(e,s,t){Object.defineProperty(t,\"__esModule\",{value:!0});const i=e(1),r=e(81),n=e(90),a=i.__importStar(e(87)),_=i.__importStar(e(19)),h=e(10);class o extends r.XYGlyphView{_map_data(){\"data\"==this.model.properties.radius.units?this.sradius=this.sdist(this.renderer.xscale,this._x,this._radius):this.sradius=this._radius}_render(e,s,{sx:t,sy:i,sradius:r,_start_angle:n,_end_angle:a}){const _=this.model.properties.direction.value();for(const h of s)isNaN(t[h]+i[h]+r[h]+n[h]+a[h])||(e.beginPath(),e.arc(t[h],i[h],r[h],n[h],a[h],_),e.lineTo(t[h],i[h]),e.closePath(),this.visuals.fill.doit&&(this.visuals.fill.set_vectorize(e,h),e.fill()),this.visuals.line.doit&&(this.visuals.line.set_vectorize(e,h),e.stroke()))}_hit_point(e){let s,t,i,r,n,_,o,d,l;const{sx:c,sy:u}=e,p=this.renderer.xscale.invert(c),x=this.renderer.yscale.invert(u),g=2*this.max_radius;\"data\"===this.model.properties.radius.units?(_=p-g,o=p+g,d=x-g,l=x+g):(t=c-g,i=c+g,[_,o]=this.renderer.xscale.r_invert(t,i),r=u-g,n=u+g,[d,l]=this.renderer.yscale.r_invert(r,n));const y=[];for(const e of this.index.indices({x0:_,x1:o,y0:d,y1:l})){const a=Math.pow(this.sradius[e],2);[t,i]=this.renderer.xscale.r_compute(p,this._x[e]),[r,n]=this.renderer.yscale.r_compute(x,this._y[e]),s=Math.pow(t-i,2)+Math.pow(r-n,2),s<=a&&y.push([e,s])}const f=this.model.properties.direction.value(),v=[];for(const[e,s]of y){const t=Math.atan2(u-this.sy[e],c-this.sx[e]);h.angle_between(-t,-this._start_angle[e],-this._end_angle[e],f)&&v.push([e,s])}return a.create_hit_test_result_from_hits(v)}draw_legend_for_index(e,s,t){n.generic_area_legend(this.visuals,e,s,t)}_scenterxy(e){const s=this.sradius[e]/2,t=(this._start_angle[e]+this._end_angle[e])/2;return{x:this.sx[e]+s*Math.cos(t),y:this.sy[e]+s*Math.sin(t)}}scenterx(e){return this._scenterxy(e).x}scentery(e){return this._scenterxy(e).y}}t.WedgeView=o,o.__name__=\"WedgeView\";class d extends r.XYGlyph{constructor(e){super(e)}static init_Wedge(){this.prototype.default_view=o,this.mixins([\"line\",\"fill\"]),this.define({direction:[_.Direction,\"anticlock\"],radius:[_.DistanceSpec],start_angle:[_.AngleSpec],end_angle:[_.AngleSpec]})}}t.Wedge=d,d.__name__=\"Wedge\",d.init_Wedge()},\n",
       "      function _(e,t,_){Object.defineProperty(_,\"__esModule\",{value:!0});const r=e(1);r.__exportStar(e(98),_),r.__exportStar(e(238),_),r.__exportStar(e(239),_)},\n",
       "      function _(e,o,r){Object.defineProperty(r,\"__esModule\",{value:!0});const t=e(69);class n extends t.Model{constructor(e){super(e)}}r.LayoutProvider=n,n.__name__=\"LayoutProvider\"},\n",
       "      function _(t,a,e){Object.defineProperty(e,\"__esModule\",{value:!0});const o=t(1),r=t(238),s=o.__importStar(t(19));class n extends r.LayoutProvider{constructor(t){super(t)}static init_StaticLayoutProvider(){this.define({graph_layout:[s.Any,{}]})}get_node_coordinates(t){const a=[],e=[],o=t.data.index;for(let t=0,r=o.length;t<r;t++){const r=this.graph_layout[o[t]],[s,n]=null!=r?r:[NaN,NaN];a.push(s),e.push(n)}return[a,e]}get_edge_coordinates(t){const a=[],e=[],o=t.data.start,r=t.data.end,s=null!=t.data.xs&&null!=t.data.ys;for(let n=0,u=o.length;n<u;n++){const u=null!=this.graph_layout[o[n]]&&null!=this.graph_layout[r[n]];if(s&&u)a.push(t.data.xs[n]),e.push(t.data.ys[n]);else{let t,s;[s,t]=u?[this.graph_layout[o[n]],this.graph_layout[r[n]]]:[[NaN,NaN],[NaN,NaN]],a.push([s[0],t[0]]),e.push([s[1],t[1]])}}return[a,e]}}e.StaticLayoutProvider=n,n.__name__=\"StaticLayoutProvider\",n.init_StaticLayoutProvider()},\n",
       "      function _(e,r,d){Object.defineProperty(d,\"__esModule\",{value:!0});var i=e(241);d.Grid=i.Grid},\n",
       "      function _(e,i,t){Object.defineProperty(t,\"__esModule\",{value:!0});const n=e(1),s=e(149),r=n.__importStar(e(19)),_=e(8);class o extends s.GuideRendererView{render(){if(!this.model.visible)return;const e=this.plot_view.canvas_view.ctx;e.save(),this._draw_regions(e),this._draw_minor_grids(e),this._draw_grids(e),e.restore()}connect_signals(){super.connect_signals(),this.connect(this.model.change,()=>this.request_render())}_draw_regions(e){if(!this.visuals.band_fill.doit&&!this.visuals.band_hatch.doit)return;this.visuals.band_fill.set_value(e);const[i,t]=this.grid_coords(\"major\",!1);for(let n=0;n<i.length-1;n++){if(n%2!=1)continue;const[s,r]=this.plot_view.map_to_screen(i[n],t[n],this.model.x_range_name,this.model.y_range_name),[_,o]=this.plot_view.map_to_screen(i[n+1],t[n+1],this.model.x_range_name,this.model.y_range_name);this.visuals.band_fill.doit&&e.fillRect(s[0],r[0],_[1]-s[0],o[1]-r[0]),this.visuals.band_hatch.doit2(e,n,()=>{e.fillRect(s[0],r[0],_[1]-s[0],o[1]-r[0])},()=>this.request_render())}}_draw_grids(e){if(!this.visuals.grid_line.doit)return;const[i,t]=this.grid_coords(\"major\");this._draw_grid_helper(e,this.visuals.grid_line,i,t)}_draw_minor_grids(e){if(!this.visuals.minor_grid_line.doit)return;const[i,t]=this.grid_coords(\"minor\");this._draw_grid_helper(e,this.visuals.minor_grid_line,i,t)}_draw_grid_helper(e,i,t,n){i.set_value(e);for(let i=0;i<t.length;i++){const[s,r]=this.plot_view.map_to_screen(t[i],n[i],this.model.x_range_name,this.model.y_range_name);e.beginPath(),e.moveTo(Math.round(s[0]),Math.round(r[0]));for(let i=1;i<s.length;i++)e.lineTo(Math.round(s[i]),Math.round(r[i]));e.stroke()}}ranges(){const e=this.model.dimension,i=(e+1)%2,t=this.plot_view.frame,n=[t.x_ranges[this.model.x_range_name],t.y_ranges[this.model.y_range_name]];return[n[e],n[i]]}computed_bounds(){const[e]=this.ranges(),i=this.model.bounds,t=[e.min,e.max];let n,s;if(_.isArray(i))n=Math.min(i[0],i[1]),s=Math.max(i[0],i[1]),n<t[0]&&(n=t[0]),s>t[1]&&(s=t[1]);else{[n,s]=t;for(const e of this.plot_view.axis_views)e.dimension==this.model.dimension&&e.model.x_range_name==this.model.x_range_name&&e.model.y_range_name==this.model.y_range_name&&([n,s]=e.computed_bounds)}return[n,s]}grid_coords(e,i=!0){const t=this.model.dimension,n=(t+1)%2,[s,r]=this.ranges();let[_,o]=this.computed_bounds();[_,o]=[Math.min(_,o),Math.max(_,o)];const a=[[],[]],l=this.model.get_ticker();if(null==l)return a;const d=l.get_ticks(_,o,s,r.min,{})[e],h=s.min,m=s.max,c=r.min,u=r.max;i||(d[0]!=h&&d.splice(0,0,h),d[d.length-1]!=m&&d.push(m));for(let e=0;e<d.length;e++){if((d[e]==h||d[e]==m)&&i)continue;const s=[],r=[],_=2;for(let i=0;i<_;i++){const t=c+(u-c)/(_-1)*i;s.push(d[e]),r.push(t)}a[t].push(s),a[n].push(r)}return a}}t.GridView=o,o.__name__=\"GridView\";class a extends s.GuideRenderer{constructor(e){super(e)}static init_Grid(){this.prototype.default_view=o,this.mixins([\"line:grid_\",\"line:minor_grid_\",\"fill:band_\",\"hatch:band_\"]),this.define({bounds:[r.Any,\"auto\"],dimension:[r.Any,0],axis:[r.Instance],ticker:[r.Instance],x_range_name:[r.String,\"default\"],y_range_name:[r.String,\"default\"]}),this.override({level:\"underlay\",band_fill_color:null,band_fill_alpha:0,grid_line_color:\"#e5e5e5\",minor_grid_line_color:null})}get_ticker(){return null!=this.ticker?this.ticker:null!=this.axis?this.axis.ticker:null}}t.Grid=a,a.__name__=\"Grid\",a.init_Grid()},\n",
       "      function _(a,o,r){Object.defineProperty(r,\"__esModule\",{value:!0});var e=a(243);r.Box=e.Box;var v=a(245);r.Column=v.Column;var x=a(246);r.GridBox=x.GridBox;var B=a(247);r.HTMLBox=B.HTMLBox;var n=a(244);r.LayoutDOM=n.LayoutDOM;var t=a(248);r.Row=t.Row;var u=a(249);r.Spacer=u.Spacer;var d=a(250);r.Panel=d.Panel,r.Tabs=d.Tabs;var i=a(254);r.WidgetBox=i.WidgetBox},\n",
       "      function _(e,t,i){Object.defineProperty(i,\"__esModule\",{value:!0});const n=e(1),s=e(244),o=n.__importStar(e(19));class c extends s.LayoutDOMView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.children.change,()=>this.rebuild())}get child_models(){return this.model.children}}i.BoxView=c,c.__name__=\"BoxView\";class r extends s.LayoutDOM{constructor(e){super(e)}static init_Box(){this.define({children:[o.Array,[]],spacing:[o.Number,0]})}}i.Box=r,r.__name__=\"Box\",r.init_Box()},\n",
       "      function _(i,t,e){Object.defineProperty(e,\"__esModule\",{value:!0});const s=i(1),o=i(69),l=i(66),n=i(70),h=i(8),a=s.__importStar(i(19)),_=i(96),r=i(64),d=i(67);class u extends r.DOMView{constructor(){super(...arguments),this._idle_notified=!1,this._offset_parent=null,this._viewport={}}initialize(){super.initialize(),this.el.style.position=this.is_root?\"relative\":\"absolute\",this._child_views={}}async lazy_initialize(){await this.build_child_views()}remove(){for(const i of this.child_views)i.remove();this._child_views={},super.remove()}connect_signals(){super.connect_signals(),this.is_root&&(this._on_resize=()=>this.resize_layout(),window.addEventListener(\"resize\",this._on_resize),this._parent_observer=setInterval(()=>{const i=this.el.offsetParent;this._offset_parent!=i&&(this._offset_parent=i,null!=i&&(this.compute_viewport(),this.invalidate_layout()))},250));const i=this.model.properties;this.on_change([i.width,i.height,i.min_width,i.min_height,i.max_width,i.max_height,i.margin,i.width_policy,i.height_policy,i.sizing_mode,i.aspect_ratio,i.visible],()=>this.invalidate_layout()),this.on_change([i.background,i.css_classes],()=>this.invalidate_render())}disconnect_signals(){null!=this._parent_observer&&clearTimeout(this._parent_observer),null!=this._on_resize&&window.removeEventListener(\"resize\",this._on_resize),super.disconnect_signals()}css_classes(){return super.css_classes().concat(this.model.css_classes)}get child_views(){return this.child_models.map(i=>this._child_views[i.id])}async build_child_views(){await _.build_views(this._child_views,this.child_models,{parent:this})}render(){super.render(),l.empty(this.el);const{background:i}=this.model;this.el.style.backgroundColor=null!=i?i:\"\",l.classes(this.el).clear().add(...this.css_classes());for(const i of this.child_views)this.el.appendChild(i.el),i.render()}update_layout(){for(const i of this.child_views)i.update_layout();this._update_layout()}update_position(){this.el.style.display=this.model.visible?\"block\":\"none\";const i=this.is_root?this.layout.sizing.margin:void 0;l.position(this.el,this.layout.bbox,i);for(const i of this.child_views)i.update_position()}after_layout(){for(const i of this.child_views)i.after_layout();this._has_finished=!0}compute_viewport(){this._viewport=this._viewport_size()}renderTo(i){i.appendChild(this.el),this._offset_parent=this.el.offsetParent,this.compute_viewport(),this.build()}build(){return this.assert_root(),this.render(),this.update_layout(),this.compute_layout(),this}async rebuild(){await this.build_child_views(),this.invalidate_render()}compute_layout(){const i=Date.now();this.layout.compute(this._viewport),this.update_position(),this.after_layout(),n.logger.debug(`layout computed in ${Date.now()-i} ms`),this.notify_finished()}resize_layout(){this.root.compute_viewport(),this.root.compute_layout()}invalidate_layout(){this.root.update_layout(),this.root.compute_layout()}invalidate_render(){this.render(),this.invalidate_layout()}has_finished(){if(!super.has_finished())return!1;for(const i of this.child_views)if(!i.has_finished())return!1;return!0}notify_finished(){this.is_root?!this._idle_notified&&this.has_finished()&&null!=this.model.document&&(this._idle_notified=!0,this.model.document.notify_idle(this.model)):this.root.notify_finished()}_width_policy(){return null!=this.model.width?\"fixed\":\"fit\"}_height_policy(){return null!=this.model.height?\"fixed\":\"fit\"}box_sizing(){let{width_policy:i,height_policy:t,aspect_ratio:e}=this.model;\"auto\"==i&&(i=this._width_policy()),\"auto\"==t&&(t=this._height_policy());const{sizing_mode:s}=this.model;if(null!=s)if(\"fixed\"==s)i=t=\"fixed\";else if(\"stretch_both\"==s)i=t=\"max\";else if(\"stretch_width\"==s)i=\"max\";else if(\"stretch_height\"==s)t=\"max\";else switch(null==e&&(e=\"auto\"),s){case\"scale_width\":i=\"max\",t=\"min\";break;case\"scale_height\":i=\"min\",t=\"max\";break;case\"scale_both\":i=\"max\",t=\"max\"}const o={width_policy:i,height_policy:t},{min_width:l,min_height:n}=this.model;null!=l&&(o.min_width=l),null!=n&&(o.min_height=n);const{width:a,height:_}=this.model;null!=a&&(o.width=a),null!=_&&(o.height=_);const{max_width:r,max_height:d}=this.model;null!=r&&(o.max_width=r),null!=d&&(o.max_height=d),\"auto\"==e&&null!=a&&null!=_?o.aspect=a/_:h.isNumber(e)&&(o.aspect=e);const{margin:u}=this.model;if(null!=u)if(h.isNumber(u))o.margin={top:u,right:u,bottom:u,left:u};else if(2==u.length){const[i,t]=u;o.margin={top:i,right:t,bottom:i,left:t}}else{const[i,t,e,s]=u;o.margin={top:i,right:t,bottom:e,left:s}}o.visible=this.model.visible;const{align:c}=this.model;return h.isArray(c)?[o.halign,o.valign]=c:o.halign=o.valign=c,o}_viewport_size(){return l.undisplayed(this.el,()=>{let i=this.el;for(;i=i.parentElement;){if(i.classList.contains(d.bk_root))continue;if(i==document.body){const{margin:{left:i,right:t,top:e,bottom:s}}=l.extents(document.body);return{width:Math.ceil(document.documentElement.clientWidth-i-t),height:Math.ceil(document.documentElement.clientHeight-e-s)}}const{padding:{left:t,right:e,top:s,bottom:o}}=l.extents(i),{width:n,height:h}=i.getBoundingClientRect(),a=Math.ceil(n-t-e),_=Math.ceil(h-s-o);if(a>0||_>0)return{width:a>0?a:void 0,height:_>0?_:void 0}}return{}})}serializable_state(){return Object.assign(Object.assign({},super.serializable_state()),{bbox:this.layout.bbox.box,children:this.child_views.map(i=>i.serializable_state())})}}e.LayoutDOMView=u,u.__name__=\"LayoutDOMView\";class c extends o.Model{constructor(i){super(i)}static init_LayoutDOM(){this.define({width:[a.Number,null],height:[a.Number,null],min_width:[a.Number,null],min_height:[a.Number,null],max_width:[a.Number,null],max_height:[a.Number,null],margin:[a.Any,[0,0,0,0]],width_policy:[a.Any,\"auto\"],height_policy:[a.Any,\"auto\"],aspect_ratio:[a.Any,null],sizing_mode:[a.SizingMode,null],visible:[a.Boolean,!0],disabled:[a.Boolean,!1],align:[a.Any,\"start\"],background:[a.Color,null],css_classes:[a.Array,[]]})}}e.LayoutDOM=c,c.__name__=\"LayoutDOM\",c.init_LayoutDOM()},\n",
       "      function _(t,o,i){Object.defineProperty(i,\"__esModule\",{value:!0});const s=t(1),e=t(243),n=t(191),l=s.__importStar(t(19));class u extends e.BoxView{_update_layout(){const t=this.child_views.map(t=>t.layout);this.layout=new n.Column(t),this.layout.rows=this.model.rows,this.layout.spacing=[this.model.spacing,0],this.layout.set_sizing(this.box_sizing())}}i.ColumnView=u,u.__name__=\"ColumnView\";class _ extends e.Box{constructor(t){super(t)}static init_Column(){this.prototype.default_view=u,this.define({rows:[l.Any,\"auto\"]})}}i.Column=_,_.__name__=\"Column\",_.init_Column()},\n",
       "      function _(t,i,s){Object.defineProperty(s,\"__esModule\",{value:!0});const o=t(1),e=t(244),n=t(191),l=o.__importStar(t(19));class r extends e.LayoutDOMView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.children.change,()=>this.rebuild())}get child_models(){return this.model.children.map(([t])=>t)}_update_layout(){this.layout=new n.Grid,this.layout.rows=this.model.rows,this.layout.cols=this.model.cols,this.layout.spacing=this.model.spacing;for(const[t,i,s,o,e]of this.model.children){const n=this._child_views[t.id];this.layout.items.push({layout:n.layout,row:i,col:s,row_span:o,col_span:e})}this.layout.set_sizing(this.box_sizing())}}s.GridBoxView=r,r.__name__=\"GridBoxView\";class a extends e.LayoutDOM{constructor(t){super(t)}static init_GridBox(){this.prototype.default_view=r,this.define({children:[l.Array,[]],rows:[l.Any,\"auto\"],cols:[l.Any,\"auto\"],spacing:[l.Any,0]})}}s.GridBox=a,a.__name__=\"GridBox\",a.init_GridBox()},\n",
       "      function _(e,t,o){Object.defineProperty(o,\"__esModule\",{value:!0});const s=e(244),_=e(187);class n extends s.LayoutDOMView{get child_models(){return[]}_update_layout(){this.layout=new _.ContentBox(this.el),this.layout.set_sizing(this.box_sizing())}}o.HTMLBoxView=n,n.__name__=\"HTMLBoxView\";class i extends s.LayoutDOM{constructor(e){super(e)}}o.HTMLBox=i,i.__name__=\"HTMLBox\"},\n",
       "      function _(t,o,i){Object.defineProperty(i,\"__esModule\",{value:!0});const s=t(1),e=t(243),_=t(191),a=s.__importStar(t(19));class n extends e.BoxView{_update_layout(){const t=this.child_views.map(t=>t.layout);this.layout=new _.Row(t),this.layout.cols=this.model.cols,this.layout.spacing=[0,this.model.spacing],this.layout.set_sizing(this.box_sizing())}}i.RowView=n,n.__name__=\"RowView\";class l extends e.Box{constructor(t){super(t)}static init_Row(){this.prototype.default_view=n,this.define({cols:[a.Any,\"auto\"]})}}i.Row=l,l.__name__=\"Row\",l.init_Row()},\n",
       "      function _(e,t,a){Object.defineProperty(a,\"__esModule\",{value:!0});const i=e(244),s=e(187);class _ extends i.LayoutDOMView{get child_models(){return[]}_update_layout(){this.layout=new s.LayoutItem,this.layout.set_sizing(this.box_sizing())}}a.SpacerView=_,_.__name__=\"SpacerView\";class o extends i.LayoutDOM{constructor(e){super(e)}static init_Spacer(){this.prototype.default_view=_}}a.Spacer=o,o.__name__=\"Spacer\",o.init_Spacer()},\n",
       "      function _(e,t,s){Object.defineProperty(s,\"__esModule\",{value:!0});const i=e(1),a=e(187),l=e(66),h=e(9),o=i.__importStar(e(19)),c=e(244),d=e(69),n=e(145),r=e(251),_=e(252),b=e(253);class p extends c.LayoutDOMView{connect_signals(){super.connect_signals(),this.connect(this.model.properties.tabs.change,()=>this.rebuild()),this.connect(this.model.properties.active.change,()=>this.on_active_change())}get child_models(){return this.model.tabs.map(e=>e.child)}_update_layout(){const e=this.model.tabs_location,t=\"above\"==e||\"below\"==e,{scroll_el:s,headers_el:i}=this;this.header=new class extends a.ContentBox{_measure(e){const a=l.size(s),o=l.children(i).slice(0,3).map(e=>l.size(e)),{width:c,height:d}=super._measure(e);if(t){const t=a.width+h.sum(o.map(e=>e.width));return{width:e.width!=1/0?e.width:t,height:d}}{const t=a.height+h.sum(o.map(e=>e.height));return{width:c,height:e.height!=1/0?e.height:t}}}}(this.header_el),t?this.header.set_sizing({width_policy:\"fit\",height_policy:\"fixed\"}):this.header.set_sizing({width_policy:\"fixed\",height_policy:\"fit\"});let o=1,c=1;switch(e){case\"above\":o-=1;break;case\"below\":o+=1;break;case\"left\":c-=1;break;case\"right\":c+=1}const d={layout:this.header,row:o,col:c},n=this.child_views.map(e=>({layout:e.layout,row:1,col:1}));this.layout=new a.Grid([d,...n]),this.layout.set_sizing(this.box_sizing())}update_position(){super.update_position(),this.header_el.style.position=\"absolute\",l.position(this.header_el,this.header.bbox);const e=this.model.tabs_location,t=\"above\"==e||\"below\"==e,s=l.size(this.scroll_el),i=l.scroll_size(this.headers_el);if(t){const{width:e}=this.header.bbox;i.width>e?(this.wrapper_el.style.maxWidth=`${e-s.width}px`,l.display(this.scroll_el)):(this.wrapper_el.style.maxWidth=\"\",l.undisplay(this.scroll_el))}else{const{height:e}=this.header.bbox;i.height>e?(this.wrapper_el.style.maxHeight=`${e-s.height}px`,l.display(this.scroll_el)):(this.wrapper_el.style.maxHeight=\"\",l.undisplay(this.scroll_el))}const{child_views:a}=this;for(const e of a)l.hide(e.el);const h=a[this.model.active];null!=h&&l.show(h.el)}render(){super.render();const{active:e}=this.model,t=this.model.tabs_location,s=\"above\"==t||\"below\"==t,i=this.model.tabs.map((t,s)=>{const i=l.div({class:[r.bk_tab,s==e?n.bk_active:null]},t.title);if(i.addEventListener(\"click\",e=>{e.target==e.currentTarget&&this.change_active(s)}),t.closable){const e=l.div({class:r.bk_close});e.addEventListener(\"click\",e=>{if(e.target==e.currentTarget){this.model.tabs=h.remove_at(this.model.tabs,s);const e=this.model.tabs.length;this.model.active>e-1&&(this.model.active=e-1)}}),i.appendChild(e)}return i});this.headers_el=l.div({class:[r.bk_headers]},i),this.wrapper_el=l.div({class:r.bk_headers_wrapper},this.headers_el);const a=l.div({class:[_.bk_btn,_.bk_btn_default],disabled:\"\"},l.div({class:[b.bk_caret,n.bk_left]})),o=l.div({class:[_.bk_btn,_.bk_btn_default]},l.div({class:[b.bk_caret,n.bk_right]}));let c=0;const d=e=>()=>{const t=this.model.tabs.length;c=\"left\"==e?Math.max(c-1,0):Math.min(c+1,t-1),0==c?a.setAttribute(\"disabled\",\"\"):a.removeAttribute(\"disabled\"),c==t-1?o.setAttribute(\"disabled\",\"\"):o.removeAttribute(\"disabled\");const i=l.children(this.headers_el).slice(0,c).map(e=>e.getBoundingClientRect());if(s){const e=-h.sum(i.map(e=>e.width));this.headers_el.style.left=`${e}px`}else{const e=-h.sum(i.map(e=>e.height));this.headers_el.style.top=`${e}px`}};a.addEventListener(\"click\",d(\"left\")),o.addEventListener(\"click\",d(\"right\")),this.scroll_el=l.div({class:_.bk_btn_group},a,o),this.header_el=l.div({class:[r.bk_tabs_header,n.bk_side(t)]},this.scroll_el,this.wrapper_el),this.el.appendChild(this.header_el)}change_active(e){e!=this.model.active&&(this.model.active=e)}on_active_change(){const e=this.model.active,t=l.children(this.headers_el);for(const e of t)e.classList.remove(n.bk_active);t[e].classList.add(n.bk_active);const{child_views:s}=this;for(const e of s)l.hide(e.el);l.show(s[e].el)}}s.TabsView=p,p.__name__=\"TabsView\";class u extends c.LayoutDOM{constructor(e){super(e)}static init_Tabs(){this.prototype.default_view=p,this.define({tabs:[o.Array,[]],tabs_location:[o.Location,\"above\"],active:[o.Number,0]})}}s.Tabs=u,u.__name__=\"Tabs\",u.init_Tabs();class m extends d.Model{constructor(e){super(e)}static init_Panel(){this.define({title:[o.String,\"\"],child:[o.Instance],closable:[o.Boolean,!1]})}}s.Panel=m,m.__name__=\"Panel\",m.init_Panel()},\n",
       "      function _(e,r,n){Object.defineProperty(n,\"__esModule\",{value:!0});const b=e(1);e(67),b.__importStar(e(66)).styles.append('.bk-root .bk-tabs-header {\\n  display: flex;\\n  display: -webkit-flex;\\n  flex-wrap: nowrap;\\n  -webkit-flex-wrap: nowrap;\\n  align-items: center;\\n  -webkit-align-items: center;\\n  overflow: hidden;\\n  user-select: none;\\n  -ms-user-select: none;\\n  -moz-user-select: none;\\n  -webkit-user-select: none;\\n}\\n.bk-root .bk-tabs-header .bk-btn-group {\\n  height: auto;\\n  margin-right: 5px;\\n}\\n.bk-root .bk-tabs-header .bk-btn-group > .bk-btn {\\n  flex-grow: 0;\\n  -webkit-flex-grow: 0;\\n  height: auto;\\n  padding: 4px 4px;\\n}\\n.bk-root .bk-tabs-header .bk-headers-wrapper {\\n  flex-grow: 1;\\n  -webkit-flex-grow: 1;\\n  overflow: hidden;\\n  color: #666666;\\n}\\n.bk-root .bk-tabs-header.bk-above .bk-headers-wrapper {\\n  border-bottom: 1px solid #e6e6e6;\\n}\\n.bk-root .bk-tabs-header.bk-right .bk-headers-wrapper {\\n  border-left: 1px solid #e6e6e6;\\n}\\n.bk-root .bk-tabs-header.bk-below .bk-headers-wrapper {\\n  border-top: 1px solid #e6e6e6;\\n}\\n.bk-root .bk-tabs-header.bk-left .bk-headers-wrapper {\\n  border-right: 1px solid #e6e6e6;\\n}\\n.bk-root .bk-tabs-header.bk-above,\\n.bk-root .bk-tabs-header.bk-below {\\n  flex-direction: row;\\n  -webkit-flex-direction: row;\\n}\\n.bk-root .bk-tabs-header.bk-above .bk-headers,\\n.bk-root .bk-tabs-header.bk-below .bk-headers {\\n  flex-direction: row;\\n  -webkit-flex-direction: row;\\n}\\n.bk-root .bk-tabs-header.bk-left,\\n.bk-root .bk-tabs-header.bk-right {\\n  flex-direction: column;\\n  -webkit-flex-direction: column;\\n}\\n.bk-root .bk-tabs-header.bk-left .bk-headers,\\n.bk-root .bk-tabs-header.bk-right .bk-headers {\\n  flex-direction: column;\\n  -webkit-flex-direction: column;\\n}\\n.bk-root .bk-tabs-header .bk-headers {\\n  position: relative;\\n  display: flex;\\n  display: -webkit-flex;\\n  flex-wrap: nowrap;\\n  -webkit-flex-wrap: nowrap;\\n  align-items: center;\\n  -webkit-align-items: center;\\n}\\n.bk-root .bk-tabs-header .bk-tab {\\n  padding: 4px 8px;\\n  border: solid transparent;\\n  white-space: nowrap;\\n  cursor: pointer;\\n}\\n.bk-root .bk-tabs-header .bk-tab:hover {\\n  background-color: #f2f2f2;\\n}\\n.bk-root .bk-tabs-header .bk-tab.bk-active {\\n  color: #4d4d4d;\\n  background-color: white;\\n  border-color: #e6e6e6;\\n}\\n.bk-root .bk-tabs-header .bk-tab .bk-close {\\n  margin-left: 10px;\\n}\\n.bk-root .bk-tabs-header.bk-above .bk-tab {\\n  border-width: 3px 1px 0px 1px;\\n  border-radius: 4px 4px 0 0;\\n}\\n.bk-root .bk-tabs-header.bk-right .bk-tab {\\n  border-width: 1px 3px 1px 0px;\\n  border-radius: 0 4px 4px 0;\\n}\\n.bk-root .bk-tabs-header.bk-below .bk-tab {\\n  border-width: 0px 1px 3px 1px;\\n  border-radius: 0 0 4px 4px;\\n}\\n.bk-root .bk-tabs-header.bk-left .bk-tab {\\n  border-width: 1px 0px 1px 3px;\\n  border-radius: 4px 0 0 4px;\\n}\\n.bk-root .bk-close {\\n  display: inline-block;\\n  width: 10px;\\n  height: 10px;\\n  vertical-align: middle;\\n  background-image: url(\\'data:image/svg+xml;utf8,\\\\\\n      <svg viewPort=\"0 0 10 10\" version=\"1.1\" xmlns=\"http://www.w3.org/2000/svg\">\\\\\\n        <line x1=\"1\" y1=\"9\" x2=\"9\" y2=\"1\" stroke=\"gray\" stroke-width=\"2\"/>\\\\\\n        <line x1=\"1\" y1=\"1\" x2=\"9\" y2=\"9\" stro