@marimo-team/frontend 0.23.5-dev5 → 0.23.5-dev7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/{CellStatus-PIeZtHEl.js → CellStatus-DKMrz26-.js} +1 -1
- package/dist/assets/{ConnectedDataExplorerComponent-BPVOWDZX.js → ConnectedDataExplorerComponent-DNoHDaQW.js} +1 -1
- package/dist/assets/{DeferredRequestRegistry-DjHgMr3S.js → DeferredRequestRegistry-CUzZ0y7K.js} +1 -1
- package/dist/assets/{ImperativeModal-BBqcKmmk.js → ImperativeModal-D7lQ0Q7_.js} +1 -1
- package/dist/assets/{JsonOutput-CsshJCMI.js → JsonOutput-Bw-rSneQ.js} +7 -7
- package/dist/assets/{LazyAnyLanguageCodeMirror-0gZO1asr.js → LazyAnyLanguageCodeMirror-BF3xpDgO.js} +2 -2
- package/dist/assets/{MarimoErrorOutput-B9_RO5eX.js → MarimoErrorOutput-Dbk0HqOA.js} +2 -2
- package/dist/assets/{RSPContexts-BeHIgT4C.js → RSPContexts-CINae4Gg.js} +1 -1
- package/dist/assets/RenderHTML-8cI8zL5y.js +1 -0
- package/dist/assets/RunButton-DHxYW_jZ.js +1 -0
- package/dist/assets/{add-cell-with-ai-DjfY8mF1.js → add-cell-with-ai-DfniMbLM.js} +8 -8
- package/dist/assets/{add-connection-dialog-BY0poJft.js → add-connection-dialog-C14LN8_M.js} +6 -6
- package/dist/assets/{agent-panel-BvH5q5xP.js → agent-panel-CkK6oJn7.js} +3 -3
- package/dist/assets/{ai-model-dropdown-By4Ohb0R.js → ai-model-dropdown-BFTnsrTP.js} +4 -4
- package/dist/assets/{any-language-editor-uGTbJddl.js → any-language-editor-C9DM60EN.js} +1 -1
- package/dist/assets/{app-config-button-YS8lpoUa.js → app-config-button-c_2rVezv.js} +1 -1
- package/dist/assets/{architectureDiagram-VXUJARFQ-Bkuya2Lz.js → architectureDiagram-VXUJARFQ-JNogHSZh.js} +1 -1
- package/dist/assets/{blockDiagram-VD42YOAC-BypAXGhs.js → blockDiagram-VD42YOAC-Dy-_c6-H.js} +1 -1
- package/dist/assets/{c4Diagram-YG6GDRKO-C8Q7ceaK.js → c4Diagram-YG6GDRKO-DHRUX7S-.js} +1 -1
- package/dist/assets/{cache-panel-BHTrsFvx.js → cache-panel-B_zs00Q_.js} +1 -1
- package/dist/assets/{cell-editor-B43gqTef.js → cell-editor-F9uW-xZK.js} +10 -10
- package/dist/assets/{cell-link-d38hFEon.js → cell-link-BRdZl0OJ.js} +1 -1
- package/dist/assets/{cells-A-ljPpuj.js → cells-CcBfzJ1Z.js} +51 -51
- package/dist/assets/channel-CWEEnT6g.js +1 -0
- package/dist/assets/{chat-display-Be0U92hE.js → chat-display-NiFkPnNN.js} +1 -1
- package/dist/assets/{chat-panel-BEz970S3.js → chat-panel-C6V6gxrr.js} +1 -1
- package/dist/assets/{chat-ui-CdW7awFa.js → chat-ui-BLiRBYhk.js} +1 -1
- package/dist/assets/{chunk-5FQGJX7Z-B4RvNAGm.js → chunk-5FQGJX7Z-e_arGD4o.js} +3 -3
- package/dist/assets/{chunk-ABZYJK2D-X_7JfTbo.js → chunk-ABZYJK2D-BInZW7OW.js} +1 -1
- package/dist/assets/{chunk-ATLVNIR6-BvOe4C7U.js → chunk-ATLVNIR6-_9Zaw7IP.js} +1 -1
- package/dist/assets/{chunk-B4BG7PRW-DuJr4Vxg.js → chunk-B4BG7PRW-Bg43tpY1.js} +1 -1
- package/dist/assets/{chunk-DI55MBZ5-U7-ld--F.js → chunk-DI55MBZ5-DX01Gov5.js} +1 -1
- package/dist/assets/{chunk-EXTU4WIE-B7W_a4w2.js → chunk-EXTU4WIE-Cwo9-IiR.js} +1 -1
- package/dist/assets/{chunk-JA3XYJ7Z-EueUUcXO.js → chunk-JA3XYJ7Z-C6cvGHie.js} +1 -1
- package/dist/assets/{chunk-JZLCHNYA-Bx4SqpPS.js → chunk-JZLCHNYA-BM-e2D_8.js} +1 -1
- package/dist/assets/{chunk-N4CR4FBY-DlrBiMsl.js → chunk-N4CR4FBY-BREYOeLP.js} +2 -2
- package/dist/assets/{chunk-QN33PNHL-DQrYk9Fj.js → chunk-QN33PNHL-DwGffwWu.js} +1 -1
- package/dist/assets/{chunk-QXUST7PY-COkAFJCN.js → chunk-QXUST7PY-Q2jlSUop.js} +1 -1
- package/dist/assets/{chunk-S3R3BYOJ-GS_DuFun.js → chunk-S3R3BYOJ-DGKPoF4U.js} +1 -1
- package/dist/assets/{chunk-TZMSLE5B-uYzKNbMS.js → chunk-TZMSLE5B-Bfbjtd_W.js} +1 -1
- package/dist/assets/classDiagram-2ON5EDUG-CBbpzZPu.js +1 -0
- package/dist/assets/classDiagram-v2-WZHVMYZB-B0cWCuuo.js +1 -0
- package/dist/assets/{code-block-37QAKDTI-JYeq6pxz.js → code-block-37QAKDTI-CtU_48GW.js} +1 -1
- package/dist/assets/{column-preview-DUPpv2dz.js → column-preview-8uxaalCj.js} +1 -1
- package/dist/assets/{command-CXDOCJwp.js → command-CBCkexpx.js} +1 -1
- package/dist/assets/{command-palette-B5AX7Cgd.js → command-palette-DicMKinS.js} +1 -1
- package/dist/assets/{common-DC9LEIym.js → common-CHmdPmWi.js} +1 -1
- package/dist/assets/{components-FepcpFGL.js → components-DVKf_7RU.js} +1 -1
- package/dist/assets/{components-BDnRtsA5.js → components-HCInimq-.js} +1 -1
- package/dist/assets/{config-ChCHm539.js → config-DczIUz0b.js} +1 -1
- package/dist/assets/{context-DGqo1TbK.js → context-B3MsQb-b.js} +1 -1
- package/dist/assets/{copy-icon-C67c9EwB.js → copy-icon-BYNydU7b.js} +1 -1
- package/dist/assets/{dagre-6UL2VRFP-DYsFeXDU.js → dagre-6UL2VRFP-DWD6iJku.js} +1 -1
- package/dist/assets/{data-grid-overlay-editor-BXZECgKd.js → data-grid-overlay-editor-DvZ8PZ2g.js} +1 -1
- package/dist/assets/{datasource-BCnGIjqn.js → datasource-Czm_KBfK.js} +2 -2
- package/dist/assets/{dates-DhByPWH5.js → dates-CAlnO9QB.js} +1 -1
- package/dist/assets/{dependency-graph-panel-k1WQZ4m-.js → dependency-graph-panel-DPKylrlr.js} +4 -4
- package/dist/assets/{diagram-PSM6KHXK-B8hv9RHG.js → diagram-PSM6KHXK-B_Cc0ttH.js} +1 -1
- package/dist/assets/{diagram-QEK2KX5R-G6A7hdno.js → diagram-QEK2KX5R-DhI0d2dH.js} +1 -1
- package/dist/assets/{diagram-S2PKOQOG-iaflbF2c.js → diagram-S2PKOQOG-cc2LNQee.js} +1 -1
- package/dist/assets/{dist-gG4VZW46.js → dist-A6v5-U3i.js} +1 -1
- package/dist/assets/{dist-C46P-i95.js → dist-B96NwXcp.js} +1 -1
- package/dist/assets/dist-BVBYIAbx.js +1 -0
- package/dist/assets/{dist-BMfl634h.js → dist-C204e66A.js} +1 -1
- package/dist/assets/{dist-COpce3-f.js → dist-CEUFTp7U.js} +1 -1
- package/dist/assets/{dist-DmZscTVZ.js → dist-CGDn0y-i.js} +1 -1
- package/dist/assets/{dist-BMGjzUx5.js → dist-CmTrDl8w.js} +1 -1
- package/dist/assets/{dist-nYyvRYnq.js → dist-Cmcbyg5X.js} +1 -1
- package/dist/assets/dist-Cn0rcGlX.js +1 -0
- package/dist/assets/{dist-CVTRujA4.js → dist-CwZoXpmG.js} +1 -1
- package/dist/assets/{dist-D68AVdXh.js → dist-Cwcldbhl.js} +1 -1
- package/dist/assets/{dist-CEysMnMQ.js → dist-DBiqbYe-.js} +1 -1
- package/dist/assets/dist-DMSWEOfO.js +1 -0
- package/dist/assets/{dist-Ds4ite_2.js → dist-DQOq2Tf-.js} +1 -1
- package/dist/assets/dist-Dn_fCOGr.js +1 -0
- package/dist/assets/dist-Dq4wQg6C.js +1 -0
- package/dist/assets/{dist-DC5pDLoK.js → dist-Dw9UX7x1.js} +1 -1
- package/dist/assets/dist-R7_s36kw.js +1 -0
- package/dist/assets/{dist-b7WC6dxf.js → dist-RsQv8CvG.js} +1 -1
- package/dist/assets/{dist-OWcDq-O3.js → dist-_XomGjg6.js} +1 -1
- package/dist/assets/{dist-0xasIeT1.js → dist-_qPWf6sD.js} +1 -1
- package/dist/assets/{dist-BtG3xAGt.js → dist-rzeRelEY.js} +1 -1
- package/dist/assets/{documentation-panel-BMrGuByB.js → documentation-panel-DZkIKuPv.js} +1 -1
- package/dist/assets/{download-Iyng0xCz.js → download-YUQiaxS9.js} +3 -3
- package/dist/assets/edit-page-BiiE4rVw.js +9 -0
- package/dist/assets/{erDiagram-Q2GNP2WA-DyZONgFt.js → erDiagram-Q2GNP2WA-CPtVWZYn.js} +1 -1
- package/dist/assets/{error-banner-CTBwdcdk.js → error-banner-C6aBa98y.js} +1 -1
- package/dist/assets/{error-panel-CHSsnRFF.js → error-panel-C4UQHEjp.js} +1 -1
- package/dist/assets/{es-YQvzKo5h.js → es-DaYh1PsD.js} +1 -1
- package/dist/assets/{esm-CbD72kxC.js → esm-BRNC35J6.js} +1 -1
- package/dist/assets/{esm-G1JMtvxe.js → esm-BmrwxxCo.js} +1 -1
- package/dist/assets/{field-B8kJgr2A.js → field-BrLPDxsA.js} +1 -1
- package/dist/assets/file-explorer-panel-Bq320epN.js +26 -0
- package/dist/assets/{file-icons-DTNZv05h.js → file-icons-CMxkj_kV.js} +1 -1
- package/dist/assets/{file-name-input-CLlFR7p-.js → file-name-input-C70pv8AE.js} +2 -2
- package/dist/assets/{floating-outline-CSNGDMAm.js → floating-outline-BtNnv2IX.js} +1 -1
- package/dist/assets/{flowDiagram-NV44I4VS-Bo2Wh9OF.js → flowDiagram-NV44I4VS-LeaIbfPS.js} +1 -1
- package/dist/assets/{focus-Baz7rlo0.js → focus-CXQpR65O.js} +1 -1
- package/dist/assets/{form-0wZOuqB-.js → form-x5lqxs04.js} +2 -2
- package/dist/assets/{formats-BvyJSIqk.js → formats-Dsc8AdCp.js} +1 -1
- package/dist/assets/{formatting-Cncf6ptO.js → formatting-TmuwpwTs.js} +1 -1
- package/dist/assets/{gallery-page-Ddl87lwR.js → gallery-page-C4kMatxN.js} +1 -1
- package/dist/assets/{ganttDiagram-JELNMOA3-Cc_BiCCk.js → ganttDiagram-JELNMOA3-Bj-STLOZ.js} +1 -1
- package/dist/assets/{gitGraphDiagram-V2S2FVAM-CGySG6ni.js → gitGraphDiagram-V2S2FVAM-B9HDL4DZ.js} +1 -1
- package/dist/assets/{glide-data-editor-Cr2RvoIz.js → glide-data-editor-CxV4Ph39.js} +4 -4
- package/dist/assets/{globals-xVhZei_S.js → globals-B-ZMi0ZU.js} +1 -1
- package/dist/assets/{home-page-QvO22-4u.js → home-page-CaIONOO0.js} +2 -2
- package/dist/assets/{hooks-BZOcKMEB.js → hooks-Dj8Y1kvn.js} +1 -1
- package/dist/assets/{square-Dj2Cf4ne.js → house-mGK3v0Mm.js} +1 -1
- package/dist/assets/{html-to-image-tbPEMBJg.js → html-to-image-BHdf1t5J.js} +1 -1
- package/dist/assets/{index-D48a2kB0.js → index-C3mazXKw.js} +7 -7
- package/dist/assets/{infoDiagram-HS3SLOUP-Ci2MRh_P.js → infoDiagram-HS3SLOUP-BDcw9LMK.js} +1 -1
- package/dist/assets/{input-DyPS_GiK.js → input-BX98vgAu.js} +1 -1
- package/dist/assets/{journeyDiagram-XKPGCS4Q-C9-9zg54.js → journeyDiagram-XKPGCS4Q-D29tj64e.js} +1 -1
- package/dist/assets/{kanban-definition-3W4ZIXB7-D4ivIK0L.js → kanban-definition-3W4ZIXB7-DStZ4tGj.js} +1 -1
- package/dist/assets/{kiosk-mode-cWTXpegb.js → kiosk-mode-vHMq9vr1.js} +1 -1
- package/dist/assets/layout-D-cLXGXf.js +9 -0
- package/dist/assets/{linear-Bn2iRj5i.js → linear-Cof2JLCQ.js} +1 -1
- package/dist/assets/{links-BHtUMVOq.js → links-iy4RlM-h.js} +1 -1
- package/dist/assets/{logs-panel-Dgkr6V7q.js → logs-panel-DL9WeQsv.js} +1 -1
- package/dist/assets/{markdown-renderer-CFrgiLqu.js → markdown-renderer-DmnGXdCp.js} +3 -3
- package/dist/assets/mermaid-4DMBBIKO-gHC2PS1m.js +1 -0
- package/dist/assets/{mermaid-D5Aj1ujy.js → mermaid-CXmjgj4p.js} +3 -3
- package/dist/assets/{mermaid-parser.core-DP6UBthl.js → mermaid-parser.core-BQULBKwL.js} +1 -1
- package/dist/assets/{mindmap-definition-VGOIOE7T-BBFkIzCl.js → mindmap-definition-VGOIOE7T-Cy9nt356.js} +1 -1
- package/dist/assets/{name-cell-input-C5LXTI3T.js → name-cell-input-CHuLB3H7.js} +1 -1
- package/dist/assets/{number-overlay-editor-Cu1bME8q.js → number-overlay-editor-8-GuvfJX.js} +1 -1
- package/dist/assets/{outline-panel-0lyts6z4.js → outline-panel-JaSUHnmD.js} +1 -1
- package/dist/assets/{packages-panel-BhI1lbfw.js → packages-panel-BB5_Iu2c.js} +1 -1
- package/dist/assets/{panels-8fPdoW9_.js → panels-LnVrD2Ph.js} +1 -1
- package/dist/assets/{pathUtils-CSrNy17a.js → pathUtils-DOhgNpTR.js} +1 -1
- package/dist/assets/{pieDiagram-ADFJNKIX-BYGTzW8w.js → pieDiagram-ADFJNKIX-CqhovvcK.js} +1 -1
- package/dist/assets/{precisionRound-CU2C3Vxx.js → precisionRound-C3fmBb6j.js} +1 -1
- package/dist/assets/{process-output-BwZ5VxXO.js → process-output-hJso9ugZ.js} +1 -1
- package/dist/assets/{quadrantDiagram-AYHSOK5B-D8NZ19FM.js → quadrantDiagram-AYHSOK5B-BNyiC3hL.js} +1 -1
- package/dist/assets/radio-group-6t7ozlnG.js +1 -0
- package/dist/assets/react-vega-C1LnPwEN.js +1 -0
- package/dist/assets/{react-vega-BQXvtE5G.js → react-vega-SibldZnp.js} +1 -1
- package/dist/assets/readonly-python-code-JBCsN3-9.js +1 -0
- package/dist/assets/{renderShortcut-CkNNAheg.js → renderShortcut-DZpkrZaP.js} +1 -1
- package/dist/assets/{request-registry-D-jptgP0.js → request-registry-BwzANGxx.js} +1 -1
- package/dist/assets/{requirementDiagram-UZGBJVZJ-lUcxJMXj.js → requirementDiagram-UZGBJVZJ-U4CoEx7e.js} +1 -1
- package/dist/assets/{reveal-component-LHeN9pMI.css → reveal-component-CMD1_gk8.css} +1 -1
- package/dist/assets/reveal-component-DvnP8FBq.js +91 -0
- package/dist/assets/{run-page-x3v_5tzv.js → run-page-DMkxXk3G.js} +1 -1
- package/dist/assets/{sankeyDiagram-TZEHDZUN-BJExQFWg.js → sankeyDiagram-TZEHDZUN-BXgCc5j4.js} +1 -1
- package/dist/assets/scratchpad-panel-CpKz-ArR.js +1 -0
- package/dist/assets/{secrets-panel-DeNY3rAp.js → secrets-panel-DaR50P_m.js} +1 -1
- package/dist/assets/{sequenceDiagram-WL72ISMW-DcfyJdc2.js → sequenceDiagram-WL72ISMW-CB8apKmu.js} +1 -1
- package/dist/assets/session-panel-DF0m0wH3.js +1 -0
- package/dist/assets/{share-BXN2Sd1t.js → share-DIVpiHPe.js} +1 -1
- package/dist/assets/{snippets-panel-CnN632Ki.js → snippets-panel-CQKr-OMs.js} +1 -1
- package/dist/assets/square-DMaNzePN.js +1 -0
- package/dist/assets/{state-svfaehZt.js → state-B34hXjp9.js} +1 -1
- package/dist/assets/{state-CikXvgx3.js → state-CraSoEHI.js} +3 -3
- package/dist/assets/{state-Bsz477is.js → state-DCT6JLba.js} +1 -1
- package/dist/assets/{state-CoWk7q5y.js → state-Z-H4o98V.js} +1 -1
- package/dist/assets/{stateDiagram-FKZM4ZOC-D379CBmo.js → stateDiagram-FKZM4ZOC-3YqeHe0_.js} +1 -1
- package/dist/assets/stateDiagram-v2-4FDKWEC3-Dfvjjqh4.js +1 -0
- package/dist/assets/stex-D6sqtveI.js +1 -0
- package/dist/assets/{swiper-component-DLxR3y4N.js → swiper-component-B-P7FNP9.js} +1 -1
- package/dist/assets/{switch-DlgpDZMk.js → switch-ecwOrzz3.js} +1 -1
- package/dist/assets/{terminal-D8ZS2O18.js → terminal-CQZ69wrS.js} +1 -1
- package/dist/assets/{textarea-Dd0InTQJ.js → textarea-BI_mXP9w.js} +1 -1
- package/dist/assets/{time-yM1OtSdb.js → time-C12vLLcl.js} +1 -1
- package/dist/assets/{timeline-definition-IT6M3QCI-ChCqM1Sl.js → timeline-definition-IT6M3QCI-DZQqxPSn.js} +1 -1
- package/dist/assets/{tracing-BZPLfSlB.js → tracing-BF-ca60a.js} +1 -1
- package/dist/assets/{tracing-panel-DBaQBraG.js → tracing-panel-D1j7Fbvr.js} +2 -2
- package/dist/assets/{tree-actions-oMCx6WNc.js → tree-actions-Ci3CV3hN.js} +1 -1
- package/dist/assets/{useBoolean-CLFdHewv.js → useBoolean-B_vDzBHf.js} +1 -1
- package/dist/assets/useCellActionButton-CcXV09GQ.js +1 -0
- package/dist/assets/{useDateFormatter-BEz9SEXo.js → useDateFormatter-CgFoBhVq.js} +1 -1
- package/dist/assets/{useDeleteCell-C2Stbb6Q.js → useDeleteCell-BVX9aH-t.js} +1 -1
- package/dist/assets/{useDependencyPanelTab-8WaMRWbo.js → useDependencyPanelTab-CewdyAAy.js} +1 -1
- package/dist/assets/{useInstallPackage-afgh7PwB.js → useInstallPackage-D0NLybAx.js} +1 -1
- package/dist/assets/useNotebookActions-CTBSmORR.js +1 -0
- package/dist/assets/{useNumberFormatter-wQU1z0W_.js → useNumberFormatter-DtiQW2H_.js} +1 -1
- package/dist/assets/{usePress-CtfZXGno.js → usePress-CfcdTqJM.js} +1 -1
- package/dist/assets/useRunCells-CgXnbA14.js +1 -0
- package/dist/assets/{useSplitCell-BZPuhd8z.js → useSplitCell-_Q2wQXsQ.js} +1 -1
- package/dist/assets/{utils-Bq5kLQ87.js → utils-CGtUbqcR.js} +1 -1
- package/dist/assets/{vega-component-BnaMdpJB.js → vega-component-BDK4MwYT.js} +1 -1
- package/dist/assets/{vega-loader.browser-DXARUlxo.js → vega-loader.browser-BegSZk0G.js} +1 -1
- package/dist/assets/{write-secret-modal-BfflSuL6.js → write-secret-modal-BFLUPDlo.js} +1 -1
- package/dist/assets/{xychartDiagram-PRI3JC2R-DVMdJM5H.js → xychartDiagram-PRI3JC2R-CmNNcgCM.js} +1 -1
- package/dist/index.html +105 -105
- package/package.json +1 -1
- package/src/components/editor/file-tree/file-explorer.tsx +38 -8
- package/src/components/editor/file-tree/file-operations.tsx +19 -2
- package/src/components/editor/notebook-cell.tsx +33 -23
- package/src/components/editor/renderers/slides-layout/slides-layout.tsx +3 -5
- package/src/components/editor/renderers/vertical-layout/vertical-layout.tsx +2 -17
- package/src/components/slides/reveal-component.tsx +159 -47
- package/src/components/slides/reveal-slides.css +8 -0
- package/src/components/slides/slide-cell-view.tsx +182 -0
- package/src/components/slides/slide-form.tsx +2 -0
- package/src/core/cells/utils.ts +45 -0
- package/src/core/islands/stubs/slide-cell-view.tsx +30 -0
- package/src/core/meta/__tests__/code-visibility.test.tsx +141 -0
- package/src/core/meta/code-visibility.ts +48 -0
- package/dist/assets/RenderHTML-DR6lqJGS.js +0 -1
- package/dist/assets/channel-BMMN1KqZ.js +0 -1
- package/dist/assets/classDiagram-2ON5EDUG-DDa_MJVI.js +0 -1
- package/dist/assets/classDiagram-v2-WZHVMYZB-dZzbS5Uq.js +0 -1
- package/dist/assets/dist-BN_qisx5.js +0 -1
- package/dist/assets/dist-Bzlk7AB1.js +0 -1
- package/dist/assets/dist-CPCp_PIz.js +0 -1
- package/dist/assets/dist-CPWl1X8t.js +0 -1
- package/dist/assets/dist-Cc_qFbl6.js +0 -1
- package/dist/assets/dist-Crt3qZze.js +0 -1
- package/dist/assets/edit-page-Lwy52pkS.js +0 -9
- package/dist/assets/file-explorer-panel-DSahRBWr.js +0 -26
- package/dist/assets/layout-DXt0aA4F.js +0 -9
- package/dist/assets/mermaid-4DMBBIKO-BqnaUv4V.js +0 -1
- package/dist/assets/radio-group-BtBoRbGH.js +0 -1
- package/dist/assets/react-vega-BVATzlrQ.js +0 -1
- package/dist/assets/readonly-python-code-B0nrQE3U.js +0 -1
- package/dist/assets/reveal-component-CgCn23Mw.js +0 -91
- package/dist/assets/scratchpad-panel-CHFYLvso.js +0 -1
- package/dist/assets/session-panel-DMaf7Upn.js +0 -1
- package/dist/assets/slide-form-Dmi4fzLs.js +0 -1
- package/dist/assets/stateDiagram-v2-4FDKWEC3-c0yeJ4is.js +0 -1
- package/dist/assets/stex-Dn4qnyVB.js +0 -1
- package/dist/assets/useAddCell-De9xD63_.js +0 -1
- package/dist/assets/useCellActionButton-Bjxun3wK.js +0 -1
- package/dist/assets/useNotebookActions-v4SgyM_0.js +0 -1
- package/dist/assets/useRunCells-DU1tawR-.js +0 -1
- /package/dist/assets/{Deferred-DxQeE5uh.js → Deferred-DMWKlZOV.js} +0 -0
- /package/dist/assets/{SSRProvider-D3zWcDme.js → SSRProvider-kyGHZp36.js} +0 -0
- /package/dist/assets/{alert-cDholnQq.js → alert-DvqcBMUv.js} +0 -0
- /package/dist/assets/{badge-ChrPsdTW.js → badge-C7-HR1IO.js} +0 -0
- /package/dist/assets/{blob-CTort_or.js → blob-D-eV0cU3.js} +0 -0
- /package/dist/assets/{bundle.esm-DU-4isVC.js → bundle.esm-BIoPrMH_.js} +0 -0
- /package/dist/assets/{copy-B5qyZn5s.js → copy-BCF-tANo.js} +0 -0
- /package/dist/assets/{copy-Dk_3y0H-.js → copy-BwrPA9zQ.js} +0 -0
- /package/dist/assets/{database-zap-BUVn5HoR.js → database-zap-kIkTfzTX.js} +0 -0
- /package/dist/assets/{defaultLocale-BLne0bXb.js → defaultLocale-B6z1Qyqt.js} +0 -0
- /package/dist/assets/{defaultLocale-JieDVWC_.js → defaultLocale-YteS-k_t.js} +0 -0
- /package/dist/assets/{dialog-EekxpBBM.js → dialog-Dj0qTFnG.js} +0 -0
- /package/dist/assets/{dist-CRPTyqAT.js → dist-B324sPca.js} +0 -0
- /package/dist/assets/{dist-DZ2qbK2N.js → dist-E6ttb8td.js} +0 -0
- /package/dist/assets/{dist-DGxytjtv.js → dist-VjDnmGCZ.js} +0 -0
- /package/dist/assets/{ellipsis-pk06Lq82.js → ellipsis-KAhMaCIV.js} +0 -0
- /package/dist/assets/{ellipsis-vertical-gxgNyR5G.js → ellipsis-vertical-CkwWkOQL.js} +0 -0
- /package/dist/assets/{emotion-is-prop-valid.esm-DYxi7n2b.js → emotion-is-prop-valid.esm-DD4AwVTU.js} +0 -0
- /package/dist/assets/{en-US-BqRooSzc.js → en-US-D_il4jD7.js} +0 -0
- /package/dist/assets/{errors-CZb6hI2x.js → errors-TZBmrJmc.js} +0 -0
- /package/dist/assets/{events-Qeh-bHlj.js → events-BRAWQiYK.js} +0 -0
- /package/dist/assets/{extends-Co37_JfG.js → extends-B2LJnKU3.js} +0 -0
- /package/dist/assets/{eye-off-BT-KOYV5.js → eye-off-n1Li95bE.js} +0 -0
- /package/dist/assets/{file-HTLbeC2b.js → file-BrdxGLRX.js} +0 -0
- /package/dist/assets/{file-headphone-B3fuktN0.js → file-headphone-BrQspHac.js} +0 -0
- /package/dist/assets/{github-raQvpeuZ.js → github-BKS_2Qwn.js} +0 -0
- /package/dist/assets/{icons-BRopQwI3.js → icons-D9TuFTJG.js} +0 -0
- /package/dist/assets/{isValid-bmSEa3HX.js → isValid-C8T5uJYI.js} +0 -0
- /package/dist/assets/{kbd-CGShmG7L.js → kbd-B3Breaz2.js} +0 -0
- /package/dist/assets/{links-C-rLiK3d.js → links-Dpap8NI2.js} +0 -0
- /package/dist/assets/{micromark-factory-space-WzovnJik.js → micromark-factory-space-DzSMahmM.js} +0 -0
- /package/dist/assets/{numbers-OHL_xBiC.js → numbers-CAW8yjzj.js} +0 -0
- /package/dist/assets/{objectWithoutPropertiesLoose-smPWkHxB.js → objectWithoutPropertiesLoose-DaPAPabU.js} +0 -0
- /package/dist/assets/{ordinal-DEaY__23.js → ordinal-K0JYqmCT.js} +0 -0
- /package/dist/assets/{paths-CXng2XQv.js → paths-BXWH6vv4.js} +0 -0
- /package/dist/assets/{preload-helper-D2MJg03u.js → preload-helper-DItdS47A.js} +0 -0
- /package/dist/assets/{prop-types-BFRDxSKF.js → prop-types-BiQYf0aU.js} +0 -0
- /package/dist/assets/{purify.es-DC4RGS9t.js → purify.es-DBmVz-Wl.js} +0 -0
- /package/dist/assets/{range-1DwpgXvM.js → range-7fnH_zLA.js} +0 -0
- /package/dist/assets/{react-icons.esm-BUYTQ32a.js → react-icons.esm-D9xfKaPZ.js} +0 -0
- /package/dist/assets/{react-resizable-panels.browser.esm-Bcm5njwd.js → react-resizable-panels.browser.esm-BUNcfKXO.js} +0 -0
- /package/dist/assets/{session-nmTRerwF.js → session-VtovaFBS.js} +0 -0
- /package/dist/assets/{stex-jWatZkll.js → stex-CtmkcLz7.js} +0 -0
- /package/dist/assets/{table-23NNA1s9.js → table-DPyRV1LT.js} +0 -0
- /package/dist/assets/{trash-2-D280Xiwg.js → trash-2-CKlZA04n.js} +0 -0
- /package/dist/assets/{trash-uYoPsR8D.js → trash-CdBDfa8x.js} +0 -0
- /package/dist/assets/{triangle-alert-DBoAWWKA.js → triangle-alert-B8l157gP.js} +0 -0
- /package/dist/assets/{use-toast-BDYuj3zG.js → use-toast-T0_cQDma.js} +0 -0
- /package/dist/assets/{useAsyncData-dS4Ne6pU.js → useAsyncData-BFC6lWG9.js} +0 -0
- /package/dist/assets/{useDebounce-BDIglWmG.js → useDebounce-CLMpJfhX.js} +0 -0
- /package/dist/assets/{useHotkey-Bx4wWQCL.js → useHotkey-Cm0DaHEJ.js} +0 -0
- /package/dist/assets/{useIframeCapabilities-CryCjoyY.js → useIframeCapabilities-BvE4n6hj.js} +0 -0
- /package/dist/assets/{useTheme-DEcgJENn.js → useTheme-Cb4Wekek.js} +0 -0
- /package/dist/assets/{uuid-DXdzqzcr.js → uuid-DercMavo.js} +0 -0
- /package/dist/assets/{workflow-DYcZF-oV.js → workflow-ClChd5xI.js} +0 -0
- /package/dist/assets/{youtube-3lRHw8NU.js → youtube-CbdpN8oL.js} +0 -0
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
var b4=Object.defineProperty;var xx=e=>{throw TypeError(e)};var x4=(e,t,n)=>t in e?b4(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n;var R=(e,t,n)=>x4(e,typeof t!="symbol"?t+"":t,n),wx=(e,t,n)=>t.has(e)||xx("Cannot "+n);var _x=(e,t,n)=>(wx(e,t,"read from private field"),n?n.call(e):t.get(e)),kx=(e,t,n)=>t.has(e)?xx("Cannot add the same private member more than once"):t instanceof WeakSet?t.add(e):t.set(e,n),jh=(e,t,n,r)=>(wx(e,t,"write to private field"),r?r.call(e,n):t.set(e,n),n);var Cl,VM,XM;import{r as Gt,s as Ex}from"./chunk-LvLJmgfZ.js";import{t as w4}from"./react-Bj1aDYRI.js";import{t as _4}from"./jsx-runtime-BqBOg78p.js";import{$ as $x,$t as qh,A as Ax,At as fo,B as Dx,Bt as Mu,C as Sx,Ct as Uh,D as Fx,Dt as Ou,E as Cx,Et as Mx,F as Wh,Ft as Ox,Gt as sr,Ht as zx,I as Nx,It as Rx,J as ho,Jt as yn,Kt as Tx,L as Lx,Lt as $e,M as Px,Mt as Bx,N as Ix,Nt as jx,O as qx,Ot as Ux,P as Wx,Pt as Hx,Q as zu,Qt as Hh,R as Gx,Rt as Vx,S as k4,St as J,T as E4,Tt as Gh,U as Vh,Ut as Xx,V as H,Vt as ui,Wt as vn,X as qe,Xt as ci,Y as $t,Yt as Yx,Z as Q,Zt as Nu,_ as $4,_t as ia,a as Ru,at as ur,b as A4,bt as D4,c as S4,ct as po,d as F4,dt as K,en as Xh,et as Yh,f as C4,ft as Ml,g as M4,gt as N,ht as mo,i as O4,it as pe,j as Jx,jt as Ol,k as Jh,kt as Qx,l as Kx,lt as Tr,m as z4,mt as G,n as N4,nn as Qh,nt as Kh,o as Zx,ot as e2,p as R4,pt as bn,qt as t2,r as T4,rt as L,s as n2,st as fi,t as L4,tn as Tu,tt as At,u as r2,ut as i2,v as P4,vt as aa,w as B4,wt as Y,x as I4,xt as we,y as j4,yt as de,z as a2,zt as q4}from"./vega-loader.browser-
|
|
1
|
+
var b4=Object.defineProperty;var xx=e=>{throw TypeError(e)};var x4=(e,t,n)=>t in e?b4(e,t,{enumerable:!0,configurable:!0,writable:!0,value:n}):e[t]=n;var R=(e,t,n)=>x4(e,typeof t!="symbol"?t+"":t,n),wx=(e,t,n)=>t.has(e)||xx("Cannot "+n);var _x=(e,t,n)=>(wx(e,t,"read from private field"),n?n.call(e):t.get(e)),kx=(e,t,n)=>t.has(e)?xx("Cannot add the same private member more than once"):t instanceof WeakSet?t.add(e):t.set(e,n),jh=(e,t,n,r)=>(wx(e,t,"write to private field"),r?r.call(e,n):t.set(e,n),n);var Cl,VM,XM;import{r as Gt,s as Ex}from"./chunk-LvLJmgfZ.js";import{t as w4}from"./react-Bj1aDYRI.js";import{t as _4}from"./jsx-runtime-BqBOg78p.js";import{$ as $x,$t as qh,A as Ax,At as fo,B as Dx,Bt as Mu,C as Sx,Ct as Uh,D as Fx,Dt as Ou,E as Cx,Et as Mx,F as Wh,Ft as Ox,Gt as sr,Ht as zx,I as Nx,It as Rx,J as ho,Jt as yn,Kt as Tx,L as Lx,Lt as $e,M as Px,Mt as Bx,N as Ix,Nt as jx,O as qx,Ot as Ux,P as Wx,Pt as Hx,Q as zu,Qt as Hh,R as Gx,Rt as Vx,S as k4,St as J,T as E4,Tt as Gh,U as Vh,Ut as Xx,V as H,Vt as ui,Wt as vn,X as qe,Xt as ci,Y as $t,Yt as Yx,Z as Q,Zt as Nu,_ as $4,_t as ia,a as Ru,at as ur,b as A4,bt as D4,c as S4,ct as po,d as F4,dt as K,en as Xh,et as Yh,f as C4,ft as Ml,g as M4,gt as N,ht as mo,i as O4,it as pe,j as Jx,jt as Ol,k as Jh,kt as Qx,l as Kx,lt as Tr,m as z4,mt as G,n as N4,nn as Qh,nt as Kh,o as Zx,ot as e2,p as R4,pt as bn,qt as t2,r as T4,rt as L,s as n2,st as fi,t as L4,tn as Tu,tt as At,u as r2,ut as i2,v as P4,vt as aa,w as B4,wt as Y,x as I4,xt as we,y as j4,yt as de,z as a2,zt as q4}from"./vega-loader.browser-BegSZk0G.js";import{a as o2,c as zl,o as l2,s as s2}from"./precisionRound-C3fmBb6j.js";import{a as Zh,c as u2,d as Lu,f as U4,l as W4,n as go,o as di,p as H4,r as G4,s as ep,t as V4,u as tp}from"./linear-Cof2JLCQ.js";import{n as c2,r as Pu,t as X4}from"./ordinal-K0JYqmCT.js";import{a as Y4,i as J4,n as Q4,o as np,r as K4,s as oa,t as Z4}from"./time-C12vLLcl.js";import{t as nn}from"./range-7fnH_zLA.js";import{i as eO,t as tO}from"./defaultLocale-YteS-k_t.js";import{S as nO,T as rO,_ as iO,b as aO,l as oO,r as lO,s as sO,w as uO}from"./defaultLocale-B6z1Qyqt.js";import{a as f2,b as cO,d as rp,g as fO,h as dO,i as hO,n as pO,r as mO,t as gO,u as ip,v as yO,y as Bu}from"./timer-CIInKAPS.js";import{n as ap,r as Dt,t as d2}from"./path-LDcaQ64B.js";import{f as vO,p as bO,u as xO}from"./math-Bf0RgaKx.js";import{t as wO}from"./arc-ONRhTAm2.js";import{t as _O}from"./array-BCwZq3ts.js";import{_ as kO,a as EO,c as $O,d as AO,f as DO,g as SO,h as FO,i as CO,l as MO,m as OO,n as zO,o as NO,p as RO,r as TO,s as LO,t as PO,u as BO,v as h2}from"./step-BE8c2ivx.js";import{n as IO,r as jO,t as p2}from"./line-j0cbFv7-.js";import{n as la,t as hi}from"./init-DE_uL9Ns.js";import{t as cr}from"./colors-CI3VyX7X.js";import{a as op,c as m2,d as g2,f as qO,i as UO,l as WO,n as HO,o as Iu,p as GO,r as VO,s as XO,t as YO,u as ju}from"./treemap-BKxvGXqJ.js";function JO(e,t){let n=0,r,i=0,a=0;if(t===void 0)for(let o of e)o!=null&&(o=+o)>=o&&(r=o-i,i+=r/++n,a+=r*(o-i));else{let o=-1;for(let l of e)(l=t(l,++o,e))!=null&&(l=+l)>=l&&(r=l-i,i+=r/++n,a+=r*(l-i))}if(n>1)return a/(n-1)}function QO(e,t){let n=JO(e,t);return n&&Math.sqrt(n)}var St=class{constructor(){this._partials=new Float64Array(32),this._n=0}add(e){let t=this._partials,n=0;for(let r=0;r<this._n&&r<32;r++){let i=t[r],a=e+i,o=Math.abs(e)<Math.abs(i)?e-(a-i):i-(a-e);o&&(t[n++]=o),e=a}return t[n]=e,this._n=n+1,this}valueOf(){let e=this._partials,t=this._n,n,r,i,a=0;if(t>0){for(a=e[--t];t>0&&(n=a,r=e[--t],a=n+r,i=r-(a-n),!i););t>0&&(i<0&&e[t-1]<0||i>0&&e[t-1]>0)&&(r=i*2,n=a+r,r==n-a&&(a=n))}return a}};function KO(e,t){return Array.from(t,n=>e[n])}function ZO(e=zl){if(e===zl)return y2;if(typeof e!="function")throw TypeError("compare is not a function");return(t,n)=>{let r=e(t,n);return r||r===0?r:(e(n,n)===0)-(e(t,t)===0)}}function y2(e,t){return(e==null||!(e>=e))-(t==null||!(t>=t))||(e<t?-1:e>t?1:0)}function v2(e,t,n=0,r=1/0,i){if(t=Math.floor(t),n=Math.floor(Math.max(0,n)),r=Math.floor(Math.min(e.length-1,r)),!(n<=t&&t<=r))return e;for(i=i===void 0?y2:ZO(i);r>n;){if(r-n>600){let s=r-n+1,u=t-n+1,c=Math.log(s),f=.5*Math.exp(2*c/3),d=.5*Math.sqrt(c*f*(s-f)/s)*(u-s/2<0?-1:1),h=Math.max(n,Math.floor(t-u*f/s+d)),p=Math.min(r,Math.floor(t+(s-u)*f/s+d));v2(e,t,h,p,i)}let a=e[t],o=n,l=r;for(Nl(e,n,t),i(e[r],a)>0&&Nl(e,n,r);o<l;){for(Nl(e,o,l),++o,--l;i(e[o],a)<0;)++o;for(;i(e[l],a)>0;)--l}i(e[n],a)===0?Nl(e,n,l):(++l,Nl(e,l,r)),l<=t&&(n=l+1),t<=l&&(r=l-1)}return e}function Nl(e,t,n){let r=e[t];e[t]=e[n],e[n]=r}function lp(e,t,n){if(e=Float64Array.from(H4(e,n)),!(!(r=e.length)||isNaN(t=+t))){if(t<=0||r<2)return np(e);if(t>=1)return oa(e);var r,i=(r-1)*t,a=Math.floor(i),o=oa(v2(e,a).subarray(0,a+1));return o+(np(e.subarray(a+1))-o)*(i-a)}}function b2(e,t,n=U4){if(!(!(r=e.length)||isNaN(t=+t))){if(t<=0||r<2)return+n(e[0],0,e);if(t>=1)return+n(e[r-1],r-1,e);var r,i=(r-1)*t,a=Math.floor(i),o=+n(e[a],a,e);return o+(+n(e[a+1],a+1,e)-o)*(i-a)}}function e8(e,t){let n=0,r=0;if(t===void 0)for(let i of e)i!=null&&(i=+i)>=i&&(++n,r+=i);else{let i=-1;for(let a of e)(a=t(a,++i,e))!=null&&(a=+a)>=a&&(++n,r+=a)}if(n)return r/n}function x2(e,t){return lp(e,.5,t)}function*t8(e){for(let t of e)yield*t}function w2(e){return Array.from(t8(e))}function _2(e,t){let n=0;if(t===void 0)for(let r of e)(r=+r)&&(n+=r);else{let r=-1;for(let i of e)(i=+t(i,++r,e))&&(n+=i)}return n}function n8(e,...t){e=new Pu(e),t=t.map(r8);e:for(let n of e)for(let r of t)if(!r.has(n)){e.delete(n);continue e}return e}function r8(e){return e instanceof Pu?e:new Pu(e)}function i8(...e){let t=new Pu;for(let n of e)for(let r of n)t.add(r);return t}function a8(e,t,n){var r=new gO,i=t;return t==null?(r.restart(e,t,n),r):(r._restart=r.restart,r.restart=function(a,o,l){o=+o,l=l==null?pO():+l,r._restart(function s(u){u+=i,r._restart(s,i+=o,l),a(u)},o,l)},r.restart(e,t,n),r)}var o8=/("(?:[^\\"]|\\.)*")|[:,]/g;function sp(e,t={}){let n=JSON.stringify([1],void 0,t.indent===void 0?2:t.indent).slice(2,-3),r=n===""?1/0:t.maxLength===void 0?80:t.maxLength,{replacer:i}=t;return(function a(o,l,s){o&&typeof o.toJSON=="function"&&(o=o.toJSON());let u=JSON.stringify(o,i);if(u===void 0)return u;let c=r-l.length-s;if(u.length<=c){let f=u.replace(o8,(d,h)=>h||`${d} `);if(f.length<=c)return f}if(i!=null&&(o=JSON.parse(u),i=void 0),typeof o=="object"&&o){let f=l+n,d=[],h=0,p,m;if(Array.isArray(o)){p="[",m="]";let{length:g}=o;for(;h<g;h++)d.push(a(o[h],f,h===g-1?0:1)||"null")}else{p="{",m="}";let g=Object.keys(o),{length:y}=g;for(;h<y;h++){let v=g[h],b=`${JSON.stringify(v)}: `,w=a(o[v],f,b.length+(h===y-1?0:1));w!==void 0&&d.push(b+w)}}if(d.length>0)return[p,n+d.join(`,
|
|
2
2
|
${f}`),m].join(`
|
|
3
3
|
${l}`)}return u})(e,"",0)}function qu(e){let t=e||bn,n=[],r={};return n.add=i=>{let a=t(i);return r[a]||(r[a]=1,n.push(i)),n},n.remove=i=>{let a=t(i);if(r[a]){r[a]=0;let o=n.indexOf(i);o>=0&&n.splice(o,1)}return n},n}async function Uu(e,t){try{await t(e)}catch(n){e.error(n)}}var k2=Symbol("vega_id"),l8=1;function Wu(e){return!!(e&&te(e))}function te(e){return e[k2]}function E2(e,t){return e[k2]=t,e}function _e(e){let t=e===Object(e)?e:{data:e};return te(t)?t:E2(t,l8++)}function up(e){return Hu(e,_e({}))}function Hu(e,t){for(let n in e)t[n]=e[n];return t}function $2(e,t){return E2(t,te(e))}function sa(e,t){return e?t?(n,r)=>e(n,r)||te(t(n))-te(t(r)):(n,r)=>e(n,r)||te(n)-te(r):null}function A2(e){return e&&e.constructor===ua}function ua(){let e=[],t=[],n=[],r=[],i=[],a=null,o=!1;return{constructor:ua,insert(l){let s=Q(l),u=s.length;for(let c=0;c<u;++c)e.push(s[c]);return this},remove(l){let s=de(l)?r:t,u=Q(l),c=u.length;for(let f=0;f<c;++f)s.push(u[f]);return this},modify(l,s,u){let c={field:s,value:At(u)};return de(l)?(c.filter=l,i.push(c)):(c.tuple=l,n.push(c)),this},encode(l,s){return de(l)?i.push({filter:l,field:s}):n.push({tuple:l,field:s}),this},clean(l){return a=l,this},reflow(){return o=!0,this},pulse(l,s){let u={},c={},f,d,h,p,m,g;for(f=0,d=s.length;f<d;++f)u[te(s[f])]=1;for(f=0,d=t.length;f<d;++f)m=t[f],u[te(m)]=-1;for(f=0,d=r.length;f<d;++f)p=r[f],s.forEach(v=>{p(v)&&(u[te(v)]=-1)});for(f=0,d=e.length;f<d;++f)m=e[f],g=te(m),u[g]?u[g]=1:l.add.push(_e(e[f]));for(f=0,d=s.length;f<d;++f)m=s[f],u[te(m)]<0&&l.rem.push(m);function y(v,b,w){w?v[b]=w(v):l.encode=b,o||(c[te(v)]=v)}for(f=0,d=n.length;f<d;++f)h=n[f],m=h.tuple,p=h.field,g=u[te(m)],g>0&&(y(m,p,h.value),l.modifies(p));for(f=0,d=i.length;f<d;++f)h=i[f],p=h.filter,s.forEach(v=>{p(v)&&u[te(v)]>0&&y(v,h.field,h.value)}),l.modifies(h.field);if(o)l.mod=t.length||r.length?s.filter(v=>u[te(v)]>0):s.slice();else for(g in c)l.mod.push(c[g]);return(a||a==null&&(t.length||r.length))&&l.clean(!0),l}}}var Gu="_:mod:_";function Vu(){Object.defineProperty(this,Gu,{writable:!0,value:{}})}Vu.prototype={set(e,t,n,r){let i=this,a=i[e],o=i[Gu];return t!=null&&t>=0?(a[t]!==n||r)&&(a[t]=n,o[t+":"+e]=-1,o[e]=-1):(a!==n||r)&&(i[e]=n,o[e]=N(n)?1+n.length:-1),i},modified(e,t){let n=this[Gu];if(arguments.length){if(N(e)){for(let r=0;r<e.length;++r)if(n[e[r]])return!0;return!1}}else{for(let r in n)if(n[r])return!0;return!1}return t!=null&&t>=0?t+1<n[e]||!!n[t+":"+e]:!!n[e]},clear(){return this[Gu]={},this}};var s8=0,u8="pulse",c8=new Vu,f8=1,d8=2;function Oe(e,t,n,r){this.id=++s8,this.value=e,this.stamp=-1,this.rank=-1,this.qrank=-1,this.flags=0,t&&(this._update=t),n&&this.parameters(n,r)}function D2(e){return function(t){let n=this.flags;return arguments.length===0?!!(n&e):(this.flags=t?n|e:n&~e,this)}}Oe.prototype={targets(){return this._targets||(this._targets=qu(Ml))},set(e){return this.value===e?0:(this.value=e,1)},skip:D2(f8),modified:D2(d8),parameters(e,t,n){t=t!==!1;let r=this._argval=this._argval||new Vu,i=this._argops=this._argops||[],a=[],o,l,s,u,c=(f,d,h)=>{h instanceof Oe?(h!==this&&(t&&h.targets().add(this),a.push(h)),i.push({op:h,name:f,index:d})):r.set(f,d,h)};for(o in e)if(l=e[o],o===u8)Q(l).forEach(f=>{f instanceof Oe?f!==this&&(f.targets().add(this),a.push(f)):L("Pulse parameters must be operator instances.")}),this.source=l;else if(N(l))for(r.set(o,-1,Array(s=l.length)),u=0;u<s;++u)c(o,u,l[u]);else c(o,-1,l);return this.marshall().clear(),n&&(i.initonly=!0),a},marshall(e){let t=this._argval||c8,n=this._argops,r,i,a,o;if(n){let l=n.length;for(i=0;i<l;++i)r=n[i],a=r.op,o=a.modified()&&a.stamp===e,t.set(r.name,r.index,a.value,o);if(n.initonly){for(i=0;i<l;++i)r=n[i],r.op.targets().remove(this);this._argops=null,this._update=null}}return t},detach(){let e=this._argops,t,n,r,i;if(e)for(t=0,n=e.length;t<n;++t)r=e[t],i=r.op,i._targets&&i._targets.remove(this);this.pulse=null,this.source=null},evaluate(e){let t=this._update;if(t){let n=this.marshall(e.stamp),r=t.call(this,n,e);if(n.clear(),r!==this.value)this.value=r;else if(!this.modified())return e.StopPropagation}},run(e){if(e.stamp<this.stamp)return e.StopPropagation;let t;return this.skip()?(this.skip(!1),t=0):t=this.evaluate(e),this.pulse=t||e}};function h8(e,t,n,r){let i=1,a;return e instanceof Oe?a=e:e&&e.prototype instanceof Oe?a=new e:de(e)?a=new Oe(null,e):(i=0,a=new Oe(e,t)),this.rank(a),i&&(r=n,n=t),n&&this.connect(a,a.parameters(n,r)),this.touch(a),a}function p8(e,t){let n=e.rank,r=t.length;for(let i=0;i<r;++i)if(n<t[i].rank){this.rerank(e);return}}var m8=0;function Xu(e,t,n){this.id=++m8,this.value=null,n&&(this.receive=n),e&&(this._filter=e),t&&(this._apply=t)}function pi(e,t,n){return new Xu(e,t,n)}Xu.prototype={_filter:yn,_apply:bn,targets(){return this._targets||(this._targets=qu(Ml))},consume(e){return arguments.length?(this._consume=!!e,this):!!this._consume},receive(e){if(this._filter(e)){let t=this.value=this._apply(e),n=this._targets,r=n?n.length:0;for(let i=0;i<r;++i)n[i].receive(t);this._consume&&(e.preventDefault(),e.stopPropagation())}},filter(e){let t=pi(e);return this.targets().add(t),t},apply(e){let t=pi(null,e);return this.targets().add(t),t},merge(){let e=pi();this.targets().add(e);for(let t=0,n=arguments.length;t<n;++t)arguments[t].targets().add(e);return e},throttle(e){let t=-1;return this.filter(()=>{let n=Date.now();return n-t>e?(t=n,1):0})},debounce(e){let t=pi();return this.targets().add(pi(null,null,Kh(e,n=>{let r=n.dataflow;t.receive(n),r&&r.run&&r.run()}))),t},between(e,t){let n=!1;return e.targets().add(pi(null,null,()=>n=!0)),t.targets().add(pi(null,null,()=>n=!1)),this.filter(()=>n)},detach(){this._filter=yn,this._targets=null}};function g8(e,t,n,r){let i=this,a=pi(n,r),o=function(u){u.dataflow=i;try{a.receive(u)}catch(c){i.error(c)}finally{i.run()}},l;l=typeof e=="string"&&typeof document<"u"?document.querySelectorAll(e):Q(e);let s=l.length;for(let u=0;u<s;++u)l[u].addEventListener(t,o);return a}function y8(e,t){let n=this.locale();return Zx(e,t,n.timeParse,n.utcParse)}function v8(e,t,n){return t=this.parse(t,n),this.pulse(e,this.changeset().insert(t))}async function b8(e,t){let n=this,r=0,i;try{i=await n.loader().load(e,{context:"dataflow",response:n2(t&&t.type)});try{i=n.parse(i,t)}catch(a){r=-2,n.warn("Data ingestion failed",e,a)}}catch(a){r=-1,n.warn("Loading failed",e,a)}return{data:i,status:r}}async function x8(e,t,n){let r=this,i=r._pending||w8(r);i.requests+=1;let a=await r.request(t,n);return r.pulse(e,r.changeset().remove(yn).insert(a.data||[])),i.done(),a}function w8(e){let t,n=new Promise(r=>t=r);return n.requests=0,n.done=()=>{--n.requests===0&&(e._pending=null,t(e))},e._pending=n}var _8={skip:!0};function k8(e,t,n,r,i){return(e instanceof Oe?$8:E8)(this,e,t,n,r,i),this}function E8(e,t,n,r,i,a){let o=pe({},a,_8),l,s;de(n)||(n=At(n)),r===void 0?l=u=>e.touch(n(u)):de(r)?(s=new Oe(null,r,i,!1),l=u=>{s.evaluate(u);let c=n(u),f=s.value;A2(f)?e.pulse(c,f,a):e.update(c,f,o)}):l=u=>e.update(n(u),r,o),t.apply(l)}function $8(e,t,n,r,i,a){if(r===void 0)t.targets().add(n);else{let o=a||{},l=new Oe(null,A8(n,r),i,!1);l.modified(o.force),l.rank=t.rank,t.targets().add(l),n&&(l.skip(!0),l.value=n.value,l.targets().add(n),e.connect(n,[l]))}}function A8(e,t){return t=de(t)?t:At(t),e?function(n,r){let i=t(n,r);return e.skip()||(e.skip(i!==this.value).value=i),i}:t}function D8(e){e.rank=++this._rank}function S8(e){let t=[e],n,r,i;for(;t.length;)if(this.rank(n=t.pop()),r=n._targets)for(i=r.length;--i>=0;)t.push(n=r[i]),n===e&&L("Cycle detected in dataflow graph.")}var Yu={},Lr=1,mi=2,gi=4,F8=Lr|mi,S2=Lr|gi,yo=mi|5,F2=8,Rl=16,C2=32,M2=64;function yi(e,t,n){this.dataflow=e,this.stamp=t??-1,this.add=[],this.rem=[],this.mod=[],this.fields=null,this.encode=n||null}function cp(e,t){let n=[];return ci(e,t,r=>n.push(r)),n}function O2(e,t){let n={};return e.visit(t,r=>{n[te(r)]=1}),r=>n[te(r)]?null:r}function Ju(e,t){return e?(n,r)=>e(n,r)&&t(n,r):t}yi.prototype={StopPropagation:Yu,ADD:Lr,REM:mi,MOD:gi,ADD_REM:F8,ADD_MOD:S2,ALL:yo,REFLOW:F2,SOURCE:Rl,NO_SOURCE:C2,NO_FIELDS:M2,fork(e){return new yi(this.dataflow).init(this,e)},clone(){let e=this.fork(yo);return e.add=e.add.slice(),e.rem=e.rem.slice(),e.mod=e.mod.slice(),e.source&&(e.source=e.source.slice()),e.materialize(yo|Rl)},addAll(){let e=this;return!e.source||e.add===e.rem||!e.rem.length&&e.source.length===e.add.length||(e=new yi(this.dataflow).init(this),e.add=e.source,e.rem=[]),e},init(e,t){let n=this;return n.stamp=e.stamp,n.encode=e.encode,e.fields&&!(t&M2)&&(n.fields=e.fields),t&Lr?(n.addF=e.addF,n.add=e.add):(n.addF=null,n.add=[]),t&mi?(n.remF=e.remF,n.rem=e.rem):(n.remF=null,n.rem=[]),t&gi?(n.modF=e.modF,n.mod=e.mod):(n.modF=null,n.mod=[]),t&C2?(n.srcF=null,n.source=null):(n.srcF=e.srcF,n.source=e.source,e.cleans&&(n.cleans=e.cleans)),n},runAfter(e){this.dataflow.runAfter(e)},changed(e){let t=e||yo;return t&Lr&&this.add.length||t&mi&&this.rem.length||t&gi&&this.mod.length},reflow(e){if(e)return this.fork(yo).reflow();let t=this.add.length,n=this.source&&this.source.length;return n&&n!==t&&(this.mod=this.source,t&&this.filter(gi,O2(this,Lr))),this},clean(e){return arguments.length?(this.cleans=!!e,this):this.cleans},modifies(e){let t=this.fields||(this.fields={});return N(e)?e.forEach(n=>t[n]=!0):t[e]=!0,this},modified(e,t){let n=this.fields;return(t||this.mod.length)&&n?arguments.length?N(e)?e.some(r=>n[r]):n[e]:!!n:!1},filter(e,t){let n=this;return e&Lr&&(n.addF=Ju(n.addF,t)),e&mi&&(n.remF=Ju(n.remF,t)),e&gi&&(n.modF=Ju(n.modF,t)),e&Rl&&(n.srcF=Ju(n.srcF,t)),n},materialize(e){e||(e=yo);let t=this;return e&Lr&&t.addF&&(t.add=cp(t.add,t.addF),t.addF=null),e&mi&&t.remF&&(t.rem=cp(t.rem,t.remF),t.remF=null),e&gi&&t.modF&&(t.mod=cp(t.mod,t.modF),t.modF=null),e&Rl&&t.srcF&&(t.source=t.source.filter(t.srcF),t.srcF=null),t},visit(e,t){let n=this,r=t;if(e&Rl)return ci(n.source,n.srcF,r),n;e&Lr&&ci(n.add,n.addF,r),e&mi&&ci(n.rem,n.remF,r),e&gi&&ci(n.mod,n.modF,r);let i=n.source;if(e&F2&&i){let a=n.add.length+n.mod.length;a===i.length||(a?ci(i,O2(n,S2),r):ci(i,n.srcF,r))}return n}};function fp(e,t,n,r){let i=this,a=0;this.dataflow=e,this.stamp=t,this.fields=null,this.encode=r||null,this.pulses=n;for(let o of n)if(o.stamp===t){if(o.fields){let l=i.fields||(i.fields={});for(let s in o.fields)l[s]=1}o.changed(i.ADD)&&(a|=i.ADD),o.changed(i.REM)&&(a|=i.REM),o.changed(i.MOD)&&(a|=i.MOD)}this.changes=a}G(fp,yi,{fork(e){let t=new yi(this.dataflow).init(this,e&this.NO_FIELDS);return e!==void 0&&(e&t.ADD&&this.visit(t.ADD,n=>t.add.push(n)),e&t.REM&&this.visit(t.REM,n=>t.rem.push(n)),e&t.MOD&&this.visit(t.MOD,n=>t.mod.push(n))),t},changed(e){return this.changes&e},modified(e){let t=this,n=t.fields;return n&&t.changes&t.MOD?N(e)?e.some(r=>n[r]):n[e]:0},filter(){L("MultiPulse does not support filtering.")},materialize(){L("MultiPulse does not support materialization.")},visit(e,t){let n=this,r=n.pulses,i=r.length,a=0;if(e&n.SOURCE)for(;a<i;++a)r[a].visit(e,t);else for(;a<i;++a)r[a].stamp===n.stamp&&r[a].visit(e,t);return n}});async function C8(e,t,n){let r=this,i=[];if(r._pulse)return z2(r);if(r._pending&&await r._pending,t&&await Uu(r,t),!r._touched.length)return r.debug("Dataflow invoked, but nothing to do."),r;let a=++r._clock;r._pulse=new yi(r,a,e),r._touched.forEach(c=>r._enqueue(c,!0)),r._touched=qu(Ml);let o=0,l,s,u;try{for(;r._heap.size()>0;){if(l=r._heap.pop(),l.rank!==l.qrank){r._enqueue(l,!0);continue}s=l.run(r._getPulse(l,e)),s.then?s=await s:s.async&&(i.push(s.async),s=Yu),s!==Yu&&l._targets&&l._targets.forEach(c=>r._enqueue(c)),++o}}catch(c){r._heap.clear(),u=c}if(r._input={},r._pulse=null,r.debug(`Pulse ${a}: ${o} operators`),u&&(r._postrun=[],r.error(u)),r._postrun.length){let c=r._postrun.sort((f,d)=>d.priority-f.priority);r._postrun=[];for(let f=0;f<c.length;++f)await Uu(r,c[f].callback)}return n&&await Uu(r,n),i.length&&Promise.all(i).then(c=>r.runAsync(null,()=>{c.forEach(f=>{try{f(r)}catch(d){r.error(d)}})})),r}async function M8(e,t,n){for(;this._running;)await this._running;let r=()=>this._running=null;return(this._running=this.evaluate(e,t,n)).then(r,r),this._running}function O8(e,t,n){return this._pulse?z2(this):(this.evaluate(e,t,n),this)}function z8(e,t,n){if(this._pulse||t)this._postrun.push({priority:n||0,callback:e});else try{e(this)}catch(r){this.error(r)}}function z2(e){return e.error("Dataflow already running. Use runAsync() to chain invocations."),e}function N8(e,t){let n=e.stamp<this._clock;n&&(e.stamp=this._clock),(n||t)&&(e.qrank=e.rank,this._heap.push(e))}function R8(e,t){let n=e.source,r=this._clock;return n&&N(n)?new fp(this,r,n.map(i=>i.pulse),t):this._input[e.id]||T8(this._pulse,n&&n.pulse)}function T8(e,t){return t&&t.stamp===e.stamp?t:(e=e.fork(),t&&t!==Yu&&(e.source=t.source),e)}var dp={skip:!1,force:!1};function L8(e,t){let n=t||dp;return this._pulse?this._enqueue(e):this._touched.add(e),n.skip&&e.skip(!0),this}function P8(e,t,n){let r=n||dp;return(e.set(t)||r.force)&&this.touch(e,r),this}function B8(e,t,n){this.touch(e,n||dp);let r=new yi(this,this._clock+(this._pulse?0:1)),i=e.pulse&&e.pulse.source||[];return r.target=e,this._input[e.id]=t.pulse(r,i),this}function I8(e){let t=[];return{clear:()=>t=[],size:()=>t.length,peek:()=>t[0],push:n=>(t.push(n),N2(t,0,t.length-1,e)),pop:()=>{let n=t.pop(),r;return t.length?(r=t[0],t[0]=n,j8(t,0,e)):r=n,r}}}function N2(e,t,n,r){let i,a,o=e[n];for(;n>t;){if(a=n-1>>1,i=e[a],r(o,i)<0){e[n]=i,n=a;continue}break}return e[n]=o}function j8(e,t,n){let r=t,i=e.length,a=e[t],o=(t<<1)+1,l;for(;o<i;)l=o+1,l<i&&n(e[o],e[l])>=0&&(o=l),e[t]=e[o],t=o,o=(t<<1)+1;return e[t]=a,N2(e,r,t,n)}function vo(){this.logger(Ou()),this.logLevel(1),this._clock=0,this._rank=0,this._locale=Kx();try{this._loader=Ru()}catch{}this._touched=qu(Ml),this._input={},this._pulse=null,this._heap=I8((e,t)=>e.qrank-t.qrank),this._postrun=[]}function Tl(e){return function(){return this._log[e].apply(this,arguments)}}vo.prototype={stamp(){return this._clock},loader(e){return arguments.length?(this._loader=e,this):this._loader},locale(e){return arguments.length?(this._locale=e,this):this._locale},logger(e){return arguments.length?(this._log=e,this):this._log},error:Tl("error"),warn:Tl("warn"),info:Tl("info"),debug:Tl("debug"),logLevel:Tl("level"),cleanThreshold:1e4,add:h8,connect:p8,rank:D8,rerank:S8,pulse:B8,touch:L8,update:P8,changeset:ua,ingest:v8,parse:y8,preload:x8,request:b8,events:g8,on:k8,evaluate:C8,run:O8,runAsync:M8,runAfter:z8,_enqueue:N8,_getPulse:R8};function O(e,t){Oe.call(this,e,null,t)}G(O,Oe,{run(e){if(e.stamp<this.stamp)return e.StopPropagation;let t;return this.skip()?this.skip(!1):t=this.evaluate(e),t||(t=e),t.then?t=t.then(n=>this.pulse=n):t!==e.StopPropagation&&(this.pulse=t),t},evaluate(e){let t=this.marshall(e.stamp),n=this.transform(t,e);return t.clear(),n},transform(){}});var bo={};function R2(e){let t=T2(e);return t&&t.Definition||null}function T2(e){return e&&(e=e.toLowerCase()),K(bo,e)?bo[e]:null}function*L2(e,t){if(t==null)for(let n of e)n!=null&&n!==""&&(n=+n)>=n&&(yield n);else{let n=-1;for(let r of e)r=t(r,++n,e),r!=null&&r!==""&&(r=+r)>=r&&(yield r)}}function hp(e,t,n){let r=Float64Array.from(L2(e,n));return r.sort(zl),t.map(i=>b2(r,i))}function pp(e,t){return hp(e,[.25,.5,.75],t)}function mp(e,t){let n=e.length,r=QO(e,t),i=pp(e,t),a=(i[2]-i[0])/1.34;return 1.06*(Math.min(r,a)||r||Math.abs(i[0])||1)*n**-.2}function P2(e){let t=e.maxbins||20,n=e.base||10,r=Math.log(n),i=e.divide||[5,2],a=e.extent[0],o=e.extent[1],l,s,u,c,f,d,h=e.span||o-a||Math.abs(a)||1;if(e.step)l=e.step;else if(e.steps){for(c=h/t,f=0,d=e.steps.length;f<d&&e.steps[f]<c;++f);l=e.steps[Math.max(0,f-1)]}else{for(s=Math.ceil(Math.log(t)/r),u=e.minstep||0,l=Math.max(u,n**+(Math.round(Math.log(h)/r)-s));Math.ceil(h/l)>t;)l*=n;for(f=0,d=i.length;f<d;++f)c=l/i[f],c>=u&&h/c<=t&&(l=c)}c=Math.log(l);let p=n**(-(c>=0?0:~~(-c/r)+1)-1);return(e.nice||e.nice===void 0)&&(c=Math.floor(a/l+p)*l,a=a<c?c-l:c,o=Math.ceil(o/l)*l),{start:a,stop:o===a?a+l:o,step:l}}var xn=Math.random;function q8(e){xn=e}function B2(e,t,n,r){if(!e.length)return[void 0,void 0];let i=Float64Array.from(L2(e,r)),a=i.length,o=t,l,s,u,c;for(u=0,c=Array(o);u<o;++u){for(l=0,s=0;s<a;++s)l+=i[~~(xn()*a)];c[u]=l/a}return c.sort(zl),[lp(c,n/2),lp(c,1-n/2)]}function I2(e,t,n,r){r||(r=(d=>d));let i=e.length,a=new Float64Array(i),o=0,l=1,s=r(e[0]),u=s,c=s+t,f;for(;l<i;++l){if(f=r(e[l]),f>=c){for(u=(s+u)/2;o<l;++o)a[o]=u;c=f+t,s=f}u=f}for(u=(s+u)/2;o<l;++o)a[o]=u;return n?U8(a,t+t/4):a}function U8(e,t){let n=e.length,r=0,i=1,a,o;for(;e[r]===e[i];)++i;for(;i<n;){for(a=i+1;e[i]===e[a];)++a;if(e[i]-e[i-1]<t){for(o=i+(r+a-i-i>>1);o<i;)e[o++]=e[i];for(;o>i;)e[o--]=e[r]}r=i,i=a}return e}function W8(e){return function(){return e=(1103515245*e+12345)%2147483647,e/2147483647}}function H8(e,t){t??(t=e,e=0);let n,r,i,a={min(o){return arguments.length?(n=o||0,i=r-n,a):n},max(o){return arguments.length?(r=o||0,i=r-n,a):r},sample(){return n+Math.floor(i*xn())},pdf(o){return o===Math.floor(o)&&o>=n&&o<r?1/i:0},cdf(o){let l=Math.floor(o);return l<n?0:l>=r?1:(l-n+1)/i},icdf(o){return o>=0&&o<=1?n-1+Math.floor(o*i):NaN}};return a.min(e).max(t)}var j2=Math.sqrt(2*Math.PI),G8=Math.SQRT2,Ll=NaN;function Qu(e,t){e||(e=0),t??(t=1);let n=0,r=0,i,a;if(Ll===Ll)n=Ll,Ll=NaN;else{do n=xn()*2-1,r=xn()*2-1,i=n*n+r*r;while(i===0||i>1);a=Math.sqrt(-2*Math.log(i)/i),n*=a,Ll=r*a}return e+n*t}function gp(e,t,n){n??(n=1);let r=(e-(t||0))/n;return Math.exp(-.5*r*r)/(n*j2)}function Ku(e,t,n){t||(t=0),n??(n=1);let r=(e-t)/n,i=Math.abs(r),a;if(i>37)a=0;else{let o=Math.exp(-i*i/2),l;i<7.07106781186547?(l=.0352624965998911*i+.700383064443688,l=l*i+6.37396220353165,l=l*i+33.912866078383,l=l*i+112.079291497871,l=l*i+221.213596169931,l=l*i+220.206867912376,a=o*l,l=.0883883476483184*i+1.75566716318264,l=l*i+16.064177579207,l=l*i+86.7807322029461,l=l*i+296.564248779674,l=l*i+637.333633378831,l=l*i+793.826512519948,l=l*i+440.413735824752,a/=l):(l=i+.65,l=i+4/l,l=i+3/l,l=i+2/l,l=i+1/l,a=o/l/2.506628274631)}return r>0?1-a:a}function Zu(e,t,n){return e<0||e>1?NaN:(t||0)+(n??1)*G8*V8(2*e-1)}function V8(e){let t=-Math.log((1-e)*(1+e)),n;return t<6.25?(t-=3.125,n=-364441206401782e-35,n=-16850591381820166e-35+n*t,n=128584807152564e-32+n*t,n=11157877678025181e-33+n*t,n=-1333171662854621e-31+n*t,n=20972767875968562e-33+n*t,n=6637638134358324e-30+n*t,n=-4054566272975207e-29+n*t,n=-8151934197605472e-29+n*t,n=26335093153082323e-28+n*t,n=-12975133253453532e-27+n*t,n=-5415412054294628e-26+n*t,n=10512122733215323e-25+n*t,n=-4112633980346984e-24+n*t,n=-29070369957882005e-24+n*t,n=42347877827932404e-23+n*t,n=-13654692000834679e-22+n*t,n=-13882523362786469e-21+n*t,n=.00018673420803405714+n*t,n=-.000740702534166267+n*t,n=-.006033670871430149+n*t,n=.24015818242558962+n*t,n=1.6536545626831027+n*t):t<16?(t=Math.sqrt(t)-3.25,n=22137376921775787e-25,n=9075656193888539e-23+n*t,n=-27517406297064545e-23+n*t,n=18239629214389228e-24+n*t,n=15027403968909828e-22+n*t,n=-4013867526981546e-21+n*t,n=29234449089955446e-22+n*t,n=12475304481671779e-21+n*t,n=-47318229009055734e-21+n*t,n=6828485145957318e-20+n*t,n=24031110387097894e-21+n*t,n=-.0003550375203628475+n*t,n=.0009532893797373805+n*t,n=-.0016882755560235047+n*t,n=.002491442096107851+n*t,n=-.003751208507569241+n*t,n=.005370914553590064+n*t,n=1.0052589676941592+n*t,n=3.0838856104922208+n*t):Number.isFinite(t)?(t=Math.sqrt(t)-5,n=-27109920616438573e-27,n=-2555641816996525e-25+n*t,n=15076572693500548e-25+n*t,n=-3789465440126737e-24+n*t,n=761570120807834e-23+n*t,n=-1496002662714924e-23+n*t,n=2914795345090108e-23+n*t,n=-6771199775845234e-23+n*t,n=22900482228026655e-23+n*t,n=-99298272942317e-20+n*t,n=4526062597223154e-21+n*t,n=-1968177810553167e-20+n*t,n=7599527703001776e-20+n*t,n=-.00021503011930044477+n*t,n=-.00013871931833623122+n*t,n=1.0103004648645344+n*t,n=4.849906401408584+n*t):n=1/0,n*e}function yp(e,t){let n,r,i={mean(a){return arguments.length?(n=a||0,i):n},stdev(a){return arguments.length?(r=a??1,i):r},sample:()=>Qu(n,r),pdf:a=>gp(a,n,r),cdf:a=>Ku(a,n,r),icdf:a=>Zu(a,n,r)};return i.mean(e).stdev(t)}function vp(e,t){let n=yp(),r=0,i={data(a){return arguments.length?(e=a,r=a?a.length:0,i.bandwidth(t)):e},bandwidth(a){return arguments.length?(t=a,!t&&e&&(t=mp(e)),i):t},sample(){return e[~~(xn()*r)]+t*n.sample()},pdf(a){let o=0,l=0;for(;l<r;++l)o+=n.pdf((a-e[l])/t);return o/t/r},cdf(a){let o=0,l=0;for(;l<r;++l)o+=n.cdf((a-e[l])/t);return o/r},icdf(){throw Error("KDE icdf not supported.")}};return i.data(e)}function bp(e,t){return e||(e=0),t??(t=1),Math.exp(e+Qu()*t)}function xp(e,t,n){if(e<=0)return 0;t||(t=0),n??(n=1);let r=(Math.log(e)-t)/n;return Math.exp(-.5*r*r)/(n*j2*e)}function wp(e,t,n){return Ku(Math.log(e),t,n)}function _p(e,t,n){return Math.exp(Zu(e,t,n))}function q2(e,t){let n,r,i={mean(a){return arguments.length?(n=a||0,i):n},stdev(a){return arguments.length?(r=a??1,i):r},sample:()=>bp(n,r),pdf:a=>xp(a,n,r),cdf:a=>wp(a,n,r),icdf:a=>_p(a,n,r)};return i.mean(e).stdev(t)}function U2(e,t){let n=0,r;function i(o){let l=[],s=0,u;for(u=0;u<n;++u)s+=l[u]=o[u]==null?1:+o[u];for(u=0;u<n;++u)l[u]/=s;return l}let a={weights(o){return arguments.length?(r=i(t=o||[]),a):t},distributions(o){return arguments.length?(o?(n=o.length,e=o):(n=0,e=[]),a.weights(t)):e},sample(){let o=xn(),l=e[n-1],s=r[0],u=0;for(;u<n-1;s+=r[++u])if(o<s){l=e[u];break}return l.sample()},pdf(o){let l=0,s=0;for(;s<n;++s)l+=r[s]*e[s].pdf(o);return l},cdf(o){let l=0,s=0;for(;s<n;++s)l+=r[s]*e[s].cdf(o);return l},icdf(){throw Error("Mixture icdf not supported.")}};return a.distributions(e).weights(t)}function kp(e,t){return t??(t=e??1,e=0),e+(t-e)*xn()}function Ep(e,t,n){return n??(n=t??1,t=0),e>=t&&e<=n?1/(n-t):0}function $p(e,t,n){return n??(n=t??1,t=0),e<t?0:e>n?1:(e-t)/(n-t)}function Ap(e,t,n){return n??(n=t??1,t=0),e>=0&&e<=1?t+e*(n-t):NaN}function W2(e,t){let n,r,i={min(a){return arguments.length?(n=a||0,i):n},max(a){return arguments.length?(r=a??1,i):r},sample:()=>kp(n,r),pdf:a=>Ep(a,n,r),cdf:a=>$p(a,n,r),icdf:a=>Ap(a,n,r)};return t??(t=e??1,e=0),i.min(e).max(t)}function Dp(e,t,n){let r=0,i=0;for(let a of e){let o=n(a);t(a)==null||o==null||isNaN(o)||(r+=(o-r)/++i)}return{coef:[r],predict:()=>r,rSquared:0}}function Pl(e,t,n,r){let i=r-e*e,a=Math.abs(i)<1e-24?0:(n-e*t)/i;return[t-a*e,a]}function ec(e,t,n,r){e=e.filter(h=>{let p=t(h),m=n(h);return p!=null&&(p=+p)>=p&&m!=null&&(m=+m)>=m}),r&&e.sort((h,p)=>t(h)-t(p));let i=e.length,a=new Float64Array(i),o=new Float64Array(i),l=0,s=0,u=0,c,f,d;for(d of e)a[l]=c=+t(d),o[l]=f=+n(d),++l,s+=(c-s)/l,u+=(f-u)/l;for(l=0;l<i;++l)a[l]-=s,o[l]-=u;return[a,o,s,u]}function Bl(e,t,n,r){let i=-1,a,o;for(let l of e)a=t(l),o=n(l),a!=null&&(a=+a)>=a&&o!=null&&(o=+o)>=o&&r(a,o,++i)}function xo(e,t,n,r,i){let a=0,o=0;return Bl(e,t,n,(l,s)=>{let u=s-i(l),c=s-r;a+=u*u,o+=c*c}),1-a/o}function Sp(e,t,n){let r=0,i=0,a=0,o=0,l=0;Bl(e,t,n,(c,f)=>{++l,r+=(c-r)/l,i+=(f-i)/l,a+=(c*f-a)/l,o+=(c*c-o)/l});let s=Pl(r,i,a,o),u=c=>s[0]+s[1]*c;return{coef:s,predict:u,rSquared:xo(e,t,n,i,u)}}function H2(e,t,n){let r=0,i=0,a=0,o=0,l=0;Bl(e,t,n,(c,f)=>{++l,c=Math.log(c),r+=(c-r)/l,i+=(f-i)/l,a+=(c*f-a)/l,o+=(c*c-o)/l});let s=Pl(r,i,a,o),u=c=>s[0]+s[1]*Math.log(c);return{coef:s,predict:u,rSquared:xo(e,t,n,i,u)}}function G2(e,t,n){let[r,i,a,o]=ec(e,t,n),l=0,s=0,u=0,c=0,f=0,d,h,p;Bl(e,t,n,(v,b)=>{d=r[f++],h=Math.log(b),p=d*b,l+=(b*h-l)/f,s+=(p-s)/f,u+=(p*h-u)/f,c+=(d*p-c)/f});let[m,g]=Pl(s/o,l/o,u/o,c/o),y=v=>Math.exp(m+g*(v-a));return{coef:[Math.exp(m-g*a),g],predict:y,rSquared:xo(e,t,n,o,y)}}function V2(e,t,n){let r=0,i=0,a=0,o=0,l=0,s=0;Bl(e,t,n,(f,d)=>{let h=Math.log(f),p=Math.log(d);++s,r+=(h-r)/s,i+=(p-i)/s,a+=(h*p-a)/s,o+=(h*h-o)/s,l+=(d-l)/s});let u=Pl(r,i,a,o),c=f=>u[0]*f**+u[1];return u[0]=Math.exp(u[0]),{coef:u,predict:c,rSquared:xo(e,t,n,l,c)}}function Fp(e,t,n){let[r,i,a,o]=ec(e,t,n),l=r.length,s=0,u=0,c=0,f=0,d=0,h,p,m,g;for(h=0;h<l;)p=r[h],m=i[h++],g=p*p,s+=(g-s)/h,u+=(g*p-u)/h,c+=(g*g-c)/h,f+=(p*m-f)/h,d+=(g*m-d)/h;let y=c-s*s,v=s*y-u*u,b=(d*s-f*u)/v,w=(f*y-d*u)/v,_=-b*s,k=x=>(x-=a,b*x*x+w*x+_+o);return{coef:[_-w*a+b*a*a+o,w-2*b*a,b],predict:k,rSquared:xo(e,t,n,o,k)}}function X2(e,t,n,r){if(r===0)return Dp(e,t,n);if(r===1)return Sp(e,t,n);if(r===2)return Fp(e,t,n);let[i,a,o,l]=ec(e,t,n),s=i.length,u=[],c=[],f=r+1,d,h,p,m,g;for(d=0;d<f;++d){for(p=0,m=0;p<s;++p)m+=i[p]**+d*a[p];for(u.push(m),g=new Float64Array(f),h=0;h<f;++h){for(p=0,m=0;p<s;++p)m+=i[p]**+(d+h);g[h]=m}c.push(g)}c.push(u);let y=Y8(c),v=b=>{b-=o;let w=l+y[0]+y[1]*b+y[2]*b*b;for(d=3;d<f;++d)w+=y[d]*b**+d;return w};return{coef:X8(f,y,-o,l),predict:v,rSquared:xo(e,t,n,l,v)}}function X8(e,t,n,r){let i=Array(e),a,o,l,s;for(a=0;a<e;++a)i[a]=0;for(a=e-1;a>=0;--a)for(l=t[a],s=1,i[a]+=l,o=1;o<=a;++o)s*=(a+1-o)/o,i[a-o]+=l*n**+o*s;return i[0]+=r,i}function Y8(e){let t=e.length-1,n=[],r,i,a,o,l;for(r=0;r<t;++r){for(o=r,i=r+1;i<t;++i)Math.abs(e[r][i])>Math.abs(e[r][o])&&(o=i);for(a=r;a<t+1;++a)l=e[a][r],e[a][r]=e[a][o],e[a][o]=l;for(i=r+1;i<t;++i)for(a=t;a>=r;a--)e[a][i]-=e[a][r]*e[r][i]/e[r][r]}for(i=t-1;i>=0;--i){for(l=0,a=i+1;a<t;++a)l+=e[a][i]*n[a];n[i]=(e[t][i]-l)/e[i][i]}return n}var Y2=2,J2=1e-12;function Q2(e,t,n,r){let[i,a,o,l]=ec(e,t,n,!0),s=i.length,u=Math.max(2,~~(r*s)),c=new Float64Array(s),f=new Float64Array(s),d=new Float64Array(s).fill(1);for(let h=-1;++h<=Y2;){let p=[0,u-1];for(let g=0;g<s;++g){let y=i[g],v=p[0],b=p[1],w=y-i[v]>i[b]-y?v:b,_=0,k=0,x=0,E=0,$=0,D=1/Math.abs(i[w]-y||1);for(let S=v;S<=b;++S){let M=i[S],A=a[S],C=J8(Math.abs(y-M)*D)*d[S],P=M*C;_+=C,k+=P,x+=A*C,E+=A*P,$+=M*P}let[F,T]=Pl(k/_,x/_,E/_,$/_);c[g]=F+T*y,f[g]=Math.abs(a[g]-c[g]),Q8(i,g+1,p)}if(h===Y2)break;let m=x2(f);if(Math.abs(m)<J2)break;for(let g=0,y,v;g<s;++g)y=f[g]/(6*m),d[g]=y>=1?J2:(v=1-y*y)*v}return K8(i,c,o,l)}function J8(e){return(e=1-e*e*e)*e*e}function Q8(e,t,n){let r=e[t],i=n[0],a=n[1]+1;if(!(a>=e.length))for(;t>i&&e[a]-r<=r-e[i];)n[0]=++i,n[1]=a,++a}function K8(e,t,n,r){let i=e.length,a=[],o=0,l=0,s=[],u;for(;o<i;++o)u=e[o]+n,s[0]===u?s[1]+=(t[o]-s[1])/++l:(l=0,s[1]+=r,s=[u,t[o]],a.push(s));return s[1]+=r,a}var Z8=.5*Math.PI/180;function tc(e,t,n,r){n||(n=25),r=Math.max(n,r||200);let i=m=>[m,e(m)],a=t[0],o=t[1],l=o-a,s=l/r,u=[i(a)],c=[];if(n===r){for(let m=1;m<r;++m)u.push(i(a+m/n*l));return u.push(i(o)),u}else{c.push(i(o));for(let m=n;--m>0;)c.push(i(a+m/n*l))}let f=u[0],d=c[c.length-1],h=1/l,p=e9(f[1],c);for(;d;){let m=i((f[0]+d[0])/2);m[0]-f[0]>=s&&t9(f,m,d,h,p)>Z8?c.push(m):(f=d,u.push(d),c.pop()),d=c[c.length-1]}return u}function e9(e,t){let n=e,r=e,i=t.length;for(let a=0;a<i;++a){let o=t[a][1];o<n&&(n=o),o>r&&(r=o)}return 1/(r-n)}function t9(e,t,n,r,i){let a=Math.atan2(i*(n[1]-e[1]),r*(n[0]-e[0])),o=Math.atan2(i*(t[1]-e[1]),r*(t[0]-e[0]));return Math.abs(a-o)}var n9=Gt({aggregate:()=>vi,bin:()=>zp,collect:()=>Np,compare:()=>rw,countpattern:()=>Rp,cross:()=>Tp,density:()=>Lp,dotbin:()=>Bp,expression:()=>cw,extent:()=>Ip,facet:()=>nc,field:()=>fw,filter:()=>qp,flatten:()=>Up,fold:()=>Wp,formula:()=>Hp,generate:()=>dw,impute:()=>Gp,joinaggregate:()=>Vp,kde:()=>Xp,key:()=>hw,load:()=>pw,lookup:()=>Jp,multiextent:()=>mw,multivalues:()=>gw,params:()=>yw,pivot:()=>Qp,prefacet:()=>vw,project:()=>Kp,proxy:()=>bw,quantile:()=>Zp,relay:()=>xw,sample:()=>em,sequence:()=>tm,sieve:()=>ww,subflow:()=>jp,timeunit:()=>nm,tupleindex:()=>kw,values:()=>Ew,window:()=>rm},1);function r9(e){return t=>{let n=e.length,r=1,i=String(e[0](t));for(;r<n;++r)i+="|"+e[r](t);return i}}function Cp(e){return!e||!e.length?function(){return""}:e.length===1?e[0]:r9(e)}function K2(e,t,n){return n||e+(t?"_"+t:"")}var Mp=()=>{},i9={init:Mp,add:Mp,rem:Mp,idx:0},Il={values:{init:e=>e.cell.store=!0,value:e=>e.cell.data.values(),idx:-1},count:{value:e=>e.cell.num},__count__:{value:e=>e.missing+e.valid},missing:{value:e=>e.missing},valid:{value:e=>e.valid},sum:{init:e=>e.sum=0,value:e=>e.valid?e.sum:void 0,add:(e,t)=>e.sum+=+t,rem:(e,t)=>e.sum-=t},product:{init:e=>e.product=1,value:e=>e.valid?e.product:void 0,add:(e,t)=>e.product*=t,rem:(e,t)=>e.product/=t},mean:{init:e=>e.mean=0,value:e=>e.valid?e.mean:void 0,add:(e,t)=>(e.mean_d=t-e.mean,e.mean+=e.mean_d/e.valid),rem:(e,t)=>(e.mean_d=t-e.mean,e.mean-=e.valid?e.mean_d/e.valid:e.mean)},average:{value:e=>e.valid?e.mean:void 0,req:["mean"],idx:1},variance:{init:e=>e.dev=0,value:e=>e.valid>1?e.dev/(e.valid-1):void 0,add:(e,t)=>e.dev+=e.mean_d*(t-e.mean),rem:(e,t)=>e.dev-=e.mean_d*(t-e.mean),req:["mean"],idx:1},variancep:{value:e=>e.valid>1?e.dev/e.valid:void 0,req:["variance"],idx:2},stdev:{value:e=>e.valid>1?Math.sqrt(e.dev/(e.valid-1)):void 0,req:["variance"],idx:2},stdevp:{value:e=>e.valid>1?Math.sqrt(e.dev/e.valid):void 0,req:["variance"],idx:2},stderr:{value:e=>e.valid>1?Math.sqrt(e.dev/(e.valid*(e.valid-1))):void 0,req:["variance"],idx:2},distinct:{value:e=>e.cell.data.distinct(e.get),req:["values"],idx:3},ci0:{value:e=>e.cell.data.ci0(e.get),req:["values"],idx:3},ci1:{value:e=>e.cell.data.ci1(e.get),req:["values"],idx:3},median:{value:e=>e.cell.data.q2(e.get),req:["values"],idx:3},q1:{value:e=>e.cell.data.q1(e.get),req:["values"],idx:3},q3:{value:e=>e.cell.data.q3(e.get),req:["values"],idx:3},min:{init:e=>e.min=void 0,value:e=>e.min=Number.isNaN(e.min)?e.cell.data.min(e.get):e.min,add:(e,t)=>{(t<e.min||e.min===void 0)&&(e.min=t)},rem:(e,t)=>{t<=e.min&&(e.min=NaN)},req:["values"],idx:4},max:{init:e=>e.max=void 0,value:e=>e.max=Number.isNaN(e.max)?e.cell.data.max(e.get):e.max,add:(e,t)=>{(t>e.max||e.max===void 0)&&(e.max=t)},rem:(e,t)=>{t>=e.max&&(e.max=NaN)},req:["values"],idx:4},argmin:{init:e=>e.argmin=void 0,value:e=>e.argmin||e.cell.data.argmin(e.get),add:(e,t,n)=>{t<e.min&&(e.argmin=n)},rem:(e,t)=>{t<=e.min&&(e.argmin=void 0)},req:["min","values"],idx:3},argmax:{init:e=>e.argmax=void 0,value:e=>e.argmax||e.cell.data.argmax(e.get),add:(e,t,n)=>{t>e.max&&(e.argmax=n)},rem:(e,t)=>{t>=e.max&&(e.argmax=void 0)},req:["max","values"],idx:3},exponential:{init:(e,t)=>{e.exp=0,e.exp_r=t},value:e=>e.valid?e.exp*(1-e.exp_r)/(1-e.exp_r**e.valid):void 0,add:(e,t)=>e.exp=e.exp_r*e.exp+t,rem:(e,t)=>e.exp=(e.exp-t/e.exp_r**(e.valid-1))/e.exp_r},exponentialb:{value:e=>e.valid?e.exp*(1-e.exp_r):void 0,req:["exponential"],idx:1}},jl=Object.keys(Il).filter(e=>e!=="__count__");function a9(e,t){return(n,r)=>pe({name:e,aggregate_param:r,out:n||e},i9,t)}[...jl,"__count__"].forEach(e=>{Il[e]=a9(e,Il[e])});function Z2(e,t,n){return Il[e](n,t)}function ew(e,t){return e.idx-t.idx}function o9(e){let t={};e.forEach(r=>t[r.name]=r);let n=r=>{r.req&&r.req.forEach(i=>{t[i]||n(t[i]=Il[i]())})};return e.forEach(n),Object.values(t).sort(ew)}function l9(){this.valid=0,this.missing=0,this._ops.forEach(e=>e.aggregate_param==null?e.init(this):e.init(this,e.aggregate_param))}function s9(e,t){if(e==null||e===""){++this.missing;return}e===e&&(++this.valid,this._ops.forEach(n=>n.add(this,e,t)))}function u9(e,t){if(e==null||e===""){--this.missing;return}e===e&&(--this.valid,this._ops.forEach(n=>n.rem(this,e,t)))}function c9(e){return this._out.forEach(t=>e[t.out]=t.value(this)),e}function tw(e,t){let n=t||bn,r=o9(e),i=e.slice().sort(ew);function a(o){this._ops=r,this._out=i,this.cell=o,this.init()}return a.prototype.init=l9,a.prototype.add=s9,a.prototype.rem=u9,a.prototype.set=c9,a.prototype.get=n,a.fields=e.map(o=>o.out),a}function Op(e){this._key=e?Tr(e):te,this.reset()}var ct=Op.prototype;ct.reset=function(){this._add=[],this._rem=[],this._ext=null,this._get=null,this._q=null},ct.add=function(e){this._add.push(e)},ct.rem=function(e){this._rem.push(e)},ct.values=function(){if(this._get=null,this._rem.length===0)return this._add;let e=this._add,t=this._rem,n=this._key,r=e.length,i=t.length,a=Array(r-i),o={},l,s,u;for(l=0;l<i;++l)o[n(t[l])]=1;for(l=0,s=0;l<r;++l)o[n(u=e[l])]?o[n(u)]=0:a[s++]=u;return this._rem=[],this._add=a},ct.distinct=function(e){let t=this.values(),n={},r=t.length,i=0,a;for(;--r>=0;)a=e(t[r])+"",K(n,a)||(n[a]=1,++i);return i},ct.extent=function(e){if(this._get!==e||!this._ext){let t=this.values(),n=e2(t,e);this._ext=[t[n[0]],t[n[1]]],this._get=e}return this._ext},ct.argmin=function(e){return this.extent(e)[0]||{}},ct.argmax=function(e){return this.extent(e)[1]||{}},ct.min=function(e){let t=this.extent(e)[0];return t==null?void 0:e(t)},ct.max=function(e){let t=this.extent(e)[1];return t==null?void 0:e(t)},ct.quartile=function(e){return(this._get!==e||!this._q)&&(this._q=pp(this.values(),e),this._get=e),this._q},ct.q1=function(e){return this.quartile(e)[0]},ct.q2=function(e){return this.quartile(e)[1]},ct.q3=function(e){return this.quartile(e)[2]},ct.ci=function(e){return(this._get!==e||!this._ci)&&(this._ci=B2(this.values(),1e3,.05,e),this._get=e),this._ci},ct.ci0=function(e){return this.ci(e)[0]},ct.ci1=function(e){return this.ci(e)[1]};function vi(e){O.call(this,null,e),this._adds=[],this._mods=[],this._alen=0,this._mlen=0,this._drop=!0,this._cross=!1,this._dims=[],this._dnames=[],this._measures=[],this._countOnly=!1,this._counts=null,this._prev=null,this._inputs=null,this._outputs=null}vi.Definition={type:"Aggregate",metadata:{generates:!0,changes:!0},params:[{name:"groupby",type:"field",array:!0},{name:"ops",type:"enum",array:!0,values:jl},{name:"aggregate_params",type:"number",null:!0,array:!0},{name:"fields",type:"field",null:!0,array:!0},{name:"as",type:"string",null:!0,array:!0},{name:"drop",type:"boolean",default:!0},{name:"cross",type:"boolean",default:!1},{name:"key",type:"field"}]},G(vi,O,{transform(e,t){let n=this,r=t.fork(t.NO_SOURCE|t.NO_FIELDS),i=e.modified();return n.stamp=r.stamp,n.value&&(i||t.modified(n._inputs,!0))?(n._prev=n.value,n.value=i?n.init(e):Object.create(null),t.visit(t.SOURCE,a=>n.add(a))):(n.value=n.value||n.init(e),t.visit(t.REM,a=>n.rem(a)),t.visit(t.ADD,a=>n.add(a))),r.modifies(n._outputs),n._drop=e.drop!==!1,e.cross&&n._dims.length>1&&(n._drop=!1,n.cross()),t.clean()&&n._drop&&r.clean(!0).runAfter(()=>this.clean()),n.changes(r)},cross(){let e=this,t=e.value,n=e._dnames,r=n.map(()=>({})),i=n.length;function a(l){let s,u,c,f;for(s in l)for(c=l[s].tuple,u=0;u<i;++u)r[u][f=c[n[u]]]=f}a(e._prev),a(t);function o(l,s,u){let c=n[u],f=r[u++];for(let d in f){let h=l?l+"|"+d:d;s[c]=f[d],u<i?o(h,s,u):t[h]||e.cell(h,s)}}o("",{},0)},init(e){let t=this._inputs=[],n=this._outputs=[],r={};function i(v){let b=Q($t(v)),w=b.length,_=0,k;for(;_<w;++_)r[k=b[_]]||(r[k]=1,t.push(k))}this._dims=Q(e.groupby),this._dnames=this._dims.map(v=>{let b=qe(v);return i(v),n.push(b),b}),this.cellkey=e.key?e.key:Cp(this._dims),this._countOnly=!0,this._counts=[],this._measures=[];let a=e.fields||[null],o=e.ops||["count"],l=e.aggregate_params||[null],s=e.as||[],u=a.length,c={},f,d,h,p,m,g,y;for(u!==o.length&&L("Unmatched number of fields and aggregate ops."),y=0;y<u;++y){if(f=a[y],d=o[y],h=l[y]||null,f==null&&d!=="count"&&L("Null aggregate field specified."),m=qe(f),g=K2(d,m,s[y]),n.push(g),d==="count"){this._counts.push(g);continue}p=c[m],p||(i(f),p=c[m]=[],p.field=f,this._measures.push(p)),d!=="count"&&(this._countOnly=!1),p.push(Z2(d,h,g))}return this._measures=this._measures.map(v=>tw(v,v.field)),Object.create(null)},cellkey:Cp(),cell(e,t){let n=this.value[e];return n?n.num===0&&this._drop&&n.stamp<this.stamp?(n.stamp=this.stamp,this._adds[this._alen++]=n):n.stamp<this.stamp&&(n.stamp=this.stamp,this._mods[this._mlen++]=n):(n=this.value[e]=this.newcell(e,t),this._adds[this._alen++]=n),n},newcell(e,t){let n={key:e,num:0,agg:null,tuple:this.newtuple(t,this._prev&&this._prev[e]),stamp:this.stamp,store:!1};if(!this._countOnly){let r=this._measures,i=r.length;n.agg=Array(i);for(let a=0;a<i;++a)n.agg[a]=new r[a](n)}return n.store&&(n.data=new Op),n},newtuple(e,t){let n=this._dnames,r=this._dims,i=r.length,a={};for(let o=0;o<i;++o)a[n[o]]=r[o](e);return t?$2(t.tuple,a):_e(a)},clean(){let e=this.value;for(let t in e)e[t].num===0&&delete e[t]},add(e){let t=this.cellkey(e),n=this.cell(t,e);if(n.num+=1,this._countOnly)return;n.store&&n.data.add(e);let r=n.agg;for(let i=0,a=r.length;i<a;++i)r[i].add(r[i].get(e),e)},rem(e){let t=this.cellkey(e),n=this.cell(t,e);if(--n.num,this._countOnly)return;n.store&&n.data.rem(e);let r=n.agg;for(let i=0,a=r.length;i<a;++i)r[i].rem(r[i].get(e),e)},celltuple(e){let t=e.tuple,n=this._counts;e.store&&e.data.values();for(let r=0,i=n.length;r<i;++r)t[n[r]]=e.num;if(!this._countOnly){let r=e.agg;for(let i=0,a=r.length;i<a;++i)r[i].set(t)}return t},changes(e){let t=this._adds,n=this._mods,r=this._prev,i=this._drop,a=e.add,o=e.rem,l=e.mod,s,u,c,f;if(r)for(u in r)s=r[u],(!i||s.num)&&o.push(s.tuple);for(c=0,f=this._alen;c<f;++c)a.push(this.celltuple(t[c])),t[c]=null;for(c=0,f=this._mlen;c<f;++c)s=n[c],(s.num===0&&i?o:l).push(this.celltuple(s)),n[c]=null;return this._alen=this._mlen=0,this._prev=null,e}});var f9=1e-14;function zp(e){O.call(this,null,e)}zp.Definition={type:"Bin",metadata:{modifies:!0},params:[{name:"field",type:"field",required:!0},{name:"interval",type:"boolean",default:!0},{name:"anchor",type:"number"},{name:"maxbins",type:"number",default:20},{name:"base",type:"number",default:10},{name:"divide",type:"number",array:!0,default:[5,2]},{name:"extent",type:"number",array:!0,length:2,required:!0},{name:"span",type:"number"},{name:"step",type:"number"},{name:"steps",type:"number",array:!0},{name:"minstep",type:"number",default:0},{name:"nice",type:"boolean",default:!0},{name:"name",type:"string"},{name:"as",type:"string",array:!0,length:2,default:["bin0","bin1"]}]},G(zp,O,{transform(e,t){let n=e.interval!==!1,r=this._bins(e),i=r.start,a=r.step,o=e.as||["bin0","bin1"],l=o[0],s=o[1],u;return e.modified()?(t=t.reflow(!0),u=t.SOURCE):u=t.modified($t(e.field))?t.ADD_MOD:t.ADD,t.visit(u,n?c=>{let f=r(c);c[l]=f,c[s]=f==null?null:i+a*(1+(f-i)/a)}:c=>c[l]=r(c)),t.modifies(n?o:l)},_bins(e){if(this.value&&!e.modified())return this.value;let t=e.field,n=P2(e),r=n.step,i=n.start,a=i+Math.ceil((n.stop-i)/r)*r,o,l;(o=e.anchor)!=null&&(l=o-(i+r*Math.floor((o-i)/r)),i+=l,a+=l);let s=function(u){let c=vn(t(u));return c==null?null:c<i?-1/0:c>a?1/0:(c=Math.max(i,Math.min(c,a-r)),i+r*Math.floor(f9+(c-i)/r))};return s.start=i,s.stop=n.stop,s.step=r,this.value=ho(s,$t(t),e.name||"bin_"+qe(t))}});function nw(e,t,n){let r=e,i=t||[],a=n||[],o={},l=0;return{add:s=>a.push(s),remove:s=>o[r(s)]=++l,size:()=>i.length,data:(s,u)=>(l&&(l=(i=i.filter(c=>!o[r(c)]),o={},0)),u&&s&&i.sort(s),a.length&&(i=s?Qx(s,i,a.sort(s)):i.concat(a),a=[]),i)}}function Np(e){O.call(this,[],e)}Np.Definition={type:"Collect",metadata:{source:!0},params:[{name:"sort",type:"compare"}]},G(Np,O,{transform(e,t){let n=t.fork(t.ALL),r=nw(te,this.value,n.materialize(n.ADD).add),i=e.sort,a=t.changed()||i&&(e.modified("sort")||t.modified(i.fields));return n.visit(n.REM,r.remove),this.modified(a),this.value=n.source=r.data(sa(i),a),t.source&&t.source.root&&(this.value.root=t.source.root),n}});function rw(e){Oe.call(this,null,d9,e)}G(rw,Oe);function d9(e){return this.value&&!e.modified()?this.value:Yh(e.fields,e.orders)}function Rp(e){O.call(this,null,e)}Rp.Definition={type:"CountPattern",metadata:{generates:!0,changes:!0},params:[{name:"field",type:"field",required:!0},{name:"case",type:"enum",values:["upper","lower","mixed"],default:"mixed"},{name:"pattern",type:"string",default:'[\\w"]+'},{name:"stopwords",type:"string",default:""},{name:"as",type:"string",array:!0,length:2,default:["text","count"]}]};function h9(e,t,n){switch(t){case"upper":e=e.toUpperCase();break;case"lower":e=e.toLowerCase();break}return e.match(n)}G(Rp,O,{transform(e,t){let n=f=>d=>{for(var h=h9(l(d),e.case,a)||[],p,m=0,g=h.length;m<g;++m)o.test(p=h[m])||f(p)},r=this._parameterCheck(e,t),i=this._counts,a=this._match,o=this._stop,l=e.field,s=e.as||["text","count"],u=n(f=>i[f]=1+(i[f]||0)),c=n(f=>--i[f]);return r?t.visit(t.SOURCE,u):(t.visit(t.ADD,u),t.visit(t.REM,c)),this._finish(t,s)},_parameterCheck(e,t){let n=!1;return(e.modified("stopwords")||!this._stop)&&(this._stop=RegExp("^"+(e.stopwords||"")+"$","i"),n=!0),(e.modified("pattern")||!this._match)&&(this._match=new RegExp(e.pattern||"[\\w']+","g"),n=!0),(e.modified("field")||t.modified(e.field.fields))&&(n=!0),n&&(this._counts={}),n},_finish(e,t){let n=this._counts,r=this._tuples||(this._tuples={}),i=t[0],a=t[1],o=e.fork(e.NO_SOURCE|e.NO_FIELDS),l,s,u;for(l in n)s=r[l],u=n[l]||0,!s&&u?(r[l]=s=_e({}),s[i]=l,s[a]=u,o.add.push(s)):u===0?(s&&o.rem.push(s),n[l]=null,r[l]=null):s[a]!==u&&(s[a]=u,o.mod.push(s));return o.modifies(t)}});function Tp(e){O.call(this,null,e)}Tp.Definition={type:"Cross",metadata:{generates:!0},params:[{name:"filter",type:"expr"},{name:"as",type:"string",array:!0,length:2,default:["a","b"]}]},G(Tp,O,{transform(e,t){let n=t.fork(t.NO_SOURCE),r=e.as||["a","b"],i=r[0],a=r[1],o=!this.value||t.changed(t.ADD_REM)||e.modified("as")||e.modified("filter"),l=this.value;return o?(l&&(n.rem=l),l=t.materialize(t.SOURCE).source,n.add=this.value=p9(l,i,a,e.filter||yn)):n.mod=l,n.source=this.value,n.modifies(r)}});function p9(e,t,n,r){for(var i=[],a={},o=e.length,l=0,s,u;l<o;++l)for(a[t]=u=e[l],s=0;s<o;++s)a[n]=e[s],r(a)&&(i.push(_e(a)),a={},a[t]=u);return i}var iw={kde:vp,mixture:U2,normal:yp,lognormal:q2,uniform:W2},m9="distributions",aw="function",g9="field";function ow(e,t){let n=e[aw];K(iw,n)||L("Unknown distribution function: "+n);let r=iw[n]();for(let i in e)i===g9?r.data((e.from||t()).map(e[i])):i===m9?r[i](e[i].map(a=>ow(a,t))):typeof r[i]===aw&&r[i](e[i]);return r}function Lp(e){O.call(this,null,e)}var lw=[{key:{function:"normal"},params:[{name:"mean",type:"number",default:0},{name:"stdev",type:"number",default:1}]},{key:{function:"lognormal"},params:[{name:"mean",type:"number",default:0},{name:"stdev",type:"number",default:1}]},{key:{function:"uniform"},params:[{name:"min",type:"number",default:0},{name:"max",type:"number",default:1}]},{key:{function:"kde"},params:[{name:"field",type:"field",required:!0},{name:"from",type:"data"},{name:"bandwidth",type:"number",default:0}]}],y9={key:{function:"mixture"},params:[{name:"distributions",type:"param",array:!0,params:lw},{name:"weights",type:"number",array:!0}]};Lp.Definition={type:"Density",metadata:{generates:!0},params:[{name:"extent",type:"number",array:!0,length:2},{name:"steps",type:"number"},{name:"minsteps",type:"number",default:25},{name:"maxsteps",type:"number",default:200},{name:"method",type:"string",default:"pdf",values:["pdf","cdf"]},{name:"distribution",type:"param",params:lw.concat(y9)},{name:"as",type:"string",array:!0,default:["value","density"]}]},G(Lp,O,{transform(e,t){let n=t.fork(t.NO_SOURCE|t.NO_FIELDS);if(!this.value||t.changed()||e.modified()){let r=ow(e.distribution,v9(t)),i=e.steps||e.minsteps||25,a=e.steps||e.maxsteps||200,o=e.method||"pdf";o!=="pdf"&&o!=="cdf"&&L("Invalid density method: "+o),!e.extent&&!r.data&&L("Missing density extent parameter."),o=r[o];let l=e.as||["value","density"],s=e.extent||ur(r.data()),u=tc(o,s,i,a).map(c=>{let f={};return f[l[0]]=c[0],f[l[1]]=c[1],_e(f)});this.value&&(n.rem=this.value),this.value=n.add=n.source=u}return n}});function v9(e){return()=>e.materialize(e.SOURCE).source}function sw(e,t){return e?e.map((n,r)=>t[r]||qe(n)):null}function Pp(e,t,n){let r=[],i=f=>f(s),a,o,l,s,u,c;if(t==null)r.push(e.map(n));else for(a={},o=0,l=e.length;o<l;++o)s=e[o],u=t.map(i),c=a[u],c||(a[u]=c=[],c.dims=u,r.push(c)),c.push(n(s));return r}var uw="bin";function Bp(e){O.call(this,null,e)}Bp.Definition={type:"DotBin",metadata:{modifies:!0},params:[{name:"field",type:"field",required:!0},{name:"groupby",type:"field",array:!0},{name:"step",type:"number"},{name:"smooth",type:"boolean",default:!1},{name:"as",type:"string",default:uw}]};var b9=(e,t)=>Mu(ur(e,t))/30;G(Bp,O,{transform(e,t){if(this.value&&!(e.modified()||t.changed()))return t;let n=t.materialize(t.SOURCE).source,r=Pp(t.source,e.groupby,bn),i=e.smooth||!1,a=e.field,o=e.step||b9(n,a),l=sa((p,m)=>a(p)-a(m)),s=e.as||uw,u=r.length,c=1/0,f=-1/0,d=0,h;for(;d<u;++d){let p=r[d].sort(l);h=-1;for(let m of I2(p,o,i,a))m<c&&(c=m),m>f&&(f=m),p[++h][s]=m}return this.value={start:c,stop:f,step:o},t.reflow(!0).modifies(s)}});function cw(e){Oe.call(this,null,x9,e),this.modified(!0)}G(cw,Oe);function x9(e){let t=e.expr;return this.value&&!e.modified("expr")?this.value:ho(n=>t(n,e),$t(t),qe(t))}function Ip(e){O.call(this,[void 0,void 0],e)}Ip.Definition={type:"Extent",metadata:{},params:[{name:"field",type:"field",required:!0}]},G(Ip,O,{transform(e,t){let n=this.value,r=e.field,i=t.changed()||t.modified(r.fields)||e.modified("field"),a=n[0],o=n[1];if((i||a==null)&&(a=1/0,o=-1/0),t.visit(i?t.SOURCE:t.ADD,l=>{let s=vn(r(l));s!=null&&(s<a&&(a=s),s>o&&(o=s))}),!Number.isFinite(a)||!Number.isFinite(o)){let l=qe(r);l&&(l=` for field "${l}"`),t.dataflow.warn(`Infinite extent${l}: [${a}, ${o}]`),a=o=void 0}this.value=[a,o]}});function jp(e,t){Oe.call(this,e),this.parent=t,this.count=0}G(jp,Oe,{connect(e){return this.detachSubflow=e.detachSubflow,this.targets().add(e),e.source=this},add(e){this.count+=1,this.value.add.push(e)},rem(e){--this.count,this.value.rem.push(e)},mod(e){this.value.mod.push(e)},init(e){this.value.init(e,e.NO_SOURCE)},evaluate(){return this.value}});function nc(e){O.call(this,{},e),this._keys=po();let t=this._targets=[];t.active=0,t.forEach=n=>{for(let r=0,i=t.active;r<i;++r)n(t[r],r,t)}}G(nc,O,{activate(e){this._targets[this._targets.active++]=e},subflow(e,t,n,r){let i=this.value,a=K(i,e)&&i[e],o,l;return a?a.value.stamp<n.stamp&&(a.init(n),this.activate(a)):(l=r||(l=this._group[e])&&l.tuple,o=n.dataflow,a=new jp(n.fork(n.NO_SOURCE),this),o.add(a).connect(t(o,e,l)),i[e]=a,this.activate(a)),a},clean(){let e=this.value,t=0;for(let n in e)if(e[n].count===0){let r=e[n].detachSubflow;r&&r(),delete e[n],++t}if(t){let n=this._targets.filter(r=>r&&r.count>0);this.initTargets(n)}},initTargets(e){let t=this._targets,n=t.length,r=e?e.length:0,i=0;for(;i<r;++i)t[i]=e[i];for(;i<n&&t[i]!=null;++i)t[i]=null;t.active=r},transform(e,t){let n=t.dataflow,r=e.key,i=e.subflow,a=this._keys,o=e.modified("key"),l=s=>this.subflow(s,i,t);return this._group=e.group||{},this.initTargets(),t.visit(t.REM,s=>{let u=te(s),c=a.get(u);c!==void 0&&(a.delete(u),l(c).rem(s))}),t.visit(t.ADD,s=>{let u=r(s);a.set(te(s),u),l(u).add(s)}),o||t.modified(r.fields)?t.visit(t.MOD,s=>{let u=te(s),c=a.get(u),f=r(s);c===f?l(f).mod(s):(a.set(u,f),l(c).rem(s),l(f).add(s))}):t.changed(t.MOD)&&t.visit(t.MOD,s=>{l(a.get(te(s))).mod(s)}),o&&t.visit(t.REFLOW,s=>{let u=te(s),c=a.get(u),f=r(s);c!==f&&(a.set(u,f),l(c).rem(s),l(f).add(s))}),t.clean()?n.runAfter(()=>{this.clean(),a.clean()}):a.empty>n.cleanThreshold&&n.runAfter(a.clean),t}});function fw(e){Oe.call(this,null,w9,e)}G(fw,Oe);function w9(e){return this.value&&!e.modified()?this.value:N(e.name)?Q(e.name).map(t=>Tr(t)):Tr(e.name,e.as)}function qp(e){O.call(this,po(),e)}qp.Definition={type:"Filter",metadata:{changes:!0},params:[{name:"expr",type:"expr",required:!0}]},G(qp,O,{transform(e,t){let n=t.dataflow,r=this.value,i=t.fork(),a=i.add,o=i.rem,l=i.mod,s=e.expr,u=!0;t.visit(t.REM,f=>{let d=te(f);r.has(d)?r.delete(d):o.push(f)}),t.visit(t.ADD,f=>{s(f,e)?a.push(f):r.set(te(f),1)});function c(f){let d=te(f),h=s(f,e),p=r.get(d);h&&p?(r.delete(d),a.push(f)):!h&&!p?(r.set(d,1),o.push(f)):u&&h&&!p&&l.push(f)}return t.visit(t.MOD,c),e.modified()&&(u=!1,t.visit(t.REFLOW,c)),r.empty>n.cleanThreshold&&n.runAfter(r.clean),i}});function Up(e){O.call(this,[],e)}Up.Definition={type:"Flatten",metadata:{generates:!0},params:[{name:"fields",type:"field",array:!0,required:!0},{name:"index",type:"string"},{name:"as",type:"string",array:!0}]},G(Up,O,{transform(e,t){let n=t.fork(t.NO_SOURCE),r=e.fields,i=sw(r,e.as||[]),a=e.index||null,o=i.length;return n.rem=this.value,t.visit(t.SOURCE,l=>{let s=r.map(h=>h(l)),u=s.reduce((h,p)=>Math.max(h,p.length),0),c=0,f,d;for(;c<u;++c){for(d=up(l),f=0;f<o;++f)d[i[f]]=s[f][c]??null;a&&(d[a]=c),n.add.push(d)}}),this.value=n.source=n.add,a&&n.modifies(a),n.modifies(i)}});function Wp(e){O.call(this,[],e)}Wp.Definition={type:"Fold",metadata:{generates:!0},params:[{name:"fields",type:"field",array:!0,required:!0},{name:"as",type:"string",array:!0,length:2,default:["key","value"]}]},G(Wp,O,{transform(e,t){let n=t.fork(t.NO_SOURCE),r=e.fields,i=r.map(qe),a=e.as||["key","value"],o=a[0],l=a[1],s=r.length;return n.rem=this.value,t.visit(t.SOURCE,u=>{for(let c=0,f;c<s;++c)f=up(u),f[o]=i[c],f[l]=r[c](u),n.add.push(f)}),this.value=n.source=n.add,n.modifies(a)}});function Hp(e){O.call(this,null,e)}Hp.Definition={type:"Formula",metadata:{modifies:!0},params:[{name:"expr",type:"expr",required:!0},{name:"as",type:"string",required:!0},{name:"initonly",type:"boolean"}]},G(Hp,O,{transform(e,t){let n=e.expr,r=e.as,i=e.modified(),a=e.initonly?t.ADD:i?t.SOURCE:t.modified(n.fields)||t.modified(r)?t.ADD_MOD:t.ADD;return i&&(t=t.materialize().reflow(!0)),e.initonly||t.modifies(r),t.visit(a,o=>o[r]=n(o,e))}});function dw(e){O.call(this,[],e)}G(dw,O,{transform(e,t){let n=t.fork(t.ALL),r=e.generator,i=this.value,a=e.size-i.length,o,l,s;if(a>0){for(o=[];--a>=0;)o.push(s=_e(r(e))),i.push(s);n.add=n.add.length?n.materialize(n.ADD).add.concat(o):o}else l=i.slice(0,-a),n.rem=n.rem.length?n.materialize(n.REM).rem.concat(l):l,i=i.slice(-a);return n.source=this.value=i,n}});var rc={value:"value",median:x2,mean:e8,min:np,max:oa},_9=[];function Gp(e){O.call(this,[],e)}Gp.Definition={type:"Impute",metadata:{changes:!0},params:[{name:"field",type:"field",required:!0},{name:"key",type:"field",required:!0},{name:"keyvals",array:!0},{name:"groupby",type:"field",array:!0},{name:"method",type:"enum",default:"value",values:["value","mean","median","max","min"]},{name:"value",default:0}]};function k9(e){var t=e.method||rc.value,n;if(rc[t]==null)L("Unrecognized imputation method: "+t);else return t===rc.value?(n=e.value===void 0?0:e.value,()=>n):rc[t]}function E9(e){let t=e.field;return n=>n?t(n):NaN}G(Gp,O,{transform(e,t){var n=t.fork(t.ALL),r=k9(e),i=E9(e),a=qe(e.field),o=qe(e.key),l=(e.groupby||[]).map(qe),s=$9(t.source,e.groupby,e.key,e.keyvals),u=[],c=this.value,f=s.domain.length,d,h,p,m,g,y,v,b,w,_;for(g=0,b=s.length;g<b;++g)for(d=s[g],p=d.values,h=NaN,v=0;v<f;++v)if(d[v]==null){for(m=s.domain[v],_={_impute:!0},y=0,w=p.length;y<w;++y)_[l[y]]=p[y];_[o]=m,_[a]=Number.isNaN(h)?h=r(d,i):h,u.push(_e(_))}return u.length&&(n.add=n.materialize(n.ADD).add.concat(u)),c.length&&(n.rem=n.materialize(n.REM).rem.concat(c)),this.value=u,n}});function $9(e,t,n,r){var i=y=>y(g),a=[],o=r?r.slice():[],l={},s={},u,c,f,d,h,p,m,g;for(o.forEach((y,v)=>l[y]=v+1),d=0,m=e.length;d<m;++d)g=e[d],p=n(g),h=l[p]||(l[p]=o.push(p)),c=(u=t?t.map(i):_9)+"",(f=s[c])||(f=s[c]=[],a.push(f),f.values=u),f[h-1]=g;return a.domain=o,a}function Vp(e){vi.call(this,e)}Vp.Definition={type:"JoinAggregate",metadata:{modifies:!0},params:[{name:"groupby",type:"field",array:!0},{name:"fields",type:"field",null:!0,array:!0},{name:"ops",type:"enum",array:!0,values:jl},{name:"as",type:"string",null:!0,array:!0},{name:"key",type:"field"}]},G(Vp,vi,{transform(e,t){let n=this,r=e.modified(),i;return n.value&&(r||t.modified(n._inputs,!0))?(i=n.value=r?n.init(e):{},t.visit(t.SOURCE,a=>n.add(a))):(i=n.value=n.value||this.init(e),t.visit(t.REM,a=>n.rem(a)),t.visit(t.ADD,a=>n.add(a))),n.changes(),t.visit(t.SOURCE,a=>{pe(a,i[n.cellkey(a)].tuple)}),t.reflow(r).modifies(this._outputs)},changes(){let e=this._adds,t=this._mods,n,r;for(n=0,r=this._alen;n<r;++n)this.celltuple(e[n]),e[n]=null;for(n=0,r=this._mlen;n<r;++n)this.celltuple(t[n]),t[n]=null;this._alen=this._mlen=0}});function Xp(e){O.call(this,null,e)}Xp.Definition={type:"KDE",metadata:{generates:!0},params:[{name:"groupby",type:"field",array:!0},{name:"field",type:"field",required:!0},{name:"cumulative",type:"boolean",default:!1},{name:"counts",type:"boolean",default:!1},{name:"bandwidth",type:"number",default:0},{name:"extent",type:"number",array:!0,length:2},{name:"resolve",type:"enum",values:["shared","independent"],default:"independent"},{name:"steps",type:"number"},{name:"minsteps",type:"number",default:25},{name:"maxsteps",type:"number",default:200},{name:"as",type:"string",array:!0,default:["value","density"]}]},G(Xp,O,{transform(e,t){let n=t.fork(t.NO_SOURCE|t.NO_FIELDS);if(!this.value||t.changed()||e.modified()){let r=t.materialize(t.SOURCE).source,i=Pp(r,e.groupby,e.field),a=(e.groupby||[]).map(qe),o=e.bandwidth,l=e.cumulative?"cdf":"pdf",s=e.as||["value","density"],u=[],c=e.extent,f=e.steps||e.minsteps||25,d=e.steps||e.maxsteps||200;l!=="pdf"&&l!=="cdf"&&L("Invalid density method: "+l),e.resolve==="shared"&&(c||(c=ur(r,e.field)),f=d=e.steps||d),i.forEach(h=>{let p=vp(h,o)[l],m=e.counts?h.length:1;tc(p,c||ur(h),f,d).forEach(g=>{let y={};for(let v=0;v<a.length;++v)y[a[v]]=h.dims[v];y[s[0]]=g[0],y[s[1]]=g[1]*m,u.push(_e(y))})}),this.value&&(n.rem=this.value),this.value=n.add=n.source=u}return n}});function hw(e){Oe.call(this,null,A9,e)}G(hw,Oe);function A9(e){return this.value&&!e.modified()?this.value:Gh(e.fields,e.flat)}function pw(e){O.call(this,[],e),this._pending=null}G(pw,O,{transform(e,t){let n=t.dataflow;return this._pending?Yp(this,t,this._pending):D9(e)?t.StopPropagation:e.values?Yp(this,t,n.parse(e.values,e.format)):e.async?{async:n.request(e.url,e.format).then(r=>(this._pending=Q(r.data),i=>i.touch(this)))}:n.request(e.url,e.format).then(r=>Yp(this,t,Q(r.data)))}});function D9(e){return e.modified("async")&&!(e.modified("values")||e.modified("url")||e.modified("format"))}function Yp(e,t,n){n.forEach(_e);let r=t.fork(t.NO_FIELDS&t.NO_SOURCE);return r.rem=e.value,e.value=r.source=r.add=n,e._pending=null,r.rem.length&&r.clean(!0),r}function Jp(e){O.call(this,{},e)}Jp.Definition={type:"Lookup",metadata:{modifies:!0},params:[{name:"index",type:"index",params:[{name:"from",type:"data",required:!0},{name:"key",type:"field",required:!0}]},{name:"values",type:"field",array:!0},{name:"fields",type:"field",array:!0,required:!0},{name:"as",type:"string",array:!0},{name:"default",default:null}]},G(Jp,O,{transform(e,t){let n=e.fields,r=e.index,i=e.values,a=e.default==null?null:e.default,o=e.modified(),l=n.length,s=o?t.SOURCE:t.ADD,u=t,c=e.as,f,d,h;return i?(d=i.length,l>1&&!c&&L('Multi-field lookup requires explicit "as" parameter.'),c&&c.length!==l*d&&L('The "as" parameter has too few output field names.'),c||(c=i.map(qe)),f=function(p){for(var m=0,g=0,y,v;m<l;++m)if(v=r.get(n[m](p)),v==null)for(y=0;y<d;++y,++g)p[c[g]]=a;else for(y=0;y<d;++y,++g)p[c[g]]=i[y](v)}):(c||L("Missing output field names."),f=function(p){for(var m=0,g;m<l;++m)g=r.get(n[m](p)),p[c[m]]=g??a}),o?u=t.reflow(!0):(h=n.some(p=>t.modified(p.fields)),s|=h?t.MOD:0),t.visit(s,f),u.modifies(c)}});function mw(e){Oe.call(this,null,S9,e)}G(mw,Oe);function S9(e){if(this.value&&!e.modified())return this.value;let t=e.extents,n=t.length,r=1/0,i=-1/0,a,o;for(a=0;a<n;++a)o=t[a],o[0]<r&&(r=o[0]),o[1]>i&&(i=o[1]);return[r,i]}function gw(e){Oe.call(this,null,F9,e)}G(gw,Oe);function F9(e){return this.value&&!e.modified()?this.value:e.values.reduce((t,n)=>t.concat(n),[])}function yw(e){O.call(this,null,e)}G(yw,O,{transform(e,t){return this.modified(e.modified()),this.value=e,t.fork(t.NO_SOURCE|t.NO_FIELDS)}});function Qp(e){vi.call(this,e)}Qp.Definition={type:"Pivot",metadata:{generates:!0,changes:!0},params:[{name:"groupby",type:"field",array:!0},{name:"field",type:"field",required:!0},{name:"value",type:"field",required:!0},{name:"op",type:"enum",values:jl,default:"sum"},{name:"limit",type:"number",default:0},{name:"key",type:"field"}]},G(Qp,vi,{_transform:vi.prototype.transform,transform(e,t){return this._transform(C9(e,t),t)}});function C9(e,t){let n=e.field,r=e.value,i=(e.op==="count"?"__count__":e.op)||"sum",a=$t(n).concat($t(r)),o=O9(n,e.limit||0,t);return t.changed()&&e.set("__pivot__",null,null,!0),{key:e.key,groupby:e.groupby,ops:o.map(()=>i),fields:o.map(l=>M9(l,n,r,a)),as:o.map(l=>l+""),modified:e.modified.bind(e)}}function M9(e,t,n,r){return ho(i=>t(i)===e?n(i):NaN,r,e+"")}function O9(e,t,n){let r={},i=[];return n.visit(n.SOURCE,a=>{let o=e(a);r[o]||(r[o]=1,i.push(o))}),i.sort(zu),t?i.slice(0,t):i}function vw(e){nc.call(this,e)}G(vw,nc,{transform(e,t){let n=e.subflow,r=e.field,i=a=>this.subflow(te(a),n,t,a);return(e.modified("field")||r&&t.modified($t(r)))&&L("PreFacet does not support field modification."),this.initTargets(),r?(t.visit(t.MOD,a=>{let o=i(a);r(a).forEach(l=>o.mod(l))}),t.visit(t.ADD,a=>{let o=i(a);r(a).forEach(l=>o.add(_e(l)))}),t.visit(t.REM,a=>{let o=i(a);r(a).forEach(l=>o.rem(l))})):(t.visit(t.MOD,a=>i(a).mod(a)),t.visit(t.ADD,a=>i(a).add(a)),t.visit(t.REM,a=>i(a).rem(a))),t.clean()&&t.runAfter(()=>this.clean()),t}});function Kp(e){O.call(this,null,e)}Kp.Definition={type:"Project",metadata:{generates:!0,changes:!0},params:[{name:"fields",type:"field",array:!0},{name:"as",type:"string",null:!0,array:!0}]},G(Kp,O,{transform(e,t){let n=t.fork(t.NO_SOURCE),r=e.fields,i=sw(e.fields,e.as||[]),a=r?(l,s)=>z9(l,s,r,i):Hu,o;return this.value?o=this.value:(t=t.addAll(),o=this.value={}),t.visit(t.REM,l=>{let s=te(l);n.rem.push(o[s]),o[s]=null}),t.visit(t.ADD,l=>{let s=a(l,_e({}));o[te(l)]=s,n.add.push(s)}),t.visit(t.MOD,l=>{n.mod.push(a(l,o[te(l)]))}),n}});function z9(e,t,n,r){for(let i=0,a=n.length;i<a;++i)t[r[i]]=n[i](e);return t}function bw(e){O.call(this,null,e)}G(bw,O,{transform(e,t){return this.value=e.value,e.modified("value")?t.fork(t.NO_SOURCE|t.NO_FIELDS):t.StopPropagation}});function Zp(e){O.call(this,null,e)}Zp.Definition={type:"Quantile",metadata:{generates:!0,changes:!0},params:[{name:"groupby",type:"field",array:!0},{name:"field",type:"field",required:!0},{name:"probs",type:"number",array:!0},{name:"step",type:"number",default:.01},{name:"as",type:"string",array:!0,default:["prob","value"]}]};var N9=1e-14;G(Zp,O,{transform(e,t){let n=t.fork(t.NO_SOURCE|t.NO_FIELDS),r=e.as||["prob","value"];if(this.value&&!e.modified()&&!t.changed())return n.source=this.value,n;let i=t.materialize(t.SOURCE).source,a=Pp(i,e.groupby,e.field),o=(e.groupby||[]).map(qe),l=[],s=e.step||.01,u=e.probs||nn(s/2,1-N9,s),c=u.length;return a.forEach(f=>{let d=hp(f,u);for(let h=0;h<c;++h){let p={};for(let m=0;m<o.length;++m)p[o[m]]=f.dims[m];p[r[0]]=u[h],p[r[1]]=d[h],l.push(_e(p))}}),this.value&&(n.rem=this.value),this.value=n.add=n.source=l,n}});function xw(e){O.call(this,null,e)}G(xw,O,{transform(e,t){let n,r;return this.value?r=this.value:(n=t=t.addAll(),r=this.value={}),e.derive&&(n=t.fork(t.NO_SOURCE),t.visit(t.REM,i=>{let a=te(i);n.rem.push(r[a]),r[a]=null}),t.visit(t.ADD,i=>{let a=up(i);r[te(i)]=a,n.add.push(a)}),t.visit(t.MOD,i=>{let a=r[te(i)];for(let o in i)a[o]=i[o],n.modifies(o);n.mod.push(a)})),n}});function em(e){O.call(this,[],e),this.count=0}em.Definition={type:"Sample",metadata:{},params:[{name:"size",type:"number",default:1e3}]},G(em,O,{transform(e,t){let n=t.fork(t.NO_SOURCE),r=e.modified("size"),i=e.size,a=this.value.reduce((c,f)=>(c[te(f)]=1,c),{}),o=this.value,l=this.count,s=0;function u(c){let f,d;o.length<i?o.push(c):(d=~~((l+1)*xn()),d<o.length&&d>=s&&(f=o[d],a[te(f)]&&n.rem.push(f),o[d]=c)),++l}if(t.rem.length&&(t.visit(t.REM,c=>{let f=te(c);a[f]&&(a[f]=-1,n.rem.push(c)),--l}),o=o.filter(c=>a[te(c)]!==-1)),(t.rem.length||r)&&o.length<i&&t.source&&(s=l=o.length,t.visit(t.SOURCE,c=>{a[te(c)]||u(c)}),s=-1),r&&o.length>i){let c=o.length-i;for(let f=0;f<c;++f)a[te(o[f])]=-1,n.rem.push(o[f]);o=o.slice(c)}return t.mod.length&&t.visit(t.MOD,c=>{a[te(c)]&&n.mod.push(c)}),t.add.length&&t.visit(t.ADD,u),(t.add.length||s<0)&&(n.add=o.filter(c=>!a[te(c)])),this.count=l,this.value=n.source=o,n}});function tm(e){O.call(this,null,e)}tm.Definition={type:"Sequence",metadata:{generates:!0,changes:!0},params:[{name:"start",type:"number",required:!0},{name:"stop",type:"number",required:!0},{name:"step",type:"number",default:1},{name:"as",type:"string",default:"data"}]},G(tm,O,{transform(e,t){if(this.value&&!e.modified())return;let n=t.materialize().fork(t.MOD),r=e.as||"data";return n.rem=this.value?t.rem.concat(this.value):t.rem,this.value=nn(e.start,e.stop,e.step||1).map(i=>{let a={};return a[r]=i,_e(a)}),n.add=t.add.concat(this.value),n}});function ww(e){O.call(this,null,e),this.modified(!0)}G(ww,O,{transform(e,t){return this.value=t.source,t.changed()?t.fork(t.NO_SOURCE|t.NO_FIELDS):t.StopPropagation}});function nm(e){O.call(this,null,e)}var _w=["unit0","unit1"];nm.Definition={type:"TimeUnit",metadata:{modifies:!0},params:[{name:"field",type:"field",required:!0},{name:"interval",type:"boolean",default:!0},{name:"units",type:"enum",values:Sx,array:!0},{name:"step",type:"number",default:1},{name:"maxbins",type:"number",default:40},{name:"extent",type:"date",array:!0},{name:"timezone",type:"enum",default:"local",values:["local","utc"]},{name:"as",type:"string",array:!0,length:2,default:_w}]},G(nm,O,{transform(e,t){let n=e.field,r=e.interval!==!1,i=e.timezone==="utc",a=this._floor(e,t),o=(i?Wh:Jh)(a.unit).offset,l=e.as||_w,s=l[0],u=l[1],c=a.step,f=a.start||1/0,d=a.stop||-1/0,h=t.ADD;return(e.modified()||t.changed(t.REM)||t.modified($t(n)))&&(t=t.reflow(!0),h=t.SOURCE,f=1/0,d=-1/0),t.visit(h,p=>{let m=n(p),g,y;m==null?(p[s]=null,r&&(p[u]=null)):(p[s]=g=y=a(m),r&&(p[u]=y=o(g,c)),g<f&&(f=g),y>d&&(d=y))}),a.start=f,a.stop=d,t.modifies(r?l:s)},_floor(e,t){let n=e.timezone==="utc",{units:r,step:i}=e.units?{units:e.units,step:e.step||1}:Cx({extent:e.extent||ur(t.materialize(t.SOURCE).source,e.field),maxbins:e.maxbins}),a=Ix(r),o=this.value||{},l=(n?Wx:qx)(a,i);return l.unit=$e(a),l.units=a,l.step=i,l.start=o.start,l.stop=o.stop,this.value=l}});function kw(e){O.call(this,po(),e)}G(kw,O,{transform(e,t){let n=t.dataflow,r=e.field,i=this.value,a=l=>i.set(r(l),l),o=!0;return e.modified("field")||t.modified(r.fields)?(i.clear(),t.visit(t.SOURCE,a)):t.changed()?(t.visit(t.REM,l=>i.delete(r(l))),t.visit(t.ADD,a)):o=!1,this.modified(o),i.empty>n.cleanThreshold&&n.runAfter(i.clean),t.fork()}});function Ew(e){O.call(this,null,e)}G(Ew,O,{transform(e,t){(!this.value||e.modified("field")||e.modified("sort")||t.changed()||e.sort&&t.modified(e.sort.fields))&&(this.value=(e.sort?t.source.slice().sort(sa(e.sort)):t.source).map(e.field))}});function R9(e,t,n,r){let i=ql[e](t,n);return{init:i.init||Hh,update:function(a,o){o[r]=i.next(a)}}}var ql={row_number:function(){return{next:e=>e.index+1}},rank:function(){let e;return{init:()=>e=1,next:t=>{let n=t.index,r=t.data;return n&&t.compare(r[n-1],r[n])?e=n+1:e}}},dense_rank:function(){let e;return{init:()=>e=1,next:t=>{let n=t.index,r=t.data;return n&&t.compare(r[n-1],r[n])?++e:e}}},percent_rank:function(){let e=ql.rank(),t=e.next;return{init:e.init,next:n=>(t(n)-1)/(n.data.length-1)}},cume_dist:function(){let e;return{init:()=>e=0,next:t=>{let n=t.data,r=t.compare,i=t.index;if(e<i){for(;i+1<n.length&&!r(n[i],n[i+1]);)++i;e=i}return(1+e)/n.length}}},ntile:function(e,t){t=+t,t>0||L("ntile num must be greater than zero.");let n=ql.cume_dist(),r=n.next;return{init:n.init,next:i=>Math.ceil(t*r(i))}},lag:function(e,t){return t=+t||1,{next:n=>{let r=n.index-t;return r>=0?e(n.data[r]):null}}},lead:function(e,t){return t=+t||1,{next:n=>{let r=n.index+t,i=n.data;return r<i.length?e(i[r]):null}}},first_value:function(e){return{next:t=>e(t.data[t.i0])}},last_value:function(e){return{next:t=>e(t.data[t.i1-1])}},nth_value:function(e,t){return t=+t,t>0||L("nth_value nth must be greater than zero."),{next:n=>{let r=n.i0+(t-1);return r<n.i1?e(n.data[r]):null}}},prev_value:function(e){let t;return{init:()=>t=null,next:n=>{let r=e(n.data[n.index]);return r==null?t:t=r}}},next_value:function(e){let t,n;return{init:()=>(t=null,n=-1),next:r=>{let i=r.data;return r.index<=n?t:(n=T9(e,i,r.index))<0?(n=i.length,t=null):t=e(i[n])}}}};function T9(e,t,n){for(let r=t.length;n<r;++n)if(e(t[n])!=null)return n;return-1}var L9=Object.keys(ql);function $w(e){let t=Q(e.ops),n=Q(e.fields),r=Q(e.params),i=Q(e.aggregate_params),a=Q(e.as),o=this.outputs=[],l=this.windows=[],s={},u={},c=[],f=[],d=!0;function h(p){Q($t(p)).forEach(m=>s[m]=1)}h(e.sort),t.forEach((p,m)=>{let g=n[m],y=r[m],v=i[m]||null,b=qe(g),w=K2(p,b,a[m]);if(h(g),o.push(w),K(ql,p))l.push(R9(p,g,y,w));else{if(g==null&&p!=="count"&&L("Null aggregate field specified."),p==="count"){c.push(w);return}d=!1;let _=u[b];_||(_=u[b]=[],_.field=g,f.push(_)),_.push(Z2(p,v,w))}}),(c.length||f.length)&&(this.cell=P9(f,c,d)),this.inputs=Object.keys(s)}var Aw=$w.prototype;Aw.init=function(){this.windows.forEach(e=>e.init()),this.cell&&this.cell.init()},Aw.update=function(e,t){let n=this.cell,r=this.windows,i=e.data,a=r&&r.length,o;if(n){for(o=e.p0;o<e.i0;++o)n.rem(i[o]);for(o=e.p1;o<e.i1;++o)n.add(i[o]);n.set(t)}for(o=0;o<a;++o)r[o].update(e,t)};function P9(e,t,n){e=e.map(s=>tw(s,s.field));let r={num:0,agg:null,store:!1,count:t};if(!n)for(var i=e.length,a=r.agg=Array(i),o=0;o<i;++o)a[o]=new e[o](r);if(r.store)var l=r.data=new Op;return r.add=function(s){if(r.num+=1,!n){l&&l.add(s);for(let u=0;u<i;++u)a[u].add(a[u].get(s),s)}},r.rem=function(s){if(--r.num,!n){l&&l.rem(s);for(let u=0;u<i;++u)a[u].rem(a[u].get(s),s)}},r.set=function(s){let u,c;for(l&&l.values(),u=0,c=t.length;u<c;++u)s[t[u]]=r.num;if(!n)for(u=0,c=a.length;u<c;++u)a[u].set(s)},r.init=function(){r.num=0,l&&l.reset();for(let s=0;s<i;++s)a[s].init()},r}function rm(e){O.call(this,{},e),this._mlen=0,this._mods=[]}rm.Definition={type:"Window",metadata:{modifies:!0},params:[{name:"sort",type:"compare"},{name:"groupby",type:"field",array:!0},{name:"ops",type:"enum",array:!0,values:L9.concat(jl)},{name:"params",type:"number",null:!0,array:!0},{name:"aggregate_params",type:"number",null:!0,array:!0},{name:"fields",type:"field",null:!0,array:!0},{name:"as",type:"string",null:!0,array:!0},{name:"frame",type:"number",null:!0,array:!0,length:2,default:[null,0]},{name:"ignorePeers",type:"boolean",default:!1}]},G(rm,O,{transform(e,t){this.stamp=t.stamp;let n=e.modified(),r=sa(e.sort),i=Cp(e.groupby),a=l=>this.group(i(l)),o=this.state;(!o||n)&&(o=this.state=new $w(e)),n||t.modified(o.inputs)?(this.value={},t.visit(t.SOURCE,l=>a(l).add(l))):(t.visit(t.REM,l=>a(l).remove(l)),t.visit(t.ADD,l=>a(l).add(l)));for(let l=0,s=this._mlen;l<s;++l)B9(this._mods[l],o,r,e);return this._mlen=0,this._mods=[],t.reflow(n).modifies(o.outputs)},group(e){let t=this.value[e];return t||(t=this.value[e]=nw(te),t.stamp=-1),t.stamp<this.stamp&&(t.stamp=this.stamp,this._mods[this._mlen++]=t),t}});function B9(e,t,n,r){let i=r.sort,a=i&&!r.ignorePeers,o=r.frame||[null,0],l=e.data(n),s=l.length,u=a?s2(i):null,c={i0:0,i1:0,p0:0,p1:0,index:0,data:l,compare:i||At(-1)};t.init();for(let f=0;f<s;++f)I9(c,o,f,s),a&&j9(c,u),t.update(c,l[f])}function I9(e,t,n,r){e.p0=e.i0,e.p1=e.i1,e.i0=t[0]==null?0:Math.max(0,n-Math.abs(t[0])),e.i1=t[1]==null?r:Math.min(r,n+Math.abs(t[1])+1),e.index=n}function j9(e,t){let n=e.i0,r=e.i1-1,i=e.compare,a=e.data,o=a.length-1;n>0&&!i(a[n],a[n-1])&&(e.i0=t.left(a,a[n])),r<o&&!i(a[r],a[r+1])&&(e.i1=t.right(a,a[r]))}function Dw(e,t,n){var r=null,i=Dt(!0),a=null,o=h2,l=null,s=d2(u);e=typeof e=="function"?e:e===void 0?IO:Dt(+e),t=typeof t=="function"?t:Dt(t===void 0?0:+t),n=typeof n=="function"?n:n===void 0?jO:Dt(+n);function u(f){var d,h,p,m=(f=_O(f)).length,g,y=!1,v,b=Array(m),w=Array(m);for(a??(l=o(v=s())),d=0;d<=m;++d){if(!(d<m&&i(g=f[d],d,f))===y)if(y=!y)h=d,l.areaStart(),l.lineStart();else{for(l.lineEnd(),l.lineStart(),p=d-1;p>=h;--p)l.point(b[p],w[p]);l.lineEnd(),l.areaEnd()}y&&(b[d]=+e(g,d,f),w[d]=+t(g,d,f),l.point(r?+r(g,d,f):b[d],n?+n(g,d,f):w[d]))}if(v)return l=null,v+""||null}function c(){return p2().defined(i).curve(o).context(a)}return u.x=function(f){return arguments.length?(e=typeof f=="function"?f:Dt(+f),r=null,u):e},u.x0=function(f){return arguments.length?(e=typeof f=="function"?f:Dt(+f),u):e},u.x1=function(f){return arguments.length?(r=f==null?null:typeof f=="function"?f:Dt(+f),u):r},u.y=function(f){return arguments.length?(t=typeof f=="function"?f:Dt(+f),n=null,u):t},u.y0=function(f){return arguments.length?(t=typeof f=="function"?f:Dt(+f),u):t},u.y1=function(f){return arguments.length?(n=f==null?null:typeof f=="function"?f:Dt(+f),u):n},u.lineX0=u.lineY0=function(){return c().x(e).y(t)},u.lineY1=function(){return c().x(e).y(n)},u.lineX1=function(){return c().x(r).y(t)},u.defined=function(f){return arguments.length?(i=typeof f=="function"?f:Dt(!!f),u):i},u.curve=function(f){return arguments.length?(o=f,a!=null&&(l=o(a)),u):o},u.context=function(f){return arguments.length?(f==null?a=l=null:l=o(a=f),u):a},u}var q9={draw(e,t){let n=vO(t/xO);e.moveTo(n,0),e.arc(0,0,n,0,bO)}};function U9(e,t){let n=null,r=d2(i);e=typeof e=="function"?e:Dt(e||q9),t=typeof t=="function"?t:Dt(t===void 0?64:+t);function i(){let a;if(n||(n=a=r()),e.apply(this,arguments).draw(n,+t.apply(this,arguments)),a)return n=null,a+""||null}return i.type=function(a){return arguments.length?(e=typeof a=="function"?a:Dt(a),i):e},i.size=function(a){return arguments.length?(t=typeof a=="function"?a:Dt(+a),i):t},i.context=function(a){return arguments.length?(n=a??null,i):n},i}function bi(e,t){if(typeof document<"u"&&document.createElement){let n=document.createElement("canvas");if(n&&n.getContext)return n.width=e,n.height=t,n}return null}var W9=()=>typeof Image<"u"?Image:null;function Sw(e){var t;function n(r){return r==null||isNaN(r=+r)?t:r}return n.invert=n,n.domain=n.range=function(r){return arguments.length?(e=Array.from(r,u2),n):e.slice()},n.unknown=function(r){return arguments.length?(t=r,n):t},n.copy=function(){return Sw(e).unknown(t)},e=arguments.length?Array.from(e,u2):[0,1],go(n)}function Fw(e){return Math.log(e)}function Cw(e){return Math.exp(e)}function H9(e){return-Math.log(-e)}function G9(e){return-Math.exp(-e)}function V9(e){return isFinite(e)?+("1e"+e):e<0?0:e}function X9(e){return e===10?V9:e===Math.E?Math.exp:t=>e**+t}function Y9(e){return e===Math.E?Math.log:e===10&&Math.log10||e===2&&Math.log2||(e=Math.log(e),t=>Math.log(t)/e)}function Mw(e){return(t,n)=>-e(-t,n)}function im(e){let t=e(Fw,Cw),n=t.domain,r=10,i,a;function o(){return i=Y9(r),a=X9(r),n()[0]<0?(i=Mw(i),a=Mw(a),e(H9,G9)):e(Fw,Cw),t}return t.base=function(l){return arguments.length?(r=+l,o()):r},t.domain=function(l){return arguments.length?(n(l),o()):n()},t.ticks=l=>{let s=n(),u=s[0],c=s[s.length-1],f=c<u;f&&([u,c]=[c,u]);let d=i(u),h=i(c),p,m,g=l==null?10:+l,y=[];if(!(r%1)&&h-d<g){if(d=Math.floor(d),h=Math.ceil(h),u>0){for(;d<=h;++d)for(p=1;p<r;++p)if(m=d<0?p/a(-d):p*a(d),!(m<u)){if(m>c)break;y.push(m)}}else for(;d<=h;++d)for(p=r-1;p>=1;--p)if(m=d>0?p/a(-d):p*a(d),!(m<u)){if(m>c)break;y.push(m)}y.length*2<g&&(y=l2(u,c,g))}else y=l2(d,h,Math.min(h-d,g)).map(a);return f?y.reverse():y},t.tickFormat=(l,s)=>{if(l??(l=10),s??(s=r===10?"s":","),typeof s!="function"&&(!(r%1)&&(s=eO(s)).precision==null&&(s.trim=!0),s=tO(s)),l===1/0)return s;let u=Math.max(1,r*l/t.ticks().length);return c=>{let f=c/a(Math.round(i(c)));return f*r<r-.5&&(f*=r),f<=u?s(c):""}},t.nice=()=>n(K4(n(),{floor:l=>a(Math.floor(i(l))),ceil:l=>a(Math.ceil(i(l)))})),t}function Ow(){let e=im(ep()).domain([1,10]);return e.copy=()=>Zh(e,Ow()).base(e.base()),la.apply(e,arguments),e}function zw(e){return function(t){return Math.sign(t)*Math.log1p(Math.abs(t/e))}}function Nw(e){return function(t){return Math.sign(t)*Math.expm1(Math.abs(t))*e}}function am(e){var t=1,n=e(zw(t),Nw(t));return n.constant=function(r){return arguments.length?e(zw(t=+r),Nw(t)):t},go(n)}function Rw(){var e=am(ep());return e.copy=function(){return Zh(e,Rw()).constant(e.constant())},la.apply(e,arguments)}function Tw(e){return function(t){return t<0?-((-t)**+e):t**+e}}function J9(e){return e<0?-Math.sqrt(-e):Math.sqrt(e)}function Q9(e){return e<0?-e*e:e*e}function om(e){var t=e(di,di),n=1;function r(){return n===1?e(di,di):n===.5?e(J9,Q9):e(Tw(n),Tw(1/n))}return t.exponent=function(i){return arguments.length?(n=+i,r()):n},go(t)}function lm(){var e=om(ep());return e.copy=function(){return Zh(e,lm()).exponent(e.exponent())},la.apply(e,arguments),e}function K9(){return lm.apply(null,arguments).exponent(.5)}function Lw(){var e=[],t=[],n=[],r;function i(){var o=0,l=Math.max(1,t.length);for(n=Array(l-1);++o<l;)n[o-1]=b2(e,o/l);return a}function a(o){return o==null||isNaN(o=+o)?r:t[Lu(n,o)]}return a.invertExtent=function(o){var l=t.indexOf(o);return l<0?[NaN,NaN]:[l>0?n[l-1]:e[0],l<n.length?n[l]:e[e.length-1]]},a.domain=function(o){if(!arguments.length)return e.slice();e=[];for(let l of o)l!=null&&!isNaN(l=+l)&&e.push(l);return e.sort(zl),i()},a.range=function(o){return arguments.length?(t=Array.from(o),i()):t.slice()},a.unknown=function(o){return arguments.length?(r=o,a):r},a.quantiles=function(){return n.slice()},a.copy=function(){return Lw().domain(e).range(t).unknown(r)},la.apply(a,arguments)}function Pw(){var e=0,t=1,n=1,r=[.5],i=[0,1],a;function o(s){return s!=null&&s<=s?i[Lu(r,s,0,n)]:a}function l(){var s=-1;for(r=Array(n);++s<n;)r[s]=((s+1)*t-(s-n)*e)/(n+1);return o}return o.domain=function(s){return arguments.length?([e,t]=s,e=+e,t=+t,l()):[e,t]},o.range=function(s){return arguments.length?(n=(i=Array.from(s)).length-1,l()):i.slice()},o.invertExtent=function(s){var u=i.indexOf(s);return u<0?[NaN,NaN]:u<1?[e,r[0]]:u>=n?[r[n-1],t]:[r[u-1],r[u]]},o.unknown=function(s){return arguments.length&&(a=s),o},o.thresholds=function(){return r.slice()},o.copy=function(){return Pw().domain([e,t]).range(i).unknown(a)},la.apply(go(o),arguments)}function Bw(){var e=[.5],t=[0,1],n,r=1;function i(a){return a!=null&&a<=a?t[Lu(e,a,0,r)]:n}return i.domain=function(a){return arguments.length?(e=Array.from(a),r=Math.min(e.length,t.length-1),i):e.slice()},i.range=function(a){return arguments.length?(t=Array.from(a),r=Math.min(e.length,t.length-1),i):t.slice()},i.invertExtent=function(a){var o=t.indexOf(a);return[e[o-1],e[o]]},i.unknown=function(a){return arguments.length?(n=a,i):n},i.copy=function(){return Bw().domain(e).range(t).unknown(n)},la.apply(i,arguments)}function Z9(){return la.apply(Z4(Y4,J4,sO,oO,iO,aO,nO,uO,rO,lO).domain([Date.UTC(2e3,0,1),Date.UTC(2e3,0,2)]),arguments)}function ic(){var e=0,t=1,n,r,i,a,o=di,l=!1,s;function u(f){return f==null||isNaN(f=+f)?s:o(i===0?.5:(f=(a(f)-n)*i,l?Math.max(0,Math.min(1,f)):f))}u.domain=function(f){return arguments.length?([e,t]=f,n=a(e=+e),r=a(t=+t),i=n===r?0:1/(r-n),u):[e,t]},u.clamp=function(f){return arguments.length?(l=!!f,u):l},u.interpolator=function(f){return arguments.length?(o=f,u):o};function c(f){return function(d){var h,p;return arguments.length?([h,p]=d,o=f(h,p),u):[o(0),o(1)]}}return u.range=c(rp),u.rangeRound=c(ip),u.unknown=function(f){return arguments.length?(s=f,u):s},function(f){return a=f,n=f(e),r=f(t),i=n===r?0:1/(r-n),u}}function xi(e,t){return t.domain(e.domain()).interpolator(e.interpolator()).clamp(e.clamp()).unknown(e.unknown())}function sm(){var e=go(ic()(di));return e.copy=function(){return xi(e,sm())},hi.apply(e,arguments)}function Iw(){var e=im(ic()).domain([1,10]);return e.copy=function(){return xi(e,Iw()).base(e.base())},hi.apply(e,arguments)}function jw(){var e=am(ic());return e.copy=function(){return xi(e,jw()).constant(e.constant())},hi.apply(e,arguments)}function um(){var e=om(ic());return e.copy=function(){return xi(e,um()).exponent(e.exponent())},hi.apply(e,arguments)}function e7(){return um.apply(null,arguments).exponent(.5)}function ac(){var e=0,t=.5,n=1,r=1,i,a,o,l,s,u=di,c,f=!1,d;function h(m){return isNaN(m=+m)?d:(m=.5+((m=+c(m))-a)*(r*m<r*a?l:s),u(f?Math.max(0,Math.min(1,m)):m))}h.domain=function(m){return arguments.length?([e,t,n]=m,i=c(e=+e),a=c(t=+t),o=c(n=+n),l=i===a?0:.5/(a-i),s=a===o?0:.5/(o-a),r=a<i?-1:1,h):[e,t,n]},h.clamp=function(m){return arguments.length?(f=!!m,h):f},h.interpolator=function(m){return arguments.length?(u=m,h):u};function p(m){return function(g){var y,v,b;return arguments.length?([y,v,b]=g,u=f2(m,[y,v,b]),h):[u(0),u(.5),u(1)]}}return h.range=p(rp),h.rangeRound=p(ip),h.unknown=function(m){return arguments.length?(d=m,h):d},function(m){return c=m,i=m(e),a=m(t),o=m(n),l=i===a?0:.5/(a-i),s=a===o?0:.5/(o-a),r=a<i?-1:1,h}}function qw(){var e=go(ac()(di));return e.copy=function(){return xi(e,qw())},hi.apply(e,arguments)}function Uw(){var e=im(ac()).domain([.1,1,10]);return e.copy=function(){return xi(e,Uw()).base(e.base())},hi.apply(e,arguments)}function Ww(){var e=am(ac());return e.copy=function(){return xi(e,Ww()).constant(e.constant())},hi.apply(e,arguments)}function cm(){var e=om(ac());return e.copy=function(){return xi(e,cm()).exponent(e.exponent())},hi.apply(e,arguments)}function t7(){return cm.apply(null,arguments).exponent(.5)}var n7=cr("1f77b4ff7f0e2ca02cd627289467bd8c564be377c27f7f7fbcbd2217becf"),r7=cr("7fc97fbeaed4fdc086ffff99386cb0f0027fbf5b17666666"),i7=cr("1b9e77d95f027570b3e7298a66a61ee6ab02a6761d666666"),a7=cr("4269d0efb118ff725c6cc5b03ca951ff8ab7a463f297bbf59c6b4e9498a0"),o7=cr("a6cee31f78b4b2df8a33a02cfb9a99e31a1cfdbf6fff7f00cab2d66a3d9affff99b15928"),l7=cr("fbb4aeb3cde3ccebc5decbe4fed9a6ffffcce5d8bdfddaecf2f2f2"),s7=cr("b3e2cdfdcdaccbd5e8f4cae4e6f5c9fff2aef1e2cccccccc"),u7=cr("e41a1c377eb84daf4a984ea3ff7f00ffff33a65628f781bf999999"),c7=cr("66c2a5fc8d628da0cbe78ac3a6d854ffd92fe5c494b3b3b3"),f7=cr("8dd3c7ffffb3bebadafb807280b1d3fdb462b3de69fccde5d9d9d9bc80bdccebc5ffed6f");function fm(e,t,n){let r=e-t+n*2;return e?r>0?r:1:0}var d7="identity",oc="linear",dm="sqrt",hm="symlog",h7="time",wi="sequential",wo="diverging",Ul="quantile",pm="quantize",Hw="threshold",p7="ordinal",m7="point",g7="band",y7="bin-ordinal",et="continuous",Wl="discrete",Hl="discretizing",wn="interpolating",mm="temporal";function v7(e){return function(t){let n=t[0],r=t[1],i;return r<n&&(i=n,n=r,r=i),[e.invert(n),e.invert(r)]}}function b7(e){return function(t){let n=e.range(),r=t[0],i=t[1],a=-1,o,l,s,u;for(i<r&&(l=r,r=i,i=l),s=0,u=n.length;s<u;++s)n[s]>=r&&n[s]<=i&&(a<0&&(a=s),o=s);if(!(a<0))return r=e.invertExtent(n[a]),i=e.invertExtent(n[o]),[r[0]===void 0?r[1]:r[0],i[1]===void 0?i[0]:i[1]]}}function gm(){let e=c2().unknown(void 0),t=e.domain,n=e.range,r=[0,1],i,a,o=!1,l=0,s=0,u=.5;delete e.unknown;function c(){let f=t().length,d=r[1]<r[0],h=r[1-d],p=fm(f,l,s),m=r[d-0];i=(h-m)/(p||1),o&&(i=Math.floor(i)),m+=(h-m-i*(f-l))*u,a=i*(1-l),o&&(m=Math.round(m),a=Math.round(a));let g=nn(f).map(y=>m+i*y);return n(d?g.reverse():g)}return e.domain=function(f){return arguments.length?(t(f),c()):t()},e.range=function(f){return arguments.length?(r=[+f[0],+f[1]],c()):r.slice()},e.rangeRound=function(f){return r=[+f[0],+f[1]],o=!0,c()},e.bandwidth=function(){return a},e.step=function(){return i},e.round=function(f){return arguments.length?(o=!!f,c()):o},e.padding=function(f){return arguments.length?(s=Math.max(0,Math.min(1,f)),l=s,c()):l},e.paddingInner=function(f){return arguments.length?(l=Math.max(0,Math.min(1,f)),c()):l},e.paddingOuter=function(f){return arguments.length?(s=Math.max(0,Math.min(1,f)),c()):s},e.align=function(f){return arguments.length?(u=Math.max(0,Math.min(1,f)),c()):u},e.invertRange=function(f){if(f[0]==null||f[1]==null)return;let d=r[1]<r[0],h=d?n().reverse():n(),p=h.length-1,m=+f[0],g=+f[1],y,v,b;if(!(m!==m||g!==g)&&(g<m&&(b=m,m=g,g=b),!(g<h[0]||m>r[1-d])))return y=Math.max(0,tp(h,m)-1),v=m===g?y:tp(h,g)-1,m-h[y]>a+1e-10&&++y,d&&(b=y,y=p-v,v=p-b),y>v?void 0:t().slice(y,v+1)},e.invert=function(f){let d=e.invertRange([f,f]);return d&&d[0]},e.copy=function(){return gm().domain(t()).range(r).round(o).paddingInner(l).paddingOuter(s).align(u)},c()}function Gw(e){let t=e.copy;return e.padding=e.paddingOuter,delete e.paddingInner,e.copy=function(){return Gw(t())},e}function x7(){return Gw(gm().paddingInner(1))}var w7=Array.prototype.map;function _7(e){return w7.call(e,vn)}var k7=Array.prototype.slice;function Vw(){let e=[],t=[];function n(r){return r==null||r!==r?void 0:t[(Lu(e,r)-1)%t.length]}return n.domain=function(r){return arguments.length?(e=_7(r),n):e.slice()},n.range=function(r){return arguments.length?(t=k7.call(r),n):t.slice()},n.tickFormat=function(r,i){return G4(e[0],$e(e),r??10,i)},n.copy=function(){return Vw().domain(n.domain()).range(n.range())},n}var lc=new Map,Xw=Symbol("vega_scale");function Yw(e){return e[Xw]=!0,e}function Jw(e){return e&&e[Xw]===!0}function E7(e,t,n){let r=function(){let i=t();return i.invertRange||(i.invertRange=i.invert?v7(i):i.invertExtent?b7(i):void 0),i.type=e,Yw(i)};return r.metadata=sr(Q(n)),r}function ve(e,t,n){return arguments.length>1?(lc.set(e,E7(e,t,n)),this):Qw(e)?lc.get(e):void 0}ve(d7,Sw),ve(oc,V4,et),ve("log",Ow,[et,"log"]),ve("pow",lm,et),ve(dm,K9,et),ve(hm,Rw,et),ve(h7,Q4,[et,mm]),ve("utc",Z9,[et,mm]),ve(wi,sm,[et,wn]),ve(`${wi}-${oc}`,sm,[et,wn]),ve(`${wi}-log`,Iw,[et,wn,"log"]),ve(`${wi}-pow`,um,[et,wn]),ve(`${wi}-${dm}`,e7,[et,wn]),ve(`${wi}-${hm}`,jw,[et,wn]),ve(`${wo}-${oc}`,qw,[et,wn]),ve(`${wo}-log`,Uw,[et,wn,"log"]),ve(`${wo}-pow`,cm,[et,wn]),ve(`${wo}-${dm}`,t7,[et,wn]),ve(`${wo}-${hm}`,Ww,[et,wn]),ve(Ul,Lw,[Hl,Ul]),ve(pm,Pw,Hl),ve(Hw,Bw,Hl),ve(y7,Vw,[Wl,Hl]),ve(p7,c2,Wl),ve(g7,gm,Wl),ve(m7,x7,Wl);function Qw(e){return lc.has(e)}function ca(e,t){let n=lc.get(e);return n&&n.metadata[t]}function ym(e){return ca(e,et)}function _o(e){return ca(e,Wl)}function vm(e){return ca(e,Hl)}function Kw(e){return ca(e,"log")}function $7(e){return ca(e,mm)}function Zw(e){return ca(e,wn)}function e_(e){return ca(e,Ul)}var A7=["clamp","base","constant","exponent"];function t_(e,t){let n=t[0],r=$e(t)-n;return function(i){return e(n+i*r)}}function sc(e,t,n){return f2(bm(t||"rgb",n),e)}function n_(e,t){let n=Array(t),r=t+1;for(let i=0;i<t;)n[i]=e(++i/r);return n}function r_(e,t,n){let r=n-t,i,a,o;return!r||!Number.isFinite(r)?At(.5):(i=(a=e.type).indexOf("-"),a=i<0?a:a.slice(i+1),o=ve(a)().domain([t,n]).range([0,1]),A7.forEach(l=>e[l]?o[l](e[l]()):0),o)}function bm(e,t){let n=hO[D7(e)];return t!=null&&n&&n.gamma?n.gamma(t):n}function D7(e){return"interpolate"+e.toLowerCase().split("-").map(t=>t[0].toUpperCase()+t.slice(1)).join("")}var S7={blues:"cfe1f2bed8eca8cee58fc1de74b2d75ba3cf4592c63181bd206fb2125ca40a4a90",greens:"d3eecdc0e6baabdda594d3917bc77d60ba6c46ab5e329a512089430e7735036429",greys:"e2e2e2d4d4d4c4c4c4b1b1b19d9d9d8888887575756262624d4d4d3535351e1e1e",oranges:"fdd8b3fdc998fdb87bfda55efc9244f87f2cf06b18e4580bd14904b93d029f3303",purples:"e2e1efd4d4e8c4c5e0b4b3d6a3a0cc928ec3827cb97566ae684ea25c3696501f8c",reds:"fdc9b4fcb49afc9e80fc8767fa7051f6573fec3f2fdc2a25c81b1db21218970b13",blueGreen:"d5efedc1e8e0a7ddd18bd2be70c6a958ba9144ad77319c5d2089460e7736036429",bluePurple:"ccddecbad0e4a8c2dd9ab0d4919cc98d85be8b6db28a55a6873c99822287730f71",greenBlue:"d3eecec5e8c3b1e1bb9bd8bb82cec269c2ca51b2cd3c9fc7288abd1675b10b60a1",orangeRed:"fddcaffdcf9bfdc18afdad77fb9562f67d53ee6545e24932d32d1ebf130da70403",purpleBlue:"dbdaebc8cee4b1c3de97b7d87bacd15b9fc93a90c01e7fb70b70ab056199045281",purpleBlueGreen:"dbd8eac8cee4b0c3de93b7d872acd1549fc83892bb1c88a3097f8702736b016353",purpleRed:"dcc9e2d3b3d7ce9eccd186c0da6bb2e14da0e23189d91e6fc61159ab07498f023a",redPurple:"fccfccfcbec0faa9b8f98faff571a5ec539ddb3695c41b8aa908808d0179700174",yellowGreen:"e4f4acd1eca0b9e2949ed68880c97c62bb6e47aa5e3297502083440e723b036034",yellowOrangeBrown:"feeaa1fedd84fecc63feb746fca031f68921eb7215db5e0bc54c05ab3d038f3204",yellowOrangeRed:"fee087fed16ffebd59fea849fd903efc7335f9522bee3423de1b20ca0b22af0225",blueOrange:"134b852f78b35da2cb9dcae1d2e5eff2f0ebfce0bafbbf74e8932fc5690d994a07",brownBlueGreen:"704108a0651ac79548e3c78af3e6c6eef1eac9e9e48ed1c74da79e187a72025147",purpleGreen:"5b1667834792a67fb6c9aed3e6d6e8eff0efd9efd5aedda971bb75368e490e5e29",purpleOrange:"4114696647968f83b7b9b4d6dadbebf3eeeafce0bafbbf74e8932fc5690d994a07",redBlue:"8c0d25bf363adf745ef4ae91fbdbc9f2efeed2e5ef9dcae15da2cb2f78b3134b85",redGrey:"8c0d25bf363adf745ef4ae91fcdccbfaf4f1e2e2e2c0c0c0969696646464343434",yellowGreenBlue:"eff9bddbf1b4bde5b594d5b969c5be45b4c22c9ec02182b82163aa23479c1c3185",redYellowBlue:"a50026d4322cf16e43fcac64fedd90faf8c1dcf1ecabd6e875abd04a74b4313695",redYellowGreen:"a50026d4322cf16e43fcac63fedd8df9f7aed7ee8ea4d86e64bc6122964f006837",pinkYellowGreen:"8e0152c0267edd72adf0b3d6faddedf5f3efe1f2cab6de8780bb474f9125276419",spectral:"9e0142d13c4bf0704afcac63fedd8dfbf8b0e0f3a1a9dda269bda94288b55e4fa2",viridis:"440154470e61481a6c482575472f7d443a834144873d4e8a39568c35608d31688e2d708e2a788e27818e23888e21918d1f988b1fa08822a8842ab07f35b77943bf7154c56866cc5d7ad1518fd744a5db36bcdf27d2e21be9e51afde725",magma:"0000040404130b0924150e3720114b2c11603b0f704a107957157e651a80721f817f24828c29819a2e80a8327db6377ac43c75d1426fde4968e95462f1605df76f5cfa7f5efc8f65fe9f6dfeaf78febf84fece91fddea0fcedaffcfdbf",inferno:"0000040403130c0826170c3b240c4f330a5f420a68500d6c5d126e6b176e781c6d86216b932667a12b62ae305cbb3755c73e4cd24644dd513ae65c30ed6925f3771af8850ffb9506fca50afcb519fac62df6d645f2e661f3f484fcffa4",plasma:"0d088723069033059742039d5002a25d01a66a00a87801a88405a7900da49c179ea72198b12a90ba3488c33d80cb4779d35171da5a69e16462e76e5bed7953f2834cf68f44fa9a3dfca636fdb32ffec029fcce25f9dc24f5ea27f0f921",cividis:"00205100235800265d002961012b65042e670831690d346b11366c16396d1c3c6e213f6e26426e2c456e31476e374a6e3c4d6e42506e47536d4c566d51586e555b6e5a5e6e5e616e62646f66676f6a6a706e6d717270717573727976737c79747f7c75827f758682768985778c8877908b78938e789691789a94789e9778a19b78a59e77a9a177aea575b2a874b6ab73bbaf71c0b26fc5b66dc9b96acebd68d3c065d8c462ddc85fe2cb5ce7cf58ebd355f0d652f3da4ff7de4cfae249fce647",rainbow:"6e40aa883eb1a43db3bf3cafd83fa4ee4395fe4b83ff576eff6659ff7847ff8c38f3a130e2b72fcfcc36bee044aff05b8ff4576ff65b52f6673af27828ea8d1ddfa319d0b81cbecb23abd82f96e03d82e14c6edb5a5dd0664dbf6e40aa",sinebow:"ff4040fc582af47218e78d0bd5a703bfbf00a7d5038de70b72f41858fc2a40ff402afc5818f4720be78d03d5a700bfbf03a7d50b8de71872f42a58fc4040ff582afc7218f48d0be7a703d5bf00bfd503a7e70b8df41872fc2a58ff4040",turbo:"23171b32204a3e2a71453493493eae4b49c54a53d7485ee44569ee4074f53c7ff8378af93295f72e9ff42ba9ef28b3e926bce125c5d925cdcf27d5c629dcbc2de3b232e9a738ee9d3ff39347f68950f9805afc7765fd6e70fe667cfd5e88fc5795fb51a1f84badf545b9f140c5ec3cd0e637dae034e4d931ecd12ef4c92bfac029ffb626ffad24ffa223ff9821ff8d1fff821dff771cfd6c1af76118f05616e84b14df4111d5380fcb2f0dc0260ab61f07ac1805a313029b0f00950c00910b00",browns:"eedbbdecca96e9b97ae4a865dc9856d18954c7784cc0673fb85536ad44339f3632",tealBlues:"bce4d89dd3d181c3cb65b3c245a2b9368fae347da0306a932c5985",teals:"bbdfdfa2d4d58ac9c975bcbb61b0af4da5a43799982b8b8c1e7f7f127273006667",warmGreys:"dcd4d0cec5c1c0b8b4b3aaa7a59c9998908c8b827f7e7673726866665c5a59504e",goldGreen:"f4d166d5ca60b6c35c98bb597cb25760a6564b9c533f8f4f33834a257740146c36",goldOrange:"f4d166f8be5cf8aa4cf5983bf3852aef701be2621fd65322c54923b142239e3a26",goldRed:"f4d166f6be59f9aa51fc964ef6834bee734ae56249db5247cf4244c43141b71d3e",lightGreyRed:"efe9e6e1dad7d5cbc8c8bdb9bbaea9cd967ddc7b43e15f19df4011dc000b",lightGreyTeal:"e4eaead6dcddc8ced2b7c2c7a6b4bc64b0bf22a6c32295c11f85be1876bc",lightMulti:"e0f1f2c4e9d0b0de9fd0e181f6e072f6c053f3993ef77440ef4a3c",lightOrange:"f2e7daf7d5baf9c499fab184fa9c73f68967ef7860e8645bde515bd43d5b",lightTealBlue:"e3e9e0c0dccf9aceca7abfc859afc0389fb9328dad2f7ca0276b95255988",darkBlue:"3232322d46681a5c930074af008cbf05a7ce25c0dd38daed50f3faffffff",darkGold:"3c3c3c584b37725e348c7631ae8b2bcfa424ecc31ef9de30fff184ffffff",darkGreen:"3a3a3a215748006f4d048942489e4276b340a6c63dd2d836ffeb2cffffaa",darkMulti:"3737371f5287197d8c29a86995ce3fffe800ffffff",darkRed:"3434347036339e3c38cc4037e75d1eec8620eeab29f0ce32ffeb2c"},F7={accent:r7,category10:n7,category20:"1f77b4aec7e8ff7f0effbb782ca02c98df8ad62728ff98969467bdc5b0d58c564bc49c94e377c2f7b6d27f7f7fc7c7c7bcbd22dbdb8d17becf9edae5",category20b:"393b795254a36b6ecf9c9ede6379398ca252b5cf6bcedb9c8c6d31bd9e39e7ba52e7cb94843c39ad494ad6616be7969c7b4173a55194ce6dbdde9ed6",category20c:"3182bd6baed69ecae1c6dbefe6550dfd8d3cfdae6bfdd0a231a35474c476a1d99bc7e9c0756bb19e9ac8bcbddcdadaeb636363969696bdbdbdd9d9d9",dark2:i7,observable10:a7,paired:o7,pastel1:l7,pastel2:s7,set1:u7,set2:c7,set3:f7,tableau10:"4c78a8f58518e4575672b7b254a24beeca3bb279a2ff9da69d755dbab0ac",tableau20:"4c78a89ecae9f58518ffbf7954a24b88d27ab79a20f2cf5b43989483bcb6e45756ff9d9879706ebab0acd67195fcbfd2b279a2d6a5c99e765fd8b5a5"};function i_(e){if(N(e))return e;let t=e.length/6|0,n=Array(t);for(let r=0;r<t;)n[r]="#"+e.slice(r*6,++r*6);return n}function a_(e,t){for(let n in e)xm(n,t(e[n]))}var o_={};a_(F7,i_),a_(S7,e=>sc(i_(e)));function xm(e,t){return e&&(e=e.toLowerCase()),arguments.length>1?(o_[e]=t,this):o_[e]}var C7=e=>N(e)?e.map(t=>String(t)):String(e),M7=(e,t)=>e[1]-t[1],O7=(e,t)=>t[1]-e[1];function wm(e,t,n){let r;return we(t)&&(e.bins&&(t=Math.max(t,e.bins.length)),n!=null&&(t=Math.min(t,Math.floor(Mu(e.domain())/n||1)+1))),J(t)&&(r=t.step,t=t.interval),Y(t)&&(t=e.type==="time"?Jh(t):e.type=="utc"?Wh(t):L("Only time and utc scales accept interval strings."),r&&(t=t.every(r))),t}function l_(e,t,n){let r=e.range(),i=r[0],a=$e(r),o=M7;if(i>a&&(r=a,a=i,i=r,o=O7),i=Math.floor(i),a=Math.ceil(a),t=t.map(l=>[l,e(l)]).filter(l=>i<=l[1]&&l[1]<=a).sort(o).map(l=>l[0]),n>0&&t.length>1){let l=[t[0],$e(t)];for(;t.length>n&&t.length>=3;)t=t.filter((s,u)=>!(u%2));t.length<3&&(t=l)}return t}function _m(e,t){return e.bins?l_(e,e.bins,t):e.ticks?e.ticks(t):e.domain()}function s_(e,t,n,r,i,a){let o=t.type,l=C7;if(o==="time"||i==="time")l=e.timeFormat(r);else if(o==="utc"||i==="utc")l=e.utcFormat(r);else if(Kw(o)){let s=e.formatFloat(r);if(a||t.bins)l=s;else{let u=u_(t,n,!1);l=c=>u(c)?s(c):""}}else if(t.tickFormat){let s=t.domain();l=e.formatSpan(s[0],s[s.length-1],n,r)}else r&&(l=e.format(r));return l}function u_(e,t,n){let r=_m(e,t),i=e.base(),a=Math.log(i),o=Math.max(1,i*t/r.length),l=s=>{let u=s/i**+Math.round(Math.log(s)/a);return u*i<i-.5&&(u*=i),u<=o};return n?r.filter(l):l}var km={[Ul]:"quantiles",[pm]:"thresholds",[Hw]:"domain"},c_={[Ul]:"quantiles",[pm]:"domain"};function f_(e,t){return e.bins?R7(e.bins):e.type==="log"?u_(e,t,!0):km[e.type]?N7(e[km[e.type]]()):_m(e,t)}function z7(e,t,n){let r=t[c_[t.type]](),i=r.length,a=i>1?r[1]-r[0]:r[0],o;for(o=1;o<i;++o)a=Math.min(a,r[o]-r[o-1]);return e.formatSpan(0,a,30,n)}function N7(e){let t=[-1/0].concat(e);return t.max=1/0,t}function R7(e){let t=e.slice(0,-1);return t.max=$e(e),t}var T7=e=>km[e.type]||e.bins;function d_(e,t,n,r,i,a,o){let l=c_[t.type]&&a!=="time"&&a!=="utc"?z7(e,t,i):s_(e,t,n,i,a,o);return r==="symbol"&&T7(t)?L7(l):r==="discrete"?P7(l):B7(l)}var L7=e=>(t,n,r)=>{let i=h_(r[n+1],h_(r.max,1/0)),a=p_(t,e),o=p_(i,e);return a&&o?a+" \u2013 "+o:o?"< "+o:"\u2265 "+a},h_=(e,t)=>e??t,P7=e=>(t,n)=>n?e(t):null,B7=e=>t=>e(t),p_=(e,t)=>Number.isFinite(e)?t(e):null;function I7(e){let t=e.domain(),n=t.length-1,r=+t[0],i=+$e(t),a=i-r;if(e.type==="threshold"){let o=n?a/n:.1;r-=o,i+=o,a=i-r}return o=>(o-r)/a}function j7(e,t,n,r){let i=r||t.type;return Y(n)&&$7(i)&&(n=n.replace(/%a/g,"%A").replace(/%b/g,"%B")),!n&&i==="time"?e.timeFormat("%A, %d %B %Y, %X"):!n&&i==="utc"?e.utcFormat("%A, %d %B %Y, %X UTC"):d_(e,t,5,null,n,r,!0)}function m_(e,t,n){n||(n={});let r=Math.max(3,n.maxlen||7),i=j7(e,t,n.format,n.formatType);if(vm(t.type)){let a=f_(t).slice(1).map(i),o=a.length;return`${o} boundar${o===1?"y":"ies"}: ${a.join(", ")}`}else if(_o(t.type)){let a=t.domain(),o=a.length,l=o>r?a.slice(0,r-2).map(i).join(", ")+", ending with "+a.slice(-1).map(i):a.map(i).join(", ");return`${o} value${o===1?"":"s"}: ${l}`}else{let a=t.domain();return`values from ${i(a[0])} to ${i($e(a))}`}}var g_=0;function q7(){g_=0}var uc="p_";function Em(e){return e&&e.gradient}function y_(e,t,n){let r=e.gradient,i=e.id,a=r==="radial"?uc:"";return i||(i=e.id="gradient_"+g_++,r==="radial"?(e.x1=fr(e.x1,.5),e.y1=fr(e.y1,.5),e.r1=fr(e.r1,0),e.x2=fr(e.x2,.5),e.y2=fr(e.y2,.5),e.r2=fr(e.r2,.5),a=uc):(e.x1=fr(e.x1,0),e.y1=fr(e.y1,0),e.x2=fr(e.x2,1),e.y2=fr(e.y2,0))),t[i]=e,"url("+(n||"")+"#"+a+i+")"}function fr(e,t){return e??t}function v_(e,t){var n=[],r;return r={gradient:"linear",x1:e?e[0]:0,y1:e?e[1]:0,x2:t?t[0]:1,y2:t?t[1]:0,stops:n,stop:function(i,a){return n.push({offset:i,color:a}),r}}}var b_={basis:{curve:kO},"basis-closed":{curve:SO},"basis-open":{curve:FO},bundle:{curve:OO,tension:"beta",value:.85},cardinal:{curve:RO,tension:"tension",value:0},"cardinal-open":{curve:AO,tension:"tension",value:0},"cardinal-closed":{curve:DO,tension:"tension",value:0},"catmull-rom":{curve:BO,tension:"alpha",value:.5},"catmull-rom-closed":{curve:MO,tension:"alpha",value:.5},"catmull-rom-open":{curve:$O,tension:"alpha",value:.5},linear:{curve:h2},"linear-closed":{curve:LO},monotone:{horizontal:NO,vertical:EO},natural:{curve:CO},step:{curve:TO},"step-after":{curve:PO},"step-before":{curve:zO}};function $m(e,t,n){var r=K(b_,e)&&b_[e],i=null;return r&&(i=r.curve||r[t||"vertical"],r.tension&&n!=null&&(i=i[r.tension](n))),i}var U7={m:2,l:2,h:1,v:1,z:0,c:6,s:4,q:4,t:2,a:7},W7=/[mlhvzcsqta]([^mlhvzcsqta]+|$)/gi,H7=/^[+-]?(([0-9]*\.[0-9]+)|([0-9]+\.)|([0-9]+))([eE][+-]?[0-9]+)?/,G7=/^((\s+,?\s*)|(,\s*))/,V7=/^[01]/;function ko(e){let t=[];return(e.match(W7)||[]).forEach(n=>{let r=n[0],i=r.toLowerCase(),a=U7[i],o=X7(i,a,n.slice(1).trim()),l=o.length;if(l<a||l&&l%a!==0)throw Error("Invalid SVG path, incorrect parameter count");if(t.push([r,...o.slice(0,a)]),l!==a){i==="m"&&(r=r==="M"?"L":"l");for(let s=a;s<l;s+=a)t.push([r,...o.slice(s,s+a)])}}),t}function X7(e,t,n){let r=[];for(let i=0;t&&i<n.length;)for(let a=0;a<t;++a){let o=e==="a"&&(a===3||a===4)?V7:H7,l=n.slice(i).match(o);if(l===null)throw Error("Invalid SVG path, incorrect parameter type");i+=l[0].length,r.push(+l[0]);let s=n.slice(i).match(G7);s!==null&&(i+=s[0].length)}return r}var _i=Math.PI/180,Y7=1e-14,fa=Math.PI/2,dr=Math.PI*2,Eo=Math.sqrt(3)/2,Am={},Dm={},x_=[].join;function J7(e,t,n,r,i,a,o,l,s){let u=x_.call(arguments);if(Am[u])return Am[u];let c=o*_i,f=Math.sin(c),d=Math.cos(c);n=Math.abs(n),r=Math.abs(r);let h=d*(l-e)*.5+f*(s-t)*.5,p=d*(s-t)*.5-f*(l-e)*.5,m=h*h/(n*n)+p*p/(r*r);m>1&&(m=Math.sqrt(m),n*=m,r*=m);let g=d/n,y=f/n,v=-f/r,b=d/r,w=g*l+y*s,_=v*l+b*s,k=g*e+y*t,x=v*e+b*t,E=1/((k-w)*(k-w)+(x-_)*(x-_))-.25;E<0&&(E=0);let $=Math.sqrt(E);a==i&&($=-$);let D=.5*(w+k)-$*(x-_),F=.5*(_+x)+$*(k-w),T=Math.atan2(_-F,w-D),S=Math.atan2(x-F,k-D)-T;S<0&&a===1?S+=dr:S>0&&a===0&&(S-=dr);let M=Math.ceil(Math.abs(S/(fa+.001))),A=[];for(let C=0;C<M;++C)A[C]=[D,F,T+C*S/M,T+(C+1)*S/M,n,r,f,d];return Am[u]=A}function Q7(e){let t=x_.call(e);if(Dm[t])return Dm[t];var n=e[0],r=e[1],i=e[2],a=e[3],o=e[4],l=e[5],s=e[6],u=e[7];let c=u*o,f=-s*l,d=s*o,h=u*l,p=Math.cos(i),m=Math.sin(i),g=Math.cos(a),y=Math.sin(a),v=.5*(a-i),b=Math.sin(v*.5),w=8/3*b*b/Math.sin(v),_=n+p-w*m,k=r+m+w*p,x=n+g,E=r+y,$=x+w*y,D=E-w*g;return Dm[t]=[c*_+f*k,d*_+h*k,c*$+f*D,d*$+h*D,c*x+f*E,d*x+h*E]}var _n=["l",0,0,0,0,0,0,0];function K7(e,t,n){let r=_n[0]=e[0];if(r==="a"||r==="A")_n[1]=t*e[1],_n[2]=n*e[2],_n[3]=e[3],_n[4]=e[4],_n[5]=e[5],_n[6]=t*e[6],_n[7]=n*e[7];else if(r==="h"||r==="H")_n[1]=t*e[1];else if(r==="v"||r==="V")_n[1]=n*e[1];else for(var i=1,a=e.length;i<a;++i)_n[i]=(i%2==1?t:n)*e[i];return _n}function Gl(e,t,n,r,i,a){var o,l=null,s=0,u=0,c=0,f=0,d,h,p,m,g=0,y=0;n??(n=0),r??(r=0),i??(i=1),a??(a=i),e.beginPath&&e.beginPath();for(var v=0,b=t.length;v<b;++v){switch(o=t[v],(i!==1||a!==1)&&(o=K7(o,i,a)),o[0]){case"l":s+=o[1],u+=o[2],e.lineTo(s+n,u+r);break;case"L":s=o[1],u=o[2],e.lineTo(s+n,u+r);break;case"h":s+=o[1],e.lineTo(s+n,u+r);break;case"H":s=o[1],e.lineTo(s+n,u+r);break;case"v":u+=o[1],e.lineTo(s+n,u+r);break;case"V":u=o[1],e.lineTo(s+n,u+r);break;case"m":s+=o[1],u+=o[2],g=s,y=u,e.moveTo(s+n,u+r);break;case"M":s=o[1],u=o[2],g=s,y=u,e.moveTo(s+n,u+r);break;case"c":d=s+o[5],h=u+o[6],c=s+o[3],f=u+o[4],e.bezierCurveTo(s+o[1]+n,u+o[2]+r,c+n,f+r,d+n,h+r),s=d,u=h;break;case"C":s=o[5],u=o[6],c=o[3],f=o[4],e.bezierCurveTo(o[1]+n,o[2]+r,c+n,f+r,s+n,u+r);break;case"s":d=s+o[3],h=u+o[4],c=2*s-c,f=2*u-f,e.bezierCurveTo(c+n,f+r,s+o[1]+n,u+o[2]+r,d+n,h+r),c=s+o[1],f=u+o[2],s=d,u=h;break;case"S":d=o[3],h=o[4],c=2*s-c,f=2*u-f,e.bezierCurveTo(c+n,f+r,o[1]+n,o[2]+r,d+n,h+r),s=d,u=h,c=o[1],f=o[2];break;case"q":d=s+o[3],h=u+o[4],c=s+o[1],f=u+o[2],e.quadraticCurveTo(c+n,f+r,d+n,h+r),s=d,u=h;break;case"Q":d=o[3],h=o[4],e.quadraticCurveTo(o[1]+n,o[2]+r,d+n,h+r),s=d,u=h,c=o[1],f=o[2];break;case"t":d=s+o[1],h=u+o[2],l[0].match(/[QqTt]/)===null?(c=s,f=u):l[0]==="t"?(c=2*s-p,f=2*u-m):l[0]==="q"&&(c=2*s-c,f=2*u-f),p=c,m=f,e.quadraticCurveTo(c+n,f+r,d+n,h+r),s=d,u=h,c=s+o[1],f=u+o[2];break;case"T":d=o[1],h=o[2],c=2*s-c,f=2*u-f,e.quadraticCurveTo(c+n,f+r,d+n,h+r),s=d,u=h;break;case"a":w_(e,s+n,u+r,[o[1],o[2],o[3],o[4],o[5],o[6]+s+n,o[7]+u+r]),s+=o[6],u+=o[7];break;case"A":w_(e,s+n,u+r,[o[1],o[2],o[3],o[4],o[5],o[6]+n,o[7]+r]),s=o[6],u=o[7];break;case"z":case"Z":s=g,u=y,e.closePath();break}l=o}}function w_(e,t,n,r){let i=J7(r[5],r[6],r[0],r[1],r[3],r[4],r[2],t,n);for(let a=0;a<i.length;++a){let o=Q7(i[a]);e.bezierCurveTo(o[0],o[1],o[2],o[3],o[4],o[5])}}var __=.5773502691896257,k_={circle:{draw:function(e,t){let n=Math.sqrt(t)/2;e.moveTo(n,0),e.arc(0,0,n,0,dr)}},cross:{draw:function(e,t){var n=Math.sqrt(t)/2,r=n/2.5;e.moveTo(-n,-r),e.lineTo(-n,r),e.lineTo(-r,r),e.lineTo(-r,n),e.lineTo(r,n),e.lineTo(r,r),e.lineTo(n,r),e.lineTo(n,-r),e.lineTo(r,-r),e.lineTo(r,-n),e.lineTo(-r,-n),e.lineTo(-r,-r),e.closePath()}},diamond:{draw:function(e,t){let n=Math.sqrt(t)/2;e.moveTo(-n,0),e.lineTo(0,-n),e.lineTo(n,0),e.lineTo(0,n),e.closePath()}},square:{draw:function(e,t){var n=Math.sqrt(t),r=-n/2;e.rect(r,r,n,n)}},arrow:{draw:function(e,t){var n=Math.sqrt(t)/2,r=n/7,i=n/2.5,a=n/8;e.moveTo(-r,n),e.lineTo(r,n),e.lineTo(r,-a),e.lineTo(i,-a),e.lineTo(0,-n),e.lineTo(-i,-a),e.lineTo(-r,-a),e.closePath()}},wedge:{draw:function(e,t){var n=Math.sqrt(t)/2,r=Eo*n,i=r-n*__,a=n/4;e.moveTo(0,-r-i),e.lineTo(-a,r-i),e.lineTo(a,r-i),e.closePath()}},triangle:{draw:function(e,t){var n=Math.sqrt(t)/2,r=Eo*n,i=r-n*__;e.moveTo(0,-r-i),e.lineTo(-n,r-i),e.lineTo(n,r-i),e.closePath()}},"triangle-up":{draw:function(e,t){var n=Math.sqrt(t)/2,r=Eo*n;e.moveTo(0,-r),e.lineTo(-n,r),e.lineTo(n,r),e.closePath()}},"triangle-down":{draw:function(e,t){var n=Math.sqrt(t)/2,r=Eo*n;e.moveTo(0,r),e.lineTo(-n,-r),e.lineTo(n,-r),e.closePath()}},"triangle-right":{draw:function(e,t){var n=Math.sqrt(t)/2,r=Eo*n;e.moveTo(r,0),e.lineTo(-r,-n),e.lineTo(-r,n),e.closePath()}},"triangle-left":{draw:function(e,t){var n=Math.sqrt(t)/2,r=Eo*n;e.moveTo(-r,0),e.lineTo(r,-n),e.lineTo(r,n),e.closePath()}},stroke:{draw:function(e,t){let n=Math.sqrt(t)/2;e.moveTo(-n,0),e.lineTo(n,0)}}};function E_(e){return K(k_,e)?k_[e]:Z7(e)}var Sm={};function Z7(e){if(!K(Sm,e)){let t=ko(e);Sm[e]={draw:function(n,r){Gl(n,t,0,0,Math.sqrt(r)/2)}}}return Sm[e]}var ki=.448084975506;function ez(e){return e.x}function tz(e){return e.y}function nz(e){return e.width}function rz(e){return e.height}function Pr(e){return typeof e=="function"?e:()=>+e}function cc(e,t,n){return Math.max(t,Math.min(e,n))}function $_(){var e=ez,t=tz,n=nz,r=rz,i=Pr(0),a=i,o=i,l=i,s=null;function u(c,f,d){var h,p=f??+e.call(this,c),m=d??+t.call(this,c),g=+n.call(this,c),y=+r.call(this,c),v=Math.min(g,y)/2,b=cc(+i.call(this,c),0,v),w=cc(+a.call(this,c),0,v),_=cc(+o.call(this,c),0,v),k=cc(+l.call(this,c),0,v);if(s||(s=h=ap()),b<=0&&w<=0&&_<=0&&k<=0)s.rect(p,m,g,y);else{var x=p+g,E=m+y;s.moveTo(p+b,m),s.lineTo(x-w,m),s.bezierCurveTo(x-ki*w,m,x,m+ki*w,x,m+w),s.lineTo(x,E-k),s.bezierCurveTo(x,E-ki*k,x-ki*k,E,x-k,E),s.lineTo(p+_,E),s.bezierCurveTo(p+ki*_,E,p,E-ki*_,p,E-_),s.lineTo(p,m+b),s.bezierCurveTo(p,m+ki*b,p+ki*b,m,p+b,m),s.closePath()}if(h)return s=null,h+""||null}return u.x=function(c){return arguments.length?(e=Pr(c),u):e},u.y=function(c){return arguments.length?(t=Pr(c),u):t},u.width=function(c){return arguments.length?(n=Pr(c),u):n},u.height=function(c){return arguments.length?(r=Pr(c),u):r},u.cornerRadius=function(c,f,d,h){return arguments.length?(i=Pr(c),a=f==null?i:Pr(f),l=d==null?i:Pr(d),o=h==null?a:Pr(h),u):i},u.context=function(c){return arguments.length?(s=c??null,u):s},u}function A_(){var e,t,n,r,i=null,a,o,l,s;function u(f,d,h){let p=h/2;if(a){var m=l-d,g=f-o;if(m||g){var y=Math.hypot(m,g),v=(m/=y)*s,b=(g/=y)*s,w=Math.atan2(g,m);i.moveTo(o-v,l-b),i.lineTo(f-m*p,d-g*p),i.arc(f,d,p,w-Math.PI,w),i.lineTo(o+v,l+b),i.arc(o,l,s,w,w+Math.PI)}else i.arc(f,d,p,0,dr);i.closePath()}else a=1;o=f,l=d,s=p}function c(f){var d,h=f.length,p,m=!1,g;for(i??(i=g=ap()),d=0;d<=h;++d)!(d<h&&r(p=f[d],d,f))===m&&(m=!m)&&(a=0),m&&u(+e(p,d,f),+t(p,d,f),+n(p,d,f));if(g)return i=null,g+""||null}return c.x=function(f){return arguments.length?(e=f,c):e},c.y=function(f){return arguments.length?(t=f,c):t},c.size=function(f){return arguments.length?(n=f,c):n},c.defined=function(f){return arguments.length?(r=f,c):r},c.context=function(f){return arguments.length?(i=f??null,c):i},c}function Vl(e,t){return e??t}var Xl=e=>e.x||0,Yl=e=>e.y||0,iz=e=>e.width||0,az=e=>e.height||0,oz=e=>(e.x||0)+(e.width||0),lz=e=>(e.y||0)+(e.height||0),sz=e=>e.startAngle||0,uz=e=>e.endAngle||0,cz=e=>e.padAngle||0,fz=e=>e.innerRadius||0,dz=e=>e.outerRadius||0,hz=e=>e.cornerRadius||0,pz=e=>Vl(e.cornerRadiusTopLeft,e.cornerRadius)||0,mz=e=>Vl(e.cornerRadiusTopRight,e.cornerRadius)||0,gz=e=>Vl(e.cornerRadiusBottomRight,e.cornerRadius)||0,yz=e=>Vl(e.cornerRadiusBottomLeft,e.cornerRadius)||0,vz=e=>Vl(e.size,64),bz=e=>e.size||1,fc=e=>e.defined!==!1,xz=e=>E_(e.shape||"circle"),wz=wO().startAngle(sz).endAngle(uz).padAngle(cz).innerRadius(fz).outerRadius(dz).cornerRadius(hz),_z=Dw().x(Xl).y1(Yl).y0(lz).defined(fc),kz=Dw().y(Yl).x1(Xl).x0(oz).defined(fc),Ez=p2().x(Xl).y(Yl).defined(fc),$z=$_().x(Xl).y(Yl).width(iz).height(az).cornerRadius(pz,mz,gz,yz),Az=U9().type(xz).size(vz),Dz=A_().x(Xl).y(Yl).defined(fc).size(bz);function Fm(e){return e.cornerRadius||e.cornerRadiusTopLeft||e.cornerRadiusTopRight||e.cornerRadiusBottomRight||e.cornerRadiusBottomLeft}function Sz(e,t){return wz.context(e)(t)}function Fz(e,t){let n=t[0],r=n.interpolate||"linear";return(n.orient==="horizontal"?kz:_z).curve($m(r,n.orient,n.tension)).context(e)(t)}function Cz(e,t){let n=t[0],r=n.interpolate||"linear";return Ez.curve($m(r,n.orient,n.tension)).context(e)(t)}function $o(e,t,n,r){return $z.context(e)(t,n,r)}function Mz(e,t){return(t.mark.shape||t.shape).context(e)(t)}function Oz(e,t){return Az.context(e)(t)}function zz(e,t){return Dz.context(e)(t)}var D_=1;function Nz(){D_=1}function Cm(e,t,n){var r=t.clip,i=e._defs,a=t.clip_id||(t.clip_id="clip"+D_++),o=i.clipping[a]||(i.clipping[a]={id:a});return de(r)?o.path=r(null):Fm(n)?o.path=$o(null,n,0,0):(o.width=n.width||0,o.height=n.height||0),"url(#"+a+")"}function Ke(e){this.clear(),e&&this.union(e)}Ke.prototype={clone(){return new Ke(this)},clear(){return this.x1=+Number.MAX_VALUE,this.y1=+Number.MAX_VALUE,this.x2=-Number.MAX_VALUE,this.y2=-Number.MAX_VALUE,this},empty(){return this.x1===+Number.MAX_VALUE&&this.y1===+Number.MAX_VALUE&&this.x2===-Number.MAX_VALUE&&this.y2===-Number.MAX_VALUE},equals(e){return this.x1===e.x1&&this.y1===e.y1&&this.x2===e.x2&&this.y2===e.y2},set(e,t,n,r){return n<e?(this.x2=e,this.x1=n):(this.x1=e,this.x2=n),r<t?(this.y2=t,this.y1=r):(this.y1=t,this.y2=r),this},add(e,t){return e<this.x1&&(this.x1=e),t<this.y1&&(this.y1=t),e>this.x2&&(this.x2=e),t>this.y2&&(this.y2=t),this},expand(e){return this.x1-=e,this.y1-=e,this.x2+=e,this.y2+=e,this},round(){return this.x1=Math.floor(this.x1),this.y1=Math.floor(this.y1),this.x2=Math.ceil(this.x2),this.y2=Math.ceil(this.y2),this},scale(e){return this.x1*=e,this.y1*=e,this.x2*=e,this.y2*=e,this},translate(e,t){return this.x1+=e,this.x2+=e,this.y1+=t,this.y2+=t,this},rotate(e,t,n){let r=this.rotatedPoints(e,t,n);return this.clear().add(r[0],r[1]).add(r[2],r[3]).add(r[4],r[5]).add(r[6],r[7])},rotatedPoints(e,t,n){var{x1:r,y1:i,x2:a,y2:o}=this,l=Math.cos(e),s=Math.sin(e),u=t-t*l+n*s,c=n-t*s-n*l;return[l*r-s*i+u,s*r+l*i+c,l*r-s*o+u,s*r+l*o+c,l*a-s*i+u,s*a+l*i+c,l*a-s*o+u,s*a+l*o+c]},union(e){return e.x1<this.x1&&(this.x1=e.x1),e.y1<this.y1&&(this.y1=e.y1),e.x2>this.x2&&(this.x2=e.x2),e.y2>this.y2&&(this.y2=e.y2),this},intersect(e){return e.x1>this.x1&&(this.x1=e.x1),e.y1>this.y1&&(this.y1=e.y1),e.x2<this.x2&&(this.x2=e.x2),e.y2<this.y2&&(this.y2=e.y2),this},encloses(e){return e&&this.x1<=e.x1&&this.x2>=e.x2&&this.y1<=e.y1&&this.y2>=e.y2},alignsWith(e){return e&&(this.x1==e.x1||this.x2==e.x2||this.y1==e.y1||this.y2==e.y2)},intersects(e){return e&&!(this.x2<e.x1||this.x1>e.x2||this.y2<e.y1||this.y1>e.y2)},contains(e,t){return!(e<this.x1||e>this.x2||t<this.y1||t>this.y2)},width(){return this.x2-this.x1},height(){return this.y2-this.y1}};function dc(e){this.mark=e,this.bounds=this.bounds||new Ke}function hc(e){dc.call(this,e),this.items=this.items||[]}G(hc,dc);var S_=class{constructor(e){this._pending=0,this._loader=e||Ru()}pending(){return this._pending}sanitizeURL(e){let t=this;return F_(t),t._loader.sanitize(e,{context:"href"}).then(n=>(Jl(t),n)).catch(()=>(Jl(t),null))}loadImage(e){let t=this,n=W9();return F_(t),t._loader.sanitize(e,{context:"image"}).then(r=>{let i=r.href;if(!i||!n)throw{url:i};let a=new n,o=K(r,"crossOrigin")?r.crossOrigin:"anonymous";return o!=null&&(a.crossOrigin=o),a.onload=()=>Jl(t),a.onerror=()=>Jl(t),a.src=i,a}).catch(r=>(Jl(t),{complete:!1,width:0,height:0,src:r&&r.url||""}))}ready(){let e=this;return new Promise(t=>{function n(r){e.pending()?setTimeout(()=>{n(!0)},10):t(r)}n(!1)})}};function F_(e){e._pending+=1}function Jl(e){--e._pending}function Br(e,t,n){if(t.stroke&&t.opacity!==0&&t.strokeOpacity!==0){let r=t.strokeWidth==null?1:+t.strokeWidth;e.expand(r+(n?Rz(t,r):0))}return e}function Rz(e,t){return e.strokeJoin&&e.strokeJoin!=="miter"?0:t}var Tz=dr-1e-8,pc,mc,gc,da,Mm,yc,Om,zm,Ei=(e,t)=>pc.add(e,t),vc=(e,t)=>Ei(mc=e,gc=t),C_=e=>Ei(e,pc.y1),M_=e=>Ei(pc.x1,e),ha=(e,t)=>Mm*e+Om*t,pa=(e,t)=>yc*e+zm*t,Nm=(e,t)=>Ei(ha(e,t),pa(e,t)),Rm=(e,t)=>vc(ha(e,t),pa(e,t));function Ql(e,t){return pc=e,t?(da=t*_i,Mm=zm=Math.cos(da),yc=Math.sin(da),Om=-yc):(Mm=zm=1,da=yc=Om=0),Lz}var Lz={beginPath(){},closePath(){},moveTo:Rm,lineTo:Rm,rect(e,t,n,r){da?(Nm(e+n,t),Nm(e+n,t+r),Nm(e,t+r),Rm(e,t)):(Ei(e+n,t+r),vc(e,t))},quadraticCurveTo(e,t,n,r){let i=ha(e,t),a=pa(e,t),o=ha(n,r),l=pa(n,r);O_(mc,i,o,C_),O_(gc,a,l,M_),vc(o,l)},bezierCurveTo(e,t,n,r,i,a){let o=ha(e,t),l=pa(e,t),s=ha(n,r),u=pa(n,r),c=ha(i,a),f=pa(i,a);z_(mc,o,s,c,C_),z_(gc,l,u,f,M_),vc(c,f)},arc(e,t,n,r,i,a){if(r+=da,i+=da,mc=n*Math.cos(i)+e,gc=n*Math.sin(i)+t,Math.abs(i-r)>Tz)Ei(e-n,t-n),Ei(e+n,t+n);else{let o=u=>Ei(n*Math.cos(u)+e,n*Math.sin(u)+t),l,s;if(o(r),o(i),i!==r)if(r%=dr,r<0&&(r+=dr),i%=dr,i<0&&(i+=dr),i<r&&(a=!a,l=r,r=i,i=l),a)for(i-=dr,l=r-r%fa,s=0;s<4&&l>i;++s,l-=fa)o(l);else for(l=r-r%fa+fa,s=0;s<4&&l<i;++s,l+=fa)o(l)}}};function O_(e,t,n,r){let i=(e-t)/(e+n-2*t);0<i&&i<1&&r(e+(t-e)*i)}function z_(e,t,n,r,i){let a=r-e+3*t-3*n,o=e+n-2*t,l=e-t,s=0,u=0,c;Math.abs(a)>Y7?(c=o*o+l*a,c>=0&&(c=Math.sqrt(c),s=(-o+c)/a,u=(-o-c)/a)):s=.5*l/o,0<s&&s<1&&i(N_(s,e,t,n,r)),0<u&&u<1&&i(N_(u,e,t,n,r))}function N_(e,t,n,r,i){let a=1-e,o=a*a,l=e*e;return o*a*t+3*o*e*n+3*a*l*r+l*e*i}var $i=($i=bi(1,1))?$i.getContext("2d"):null,Tm=new Ke;function Lm(e){return function(t,n){if(!$i)return!0;e($i,t),Tm.clear().union(t.bounds).intersect(n).round();let{x1:r,y1:i,x2:a,y2:o}=Tm;for(let l=i;l<=o;++l)for(let s=r;s<=a;++s)if($i.isPointInPath(s,l))return!0;return!1}}function Pm(e,t){return t.contains(e.x||0,e.y||0)}function R_(e,t){let n=e.x||0,r=e.y||0,i=e.width||0,a=e.height||0;return t.intersects(Tm.set(n,r,n+i,r+a))}function T_(e,t){let n=e.x||0,r=e.y||0;return Ao(t,n,r,e.x2==null?n:e.x2,e.y2==null?r:e.y2)}function Ao(e,t,n,r,i){let{x1:a,y1:o,x2:l,y2:s}=e,u=r-t,c=i-n,f=0,d=1,h,p,m,g;for(g=0;g<4;++g){if(g===0&&(h=-u,p=-(a-t)),g===1&&(h=u,p=l-t),g===2&&(h=-c,p=-(o-n)),g===3&&(h=c,p=s-n),Math.abs(h)<1e-10&&p<0)return!1;if(m=p/h,h<0){if(m>d)return!1;m>f&&(f=m)}else if(h>0){if(m<f)return!1;m<d&&(d=m)}}return!0}function Do(e,t){e.globalCompositeOperation=t.blend||"source-over"}function Rn(e,t){return e??t}function L_(e,t){let n=t.length;for(let r=0;r<n;++r)e.addColorStop(t[r].offset,t[r].color);return e}function Pz(e,t,n){let r=n.width(),i=n.height(),a;if(t.gradient==="radial")a=e.createRadialGradient(n.x1+Rn(t.x1,.5)*r,n.y1+Rn(t.y1,.5)*i,Math.max(r,i)*Rn(t.r1,0),n.x1+Rn(t.x2,.5)*r,n.y1+Rn(t.y2,.5)*i,Math.max(r,i)*Rn(t.r2,.5));else{let o=Rn(t.x1,0),l=Rn(t.y1,0),s=Rn(t.x2,1),u=Rn(t.y2,0);if(o===s||l===u||r===i)a=e.createLinearGradient(n.x1+o*r,n.y1+l*i,n.x1+s*r,n.y1+u*i);else{let c=bi(Math.ceil(r),Math.ceil(i)),f=c.getContext("2d");return f.scale(r,i),f.fillStyle=L_(f.createLinearGradient(o,l,s,u),t.stops),f.fillRect(0,0,r,i),e.createPattern(c,"no-repeat")}}return L_(a,t.stops)}function P_(e,t,n){return Em(n)?Pz(e,n,t.bounds):n}function bc(e,t,n){return n*=t.fillOpacity==null?1:t.fillOpacity,n>0?(e.globalAlpha=n,e.fillStyle=P_(e,t,t.fill),!0):!1}var Bz=[];function So(e,t,n){var r=(r=t.strokeWidth)??1;return r<=0?!1:(n*=t.strokeOpacity==null?1:t.strokeOpacity,n>0?(e.globalAlpha=n,e.strokeStyle=P_(e,t,t.stroke),e.lineWidth=r,e.lineCap=t.strokeCap||"butt",e.lineJoin=t.strokeJoin||"miter",e.miterLimit=t.strokeMiterLimit||10,e.setLineDash&&(e.setLineDash(t.strokeDash||Bz),e.lineDashOffset=t.strokeDashOffset||0),!0):!1)}function Iz(e,t){return e.zindex-t.zindex||e.index-t.index}function Bm(e){if(!e.zdirty)return e.zitems;var t=e.items,n=[],r,i,a;for(i=0,a=t.length;i<a;++i)r=t[i],r.index=i,r.zindex&&n.push(r);return e.zdirty=!1,e.zitems=n.sort(Iz)}function Tn(e,t){var n=e.items,r,i;if(!n||!n.length)return;let a=Bm(e);if(a&&a.length){for(r=0,i=n.length;r<i;++r)n[r].zindex||t(n[r]);n=a}for(r=0,i=n.length;r<i;++r)t(n[r])}function xc(e,t){var n=e.items,r,i;if(!n||!n.length)return null;let a=Bm(e);for(a&&a.length&&(n=a),i=n.length;--i>=0;)if(r=t(n[i]))return r;if(n===a){for(n=e.items,i=n.length;--i>=0;)if(!n[i].zindex&&(r=t(n[i])))return r}return null}function Im(e){return function(t,n,r){Tn(n,i=>{(!r||r.intersects(i.bounds))&&B_(e,t,i,i)})}}function jz(e){return function(t,n,r){n.items.length&&(!r||r.intersects(n.bounds))&&B_(e,t,n.items[0],n.items)}}function B_(e,t,n,r){var i=n.opacity==null?1:n.opacity;i!==0&&(e(t,r)||(Do(t,n),n.fill&&bc(t,n,i)&&t.fill(),n.stroke&&So(t,n,i)&&t.stroke()))}function wc(e){return e||(e=yn),function(t,n,r,i,a,o){return r*=t.pixelRatio,i*=t.pixelRatio,xc(n,l=>{let s=l.bounds;if(!(s&&!s.contains(a,o)||!s)&&e(t,l,r,i,a,o))return l})}}function Kl(e,t){return function(n,r,i,a){var o=Array.isArray(r)?r[0]:r,l=t??o.fill,s=o.stroke&&n.isPointInStroke,u,c;return s&&(u=o.strokeWidth,c=o.strokeCap,n.lineWidth=u??1,n.lineCap=c??"butt"),e(n,r)?!1:l&&n.isPointInPath(i,a)||s&&n.isPointInStroke(i,a)}}function jm(e){return wc(Kl(e))}function ma(e,t){return"translate("+e+","+t+")"}function qm(e){return"rotate("+e+")"}function qz(e,t){return"scale("+e+","+t+")"}function I_(e){return ma(e.x||0,e.y||0)}function Uz(e){return ma(e.x||0,e.y||0)+(e.angle?" "+qm(e.angle):"")}function Wz(e){return ma(e.x||0,e.y||0)+(e.angle?" "+qm(e.angle):"")+(e.scaleX||e.scaleY?" "+qz(e.scaleX||1,e.scaleY||1):"")}function Um(e,t,n){function r(o,l){o("transform",Uz(l)),o("d",t(null,l))}function i(o,l){return t(Ql(o,l.angle),l),Br(o,l).translate(l.x||0,l.y||0)}function a(o,l){var s=l.x||0,u=l.y||0,c=l.angle||0;o.translate(s,u),c&&o.rotate(c*=_i),o.beginPath(),t(o,l),c&&o.rotate(-c),o.translate(-s,-u)}return{type:e,tag:"path",nested:!1,attr:r,bound:i,draw:Im(a),pick:jm(a),isect:n||Lm(a)}}var Hz=Um("arc",Sz);function Gz(e,t){for(var n=e[0].orient==="horizontal"?t[1]:t[0],r=e[0].orient==="horizontal"?"y":"x",i=e.length,a=1/0,o,l;--i>=0;)e[i].defined!==!1&&(l=Math.abs(e[i][r]-n),l<a&&(a=l,o=e[i]));return o}function Vz(e,t){for(var n=(e[0].strokeWidth||1)**2,r=e.length,i,a,o;--r>=0;)if(e[r].defined!==!1&&(i=e[r].x-t[0],a=e[r].y-t[1],o=i*i+a*a,o<n))return e[r];return null}function Xz(e,t){for(var n=e.length,r,i,a;--n>=0;)if(e[n].defined!==!1&&(r=e[n].x-t[0],i=e[n].y-t[1],a=r*r+i*i,r=e[n].size||1,a<r*r))return e[n];return null}function Wm(e,t,n){function r(s,u){var c=u.mark.items;c.length&&s("d",t(null,c))}function i(s,u){var c=u.items;return c.length===0?s:(t(Ql(s),c),Br(s,c[0]))}function a(s,u){s.beginPath(),t(s,u)}let o=Kl(a);function l(s,u,c,f,d,h){var p=u.items,m=u.bounds;return!p||!p.length||m&&!m.contains(d,h)?null:(c*=s.pixelRatio,f*=s.pixelRatio,o(s,p,c,f)?p[0]:null)}return{type:e,tag:"path",nested:!0,attr:r,bound:i,draw:jz(a),pick:l,isect:Pm,tip:n}}var Yz=Wm("area",Fz,Gz);function Jz(e,t){var n=t.clip;e.save(),de(n)?(e.beginPath(),n(e),e.clip()):j_(e,t.group)}function j_(e,t){e.beginPath(),Fm(t)?$o(e,t,0,0):e.rect(0,0,t.width||0,t.height||0),e.clip()}function q_(e){let t=Rn(e.strokeWidth,1);return e.strokeOffset==null?e.stroke&&t>.5&&t<1.5?.5-Math.abs(t-1):0:e.strokeOffset}function Qz(e,t){e("transform",I_(t))}function U_(e,t){let n=q_(t);e("d",$o(null,t,n,n))}function Kz(e,t){e("class","background"),e("aria-hidden",!0),U_(e,t)}function Zz(e,t){e("class","foreground"),e("aria-hidden",!0),t.strokeForeground?U_(e,t):e("d","")}function eN(e,t,n){e("clip-path",t.clip?Cm(n,t,t):null)}function tN(e,t){if(!t.clip&&t.items){let n=t.items,r=n.length;for(let i=0;i<r;++i)e.union(n[i].bounds)}return(t.clip||t.width||t.height)&&!t.noBound&&e.add(0,0).add(t.width||0,t.height||0),Br(e,t),e.translate(t.x||0,t.y||0)}function Zl(e,t,n,r){let i=q_(t);e.beginPath(),$o(e,t,(n||0)+i,(r||0)+i)}var nN=Kl(Zl),rN=Kl(Zl,!1),iN=Kl(Zl,!0);function aN(e,t,n,r){Tn(t,i=>{let a=i.x||0,o=i.y||0,l=i.strokeForeground,s=i.opacity==null?1:i.opacity;(i.stroke||i.fill)&&s&&(Zl(e,i,a,o),Do(e,i),i.fill&&bc(e,i,s)&&e.fill(),i.stroke&&!l&&So(e,i,s)&&e.stroke()),e.save(),e.translate(a,o),i.clip&&j_(e,i),n&&n.translate(-a,-o),Tn(i,u=>{(u.marktype==="group"||r==null||r.includes(u.marktype))&&this.draw(e,u,n,r)}),n&&n.translate(a,o),e.restore(),l&&i.stroke&&s&&(Zl(e,i,a,o),Do(e,i),So(e,i,s)&&e.stroke())})}function oN(e,t,n,r,i,a){if(t.bounds&&!t.bounds.contains(i,a)||!t.items)return null;let o=n*e.pixelRatio,l=r*e.pixelRatio;return xc(t,s=>{let u,c,f,d=s.bounds;if(d&&!d.contains(i,a))return;c=s.x||0,f=s.y||0;let h=c+(s.width||0),p=f+(s.height||0),m=s.clip;if(m&&(i<c||i>h||a<f||a>p))return;if(e.save(),e.translate(c,f),c=i-c,f=a-f,m&&Fm(s)&&!iN(e,s,o,l))return e.restore(),null;let g=s.strokeForeground,y=t.interactive!==!1;return y&&g&&s.stroke&&rN(e,s,o,l)?(e.restore(),s):(u=xc(s,v=>lN(v,c,f)?this.pick(v,n,r,c,f):null),!u&&y&&(s.fill||!g&&s.stroke)&&nN(e,s,o,l)&&(u=s),e.restore(),u||null)})}function lN(e,t,n){return(e.interactive!==!1||e.marktype==="group")&&e.bounds&&e.bounds.contains(t,n)}var sN={type:"group",tag:"g",nested:!1,attr:Qz,bound:tN,draw:aN,pick:oN,isect:R_,content:eN,background:Kz,foreground:Zz},es={xmlns:"http://www.w3.org/2000/svg","xmlns:xlink":"http://www.w3.org/1999/xlink",version:"1.1"};function Hm(e,t){var n=e.image;return(!n||e.url&&e.url!==n.url)&&(n={complete:!1,width:0,height:0},t.loadImage(e.url).then(r=>{e.image=r,e.image.url=e.url})),n}function Gm(e,t){return e.width==null?!t||!t.width?0:e.aspect!==!1&&e.height?e.height*t.width/t.height:t.width:e.width}function Vm(e,t){return e.height==null?!t||!t.height?0:e.aspect!==!1&&e.width?e.width*t.height/t.width:t.height:e.height}function _c(e,t){return e==="center"?t/2:e==="right"?t:0}function kc(e,t){return e==="middle"?t/2:e==="bottom"?t:0}function uN(e,t,n){let r=Hm(t,n),i=Gm(t,r),a=Vm(t,r),o=(t.x||0)-_c(t.align,i),l=(t.y||0)-kc(t.baseline,a);e("href",!r.src&&r.toDataURL?r.toDataURL():r.src||"",es["xmlns:xlink"],"xlink:href"),e("transform",ma(o,l)),e("width",i),e("height",a),e("preserveAspectRatio",t.aspect===!1?"none":"xMidYMid")}function cN(e,t){let n=t.image,r=Gm(t,n),i=Vm(t,n),a=(t.x||0)-_c(t.align,r),o=(t.y||0)-kc(t.baseline,i);return e.set(a,o,a+r,o+i)}function fN(e,t,n){Tn(t,r=>{if(n&&!n.intersects(r.bounds))return;let i=Hm(r,this),a=Gm(r,i),o=Vm(r,i);if(a===0||o===0)return;let l=(r.x||0)-_c(r.align,a),s=(r.y||0)-kc(r.baseline,o),u,c,f;r.aspect!==!1&&(u=i.width/i.height,c=r.width/r.height,u===u&&c===c&&u!==c&&(c<u?(f=a/u,s+=(o-f)/2,o=f):(f=o*u,l+=(a-f)/2,a=f))),(i.complete||i.toDataURL)&&(Do(e,r),e.globalAlpha=r.opacity??1,e.imageSmoothingEnabled=r.smooth!==!1,e.drawImage(i,l,s,a,o))})}var dN={type:"image",tag:"image",nested:!1,attr:uN,bound:cN,draw:fN,pick:wc(),isect:yn,get:Hm,xOffset:_c,yOffset:kc},hN=Wm("line",Cz,Vz);function pN(e,t){var n=t.scaleX||1,r=t.scaleY||1;(n!==1||r!==1)&&e("vector-effect","non-scaling-stroke"),e("transform",Wz(t)),e("d",t.path)}function Ec(e,t){var n=t.path;if(n==null)return!0;var r=t.x||0,i=t.y||0,a=t.scaleX||1,o=t.scaleY||1,l=(t.angle||0)*_i,s=t.pathCache;(!s||s.path!==n)&&((t.pathCache=s=ko(n)).path=n),l&&e.rotate&&e.translate?(e.translate(r,i),e.rotate(l),Gl(e,s,0,0,a,o),e.rotate(-l),e.translate(-r,-i)):Gl(e,s,r,i,a,o)}function mN(e,t){return Ec(Ql(e,t.angle),t)?e.set(0,0,0,0):Br(e,t,!0)}var gN={type:"path",tag:"path",nested:!1,attr:pN,bound:mN,draw:Im(Ec),pick:jm(Ec),isect:Lm(Ec)};function yN(e,t){e("d",$o(null,t))}function vN(e,t){var n,r;return Br(e.set(n=t.x||0,r=t.y||0,n+t.width||0,r+t.height||0),t)}function W_(e,t){e.beginPath(),$o(e,t)}var bN={type:"rect",tag:"path",nested:!1,attr:yN,bound:vN,draw:Im(W_),pick:jm(W_),isect:R_};function xN(e,t){e("transform",I_(t)),e("x2",t.x2==null?0:t.x2-(t.x||0)),e("y2",t.y2==null?0:t.y2-(t.y||0))}function wN(e,t){var n,r;return Br(e.set(n=t.x||0,r=t.y||0,t.x2==null?n:t.x2,t.y2==null?r:t.y2),t)}function H_(e,t,n){var r,i,a,o;return t.stroke&&So(e,t,n)?(r=t.x||0,i=t.y||0,a=t.x2==null?r:t.x2,o=t.y2==null?i:t.y2,e.beginPath(),e.moveTo(r,i),e.lineTo(a,o),!0):!1}function _N(e,t,n){Tn(t,r=>{if(!(n&&!n.intersects(r.bounds))){var i=r.opacity==null?1:r.opacity;i&&H_(e,r,i)&&(Do(e,r),e.stroke())}})}function kN(e,t,n,r){return e.isPointInStroke?H_(e,t,1)&&e.isPointInStroke(n,r):!1}var EN={type:"rule",tag:"line",nested:!1,attr:xN,bound:wN,draw:_N,pick:wc(kN),isect:T_},$N=Um("shape",Mz),AN=Um("symbol",Oz,Pm),G_=Ux(),rn={height:hr,measureWidth:Xm,estimateWidth:$c,width:$c,canvas:V_};V_(!0);function V_(e){rn.width=e&&$i?Xm:$c}function $c(e,t){return X_(Di(e,t),hr(e))}function X_(e,t){return~~(.8*e.length*t)}function Xm(e,t){return hr(e)<=0||!(t=Di(e,t))?0:Y_(t,Ac(e))}function Y_(e,t){let n=`(${t}) ${e}`,r=G_.get(n);return r===void 0&&($i.font=t,r=$i.measureText(e).width,G_.set(n,r)),r}function hr(e){return e.fontSize==null?11:+e.fontSize||0}function Ai(e){return e.lineHeight==null?hr(e)+2:e.lineHeight}function DN(e){return N(e)?e.length>1?e:e[0]:e}function ts(e){return DN(e.lineBreak&&e.text&&!N(e.text)?e.text.split(e.lineBreak):e.text)}function Ym(e){let t=ts(e);return(N(t)?t.length-1:0)*Ai(e)}function Di(e,t){let n=t==null?"":(t+"").trim();return e.limit>0&&n.length?FN(e,n):n}function SN(e){if(rn.width===Xm){let t=Ac(e);return n=>Y_(n,t)}else if(rn.width===$c){let t=hr(e);return n=>X_(n,t)}else return t=>rn.width(e,t)}function FN(e,t){var n=+e.limit,r=SN(e);if(r(t)<n)return t;var i=e.ellipsis||"\u2026",a=e.dir==="rtl",o=0,l=t.length,s;if(n-=r(i),a){for(;o<l;)s=o+l>>>1,r(t.slice(s))>n?o=s+1:l=s;return i+t.slice(o)}else{for(;o<l;)s=1+(o+l>>>1),r(t.slice(0,s))<n?o=s:l=s-1;return t.slice(0,o)+i}}function ns(e,t){var n=e.font;return(t&&n?String(n).replace(/"/g,"'"):n)||"sans-serif"}function Ac(e,t){return(e.fontStyle?e.fontStyle+" ":"")+(e.fontVariant?e.fontVariant+" ":"")+(e.fontWeight?e.fontWeight+" ":"")+hr(e)+"px "+ns(e,t)}function Jm(e){var t=e.baseline,n=hr(e);return Math.round(t==="top"?.79*n:t==="middle"?.3*n:t==="bottom"?-.21*n:t==="line-top"?.29*n+.5*Ai(e):t==="line-bottom"?.29*n-.5*Ai(e):0)}var CN={left:"start",center:"middle",right:"end"},rs=new Ke;function Dc(e){var t=e.x||0,n=e.y||0,r=e.radius||0,i;return r&&(i=(e.theta||0)-fa,t+=r*Math.cos(i),n+=r*Math.sin(i)),rs.x1=t,rs.y1=n,rs}function MN(e,t){var n=t.dx||0,r=(t.dy||0)+Jm(t),i=Dc(t),a=i.x1,o=i.y1,l=t.angle||0,s;e("text-anchor",CN[t.align]||"start"),l?(s=ma(a,o)+" "+qm(l),(n||r)&&(s+=" "+ma(n,r))):s=ma(a+n,o+r),e("transform",s)}function Qm(e,t,n){var r=rn.height(t),i=t.align,a=Dc(t),o=a.x1,l=a.y1,s=t.dx||0,u=(t.dy||0)+Jm(t)-Math.round(.8*r),c=ts(t),f;if(N(c)?(r+=Ai(t)*(c.length-1),f=c.reduce((d,h)=>Math.max(d,rn.width(t,h)),0)):f=rn.width(t,c),i==="center"?s-=f/2:i==="right"&&(s-=f),e.set(s+=o,u+=l,s+f,u+r),t.angle&&!n)e.rotate(t.angle*_i,o,l);else if(n===2)return e.rotatedPoints(t.angle*_i,o,l);return e}function ON(e,t,n){Tn(t,r=>{var i=r.opacity==null?1:r.opacity,a,o,l,s,u,c,f;if(!(n&&!n.intersects(r.bounds)||i===0||r.fontSize<=0||r.text==null||r.text.length===0)){if(e.font=Ac(r),e.textAlign=r.align||"left",a=Dc(r),o=a.x1,l=a.y1,r.angle&&(e.save(),e.translate(o,l),e.rotate(r.angle*_i),o=l=0),o+=r.dx||0,l+=(r.dy||0)+Jm(r),c=ts(r),Do(e,r),N(c))for(u=Ai(r),s=0;s<c.length;++s)f=Di(r,c[s]),r.fill&&bc(e,r,i)&&e.fillText(f,o,l),r.stroke&&So(e,r,i)&&e.strokeText(f,o,l),l+=u;else f=Di(r,c),r.fill&&bc(e,r,i)&&e.fillText(f,o,l),r.stroke&&So(e,r,i)&&e.strokeText(f,o,l);r.angle&&e.restore()}})}function zN(e,t,n,r,i,a){if(t.fontSize<=0)return!1;if(!t.angle)return!0;var o=Dc(t),l=o.x1,s=o.y1,u=Qm(rs,t,1),c=-t.angle*_i,f=Math.cos(c),d=Math.sin(c),h=f*i-d*a+(l-f*l+d*s),p=d*i+f*a+(s-d*l-f*s);return u.contains(h,p)}function NN(e,t){let n=Qm(rs,e,2);return Ao(t,n[0],n[1],n[2],n[3])||Ao(t,n[0],n[1],n[4],n[5])||Ao(t,n[4],n[5],n[6],n[7])||Ao(t,n[2],n[3],n[6],n[7])}var an={arc:Hz,area:Yz,group:sN,image:dN,line:hN,path:gN,rect:bN,rule:EN,shape:$N,symbol:AN,text:{type:"text",tag:"text",nested:!1,attr:MN,bound:Qm,draw:ON,pick:wc(zN),isect:NN},trail:Wm("trail",zz,Xz)};function Km(e,t,n){var r=an[e.mark.marktype],i=t||r.bound;return r.nested&&(e=e.mark),i(e.bounds||(e.bounds=new Ke),e,n)}var J_={mark:null};function Q_(e,t,n){var r=an[e.marktype],i=r.bound,a=e.items,o=a&&a.length,l,s,u,c;if(r.nested)return o?u=a[0]:(J_.mark=e,u=J_),c=Km(u,i,n),t=t&&t.union(c)||c,t;if(t=t||e.bounds&&e.bounds.clear()||new Ke,o)for(l=0,s=a.length;l<s;++l)t.union(Km(a[l],i,n));return e.bounds=t}var RN="marktype.name.role.interactive.clip.items.zindex.x.y.width.height.align.baseline.fill.fillOpacity.opacity.blend.stroke.strokeOpacity.strokeWidth.strokeCap.strokeDash.strokeDashOffset.strokeForeground.strokeOffset.startAngle.endAngle.innerRadius.outerRadius.cornerRadius.padAngle.cornerRadiusTopLeft.cornerRadiusTopRight.cornerRadiusBottomLeft.cornerRadiusBottomRight.interpolate.tension.orient.defined.url.aspect.smooth.path.scaleX.scaleY.x2.y2.size.shape.text.angle.theta.radius.dir.dx.dy.ellipsis.limit.lineBreak.lineHeight.font.fontSize.fontWeight.fontStyle.fontVariant.description.aria.ariaRole.ariaRoleDescription".split(".");function K_(e,t){return JSON.stringify(e,RN,t)}function Z_(e){return ek(typeof e=="string"?JSON.parse(e):e)}function ek(e){var t=e.marktype,n=e.items,r,i,a;if(n)for(i=0,a=n.length;i<a;++i)r=t?"mark":"group",n[i][r]=e,n[i].zindex&&(n[i][r].zdirty=!0),(t||r)==="group"&&ek(n[i]);return t&&Q_(e),e}var tk=class{constructor(e){arguments.length?this.root=Z_(e):(this.root=nk({marktype:"group",name:"root",role:"frame"}),this.root.items=[new hc(this.root)])}toJSON(e){return K_(this.root,e||0)}mark(e,t,n){t||(t=this.root.items[0]);let r=nk(e,t);return t.items[n]=r,r.zindex&&(r.group.zdirty=!0),r}};function nk(e,t){let n={bounds:new Ke,clip:!!e.clip,group:t,interactive:e.interactive!==!1,items:[],marktype:e.marktype,name:e.name||void 0,role:e.role||void 0,zindex:e.zindex||0};return e.aria!=null&&(n.aria=e.aria),e.description&&(n.description=e.description),n}function Si(e,t,n){return!e&&typeof document<"u"&&document.createElement&&(e=document),e?n?e.createElementNS(n,t):e.createElement(t):null}function Zm(e,t){t=t.toLowerCase();for(var n=e.childNodes,r=0,i=n.length;r<i;++r)if(n[r].tagName.toLowerCase()===t)return n[r]}function tt(e,t,n,r){var i=e.childNodes[t],a;return(!i||i.tagName.toLowerCase()!==n.toLowerCase())&&(a=i||null,i=Si(e.ownerDocument,n,r),e.insertBefore(i,a)),i}function kn(e,t){for(var n=e.childNodes,r=n.length;r>t;)e.removeChild(n[--r]);return e}function rk(e){return"mark-"+e.marktype+(e.role?" role-"+e.role:"")+(e.name?" "+e.name:"")}function Sc(e,t){let n=t.getBoundingClientRect();return[e.clientX-n.left-(t.clientLeft||0),e.clientY-n.top-(t.clientTop||0)]}function TN(e,t,n,r){var i=e&&e.mark,a,o;if(i&&(a=an[i.marktype]).tip){for(o=Sc(t,n),o[0]-=r[0],o[1]-=r[1];e=e.mark.group;)o[0]-=e.x||0,o[1]-=e.y||0;e=a.tip(i.items,o)}return e}var eg=class{constructor(e,t){this._active=null,this._handlers={},this._loader=e||Ru(),this._tooltip=t||LN}initialize(e,t,n){return this._el=e,this._obj=n||null,this.origin(t)}element(){return this._el}canvas(){return this._el&&this._el.firstChild}origin(e){return arguments.length?(this._origin=e||[0,0],this):this._origin.slice()}scene(e){return arguments.length?(this._scene=e,this):this._scene}on(){}off(){}_handlerIndex(e,t,n){for(let r=e?e.length:0;--r>=0;)if(e[r].type===t&&(!n||e[r].handler===n))return r;return-1}handlers(e){let t=this._handlers,n=[];if(e)n.push(...t[this.eventName(e)]);else for(let r in t)n.push(...t[r]);return n}eventName(e){let t=e.indexOf(".");return t<0?e:e.slice(0,t)}handleHref(e,t,n){this._loader.sanitize(n,{context:"href"}).then(r=>{let i=new MouseEvent(e.type,e),a=Si(null,"a");for(let o in r)a.setAttribute(o,r[o]);a.dispatchEvent(i)}).catch(()=>{})}handleTooltip(e,t,n){if(t&&t.tooltip!=null){t=TN(t,e,this.canvas(),this._origin);let r=n&&t&&t.tooltip||null;this._tooltip.call(this._obj,this,e,t,r)}}getItemBoundingClientRect(e){let t=this.canvas();if(!t)return;let n=t.getBoundingClientRect(),r=this._origin,i=e.bounds,a=i.width(),o=i.height(),l=i.x1+r[0]+n.left,s=i.y1+r[1]+n.top;for(;e.mark&&(e=e.mark.group);)l+=e.x||0,s+=e.y||0;return{x:l,y:s,width:a,height:o,left:l,top:s,right:l+a,bottom:s+o}}};function LN(e,t,n,r){e.element().setAttribute("title",r||"")}var is=class{constructor(e){this._el=null,this._bgcolor=null,this._loader=new S_(e)}initialize(e,t,n,r,i){return this._el=e,this.resize(t,n,r,i)}element(){return this._el}canvas(){return this._el&&this._el.firstChild}background(e){return arguments.length===0?this._bgcolor:(this._bgcolor=e,this)}resize(e,t,n,r){return this._width=e,this._height=t,this._origin=n||[0,0],this._scale=r||1,this}dirty(){}render(e,t){let n=this;return n._call=function(){n._render(e,t)},n._call(),n._call=null,n}_render(){}renderAsync(e,t){let n=this.render(e,t);return this._ready?this._ready.then(()=>n):Promise.resolve(n)}_load(e,t){var n=this,r=n._loader[e](t);if(!n._ready){let i=n._call;n._ready=n._loader.ready().then(a=>{a&&i(),n._ready=null})}return r}sanitizeURL(e){return this._load("sanitizeURL",e)}loadImage(e){return this._load("loadImage",e)}},PN="keydown",BN="keypress",IN="keyup",ik="dragenter",Fc="dragleave",ak="dragover",tg="pointerdown",jN="pointerup",Cc="pointermove",Mc="pointerout",ok="pointerover",ng="mousedown",qN="mouseup",lk="mousemove",Oc="mouseout",sk="mouseover",zc="click",UN="dblclick",WN="wheel",uk="mousewheel",Nc="touchstart",Rc="touchmove",Tc="touchend",HN=[PN,BN,IN,ik,Fc,ak,tg,jN,Cc,Mc,ok,ng,qN,lk,Oc,sk,zc,UN,WN,uk,Nc,Rc,Tc],rg=Cc,as=Oc,ig=zc,os=class extends eg{constructor(e,t){super(e,t),this._down=null,this._touch=null,this._first=!0,this._events={},this.events=HN,this.pointermove=fk([Cc,lk],[ok,sk],[Mc,Oc]),this.dragover=fk([ak],[ik],[Fc]),this.pointerout=dk([Mc,Oc]),this.dragleave=dk([Fc])}initialize(e,t,n){return this._canvas=e&&Zm(e,"canvas"),[zc,ng,tg,Cc,Mc,Fc].forEach(r=>ck(this,r)),super.initialize(e,t,n)}canvas(){return this._canvas}context(){return this._canvas.getContext("2d")}DOMMouseScroll(e){this.fire(uk,e)}pointerdown(e){this._down=this._active,this.fire(tg,e)}mousedown(e){this._down=this._active,this.fire(ng,e)}click(e){this._down===this._active&&(this.fire(zc,e),this._down=null)}touchstart(e){this._touch=this.pickEvent(e.changedTouches[0]),this._first&&(this._first=(this._active=this._touch,!1)),this.fire(Nc,e,!0)}touchmove(e){this.fire(Rc,e,!0)}touchend(e){this.fire(Tc,e,!0),this._touch=null}fire(e,t,n){let r=n?this._touch:this._active,i=this._handlers[e];if(t.vegaType=e,e===ig&&r&&r.href?this.handleHref(t,r,r.href):(e===rg||e===as)&&this.handleTooltip(t,r,e!==as),i)for(let a=0,o=i.length;a<o;++a)i[a].handler.call(this._obj,t,r)}on(e,t){let n=this.eventName(e),r=this._handlers;return this._handlerIndex(r[n],e,t)<0&&(ck(this,e),(r[n]||(r[n]=[])).push({type:e,handler:t})),this}off(e,t){let n=this.eventName(e),r=this._handlers[n],i=this._handlerIndex(r,e,t);return i>=0&&r.splice(i,1),this}pickEvent(e){let t=Sc(e,this._canvas),n=this._origin;return this.pick(this._scene,t[0],t[1],t[0]-n[0],t[1]-n[1])}pick(e,t,n,r,i){let a=this.context();return an[e.marktype].pick.call(this,a,e,t,n,r,i)}},GN=e=>e===Nc||e===Rc||e===Tc?[Nc,Rc,Tc]:[e];function ck(e,t){GN(t).forEach(n=>VN(e,n))}function VN(e,t){let n=e.canvas();n&&!e._events[t]&&(e._events[t]=1,n.addEventListener(t,e[t]?r=>e[t](r):r=>e.fire(t,r)))}function ls(e,t,n){t.forEach(r=>e.fire(r,n))}function fk(e,t,n){return function(r){let i=this._active,a=this.pickEvent(r);a===i?ls(this,e,r):((!i||!i.exit)&&ls(this,n,r),this._active=a,ls(this,t,r),ls(this,e,r))}}function dk(e){return function(t){ls(this,e,t),this._active=null}}function XN(){return typeof window<"u"&&window.devicePixelRatio||1}function YN(e,t,n,r,i,a){let o=typeof HTMLElement<"u"&&e instanceof HTMLElement&&e.parentNode!=null,l=e.getContext("2d"),s=o?XN():i;for(let u in e.width=t*s,e.height=n*s,a)l[u]=a[u];return o&&s!==1&&(e.style.width=t+"px",e.style.height=n+"px"),l.pixelRatio=s,l.setTransform(s,0,0,s,s*r[0],s*r[1]),e}var Lc=class extends is{constructor(e){super(e),this._options={},this._redraw=!1,this._dirty=new Ke,this._tempb=new Ke}initialize(e,t,n,r,i,a){return this._options=a||{},this._canvas=this._options.externalContext?null:bi(1,1,this._options.type),e&&this._canvas&&(kn(e,0).appendChild(this._canvas),this._canvas.setAttribute("class","marks")),super.initialize(e,t,n,r,i)}resize(e,t,n,r){if(super.resize(e,t,n,r),this._canvas)YN(this._canvas,this._width,this._height,this._origin,this._scale,this._options.context);else{let i=this._options.externalContext;i||L("CanvasRenderer is missing a valid canvas or context"),i.scale(this._scale,this._scale),i.translate(this._origin[0],this._origin[1])}return this._redraw=!0,this}canvas(){return this._canvas}context(){return this._options.externalContext||(this._canvas?this._canvas.getContext("2d"):null)}dirty(e){let t=this._tempb.clear().union(e.bounds),n=e.mark.group;for(;n;)t.translate(n.x||0,n.y||0),n=n.mark.group;this._dirty.union(t)}_render(e,t){let n=this.context(),r=this._origin,i=this._width,a=this._height,o=this._dirty,l=JN(r,i,a);n.save();let s=this._redraw||o.empty()?(this._redraw=!1,l.expand(1)):QN(n,l.intersect(o),r);return this.clear(-r[0],-r[1],i,a),this.draw(n,e,s,t),n.restore(),o.clear(),this}draw(e,t,n,r){if(t.marktype!=="group"&&r!=null&&!r.includes(t.marktype))return;let i=an[t.marktype];t.clip&&Jz(e,t),i.draw.call(this,e,t,n,r),t.clip&&e.restore()}clear(e,t,n,r){let i=this._options,a=this.context();i.type!=="pdf"&&!i.externalContext&&a.clearRect(e,t,n,r),this._bgcolor!=null&&(a.fillStyle=this._bgcolor,a.fillRect(e,t,n,r))}},JN=(e,t,n)=>new Ke().set(0,0,t,n).translate(-e[0],-e[1]);function QN(e,t,n){return t.expand(1).round(),e.pixelRatio%1&&t.scale(e.pixelRatio).round().scale(1/e.pixelRatio),t.translate(-(n[0]%1),-(n[1]%1)),e.beginPath(),e.rect(t.x1,t.y1,t.width(),t.height()),e.clip(),t}var hk=class extends eg{constructor(e,t){super(e,t);let n=this;n._hrefHandler=ag(n,(r,i)=>{i&&i.href&&n.handleHref(r,i,i.href)}),n._tooltipHandler=ag(n,(r,i)=>{n.handleTooltip(r,i,r.type!==as)})}initialize(e,t,n){let r=this._svg;return r&&(r.removeEventListener(ig,this._hrefHandler),r.removeEventListener(rg,this._tooltipHandler),r.removeEventListener(as,this._tooltipHandler)),this._svg=r=e&&Zm(e,"svg"),r&&(r.addEventListener(ig,this._hrefHandler),r.addEventListener(rg,this._tooltipHandler),r.addEventListener(as,this._tooltipHandler)),super.initialize(e,t,n)}canvas(){return this._svg}on(e,t){let n=this.eventName(e),r=this._handlers;if(this._handlerIndex(r[n],e,t)<0){let i={type:e,handler:t,listener:ag(this,t)};(r[n]||(r[n]=[])).push(i),this._svg&&this._svg.addEventListener(n,i.listener)}return this}off(e,t){let n=this.eventName(e),r=this._handlers[n],i=this._handlerIndex(r,e,t);return i>=0&&(this._svg&&this._svg.removeEventListener(n,r[i].listener),r.splice(i,1)),this}},ag=(e,t)=>n=>{let r=n.target.__data__;r=Array.isArray(r)?r[0]:r,n.vegaType=n.type,t.call(e._obj,n,r)},pk="aria-hidden",og="aria-label",lg="role",sg="aria-roledescription",mk="graphics-object",ug="graphics-symbol",gk=(e,t,n)=>({[lg]:e,[sg]:t,[og]:n||void 0}),KN=sr(["axis-domain","axis-grid","axis-label","axis-tick","axis-title","legend-band","legend-entry","legend-gradient","legend-label","legend-title","legend-symbol","title"]),yk={axis:{desc:"axis",caption:tR},legend:{desc:"legend",caption:nR},"title-text":{desc:"title",caption:e=>`Title text '${wk(e)}'`},"title-subtitle":{desc:"subtitle",caption:e=>`Subtitle text '${wk(e)}'`}},vk={ariaRole:lg,ariaRoleDescription:sg,description:og};function bk(e,t){let n=t.aria===!1;if(e(pk,n||void 0),n||t.description==null)for(let r in vk)e(vk[r],void 0);else{let r=t.mark.marktype;e(og,t.description),e(lg,t.ariaRole||(r==="group"?mk:ug)),e(sg,t.ariaRoleDescription||`${r} mark`)}}function xk(e){return e.aria===!1?{[pk]:!0}:KN[e.role]?null:yk[e.role]?eR(e,yk[e.role]):ZN(e)}function ZN(e){let t=e.marktype;return gk(t==="group"||t==="text"||e.items.some(n=>n.description!=null&&n.aria!==!1)?mk:ug,`${t} mark container`,e.description)}function eR(e,t){try{let n=e.items[0],r=t.caption||(()=>"");return gk(t.role||ug,t.desc,n.description||r(n))}catch{return null}}function wk(e){return Q(e.text).join(" ")}function tR(e){let t=e.datum,n=e.orient,r=t.title?_k(e):null,i=e.context,a=i.scales[t.scale].value,o=i.dataflow.locale(),l=a.type;return`${n==="left"||n==="right"?"Y":"X"}-axis`+(r?` titled '${r}'`:"")+` for a ${_o(l)?"discrete":l} scale with ${m_(o,a,e)}`}function nR(e){let t=e.datum,n=t.title?_k(e):null,r=`${t.type||""} legend`.trim(),i=t.scales,a=Object.keys(i),o=e.context,l=o.scales[i[a[0]]].value,s=o.dataflow.locale();return iR(r)+(n?` titled '${n}'`:"")+` for ${rR(a)} with ${m_(s,l,e)}`}function _k(e){try{return Q($e(e.items).items[0].text).join(" ")}catch{return null}}function rR(e){return e=e.map(t=>t+(t==="fill"||t==="stroke"?" color":"")),e.length<2?e[0]:e.slice(0,-1).join(", ")+" and "+$e(e)}function iR(e){return e.length?e[0].toUpperCase()+e.slice(1):e}var kk=e=>(e+"").replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">"),aR=e=>kk(e).replace(/"/g,""").replace(/\t/g,"	").replace(/\n/g,"
").replace(/\r/g,"
");function cg(){let e="",t="",n="",r=[],i=()=>t=n="",a=s=>{t&&(e+=`${t}>${n}`,i()),r.push(s)},o=(s,u)=>(u!=null&&(t+=` ${s}="${aR(u)}"`),l),l={open(s,...u){a(s),t="<"+s;for(let c of u)for(let f in c)o(f,c[f]);return l},close(){let s=r.pop();return t?e+=t+(n?`>${n}</${s}>`:"/>"):e+=`</${s}>`,i(),l},attr:o,text:s=>(n+=kk(s),l),toString:()=>e};return l}var Ek=e=>$k(cg(),e)+"";function $k(e,t){if(e.open(t.tagName),t.hasAttributes()){let n=t.attributes,r=n.length;for(let i=0;i<r;++i)e.attr(n[i].name,n[i].value)}if(t.hasChildNodes()){let n=t.childNodes;for(let r of n)r.nodeType===3?e.text(r.nodeValue):$k(e,r)}return e.close()}var Pc={fill:"fill",fillOpacity:"fill-opacity",stroke:"stroke",strokeOpacity:"stroke-opacity",strokeWidth:"stroke-width",strokeCap:"stroke-linecap",strokeJoin:"stroke-linejoin",strokeDash:"stroke-dasharray",strokeDashOffset:"stroke-dashoffset",strokeMiterLimit:"stroke-miterlimit",opacity:"opacity"},Bc={blend:"mix-blend-mode"},Ak={fill:"none","stroke-miterlimit":10},ss=0,Dk="http://www.w3.org/2000/xmlns/",nt=es.xmlns,fg=class extends is{constructor(e){super(e),this._dirtyID=0,this._dirty=[],this._svg=null,this._root=null,this._defs=null}initialize(e,t,n,r,i){return this._defs={},this._clearDefs(),e&&(this._svg=tt(e,0,"svg",nt),this._svg.setAttributeNS(Dk,"xmlns",nt),this._svg.setAttributeNS(Dk,"xmlns:xlink",es["xmlns:xlink"]),this._svg.setAttribute("version",es.version),this._svg.setAttribute("class","marks"),kn(e,1),this._root=tt(this._svg,ss,"g",nt),Fi(this._root,Ak),kn(this._svg,ss+1)),this.background(this._bgcolor),super.initialize(e,t,n,r,i)}background(e){return arguments.length&&this._svg&&this._svg.style.setProperty("background-color",e),super.background(...arguments)}resize(e,t,n,r){return super.resize(e,t,n,r),this._svg&&(Fi(this._svg,{width:this._width*this._scale,height:this._height*this._scale,viewBox:`0 0 ${this._width} ${this._height}`}),this._root.setAttribute("transform",`translate(${this._origin})`)),this._dirty=[],this}canvas(){return this._svg}svg(){let e=this._svg,t=this._bgcolor;if(!e)return null;let n;t&&(e.removeAttribute("style"),n=tt(e,ss,"rect",nt),Fi(n,{width:this._width,height:this._height,fill:t}));let r=Ek(e);return t&&(e.removeChild(n),this._svg.style.setProperty("background-color",t)),r}_render(e,t){return this._dirtyCheck()&&(this._dirtyAll&&this._clearDefs(),this.mark(this._root,e,void 0,t),kn(this._root,1)),this.defs(),this._dirty=[],++this._dirtyID,this}dirty(e){e.dirty!==this._dirtyID&&(e.dirty=this._dirtyID,this._dirty.push(e))}isDirty(e){return this._dirtyAll||!e._svg||!e._svg.ownerSVGElement||e.dirty===this._dirtyID}_dirtyCheck(){this._dirtyAll=!0;let e=this._dirty;if(!e.length||!this._dirtyID)return!0;let t=++this._dirtyID,n,r,i,a,o,l,s;for(o=0,l=e.length;o<l;++o)if(n=e[o],r=n.mark,r.marktype!==i&&(i=r.marktype,a=an[i]),r.zdirty&&r.dirty!==t&&(this._dirtyAll=!1,Sk(n,t),r.items.forEach(u=>{u.dirty=t})),!r.zdirty){if(n.exit){a.nested&&r.items.length?(s=r.items[0],s._svg&&this._update(a,s._svg,s)):n._svg&&(s=n._svg.parentNode,s&&s.removeChild(n._svg)),n._svg=null;continue}n=a.nested?r.items[0]:n,n._update!==t&&(!n._svg||!n._svg.ownerSVGElement?(this._dirtyAll=!1,Sk(n,t)):this._update(a,n._svg,n),n._update=t)}return!this._dirtyAll}mark(e,t,n,r){if(!this.isDirty(t))return t._svg;let i=this._svg,a=t.marktype,o=an[a],l=t.interactive===!1?"none":null,s=o.tag==="g",u=Fk(t,e,n,"g",i);if(a!=="group"&&r!=null&&!r.includes(a))return kn(u,0),t._svg;u.setAttribute("class",rk(t));let c=xk(t);for(let p in c)Ft(u,p,c[p]);s||Ft(u,"pointer-events",l),Ft(u,"clip-path",t.clip?Cm(this,t,t.group):null);let f=null,d=0,h=p=>{let m=this.isDirty(p),g=Fk(p,u,f,o.tag,i);m&&(this._update(o,g,p),s&&sR(this,g,p,r)),f=g,++d};return o.nested?t.items.length&&h(t.items[0]):Tn(t,h),kn(u,d),u}_update(e,t,n){Ir=t,vt=t.__values__,bk(us,n),e.attr(us,n,this);let r=cR[e.type];r&&r.call(this,e,t,n),Ir&&this.style(Ir,n)}style(e,t){if(t!=null){for(let n in Pc){let r=n==="font"?ns(t):t[n];if(r===vt[n])continue;let i=Pc[n];r==null?e.removeAttribute(i):(Em(r)&&(r=y_(r,this._defs.gradient,Ck())),e.setAttribute(i,r+"")),vt[n]=r}for(let n in Bc)Ic(e,Bc[n],t[n])}}defs(){let e=this._svg,t=this._defs,n=t.el,r=0;for(let i in t.gradient)n||(t.el=n=tt(e,ss+1,"defs",nt)),r=oR(n,t.gradient[i],r);for(let i in t.clipping)n||(t.el=n=tt(e,ss+1,"defs",nt)),r=lR(n,t.clipping[i],r);n&&(r===0?(e.removeChild(n),t.el=null):kn(n,r))}_clearDefs(){let e=this._defs;e.gradient={},e.clipping={}}};function Sk(e,t){for(;e&&e.dirty!==t;e=e.mark.group)if(e.dirty=t,e.mark&&e.mark.dirty!==t)e.mark.dirty=t;else return}function oR(e,t,n){let r,i,a;if(t.gradient==="radial"){let o=tt(e,n++,"pattern",nt);Fi(o,{id:uc+t.id,viewBox:"0,0,1,1",width:"100%",height:"100%",preserveAspectRatio:"xMidYMid slice"}),o=tt(o,0,"rect",nt),Fi(o,{width:1,height:1,fill:`url(${Ck()}#${t.id})`}),e=tt(e,n++,"radialGradient",nt),Fi(e,{id:t.id,fx:t.x1,fy:t.y1,fr:t.r1,cx:t.x2,cy:t.y2,r:t.r2})}else e=tt(e,n++,"linearGradient",nt),Fi(e,{id:t.id,x1:t.x1,x2:t.x2,y1:t.y1,y2:t.y2});for(r=0,i=t.stops.length;r<i;++r)a=tt(e,r,"stop",nt),a.setAttribute("offset",t.stops[r].offset),a.setAttribute("stop-color",t.stops[r].color);return kn(e,r),n}function lR(e,t,n){let r;return e=tt(e,n,"clipPath",nt),e.setAttribute("id",t.id),t.path?(r=tt(e,0,"path",nt),r.setAttribute("d",t.path)):(r=tt(e,0,"rect",nt),Fi(r,{x:0,y:0,width:t.width,height:t.height})),kn(e,1),n+1}function sR(e,t,n,r){t=t.lastChild.previousSibling;let i,a=0;Tn(n,o=>{i=e.mark(t,o,i,r),++a}),kn(t,1+a)}function Fk(e,t,n,r,i){let a=e._svg,o;if(!a&&(o=t.ownerDocument,a=Si(o,r,nt),e._svg=a,e.mark&&(a.__data__=e,a.__values__={fill:"default"},r==="g"))){let l=Si(o,"path",nt);a.appendChild(l),l.__data__=e;let s=Si(o,"g",nt);a.appendChild(s),s.__data__=e;let u=Si(o,"path",nt);a.appendChild(u),u.__data__=e,u.__values__={fill:"default"}}return(a.ownerSVGElement!==i||uR(a,n))&&t.insertBefore(a,n?n.nextSibling:t.firstChild),a}function uR(e,t){return e.parentNode&&e.parentNode.childNodes.length>1&&e.previousSibling!=t}var Ir=null,vt=null,cR={group(e,t,n){let r=Ir=t.childNodes[2];vt=r.__values__,e.foreground(us,n,this),vt=t.__values__,Ir=t.childNodes[1],e.content(us,n,this);let i=Ir=t.childNodes[0];e.background(us,n,this);let a=n.mark.interactive===!1?"none":null;if(a!==vt.events&&(Ft(r,"pointer-events",a),Ft(i,"pointer-events",a),vt.events=a),n.strokeForeground&&n.stroke){let o=n.fill;Ft(r,"display",null),this.style(i,n),Ft(i,"stroke",null),o&&(n.fill=null),vt=r.__values__,this.style(r,n),o&&(n.fill=o),Ir=null}else Ft(r,"display","none")},image(e,t,n){n.smooth===!1?(Ic(t,"image-rendering","optimizeSpeed"),Ic(t,"image-rendering","pixelated")):Ic(t,"image-rendering",null)},text(e,t,n){let r=ts(n),i,a,o,l;N(r)?(a=r.map(s=>Di(n,s)),i=a.join(`
|
|
4
4
|
`),i!==vt.text&&(kn(t,0),o=t.ownerDocument,l=Ai(n),a.forEach((s,u)=>{let c=Si(o,"tspan",nt);c.__data__=n,c.textContent=s,u&&(c.setAttribute("x",0),c.setAttribute("dy",l)),t.appendChild(c)}),vt.text=i)):(a=Di(n,r),a!==vt.text&&(t.textContent=a,vt.text=a)),Ft(t,"font-family",ns(n)),Ft(t,"font-size",hr(n)+"px"),Ft(t,"font-style",n.fontStyle),Ft(t,"font-variant",n.fontVariant),Ft(t,"font-weight",n.fontWeight)}};function us(e,t,n){t!==vt[e]&&(n?fR(Ir,e,t,n):Ft(Ir,e,t),vt[e]=t)}function Ic(e,t,n){n!==vt[t]&&(n==null?e.style.removeProperty(t):e.style.setProperty(t,n+""),vt[t]=n)}function Fi(e,t){for(let n in t)Ft(e,n,t[n])}function Ft(e,t,n){n==null?e.removeAttribute(t):e.setAttribute(t,n)}function fR(e,t,n,r){n==null?e.removeAttributeNS(r,t):e.setAttributeNS(r,t,n)}function Ck(){let e;return typeof window>"u"?"":(e=window.location).hash?e.href.slice(0,-e.hash.length):e.href}var Mk=class extends is{constructor(e){super(e),this._text=null,this._defs={gradient:{},clipping:{}}}svg(){return this._text}_render(e){let t=cg();t.open("svg",pe({},es,{class:"marks",width:this._width*this._scale,height:this._height*this._scale,viewBox:`0 0 ${this._width} ${this._height}`}));let n=this._bgcolor;return n&&n!=="transparent"&&n!=="none"&&t.open("rect",{width:this._width,height:this._height,fill:n}).close(),t.open("g",Ak,{transform:"translate("+this._origin+")"}),this.mark(t,e),t.close(),this.defs(t),this._text=t.close()+"",this}mark(e,t){let n=an[t.marktype],r=n.tag,i=[bk,n.attr];e.open("g",{class:rk(t),"clip-path":t.clip?Cm(this,t,t.group):null},xk(t),{"pointer-events":r!=="g"&&t.interactive===!1?"none":null});let a=o=>{let l=this.href(o);if(l&&e.open("a",l),e.open(r,this.attr(t,o,i,r==="g"?null:r)),r==="text"){let s=ts(o);if(N(s)){let u={x:0,dy:Ai(o)};for(let c=0;c<s.length;++c)e.open("tspan",c?u:null).text(Di(o,s[c])).close()}else e.text(Di(o,s))}else if(r==="g"){let s=o.strokeForeground,u=o.fill,c=o.stroke;s&&c&&(o.stroke=null),e.open("path",this.attr(t,o,n.background,"bgrect")).close(),e.open("g",this.attr(t,o,n.content)),Tn(o,f=>this.mark(e,f)),e.close(),s&&c?(u&&(o.fill=null),o.stroke=c,e.open("path",this.attr(t,o,n.foreground,"bgrect")).close(),u&&(o.fill=u)):e.open("path",this.attr(t,o,n.foreground,"bgfore")).close()}e.close(),l&&e.close()};return n.nested?t.items&&t.items.length&&a(t.items[0]):Tn(t,a),e.close()}href(e){let t=e.href,n;if(t){if(n=this._hrefs&&this._hrefs[t])return n;this.sanitizeURL(t).then(r=>{r["xlink:href"]=r.href,r.href=null,(this._hrefs||(this._hrefs={}))[t]=r})}return null}attr(e,t,n,r){let i={},a=(o,l,s,u)=>{i[u||o]=l};return Array.isArray(n)?n.forEach(o=>o(a,t,this)):n(a,t,this),r&&dR(i,t,e,r,this._defs),i}defs(e){let t=this._defs.gradient,n=this._defs.clipping;if(Object.keys(t).length+Object.keys(n).length!==0){for(let r in e.open("defs"),t){let i=t[r],a=i.stops;i.gradient==="radial"?(e.open("pattern",{id:uc+r,viewBox:"0,0,1,1",width:"100%",height:"100%",preserveAspectRatio:"xMidYMid slice"}),e.open("rect",{width:"1",height:"1",fill:"url(#"+r+")"}).close(),e.close(),e.open("radialGradient",{id:r,fx:i.x1,fy:i.y1,fr:i.r1,cx:i.x2,cy:i.y2,r:i.r2})):e.open("linearGradient",{id:r,x1:i.x1,x2:i.x2,y1:i.y1,y2:i.y2});for(let o=0;o<a.length;++o)e.open("stop",{offset:a[o].offset,"stop-color":a[o].color}).close();e.close()}for(let r in n){let i=n[r];e.open("clipPath",{id:r}),i.path?e.open("path",{d:i.path}).close():e.open("rect",{x:0,y:0,width:i.width,height:i.height}).close(),e.close()}e.close()}}};function dR(e,t,n,r,i){let a;if(t==null||(r==="bgrect"&&n.interactive===!1&&(e["pointer-events"]="none"),r==="bgfore"&&(n.interactive===!1&&(e["pointer-events"]="none"),e.display="none",t.fill!==null)))return e;for(let o in r==="image"&&t.smooth===!1&&(a=["image-rendering: optimizeSpeed;","image-rendering: pixelated;"]),r==="text"&&(e["font-family"]=ns(t),e["font-size"]=hr(t)+"px",e["font-style"]=t.fontStyle,e["font-variant"]=t.fontVariant,e["font-weight"]=t.fontWeight),Pc){let l=t[o],s=Pc[o];l==="transparent"&&(s==="fill"||s==="stroke")||l!=null&&(Em(l)&&(l=y_(l,i.gradient,"")),e[s]=l)}for(let o in Bc){let l=t[o];l!=null&&(a||(a=[]),a.push(`${Bc[o]}: ${l};`))}return a&&(e.style=a.join(" ")),e}var Ln={svgMarkTypes:["text"],svgOnTop:!0,debug:!1};function hR(e){Ln.svgMarkTypes=e.svgMarkTypes??["text"],Ln.svgOnTop=e.svgOnTop??!0,Ln.debug=e.debug??!1}var dg=class extends is{constructor(e){super(e),this._svgRenderer=new fg(e),this._canvasRenderer=new Lc(e)}initialize(e,t,n,r,i){this._root_el=tt(e,0,"div");let a=tt(this._root_el,0,"div"),o=tt(this._root_el,1,"div");return this._root_el.style.position="relative",Ln.debug||(a.style.height="100%",o.style.position="absolute",o.style.top="0",o.style.left="0",o.style.height="100%",o.style.width="100%"),this._svgEl=Ln.svgOnTop?o:a,this._canvasEl=Ln.svgOnTop?a:o,this._svgEl.style.pointerEvents="none",this._canvasRenderer.initialize(this._canvasEl,t,n,r,i),this._svgRenderer.initialize(this._svgEl,t,n,r,i),super.initialize(e,t,n,r,i)}dirty(e){return Ln.svgMarkTypes.includes(e.mark.marktype)?this._svgRenderer.dirty(e):this._canvasRenderer.dirty(e),this}_render(e,t){let n=(t??["arc","area","image","line","path","rect","rule","shape","symbol","text","trail"]).filter(r=>!Ln.svgMarkTypes.includes(r));this._svgRenderer.render(e,Ln.svgMarkTypes),this._canvasRenderer.render(e,n)}resize(e,t,n,r){return super.resize(e,t,n,r),this._svgRenderer.resize(e,t,n,r),this._canvasRenderer.resize(e,t,n,r),this}background(e){return Ln.svgOnTop?this._canvasRenderer.background(e):this._svgRenderer.background(e),this}},Ok=class extends os{constructor(e,t){super(e,t)}initialize(e,t,n){let r=tt(tt(e,0,"div"),Ln.svgOnTop?0:1,"div");return super.initialize(r,t,n)}},zk="canvas",Nk="hybrid",Rk="png",Tk="svg",Lk="none",Ci={Canvas:zk,PNG:Rk,SVG:Tk,Hybrid:Nk,None:Lk},ga={};ga[zk]=ga[Rk]={renderer:Lc,headless:Lc,handler:os},ga[Tk]={renderer:fg,headless:Mk,handler:hk},ga[Nk]={renderer:dg,headless:dg,handler:Ok},ga[Lk]={};function jc(e,t){return e=String(e||"").toLowerCase(),arguments.length>1?(ga[e]=t,this):ga[e]}function Pk(e,t,n){let r=[],i=new Ke().union(t),a=e.marktype;return a?Bk(e,i,n,r):a==="group"?Ik(e,i,n,r):L("Intersect scene must be mark node or group item.")}function Bk(e,t,n,r){if(pR(e,t,n)){let i=e.items,a=e.marktype,o=i.length,l=0;if(a==="group")for(;l<o;++l)Ik(i[l],t,n,r);else for(let s=an[a].isect;l<o;++l){let u=i[l];jk(u,t,s)&&r.push(u)}}return r}function pR(e,t,n){return e.bounds&&t.intersects(e.bounds)&&(e.marktype==="group"||e.interactive!==!1&&(!n||n(e)))}function Ik(e,t,n,r){n&&n(e.mark)&&jk(e,t,an.group.isect)&&r.push(e);let i=e.items,a=i&&i.length;if(a){let o=e.x||0,l=e.y||0;t.translate(-o,-l);for(let s=0;s<a;++s)Bk(i[s],t,n,r);t.translate(o,l)}return r}function jk(e,t,n){let r=e.bounds;return t.encloses(r)||t.intersects(r)&&n(e,t)}var hg=new Ke;function qk(e){let t=e.clip;if(de(t))t(Ql(hg.clear()));else if(t)hg.set(0,0,e.group.width,e.group.height);else return;e.bounds.intersect(hg)}var mR=1e-9;function pg(e,t,n){return e===t?!0:n==="path"?Uk(e,t):e instanceof Date&&t instanceof Date?+e==+t:we(e)&&we(t)?Math.abs(e-t)<=mR:!e||!t||!J(e)&&!J(t)?e==t:gR(e,t)}function Uk(e,t){return pg(ko(e),ko(t))}function gR(e,t){var n=Object.keys(e),r=Object.keys(t),i,a;if(n.length!==r.length)return!1;for(n.sort(),r.sort(),a=n.length-1;a>=0;a--)if(n[a]!=r[a])return!1;for(a=n.length-1;a>=0;a--)if(i=n[a],!pg(e[i],t[i],i))return!1;return typeof e==typeof t}function yR(){Nz(),q7()}var vR=Gt({bound:()=>Zk,identifier:()=>kg,mark:()=>tE,overlap:()=>nE,render:()=>sE,viewlayout:()=>pE},1),Fo="top",Pn="left",Bn="right",Mi="bottom",bR="top-left",xR="top-right",wR="bottom-left",_R="bottom-right",mg="start",gg="middle",Ct="end",kR="x",ER="y",qc="group",yg="axis",vg="title",$R="frame",AR="scope",bg="legend",Wk="row-header",Hk="row-footer",Gk="row-title",Vk="column-header",Xk="column-footer",Yk="column-title",DR="padding",SR="symbol",Jk="fit",Qk="fit-x",Kk="fit-y",FR="pad",xg="none",Uc="all",wg="each",_g="flush",Oi="column",zi="row";function Zk(e){O.call(this,null,e)}G(Zk,O,{transform(e,t){let n=t.dataflow,r=e.mark,i=r.marktype,a=an[i],o=a.bound,l=r.bounds,s;if(a.nested)r.items.length&&n.dirty(r.items[0]),l=Wc(r,o),r.items.forEach(u=>{u.bounds.clear().union(l)});else if(i===qc||e.modified())switch(t.visit(t.MOD,u=>n.dirty(u)),l.clear(),r.items.forEach(u=>l.union(Wc(u,o))),r.role){case yg:case bg:case vg:t.reflow()}else s=t.changed(t.REM),t.visit(t.ADD,u=>{l.union(Wc(u,o))}),t.visit(t.MOD,u=>{s||(s=l.alignsWith(u.bounds)),n.dirty(u),l.union(Wc(u,o))}),s&&(l.clear(),r.items.forEach(u=>l.union(u.bounds)));return qk(r),t.modifies("bounds")}});function Wc(e,t,n){return t(e.bounds.clear(),e,n)}var eE=":vega_identifier:";function kg(e){O.call(this,0,e)}kg.Definition={type:"Identifier",metadata:{modifies:!0},params:[{name:"as",type:"string",required:!0}]},G(kg,O,{transform(e,t){let n=CR(t.dataflow),r=e.as,i=n.value;return t.visit(t.ADD,a=>a[r]=a[r]||++i),n.set(this.value=i),t}});function CR(e){return e._signals[eE]||(e._signals[eE]=e.add(0))}function tE(e){O.call(this,null,e)}G(tE,O,{transform(e,t){let n=this.value;n||(n=t.dataflow.scenegraph().mark(e.markdef,MR(e),e.index),n.group.context=e.context,e.context.group||(e.context.group=n.group),n.source=this.source,n.clip=e.clip,n.interactive=e.interactive,this.value=n);let r=n.marktype===qc?hc:dc;return t.visit(t.ADD,i=>r.call(i,n)),(e.modified("clip")||e.modified("interactive"))&&(n.clip=e.clip,n.interactive=!!e.interactive,n.zdirty=!0,t.reflow()),n.items=t.source,t}});function MR(e){let t=e.groups,n=e.parent;return t&&t.size===1?t.get(Object.keys(t.object)[0]):t&&n?t.lookup(n):null}function nE(e){O.call(this,null,e)}var rE={parity:e=>e.filter((t,n)=>n%2?t.opacity=0:1),greedy:(e,t)=>{let n;return e.filter((r,i)=>!i||!iE(n.bounds,r.bounds,t)?(n=r,1):r.opacity=0)}},iE=(e,t,n)=>n>Math.max(t.x1-e.x2,e.x1-t.x2,t.y1-e.y2,e.y1-t.y2),aE=(e,t)=>{for(var n=1,r=e.length,i=e[0].bounds,a;n<r;i=a,++n)if(iE(i,a=e[n].bounds,t))return!0},OR=e=>{let t=e.bounds;return t.width()>1&&t.height()>1},zR=(e,t,n)=>{var r=e.range(),i=new Ke;return t===Fo||t===Mi?i.set(r[0],-1/0,r[1],1/0):i.set(-1/0,r[0],1/0,r[1]),i.expand(n||1),a=>i.encloses(a.bounds)},oE=e=>(e.forEach(t=>t.opacity=1),e),lE=(e,t)=>e.reflow(t.modified()).modifies("opacity");G(nE,O,{transform(e,t){let n=rE[e.method]||rE.parity,r=e.separation||0,i=t.materialize(t.SOURCE).source,a,o;if(!i||!i.length)return;if(!e.method)return e.modified("method")&&(oE(i),t=lE(t,e)),t;if(i=i.filter(OR),!i.length)return;if(e.sort&&(i=i.slice().sort(e.sort)),a=oE(i),t=lE(t,e),a.length>=3&&aE(a,r)){do a=n(a,r);while(a.length>=3&&aE(a,r));a.length<3&&!$e(i).opacity&&(a.length>1&&($e(a).opacity=0),$e(i).opacity=1)}e.boundScale&&e.boundTolerance>=0&&(o=zR(e.boundScale,e.boundOrient,+e.boundTolerance),i.forEach(s=>{o(s)||(s.opacity=0)}));let l=a[0].mark.bounds.clear();return i.forEach(s=>{s.opacity&&l.union(s.bounds)}),t}});function sE(e){O.call(this,null,e)}G(sE,O,{transform(e,t){let n=t.dataflow;if(t.visit(t.ALL,r=>n.dirty(r)),t.fields&&t.fields.zindex){let r=t.source&&t.source[0];r&&(r.mark.zdirty=!0)}}});var bt=new Ke;function Co(e,t,n){return e[t]===n?0:(e[t]=n,1)}function NR(e){var t=e.items[0].orient;return t===Pn||t===Bn}function RR(e){let t=+e.grid;return[e.ticks?t++:-1,e.labels?t++:-1,t+ +e.domain]}function TR(e,t,n,r){var i=t.items[0],a=i.datum,o=i.translate==null?.5:i.translate,l=i.orient,s=RR(a),u=i.range,c=i.offset,f=i.position,d=i.minExtent,h=i.maxExtent,p=a.title&&i.items[s[2]].items[0],m=i.titlePadding,g=i.bounds,y=p&&Ym(p),v=0,b=0,w,_;switch(bt.clear().union(g),g.clear(),(w=s[0])>-1&&g.union(i.items[w].bounds),(w=s[1])>-1&&g.union(i.items[w].bounds),l){case Fo:v=f||0,b=-c,_=Math.max(d,Math.min(h,-g.y1)),g.add(0,-_).add(u,0),p&&Hc(e,p,_,m,y,0,-1,g);break;case Pn:v=-c,b=f||0,_=Math.max(d,Math.min(h,-g.x1)),g.add(-_,0).add(0,u),p&&Hc(e,p,_,m,y,1,-1,g);break;case Bn:v=n+c,b=f||0,_=Math.max(d,Math.min(h,g.x2)),g.add(0,0).add(_,u),p&&Hc(e,p,_,m,y,1,1,g);break;case Mi:v=f||0,b=r+c,_=Math.max(d,Math.min(h,g.y2)),g.add(0,0).add(u,_),p&&Hc(e,p,_,m,0,0,1,g);break;default:v=i.x,b=i.y}return Br(g.translate(v,b),i),Co(i,"x",v+o)|Co(i,"y",b+o)&&(i.bounds=bt,e.dirty(i),i.bounds=g,e.dirty(i)),i.mark.bounds.clear().union(g)}function Hc(e,t,n,r,i,a,o,l){let s=t.bounds;if(t.auto){let u=o*(n+i+r),c=0,f=0;e.dirty(t),a?c=(t.x||0)-(t.x=u):f=(t.y||0)-(t.y=u),t.mark.bounds.clear().union(s.translate(-c,-f)),e.dirty(t)}l.union(s)}var uE=(e,t)=>Math.floor(Math.min(e,t)),cE=(e,t)=>Math.ceil(Math.max(e,t));function LR(e){var t=e.items,n=t.length,r=0,i,a;let o={marks:[],rowheaders:[],rowfooters:[],colheaders:[],colfooters:[],rowtitle:null,coltitle:null};for(;r<n;++r)if(i=t[r],a=i.items,i.marktype===qc)switch(i.role){case yg:case bg:case vg:break;case Wk:o.rowheaders.push(...a);break;case Hk:o.rowfooters.push(...a);break;case Vk:o.colheaders.push(...a);break;case Xk:o.colfooters.push(...a);break;case Gk:o.rowtitle=a[0];break;case Yk:o.coltitle=a[0];break;default:o.marks.push(...a)}return o}function PR(e){return new Ke().set(0,0,e.width||0,e.height||0)}function BR(e){let t=e.bounds.clone();return t.empty()?t.set(0,0,0,0):t.translate(-(e.x||0),-(e.y||0))}function Le(e,t,n){return(J(e)?e[t]:e)??(n===void 0?0:n)}function fE(e){return e<0?Math.ceil(-e):0}function dE(e,t,n){var r=!n.nodirty,i=n.bounds===_g?PR:BR,a=bt.set(0,0,0,0),o=Le(n.align,Oi),l=Le(n.align,zi),s=Le(n.padding,Oi),u=Le(n.padding,zi),c=n.columns||t.length,f=c<=0?1:Math.ceil(t.length/c),d=t.length,h=Array(d),p=Array(c),m=0,g=Array(d),y=Array(f),v=0,b=Array(d),w=Array(d),_=Array(d),k,x,E,$,D,F,T,S,M,A,C;for(x=0;x<c;++x)p[x]=0;for(x=0;x<f;++x)y[x]=0;for(x=0;x<d;++x)F=t[x],D=_[x]=i(F),F.x=F.x||0,b[x]=0,F.y=F.y||0,w[x]=0,E=x%c,$=~~(x/c),m=Math.max(m,T=Math.ceil(D.x2)),v=Math.max(v,S=Math.ceil(D.y2)),p[E]=Math.max(p[E],T),y[$]=Math.max(y[$],S),h[x]=s+fE(D.x1),g[x]=u+fE(D.y1),r&&e.dirty(t[x]);for(x=0;x<d;++x)x%c===0&&(h[x]=0),x<c&&(g[x]=0);if(o===wg)for(E=1;E<c;++E){for(C=0,x=E;x<d;x+=c)C<h[x]&&(C=h[x]);for(x=E;x<d;x+=c)h[x]=C+p[E-1]}else if(o===Uc){for(C=0,x=0;x<d;++x)x%c&&C<h[x]&&(C=h[x]);for(x=0;x<d;++x)x%c&&(h[x]=C+m)}else for(o=!1,E=1;E<c;++E)for(x=E;x<d;x+=c)h[x]+=p[E-1];if(l===wg)for($=1;$<f;++$){for(C=0,x=$*c,k=x+c;x<k;++x)C<g[x]&&(C=g[x]);for(x=$*c;x<k;++x)g[x]=C+y[$-1]}else if(l===Uc){for(C=0,x=c;x<d;++x)C<g[x]&&(C=g[x]);for(x=c;x<d;++x)g[x]=C+v}else for(l=!1,$=1;$<f;++$)for(x=$*c,k=x+c;x<k;++x)g[x]+=y[$-1];for(M=0,x=0;x<d;++x)M=h[x]+(x%c?M:0),b[x]+=M-t[x].x;for(E=0;E<c;++E)for(A=0,x=E;x<d;x+=c)A+=g[x],w[x]+=A-t[x].y;if(o&&Le(n.center,Oi)&&f>1)for(x=0;x<d;++x)D=o===Uc?m:p[x%c],M=D-_[x].x2-t[x].x-b[x],M>0&&(b[x]+=M/2);if(l&&Le(n.center,zi)&&c!==1)for(x=0;x<d;++x)D=l===Uc?v:y[~~(x/c)],A=D-_[x].y2-t[x].y-w[x],A>0&&(w[x]+=A/2);for(x=0;x<d;++x)a.union(_[x].translate(b[x],w[x]));switch(M=Le(n.anchor,kR),A=Le(n.anchor,ER),Le(n.anchor,Oi)){case Ct:M-=a.width();break;case gg:M-=a.width()/2}switch(Le(n.anchor,zi)){case Ct:A-=a.height();break;case gg:A-=a.height()/2}for(M=Math.round(M),A=Math.round(A),a.clear(),x=0;x<d;++x)t[x].mark.bounds.clear();for(x=0;x<d;++x)F=t[x],F.x+=b[x]+=M,F.y+=w[x]+=A,a.union(F.mark.bounds.union(F.bounds.translate(b[x],w[x]))),r&&e.dirty(F);return a}function IR(e,t,n){var r=LR(t),i=r.marks,a=n.bounds===_g?jR:qR,o=n.offset,l=n.columns||i.length,s=l<=0?1:Math.ceil(i.length/l),u=s*l,c,f,d,h,p,m,g;let y=dE(e,i,n);y.empty()&&y.set(0,0,0,0),r.rowheaders&&(m=Le(n.headerBand,zi,null),c=Gc(e,r.rowheaders,i,l,s,-Le(o,"rowHeader"),uE,0,a,"x1",0,l,1,m)),r.colheaders&&(m=Le(n.headerBand,Oi,null),f=Gc(e,r.colheaders,i,l,l,-Le(o,"columnHeader"),uE,1,a,"y1",0,1,l,m)),r.rowfooters&&(m=Le(n.footerBand,zi,null),d=Gc(e,r.rowfooters,i,l,s,Le(o,"rowFooter"),cE,0,a,"x2",l-1,l,1,m)),r.colfooters&&(m=Le(n.footerBand,Oi,null),h=Gc(e,r.colfooters,i,l,l,Le(o,"columnFooter"),cE,1,a,"y2",u-l,1,l,m)),r.rowtitle&&(p=Le(n.titleAnchor,zi),g=Le(o,"rowTitle"),g=p===Ct?d+g:c-g,m=Le(n.titleBand,zi,.5),hE(e,r.rowtitle,g,0,y,m)),r.coltitle&&(p=Le(n.titleAnchor,Oi),g=Le(o,"columnTitle"),g=p===Ct?h+g:f-g,m=Le(n.titleBand,Oi,.5),hE(e,r.coltitle,g,1,y,m))}function jR(e,t){return t==="x1"?e.x||0:t==="y1"?e.y||0:t==="x2"?(e.x||0)+(e.width||0):t==="y2"?(e.y||0)+(e.height||0):void 0}function qR(e,t){return e.bounds[t]}function Gc(e,t,n,r,i,a,o,l,s,u,c,f,d,h){var p=n.length,m=0,g=0,y,v,b,w,_,k,x,E,$;if(!p)return m;for(y=c;y<p;y+=f)n[y]&&(m=o(m,s(n[y],u)));if(!t.length)return m;for(t.length>i&&(e.warn("Grid headers exceed limit: "+i),t=t.slice(0,i)),m+=a,v=0,w=t.length;v<w;++v)e.dirty(t[v]),t[v].mark.bounds.clear();for(y=c,v=0,w=t.length;v<w;++v,y+=f){for(k=t[v],_=k.mark.bounds,b=y;b>=0&&(x=n[b])==null;b-=d);l?(E=h==null?x.x:Math.round(x.bounds.x1+h*x.bounds.width()),$=m):(E=m,$=h==null?x.y:Math.round(x.bounds.y1+h*x.bounds.height())),_.union(k.bounds.translate(E-(k.x||0),$-(k.y||0))),k.x=E,k.y=$,e.dirty(k),g=o(g,_[u])}return g}function hE(e,t,n,r,i,a){if(t){e.dirty(t);var o=n,l=n;r?o=Math.round(i.x1+a*i.width()):l=Math.round(i.y1+a*i.height()),t.bounds.translate(o-(t.x||0),l-(t.y||0)),t.mark.bounds.clear().union(t.bounds),t.x=o,t.y=l,e.dirty(t)}}function UR(e,t){let n=e[t]||{};return(r,i)=>n[r]==null?e[r]==null?i:e[r]:n[r]}function WR(e,t){let n=-1/0;return e.forEach(r=>{r.offset!=null&&(n=Math.max(n,r.offset))}),n>-1/0?n:t}function HR(e,t,n,r,i,a,o){let l=UR(n,t),s=WR(e,l("offset",0)),u=l("anchor",mg),c=u===Ct?1:u===gg?.5:0,f={align:wg,bounds:l("bounds",_g),columns:l("direction")==="vertical"?1:e.length,padding:l("margin",8),center:l("center"),nodirty:!0};switch(t){case Pn:f.anchor={x:Math.floor(r.x1)-s,column:Ct,y:c*(o||r.height()+2*r.y1),row:u};break;case Bn:f.anchor={x:Math.ceil(r.x2)+s,y:c*(o||r.height()+2*r.y1),row:u};break;case Fo:f.anchor={y:Math.floor(i.y1)-s,row:Ct,x:c*(a||i.width()+2*i.x1),column:u};break;case Mi:f.anchor={y:Math.ceil(i.y2)+s,x:c*(a||i.width()+2*i.x1),column:u};break;case bR:f.anchor={x:s,y:s};break;case xR:f.anchor={x:a-s,y:s,column:Ct};break;case wR:f.anchor={x:s,y:o-s,row:Ct};break;case _R:f.anchor={x:a-s,y:o-s,column:Ct,row:Ct};break}return f}function GR(e,t){var n=t.items[0],r=n.datum,i=n.orient,a=n.bounds,o=n.x,l=n.y,s,u;return n._bounds?n._bounds.clear().union(a):n._bounds=a.clone(),a.clear(),XR(e,n,n.items[0].items[0]),a=VR(n,a),s=2*n.padding,u=2*n.padding,a.empty()||(s=Math.ceil(a.width()+s),u=Math.ceil(a.height()+u)),r.type===SR&&YR(n.items[0].items[0].items[0].items),i!==xg&&(n.x=o=0,n.y=l=0),n.width=s,n.height=u,Br(a.set(o,l,o+s,l+u),n),n.mark.bounds.clear().union(a),n}function VR(e,t){return e.items.forEach(n=>t.union(n.bounds)),t.x1=e.padding,t.y1=e.padding,t}function XR(e,t,n){var r=t.padding,i=r-n.x,a=r-n.y;if(!t.datum.title)(i||a)&&cs(e,n,i,a);else{var o=t.items[1].items[0],l=o.anchor,s=t.titlePadding||0,u=r-o.x,c=r-o.y;switch(o.orient){case Pn:i+=Math.ceil(o.bounds.width())+s;break;case Bn:case Mi:break;default:a+=o.bounds.height()+s}switch((i||a)&&cs(e,n,i,a),o.orient){case Pn:c+=Mo(t,n,o,l,1,1);break;case Bn:u+=Mo(t,n,o,Ct,0,0)+s,c+=Mo(t,n,o,l,1,1);break;case Mi:u+=Mo(t,n,o,l,0,0),c+=Mo(t,n,o,Ct,-1,0,1)+s;break;default:u+=Mo(t,n,o,l,0,0)}(u||c)&&cs(e,o,u,c),(u=Math.round(o.bounds.x1-r))<0&&(cs(e,n,-u,0),cs(e,o,-u,0))}}function Mo(e,t,n,r,i,a,o){let l=e.datum.type!=="symbol",s=n.datum.vgrad,u=(l&&(a||!s)&&!o?t.items[0]:t).bounds[i?"y2":"x2"]-e.padding,c=s&&a?u:0,f=s&&a?0:u,d=i<=0?0:Ym(n);return Math.round(r===mg?c:r===Ct?f-d:.5*(u-d))}function cs(e,t,n,r){t.x+=n,t.y+=r,t.bounds.translate(n,r),t.mark.bounds.translate(n,r),e.dirty(t)}function YR(e){let t=e.reduce((n,r)=>(n[r.column]=Math.max(r.bounds.x2-r.x,n[r.column]||0),n),{});e.forEach(n=>{n.width=t[n.column],n.height=n.bounds.y2-n.y})}function JR(e,t,n,r,i){var a=t.items[0],o=a.frame,l=a.orient,s=a.anchor,u=a.offset,c=a.padding,f=a.items[0].items[0],d=a.items[1]&&a.items[1].items[0],h=l===Pn||l===Bn?r:n,p=0,m=0,g=0,y=0,v=0,b;if(o===qc?l===Pn&&(p=r,h=0):l===Pn?(p=i.y2,h=i.y1):l===Bn?(p=i.y1,h=i.y2):(p=i.x1,h=i.x2),b=s===mg?p:s===Ct?h:(p+h)/2,d&&d.text){switch(l){case Fo:case Mi:v=f.bounds.height()+c;break;case Pn:y=f.bounds.width()+c;break;case Bn:y=-f.bounds.width()-c;break}bt.clear().union(d.bounds),bt.translate(y-(d.x||0),v-(d.y||0)),Co(d,"x",y)|Co(d,"y",v)&&(e.dirty(d),d.bounds.clear().union(bt),d.mark.bounds.clear().union(bt),e.dirty(d)),bt.clear().union(d.bounds)}else bt.clear();switch(bt.union(f.bounds),l){case Fo:m=b,g=i.y1-bt.height()-u;break;case Pn:m=i.x1-bt.width()-u,g=b;break;case Bn:m=i.x2+bt.width()+u,g=b;break;case Mi:m=b,g=i.y2+u;break;default:m=a.x,g=a.y}return Co(a,"x",m)|Co(a,"y",g)&&(bt.translate(m,g),e.dirty(a),a.bounds.clear().union(bt),t.bounds.clear().union(bt),e.dirty(a)),a.bounds}function pE(e){O.call(this,null,e)}G(pE,O,{transform(e,t){let n=t.dataflow;return e.mark.items.forEach(r=>{e.layout&&IR(n,r,e.layout),KR(n,r,e)}),QR(e.mark.group)?t.reflow():t}});function QR(e){return e&&e.mark.role!=="legend-entry"}function KR(e,t,n){var r=t.items,i=Math.max(0,t.width||0),a=Math.max(0,t.height||0),o=new Ke().set(0,0,i,a),l=o.clone(),s=o.clone(),u=[],c,f,d,h,p,m;for(p=0,m=r.length;p<m;++p)switch(f=r[p],f.role){case yg:h=NR(f)?l:s,h.union(TR(e,f,i,a));break;case vg:c=f;break;case bg:u.push(GR(e,f));break;case $R:case AR:case Wk:case Hk:case Gk:case Vk:case Xk:case Yk:l.union(f.bounds),s.union(f.bounds);break;default:o.union(f.bounds)}if(u.length){let g={};for(let y in u.forEach(v=>{d=v.orient||Bn,d!==xg&&(g[d]||(g[d]=[])).push(v)}),g){let v=g[y];dE(e,v,HR(v,y,n.legends,l,s,i,a))}u.forEach(y=>{let v=y.bounds;if(v.equals(y._bounds)||(y.bounds=y._bounds,e.dirty(y),y.bounds=v,e.dirty(y)),n.autosize&&(n.autosize.type===Jk||n.autosize.type===Qk||n.autosize.type===Kk))switch(y.orient){case Pn:case Bn:o.add(v.x1,0).add(v.x2,0);break;case Fo:case Mi:o.add(0,v.y1).add(0,v.y2)}else o.union(v)})}o.union(l).union(s),c&&o.union(JR(e,c,i,a,o)),t.clip&&o.set(0,0,t.width||0,t.height||0),ZR(e,t,o,n)}function ZR(e,t,n,r){let i=r.autosize||{},a=i.type;if(e._autosize<1||!a)return;let o=e._width,l=e._height,s=Math.max(0,t.width||0),u=Math.max(0,Math.ceil(-n.x1)),c=Math.max(0,t.height||0),f=Math.max(0,Math.ceil(-n.y1)),d=Math.max(0,Math.ceil(n.x2-s)),h=Math.max(0,Math.ceil(n.y2-c));if(i.contains===DR){let p=e.padding();o-=p.left+p.right,l-=p.top+p.bottom}a===xg?(u=0,f=0,s=o,c=l):a===Jk?(s=Math.max(0,o-u-d),c=Math.max(0,l-f-h)):a===Qk?(s=Math.max(0,o-u-d),l=c+f+h):a===Kk?(o=s+u+d,c=Math.max(0,l-f-h)):a===FR&&(o=s+u+d,l=c+f+h),e._resizeView(o,l,s,c,[u,f],i.resize)}var eT=Gt({axisticks:()=>mE,datajoin:()=>gE,encode:()=>yE,legendentries:()=>vE,linkpath:()=>Eg,pie:()=>$g,scale:()=>EE,sortitems:()=>DE,stack:()=>Dg},1);function mE(e){O.call(this,null,e)}G(mE,O,{transform(e,t){if(this.value&&!e.modified())return t.StopPropagation;var n=t.dataflow.locale(),r=t.fork(t.NO_SOURCE|t.NO_FIELDS),i=this.value,a=e.scale,o=wm(a,e.count==null?e.values?e.values.length:10:e.count,e.minstep),l=e.format||s_(n,a,o,e.formatSpecifier,e.formatType,!!e.values),s=e.values?l_(a,e.values,o):_m(a,o);return i&&(r.rem=i),i=s.map((u,c)=>_e({index:c/(s.length-1||1),value:u,label:l(u)})),e.extra&&i.length&&i.push(_e({index:-1,extra:{value:i[0].value},label:""})),r.source=i,r.add=i,this.value=i,r}});function gE(e){O.call(this,null,e)}function tT(){return _e({})}function nT(e){let t=po().test(n=>n.exit);return t.lookup=n=>t.get(e(n)),t}G(gE,O,{transform(e,t){var n=t.dataflow,r=t.fork(t.NO_SOURCE|t.NO_FIELDS),i=e.item||tT,a=e.key||te,o=this.value;return N(r.encode)&&(r.encode=null),o&&(e.modified("key")||t.modified(a))&&L("DataJoin does not support modified key function or fields."),o||(t=t.addAll(),this.value=o=nT(a)),t.visit(t.ADD,l=>{let s=a(l),u=o.get(s);u?u.exit?(o.empty--,r.add.push(u)):r.mod.push(u):(u=i(l),o.set(s,u),r.add.push(u)),u.datum=l,u.exit=!1}),t.visit(t.MOD,l=>{let s=a(l),u=o.get(s);u&&(u.datum=l,r.mod.push(u))}),t.visit(t.REM,l=>{let s=a(l),u=o.get(s);l===u.datum&&!u.exit&&(r.rem.push(u),u.exit=!0,++o.empty)}),t.changed(t.ADD_MOD)&&r.modifies("datum"),(t.clean()||e.clean&&o.empty>n.cleanThreshold)&&n.runAfter(o.clean),r}});function yE(e){O.call(this,null,e)}G(yE,O,{transform(e,t){var n=t.fork(t.ADD_REM),r=e.mod||!1,i=e.encoders,a=t.encode;if(N(a))if(n.changed()||a.every(f=>i[f]))a=a[0],n.encode=null;else return t.StopPropagation;var o=a==="enter",l=i.update||fi,s=i.enter||fi,u=i.exit||fi,c=(a&&!o?i[a]:l)||fi;if(t.changed(t.ADD)&&(t.visit(t.ADD,f=>{s(f,e),l(f,e)}),n.modifies(s.output),n.modifies(l.output),c!==fi&&c!==l&&(t.visit(t.ADD,f=>{c(f,e)}),n.modifies(c.output))),t.changed(t.REM)&&u!==fi&&(t.visit(t.REM,f=>{u(f,e)}),n.modifies(u.output)),o||c!==fi){let f=t.MOD|(e.modified()?t.REFLOW:0);o?(t.visit(f,d=>{let h=s(d,e)||r;(c(d,e)||h)&&n.mod.push(d)}),n.mod.length&&n.modifies(s.output)):t.visit(f,d=>{(c(d,e)||r)&&n.mod.push(d)}),n.mod.length&&n.modifies(c.output)}return n.changed()?n:t.StopPropagation}});function vE(e){O.call(this,[],e)}G(vE,O,{transform(e,t){if(this.value!=null&&!e.modified())return t.StopPropagation;var n=t.dataflow.locale(),r=t.fork(t.NO_SOURCE|t.NO_FIELDS),i=this.value,a=e.type||"symbol",o=e.scale,l=+e.limit,s=wm(o,e.count==null?5:e.count,e.minstep),u=!!e.values||a==="symbol",c=e.format||d_(n,o,s,a,e.formatSpecifier,e.formatType,u),f=e.values||f_(o,s),d,h,p,m,g;return i&&(r.rem=i),a==="symbol"?(l&&f.length>l?(t.dataflow.warn("Symbol legend count exceeds limit, filtering items."),i=f.slice(0,l-1),g=!0):i=f,de(p=e.size)?(!e.values&&o(i[0])===0&&(i=i.slice(1)),m=i.reduce((y,v)=>Math.max(y,p(v,e)),0)):p=At(m=p||8),i=i.map((y,v)=>_e({index:v,label:c(y,v,i),value:y,offset:m,size:p(y,e)})),g&&(g=f[i.length],i.push(_e({index:i.length,label:`\u2026${f.length-i.length} entries`,value:g,offset:m,size:p(g,e)})))):a==="gradient"?(d=o.domain(),h=r_(o,d[0],$e(d)),f.length<3&&!e.values&&d[0]!==$e(d)&&(f=[d[0],$e(d)]),i=f.map((y,v)=>_e({index:v,label:c(y,v,f),value:y,perc:h(y)}))):(p=f.length-1,h=I7(o),i=f.map((y,v)=>_e({index:v,label:c(y,v,f),value:y,perc:v?h(y):0,perc2:v===p?1:h(f[v+1])}))),r.source=i,r.add=i,this.value=i,r}});var rT=e=>e.source.x,iT=e=>e.source.y,aT=e=>e.target.x,oT=e=>e.target.y;function Eg(e){O.call(this,{},e)}Eg.Definition={type:"LinkPath",metadata:{modifies:!0},params:[{name:"sourceX",type:"field",default:"source.x"},{name:"sourceY",type:"field",default:"source.y"},{name:"targetX",type:"field",default:"target.x"},{name:"targetY",type:"field",default:"target.y"},{name:"orient",type:"enum",default:"vertical",values:["horizontal","vertical","radial"]},{name:"shape",type:"enum",default:"line",values:["line","arc","curve","diagonal","orthogonal"]},{name:"require",type:"signal"},{name:"as",type:"string",default:"path"}]},G(Eg,O,{transform(e,t){var n=e.sourceX||rT,r=e.sourceY||iT,i=e.targetX||aT,a=e.targetY||oT,o=e.as||"path",l=e.orient||"vertical",s=e.shape||"line",u=_E.get(s+"-"+l)||_E.get(s);return u||L("LinkPath unsupported type: "+e.shape+(e.orient?"-"+e.orient:"")),t.visit(t.SOURCE,c=>{c[o]=u(n(c),r(c),i(c),a(c))}),t.reflow(e.modified()).modifies(o)}});var bE=(e,t,n,r)=>"M"+e+","+t+"L"+n+","+r,lT=(e,t,n,r)=>bE(t*Math.cos(e),t*Math.sin(e),r*Math.cos(n),r*Math.sin(n)),xE=(e,t,n,r)=>{var i=n-e,a=r-t,o=Math.hypot(i,a)/2,l=180*Math.atan2(a,i)/Math.PI;return"M"+e+","+t+"A"+o+","+o+" "+l+" 0 1 "+n+","+r},sT=(e,t,n,r)=>xE(t*Math.cos(e),t*Math.sin(e),r*Math.cos(n),r*Math.sin(n)),wE=(e,t,n,r)=>{let i=n-e,a=r-t,o=.2*(i+a),l=.2*(a-i);return"M"+e+","+t+"C"+(e+o)+","+(t+l)+" "+(n+l)+","+(r-o)+" "+n+","+r},uT=(e,t,n,r)=>wE(t*Math.cos(e),t*Math.sin(e),r*Math.cos(n),r*Math.sin(n)),cT=(e,t,n,r)=>"M"+e+","+t+"V"+r+"H"+n,fT=(e,t,n,r)=>"M"+e+","+t+"H"+n+"V"+r,dT=(e,t,n,r)=>{let i=Math.cos(e),a=Math.sin(e),o=Math.cos(n),l=Math.sin(n),s=Math.abs(n-e)>Math.PI?n<=e:n>e;return"M"+t*i+","+t*a+"A"+t+","+t+" 0 0,"+(s?1:0)+" "+t*o+","+t*l+"L"+r*o+","+r*l},hT=(e,t,n,r)=>{let i=(e+n)/2;return"M"+e+","+t+"C"+i+","+t+" "+i+","+r+" "+n+","+r},pT=(e,t,n,r)=>{let i=(t+r)/2;return"M"+e+","+t+"C"+e+","+i+" "+n+","+i+" "+n+","+r},mT=(e,t,n,r)=>{let i=Math.cos(e),a=Math.sin(e),o=Math.cos(n),l=Math.sin(n),s=(t+r)/2;return"M"+t*i+","+t*a+"C"+s*i+","+s*a+" "+s*o+","+s*l+" "+r*o+","+r*l},_E=po({line:bE,"line-radial":lT,arc:xE,"arc-radial":sT,curve:wE,"curve-radial":uT,"orthogonal-horizontal":cT,"orthogonal-vertical":fT,"orthogonal-radial":dT,"diagonal-horizontal":hT,"diagonal-vertical":pT,"diagonal-radial":mT});function $g(e){O.call(this,null,e)}$g.Definition={type:"Pie",metadata:{modifies:!0},params:[{name:"field",type:"field"},{name:"startAngle",type:"number",default:0},{name:"endAngle",type:"number",default:6.283185307179586},{name:"sort",type:"boolean",default:!1},{name:"as",type:"string",array:!0,length:2,default:["startAngle","endAngle"]}]},G($g,O,{transform(e,t){var n=e.as||["startAngle","endAngle"],r=n[0],i=n[1],a=e.field||Ol,o=e.startAngle||0,l=e.endAngle==null?2*Math.PI:e.endAngle,s=t.source,u=s.map(a),c=u.length,f=o,d=(l-o)/_2(u),h=nn(c),p,m,g;for(e.sort&&h.sort((y,v)=>u[y]-u[v]),p=0;p<c;++p)g=u[h[p]],m=s[h[p]],m[r]=f,m[i]=f+=g*d;return this.value=u,t.reflow(e.modified()).modifies(n)}});var gT=5;function yT(e){let t=e.type;return!e.bins&&(t==="linear"||t==="pow"||t==="sqrt")}function kE(e){return ym(e)&&e!=="sequential"}var vT=sr(["set","modified","clear","type","scheme","schemeExtent","schemeCount","domain","domainMin","domainMid","domainMax","domainRaw","domainImplicit","nice","zero","bins","range","rangeStep","round","reverse","interpolate","interpolateGamma"]);function EE(e){O.call(this,null,e),this.modified(!0)}G(EE,O,{transform(e,t){var n=t.dataflow,r=this.value,i=bT(e);for(i in(!r||i!==r.type)&&(this.value=r=ve(i)()),e)if(!vT[i]){if(i==="padding"&&kE(r.type))continue;de(r[i])?r[i](e[i]):n.warn("Unsupported scale property: "+i)}return $T(r,e,ET(r,e,wT(r,e,n))),t.fork(t.NO_SOURCE|t.NO_FIELDS)}});function bT(e){var t=e.type,n="",r;return t==="sequential"?wi+"-"+oc:(xT(e)&&(r=e.rawDomain?e.rawDomain.length:e.domain?e.domain.length+ +(e.domainMid!=null):0,n=r===2?wi+"-":r===3?wo+"-":""),(n+t||"linear").toLowerCase())}function xT(e){let t=e.type;return ym(t)&&t!=="time"&&t!=="utc"&&(e.scheme||e.range&&e.range.length&&e.range.every(Y))}function wT(e,t,n){let r=_T(e,t.domainRaw,n);if(r>-1)return r;var i=t.domain,a=e.type,o=t.zero||t.zero===void 0&&yT(e),l,s;if(!i)return 0;if((o||t.domainMin!=null||t.domainMax!=null||t.domainMid!=null)&&(l=(i=i.slice()).length-1||1,o&&(i[0]>0&&(i[0]=0),i[l]<0&&(i[l]=0)),t.domainMin!=null&&(i[0]=t.domainMin),t.domainMax!=null&&(i[l]=t.domainMax),t.domainMid!=null)){s=t.domainMid;let u=s>i[l]?l+1:s<i[0]?0:l;u!==l&&n.warn("Scale domainMid exceeds domain min or max.",s),i.splice(u,0,s)}return kE(a)&&t.padding&&i[0]!==$e(i)&&(i=kT(a,i,t.range,t.padding,t.exponent,t.constant)),e.domain($E(a,i,n)),a==="ordinal"&&e.unknown(t.domainImplicit?X4:void 0),t.nice&&e.nice&&e.nice(t.nice!==!0&&wm(e,t.nice)||null),i.length}function _T(e,t,n){return t?(e.domain($E(e.type,t,n)),t.length):-1}function kT(e,t,n,r,i,a){var o=Math.abs($e(n)-n[0]),l=o/(o-2*r),s=e==="log"?Xh(t,null,l):e==="sqrt"?Tu(t,null,l,.5):e==="pow"?Tu(t,null,l,i||1):e==="symlog"?Qh(t,null,l,a||1):qh(t,null,l);return t=t.slice(),t[0]=s[0],t[t.length-1]=s[1],t}function $E(e,t,n){return Kw(e)&&Math.abs(t.reduce((r,i)=>r+(i<0?-1:i>0?1:0),0))!==t.length&&n.warn("Log scale domain includes zero: "+H(t)),t}function ET(e,t,n){let r=t.bins;if(r&&!N(r)){let i=e.domain(),a=i[0],o=$e(i),l=r.step,s=r.start==null?a:r.start,u=r.stop==null?o:r.stop;l||L("Scale bins parameter missing step property."),s<a&&(s=l*Math.ceil(a/l)),u>o&&(u=l*Math.floor(o/l)),r=nn(s,u+l/2,l)}return r?e.bins=r:e.bins&&delete e.bins,e.type==="bin-ordinal"&&(r?!t.domain&&!t.domainRaw&&(e.domain(r),n=r.length):e.bins=e.domain()),n}function $T(e,t,n){var r=e.type,i=t.round||!1,a=t.range;if(t.rangeStep!=null)a=AT(r,t,n);else if(t.scheme&&(a=DT(r,t,n),de(a))){if(e.interpolator)return e.interpolator(a);L(`Scale type ${r} does not support interpolating color schemes.`)}if(a&&Zw(r))return e.interpolator(sc(Ag(a,t.reverse),t.interpolate,t.interpolateGamma));a&&t.interpolate&&e.interpolate?e.interpolate(bm(t.interpolate,t.interpolateGamma)):de(e.round)?e.round(i):de(e.rangeRound)&&e.interpolate(i?ip:rp),a&&e.range(Ag(a,t.reverse))}function AT(e,t,n){e!=="band"&&e!=="point"&&L("Only band and point scales support rangeStep.");var r=(t.paddingOuter==null?t.padding:t.paddingOuter)||0,i=e==="point"?1:(t.paddingInner==null?t.padding:t.paddingInner)||0;return[0,t.rangeStep*fm(n,i,r)]}function DT(e,t,n){var r=t.schemeExtent,i,a;return N(t.scheme)?a=sc(t.scheme,t.interpolate,t.interpolateGamma):(i=t.scheme.toLowerCase(),a=xm(i),a||L(`Unrecognized scheme name: ${t.scheme}`)),n=e==="threshold"?n+1:e==="bin-ordinal"?n-1:e==="quantile"||e==="quantize"?+t.schemeCount||gT:n,Zw(e)?AE(a,r,t.reverse):de(a)?n_(AE(a,r),n):e==="ordinal"?a:a.slice(0,n)}function AE(e,t,n){return de(e)&&(t||n)?t_(e,Ag(t||[0,1],n)):e}function Ag(e,t){return t?e.slice().reverse():e}function DE(e){O.call(this,null,e)}G(DE,O,{transform(e,t){let n=e.modified("sort")||t.changed(t.ADD)||t.modified(e.sort.fields)||t.modified("datum");return n&&t.source.sort(sa(e.sort)),this.modified(n),t}});var SE="zero",FE="center",CE="normalize",ME=["y0","y1"];function Dg(e){O.call(this,null,e)}Dg.Definition={type:"Stack",metadata:{modifies:!0},params:[{name:"field",type:"field"},{name:"groupby",type:"field",array:!0},{name:"sort",type:"compare"},{name:"offset",type:"enum",default:SE,values:[SE,FE,CE]},{name:"as",type:"string",array:!0,length:2,default:ME}]},G(Dg,O,{transform(e,t){var n=e.as||ME,r=n[0],i=n[1],a=sa(e.sort),o=e.field||Ol,l=e.offset===FE?ST:e.offset===CE?FT:CT,s=MT(t.source,e.groupby,a,o),u,c,f;for(u=0,c=s.length,f=s.max;u<c;++u)l(s[u],f,o,r,i);return t.reflow(e.modified()).modifies(n)}});function ST(e,t,n,r,i){for(var a=(t-e.sum)/2,o=e.length,l=0,s;l<o;++l)s=e[l],s[r]=a,s[i]=a+=Math.abs(n(s))}function FT(e,t,n,r,i){for(var a=1/e.sum,o=0,l=e.length,s=0,u=0,c;s<l;++s)c=e[s],c[r]=o,c[i]=o=a*(u+=Math.abs(n(c)))}function CT(e,t,n,r,i){for(var a=0,o=0,l=e.length,s=0,u,c;s<l;++s)c=e[s],u=+n(c),u<0?(c[r]=o,c[i]=o+=u):(c[r]=a,c[i]=a+=u)}function MT(e,t,n,r){var i=[],a=m=>m(c),o,l,s,u,c,f,d,h,p;if(t==null)i.push(e.slice());else for(o={},l=0,s=e.length;l<s;++l)c=e[l],f=t.map(a),d=o[f],d||(o[f]=d=[],i.push(d)),d.push(c);for(f=0,p=0,u=i.length;f<u;++f){for(d=i[f],l=0,h=0,s=d.length;l<s;++l)h+=Math.abs(r(d[l]));d.sum=h,h>p&&(p=h),n&&d.sort(n)}return i.max=p,i}var Ae=1e-6,he=Math.PI,Ue=he/2,Vc=he/4,Mt=he*2,Xe=180/he,ce=he/180,me=Math.abs,Oo=Math.atan,En=Math.atan2,ie=Math.cos,Xc=Math.ceil,OE=Math.exp,Sg=Math.hypot,Yc=Math.log,Fg=Math.pow,ne=Math.sin,$n=Math.sign||function(e){return e>0?1:e<0?-1:0},Ot=Math.sqrt,Cg=Math.tan;function zE(e){return e>1?0:e<-1?he:Math.acos(e)}function Vt(e){return e>1?Ue:e<-1?-Ue:Math.asin(e)}function ft(){}function Jc(e,t){e&&RE.hasOwnProperty(e.type)&&RE[e.type](e,t)}var NE={Feature:function(e,t){Jc(e.geometry,t)},FeatureCollection:function(e,t){for(var n=e.features,r=-1,i=n.length;++r<i;)Jc(n[r].geometry,t)}},RE={Sphere:function(e,t){t.sphere()},Point:function(e,t){e=e.coordinates,t.point(e[0],e[1],e[2])},MultiPoint:function(e,t){for(var n=e.coordinates,r=-1,i=n.length;++r<i;)e=n[r],t.point(e[0],e[1],e[2])},LineString:function(e,t){Mg(e.coordinates,t,0)},MultiLineString:function(e,t){for(var n=e.coordinates,r=-1,i=n.length;++r<i;)Mg(n[r],t,0)},Polygon:function(e,t){TE(e.coordinates,t)},MultiPolygon:function(e,t){for(var n=e.coordinates,r=-1,i=n.length;++r<i;)TE(n[r],t)},GeometryCollection:function(e,t){for(var n=e.geometries,r=-1,i=n.length;++r<i;)Jc(n[r],t)}};function Mg(e,t,n){var r=-1,i=e.length-n,a;for(t.lineStart();++r<i;)a=e[r],t.point(a[0],a[1],a[2]);t.lineEnd()}function TE(e,t){var n=-1,r=e.length;for(t.polygonStart();++n<r;)Mg(e[n],t,1);t.polygonEnd()}function jr(e,t){e&&NE.hasOwnProperty(e.type)?NE[e.type](e,t):Jc(e,t)}var Qc=new St,Kc=new St,LE,PE,Og,zg,Ng,pr={point:ft,lineStart:ft,lineEnd:ft,polygonStart:function(){Qc=new St,pr.lineStart=OT,pr.lineEnd=zT},polygonEnd:function(){var e=+Qc;Kc.add(e<0?Mt+e:e),this.lineStart=this.lineEnd=this.point=ft},sphere:function(){Kc.add(Mt)}};function OT(){pr.point=NT}function zT(){BE(LE,PE)}function NT(e,t){pr.point=BE,LE=e,PE=t,e*=ce,t*=ce,Og=e,zg=ie(t=t/2+Vc),Ng=ne(t)}function BE(e,t){e*=ce,t*=ce,t=t/2+Vc;var n=e-Og,r=n>=0?1:-1,i=r*n,a=ie(t),o=ne(t),l=Ng*o,s=zg*a+l*ie(i),u=l*r*ne(i);Qc.add(En(u,s)),Og=e,zg=a,Ng=o}function RT(e){return Kc=new St,jr(e,pr),Kc*2}function Zc(e){return[En(e[1],e[0]),Vt(e[2])]}function ya(e){var t=e[0],n=e[1],r=ie(n);return[r*ie(t),r*ne(t),ne(n)]}function ef(e,t){return e[0]*t[0]+e[1]*t[1]+e[2]*t[2]}function zo(e,t){return[e[1]*t[2]-e[2]*t[1],e[2]*t[0]-e[0]*t[2],e[0]*t[1]-e[1]*t[0]]}function Rg(e,t){e[0]+=t[0],e[1]+=t[1],e[2]+=t[2]}function tf(e,t){return[e[0]*t,e[1]*t,e[2]*t]}function nf(e){var t=Ot(e[0]*e[0]+e[1]*e[1]+e[2]*e[2]);e[0]/=t,e[1]/=t,e[2]/=t}var je,Xt,We,on,va,IE,jE,No,fs,Ni,qr,Ur={point:Tg,lineStart:UE,lineEnd:WE,polygonStart:function(){Ur.point=HE,Ur.lineStart=TT,Ur.lineEnd=LT,fs=new St,pr.polygonStart()},polygonEnd:function(){pr.polygonEnd(),Ur.point=Tg,Ur.lineStart=UE,Ur.lineEnd=WE,Qc<0?(je=-(We=180),Xt=-(on=90)):fs>1e-6?on=90:fs<-1e-6&&(Xt=-90),qr[0]=je,qr[1]=We},sphere:function(){je=-(We=180),Xt=-(on=90)}};function Tg(e,t){Ni.push(qr=[je=e,We=e]),t<Xt&&(Xt=t),t>on&&(on=t)}function qE(e,t){var n=ya([e*ce,t*ce]);if(No){var r=zo(No,n),i=zo([r[1],-r[0],0],r);nf(i),i=Zc(i);var a=e-va,o=a>0?1:-1,l=i[0]*Xe*o,s,u=me(a)>180;u^(o*va<l&&l<o*e)?(s=i[1]*Xe,s>on&&(on=s)):(l=(l+360)%360-180,u^(o*va<l&&l<o*e)?(s=-i[1]*Xe,s<Xt&&(Xt=s)):(t<Xt&&(Xt=t),t>on&&(on=t))),u?e<va?ln(je,e)>ln(je,We)&&(We=e):ln(e,We)>ln(je,We)&&(je=e):We>=je?(e<je&&(je=e),e>We&&(We=e)):e>va?ln(je,e)>ln(je,We)&&(We=e):ln(e,We)>ln(je,We)&&(je=e)}else Ni.push(qr=[je=e,We=e]);t<Xt&&(Xt=t),t>on&&(on=t),No=n,va=e}function UE(){Ur.point=qE}function WE(){qr[0]=je,qr[1]=We,Ur.point=Tg,No=null}function HE(e,t){if(No){var n=e-va;fs.add(me(n)>180?n+(n>0?360:-360):n)}else IE=e,jE=t;pr.point(e,t),qE(e,t)}function TT(){pr.lineStart()}function LT(){HE(IE,jE),pr.lineEnd(),me(fs)>1e-6&&(je=-(We=180)),qr[0]=je,qr[1]=We,No=null}function ln(e,t){return(t-=e)<0?t+360:t}function PT(e,t){return e[0]-t[0]}function GE(e,t){return e[0]<=e[1]?e[0]<=t&&t<=e[1]:t<e[0]||e[1]<t}function BT(e){var t,n,r,i,a,o,l;if(on=We=-(je=Xt=1/0),Ni=[],jr(e,Ur),n=Ni.length){for(Ni.sort(PT),t=1,r=Ni[0],a=[r];t<n;++t)i=Ni[t],GE(r,i[0])||GE(r,i[1])?(ln(r[0],i[1])>ln(r[0],r[1])&&(r[1]=i[1]),ln(i[0],r[1])>ln(r[0],r[1])&&(r[0]=i[0])):a.push(r=i);for(o=-1/0,n=a.length-1,t=0,r=a[n];t<=n;r=i,++t)i=a[t],(l=ln(r[1],i[0]))>o&&(o=l,je=i[0],We=r[1])}return Ni=qr=null,je===1/0||Xt===1/0?[[NaN,NaN],[NaN,NaN]]:[[je,Xt],[We,on]]}var ds,rf,af,of,lf,sf,uf,cf,Lg,Pg,Bg,VE,XE,zt,Nt,Rt,In={sphere:ft,point:Ig,lineStart:YE,lineEnd:JE,polygonStart:function(){In.lineStart=qT,In.lineEnd=UT},polygonEnd:function(){In.lineStart=YE,In.lineEnd=JE}};function Ig(e,t){e*=ce,t*=ce;var n=ie(t);hs(n*ie(e),n*ne(e),ne(t))}function hs(e,t,n){++ds,af+=(e-af)/ds,of+=(t-of)/ds,lf+=(n-lf)/ds}function YE(){In.point=IT}function IT(e,t){e*=ce,t*=ce;var n=ie(t);zt=n*ie(e),Nt=n*ne(e),Rt=ne(t),In.point=jT,hs(zt,Nt,Rt)}function jT(e,t){e*=ce,t*=ce;var n=ie(t),r=n*ie(e),i=n*ne(e),a=ne(t),o=En(Ot((o=Nt*a-Rt*i)*o+(o=Rt*r-zt*a)*o+(o=zt*i-Nt*r)*o),zt*r+Nt*i+Rt*a);rf+=o,sf+=o*(zt+(zt=r)),uf+=o*(Nt+(Nt=i)),cf+=o*(Rt+(Rt=a)),hs(zt,Nt,Rt)}function JE(){In.point=Ig}function qT(){In.point=WT}function UT(){QE(VE,XE),In.point=Ig}function WT(e,t){VE=e,XE=t,e*=ce,t*=ce,In.point=QE;var n=ie(t);zt=n*ie(e),Nt=n*ne(e),Rt=ne(t),hs(zt,Nt,Rt)}function QE(e,t){e*=ce,t*=ce;var n=ie(t),r=n*ie(e),i=n*ne(e),a=ne(t),o=Nt*a-Rt*i,l=Rt*r-zt*a,s=zt*i-Nt*r,u=Sg(o,l,s),c=Vt(u),f=u&&-c/u;Lg.add(f*o),Pg.add(f*l),Bg.add(f*s),rf+=c,sf+=c*(zt+(zt=r)),uf+=c*(Nt+(Nt=i)),cf+=c*(Rt+(Rt=a)),hs(zt,Nt,Rt)}function HT(e){ds=rf=af=of=lf=sf=uf=cf=0,Lg=new St,Pg=new St,Bg=new St,jr(e,In);var t=+Lg,n=+Pg,r=+Bg,i=Sg(t,n,r);return i<1e-12&&(t=sf,n=uf,r=cf,rf<1e-6&&(t=af,n=of,r=lf),i=Sg(t,n,r),i<1e-12)?[NaN,NaN]:[En(n,t)*Xe,Vt(r/i)*Xe]}function jg(e,t){function n(r,i){return r=e(r,i),t(r[0],r[1])}return e.invert&&t.invert&&(n.invert=function(r,i){return r=t.invert(r,i),r&&e.invert(r[0],r[1])}),n}function qg(e,t){return me(e)>he&&(e-=Math.round(e/Mt)*Mt),[e,t]}qg.invert=qg;function KE(e,t,n){return(e%=Mt)?t||n?jg(e$(e),t$(t,n)):e$(e):t||n?t$(t,n):qg}function ZE(e){return function(t,n){return t+=e,me(t)>he&&(t-=Math.round(t/Mt)*Mt),[t,n]}}function e$(e){var t=ZE(e);return t.invert=ZE(-e),t}function t$(e,t){var n=ie(e),r=ne(e),i=ie(t),a=ne(t);function o(l,s){var u=ie(s),c=ie(l)*u,f=ne(l)*u,d=ne(s),h=d*n+c*r;return[En(f*i-h*a,c*n-d*r),Vt(h*i+f*a)]}return o.invert=function(l,s){var u=ie(s),c=ie(l)*u,f=ne(l)*u,d=ne(s),h=d*i-f*a;return[En(f*i+d*a,c*n+h*r),Vt(h*n-c*r)]},o}function GT(e){e=KE(e[0]*ce,e[1]*ce,e.length>2?e[2]*ce:0);function t(n){return n=e(n[0]*ce,n[1]*ce),n[0]*=Xe,n[1]*=Xe,n}return t.invert=function(n){return n=e.invert(n[0]*ce,n[1]*ce),n[0]*=Xe,n[1]*=Xe,n},t}function VT(e,t,n,r,i,a){if(n){var o=ie(t),l=ne(t),s=r*n;i==null?(i=t+r*Mt,a=t-s/2):(i=n$(o,i),a=n$(o,a),(r>0?i<a:i>a)&&(i+=r*Mt));for(var u,c=i;r>0?c>a:c<a;c-=s)u=Zc([o,-l*ie(c),-l*ne(c)]),e.point(u[0],u[1])}}function n$(e,t){t=ya(t),t[0]-=e,nf(t);var n=zE(-t[1]);return((-t[2]<0?-n:n)+Mt-Ae)%Mt}function r$(){var e=[],t;return{point:function(n,r,i){t.push([n,r,i])},lineStart:function(){e.push(t=[])},lineEnd:ft,rejoin:function(){e.length>1&&e.push(e.pop().concat(e.shift()))},result:function(){var n=e;return e=[],t=null,n}}}function ff(e,t){return me(e[0]-t[0])<1e-6&&me(e[1]-t[1])<1e-6}function df(e,t,n,r){this.x=e,this.z=t,this.o=n,this.e=r,this.v=!1,this.n=this.p=null}function i$(e,t,n,r,i){var a=[],o=[],l,s;if(e.forEach(function(p){if(!((m=p.length-1)<=0)){var m,g=p[0],y=p[m],v;if(ff(g,y)){if(!g[2]&&!y[2]){for(i.lineStart(),l=0;l<m;++l)i.point((g=p[l])[0],g[1]);i.lineEnd();return}y[0]+=2*Ae}a.push(v=new df(g,p,null,!0)),o.push(v.o=new df(g,null,v,!1)),a.push(v=new df(y,p,null,!1)),o.push(v.o=new df(y,null,v,!0))}}),a.length){for(o.sort(t),a$(a),a$(o),l=0,s=o.length;l<s;++l)o[l].e=n=!n;for(var u=a[0],c,f;;){for(var d=u,h=!0;d.v;)if((d=d.n)===u)return;c=d.z,i.lineStart();do{if(d.v=d.o.v=!0,d.e){if(h)for(l=0,s=c.length;l<s;++l)i.point((f=c[l])[0],f[1]);else r(d.x,d.n.x,1,i);d=d.n}else{if(h)for(c=d.p.z,l=c.length-1;l>=0;--l)i.point((f=c[l])[0],f[1]);else r(d.x,d.p.x,-1,i);d=d.p}d=d.o,c=d.z,h=!h}while(!d.v);i.lineEnd()}}}function a$(e){if(t=e.length){for(var t,n=0,r=e[0],i;++n<t;)r.n=i=e[n],i.p=r,r=i;r.n=i=e[0],i.p=r}}function Ug(e){return me(e[0])<=he?e[0]:$n(e[0])*((me(e[0])+he)%Mt-he)}function XT(e,t){var n=Ug(t),r=t[1],i=ne(r),a=[ne(n),-ie(n),0],o=0,l=0,s=new St;i===1?r=Ue+Ae:i===-1&&(r=-Ue-Ae);for(var u=0,c=e.length;u<c;++u)if(d=(f=e[u]).length)for(var f,d,h=f[d-1],p=Ug(h),m=h[1]/2+Vc,g=ne(m),y=ie(m),v=0;v<d;++v,p=w,g=k,y=x,h=b){var b=f[v],w=Ug(b),_=b[1]/2+Vc,k=ne(_),x=ie(_),E=w-p,$=E>=0?1:-1,D=$*E,F=D>he,T=g*k;if(s.add(En(T*$*ne(D),y*x+T*ie(D))),o+=F?E+$*Mt:E,F^p>=n^w>=n){var S=zo(ya(h),ya(b));nf(S);var M=zo(a,S);nf(M);var A=(F^E>=0?-1:1)*Vt(M[2]);(r>A||r===A&&(S[0]||S[1]))&&(l+=F^E>=0?1:-1)}}return(o<-1e-6||o<1e-6&&s<-1e-12)^l&1}function o$(e,t,n,r){return function(i){var a=t(i),o=r$(),l=t(o),s=!1,u,c,f,d={point:h,lineStart:m,lineEnd:g,polygonStart:function(){d.point=y,d.lineStart=v,d.lineEnd=b,c=[],u=[]},polygonEnd:function(){d.point=h,d.lineStart=m,d.lineEnd=g,c=w2(c);var w=XT(u,r);c.length?(s||(s=(i.polygonStart(),!0)),i$(c,JT,w,n,i)):w&&(s||(s=(i.polygonStart(),!0)),i.lineStart(),n(null,null,1,i),i.lineEnd()),s&&(s=(i.polygonEnd(),!1)),c=u=null},sphere:function(){i.polygonStart(),i.lineStart(),n(null,null,1,i),i.lineEnd(),i.polygonEnd()}};function h(w,_){e(w,_)&&i.point(w,_)}function p(w,_){a.point(w,_)}function m(){d.point=p,a.lineStart()}function g(){d.point=h,a.lineEnd()}function y(w,_){f.push([w,_]),l.point(w,_)}function v(){l.lineStart(),f=[]}function b(){y(f[0][0],f[0][1]),l.lineEnd();var w=l.clean(),_=o.result(),k,x=_.length,E,$,D;if(f.pop(),u.push(f),f=null,x){if(w&1){if($=_[0],(E=$.length-1)>0){for(s||(s=(i.polygonStart(),!0)),i.lineStart(),k=0;k<E;++k)i.point((D=$[k])[0],D[1]);i.lineEnd()}return}x>1&&w&2&&_.push(_.pop().concat(_.shift())),c.push(_.filter(YT))}}return d}}function YT(e){return e.length>1}function JT(e,t){return((e=e.x)[0]<0?e[1]-Ue-Ae:Ue-e[1])-((t=t.x)[0]<0?t[1]-Ue-Ae:Ue-t[1])}var l$=o$(function(){return!0},QT,ZT,[-he,-Ue]);function QT(e){var t=NaN,n=NaN,r=NaN,i;return{lineStart:function(){e.lineStart(),i=1},point:function(a,o){var l=a>0?he:-he,s=me(a-t);me(s-he)<1e-6?(e.point(t,n=(n+o)/2>0?Ue:-Ue),e.point(r,n),e.lineEnd(),e.lineStart(),e.point(l,n),e.point(a,n),i=0):r!==l&&s>=he&&(me(t-r)<1e-6&&(t-=r*Ae),me(a-l)<1e-6&&(a-=l*Ae),n=KT(t,n,a,o),e.point(r,n),e.lineEnd(),e.lineStart(),e.point(l,n),i=0),e.point(t=a,n=o),r=l},lineEnd:function(){e.lineEnd(),t=n=NaN},clean:function(){return 2-i}}}function KT(e,t,n,r){var i,a,o=ne(e-n);return me(o)>1e-6?Oo((ne(t)*(a=ie(r))*ne(n)-ne(r)*(i=ie(t))*ne(e))/(i*a*o)):(t+r)/2}function ZT(e,t,n,r){var i;if(e==null)i=n*Ue,r.point(-he,i),r.point(0,i),r.point(he,i),r.point(he,0),r.point(he,-i),r.point(0,-i),r.point(-he,-i),r.point(-he,0),r.point(-he,i);else if(me(e[0]-t[0])>1e-6){var a=e[0]<t[0]?he:-he;i=n*a/2,r.point(-a,i),r.point(0,i),r.point(a,i)}else r.point(t[0],t[1])}function eL(e){var t=ie(e),n=2*ce,r=t>0,i=me(t)>Ae;function a(c,f,d,h){VT(h,e,n,d,c,f)}function o(c,f){return ie(c)*ie(f)>t}function l(c){var f,d,h,p,m;return{lineStart:function(){p=h=!1,m=1},point:function(g,y){var v=[g,y],b,w=o(g,y),_=r?w?0:u(g,y):w?u(g+(g<0?he:-he),y):0;if(!f&&(p=h=w)&&c.lineStart(),w!==h&&(b=s(f,v),(!b||ff(f,b)||ff(v,b))&&(v[2]=1)),w!==h)m=0,w?(c.lineStart(),b=s(v,f),c.point(b[0],b[1])):(b=s(f,v),c.point(b[0],b[1],2),c.lineEnd()),f=b;else if(i&&f&&r^w){var k;!(_&d)&&(k=s(v,f,!0))&&(m=0,r?(c.lineStart(),c.point(k[0][0],k[0][1]),c.point(k[1][0],k[1][1]),c.lineEnd()):(c.point(k[1][0],k[1][1]),c.lineEnd(),c.lineStart(),c.point(k[0][0],k[0][1],3)))}w&&(!f||!ff(f,v))&&c.point(v[0],v[1]),f=v,h=w,d=_},lineEnd:function(){h&&c.lineEnd(),f=null},clean:function(){return m|(p&&h)<<1}}}function s(c,f,d){var h=ya(c),p=ya(f),m=[1,0,0],g=zo(h,p),y=ef(g,g),v=g[0],b=y-v*v;if(!b)return!d&&c;var w=t*y/b,_=-t*v/b,k=zo(m,g),x=tf(m,w);Rg(x,tf(g,_));var E=k,$=ef(x,E),D=ef(E,E),F=$*$-D*(ef(x,x)-1);if(!(F<0)){var T=Ot(F),S=tf(E,(-$-T)/D);if(Rg(S,x),S=Zc(S),!d)return S;var M=c[0],A=f[0],C=c[1],P=f[1],W;A<M&&(W=M,M=A,A=W);var V=A-M,ae=me(V-he)<Ae,ue=ae||V<1e-6;if(!ae&&P<C&&(W=C,C=P,P=W),ue?ae?C+P>0^S[1]<(me(S[0]-M)<1e-6?C:P):C<=S[1]&&S[1]<=P:V>he^(M<=S[0]&&S[0]<=A)){var xe=tf(E,(-$+T)/D);return Rg(xe,x),[S,Zc(xe)]}}}function u(c,f){var d=r?e:he-e,h=0;return c<-d?h|=1:c>d&&(h|=2),f<-d?h|=4:f>d&&(h|=8),h}return o$(o,l,a,r?[0,-e]:[-he,e-he])}function tL(e,t,n,r,i,a){var o=e[0],l=e[1],s=t[0],u=t[1],c=0,f=1,d=s-o,h=u-l,p=n-o;if(!(!d&&p>0)){if(p/=d,d<0){if(p<c)return;p<f&&(f=p)}else if(d>0){if(p>f)return;p>c&&(c=p)}if(p=i-o,!(!d&&p<0)){if(p/=d,d<0){if(p>f)return;p>c&&(c=p)}else if(d>0){if(p<c)return;p<f&&(f=p)}if(p=r-l,!(!h&&p>0)){if(p/=h,h<0){if(p<c)return;p<f&&(f=p)}else if(h>0){if(p>f)return;p>c&&(c=p)}if(p=a-l,!(!h&&p<0)){if(p/=h,h<0){if(p>f)return;p>c&&(c=p)}else if(h>0){if(p<c)return;p<f&&(f=p)}return c>0&&(e[0]=o+c*d,e[1]=l+c*h),f<1&&(t[0]=o+f*d,t[1]=l+f*h),!0}}}}}var ps=1e9,hf=-ps;function s$(e,t,n,r){function i(u,c){return e<=u&&u<=n&&t<=c&&c<=r}function a(u,c,f,d){var h=0,p=0;if(u==null||(h=o(u,f))!==(p=o(c,f))||s(u,c)<0^f>0)do d.point(h===0||h===3?e:n,h>1?r:t);while((h=(h+f+4)%4)!==p);else d.point(c[0],c[1])}function o(u,c){return me(u[0]-e)<1e-6?c>0?0:3:me(u[0]-n)<1e-6?c>0?2:1:me(u[1]-t)<1e-6?c>0?1:0:c>0?3:2}function l(u,c){return s(u.x,c.x)}function s(u,c){var f=o(u,1),d=o(c,1);return f===d?f===0?c[1]-u[1]:f===1?u[0]-c[0]:f===2?u[1]-c[1]:c[0]-u[0]:f-d}return function(u){var c=u,f=r$(),d,h,p,m,g,y,v,b,w,_,k,x={point:E,lineStart:T,lineEnd:S,polygonStart:D,polygonEnd:F};function E(A,C){i(A,C)&&c.point(A,C)}function $(){for(var A=0,C=0,P=h.length;C<P;++C)for(var W=h[C],V=1,ae=W.length,ue=W[0],xe,ge,Ht=ue[0],Et=ue[1];V<ae;++V)xe=Ht,ge=Et,ue=W[V],Ht=ue[0],Et=ue[1],ge<=r?Et>r&&(Ht-xe)*(r-ge)>(Et-ge)*(e-xe)&&++A:Et<=r&&(Ht-xe)*(r-ge)<(Et-ge)*(e-xe)&&--A;return A}function D(){c=f,d=[],h=[],k=!0}function F(){var A=$(),C=k&&A,P=(d=w2(d)).length;(C||P)&&(u.polygonStart(),C&&(u.lineStart(),a(null,null,1,u),u.lineEnd()),P&&i$(d,l,A,a,u),u.polygonEnd()),c=u,d=h=p=null}function T(){x.point=M,h&&h.push(p=[]),_=!0,w=!1,v=b=NaN}function S(){d&&(M(m,g),y&&w&&f.rejoin(),d.push(f.result())),x.point=E,w&&c.lineEnd()}function M(A,C){var P=i(A,C);if(h&&p.push([A,C]),_)m=A,g=C,y=P,_=!1,P&&(c.lineStart(),c.point(A,C));else if(P&&w)c.point(A,C);else{var W=[v=Math.max(hf,Math.min(ps,v)),b=Math.max(hf,Math.min(ps,b))],V=[A=Math.max(hf,Math.min(ps,A)),C=Math.max(hf,Math.min(ps,C))];tL(W,V,e,t,n,r)?(w||(c.lineStart(),c.point(W[0],W[1])),c.point(V[0],V[1]),P||c.lineEnd(),k=!1):P&&(c.lineStart(),c.point(A,C),k=!1)}v=A,b=C,w=P}return x}}function u$(e,t,n){var r=nn(e,t-Ae,n).concat(t);return function(i){return r.map(function(a){return[i,a]})}}function c$(e,t,n){var r=nn(e,t-Ae,n).concat(t);return function(i){return r.map(function(a){return[a,i]})}}function nL(){var e,t,n,r,i,a,o,l,s=10,u=s,c=90,f=360,d,h,p,m,g=2.5;function y(){return{type:"MultiLineString",coordinates:v()}}function v(){return nn(Xc(r/c)*c,n,c).map(p).concat(nn(Xc(l/f)*f,o,f).map(m)).concat(nn(Xc(t/s)*s,e,s).filter(function(b){return me(b%c)>Ae}).map(d)).concat(nn(Xc(a/u)*u,i,u).filter(function(b){return me(b%f)>Ae}).map(h))}return y.lines=function(){return v().map(function(b){return{type:"LineString",coordinates:b}})},y.outline=function(){return{type:"Polygon",coordinates:[p(r).concat(m(o).slice(1),p(n).reverse().slice(1),m(l).reverse().slice(1))]}},y.extent=function(b){return arguments.length?y.extentMajor(b).extentMinor(b):y.extentMinor()},y.extentMajor=function(b){return arguments.length?(r=+b[0][0],n=+b[1][0],l=+b[0][1],o=+b[1][1],r>n&&(b=r,r=n,n=b),l>o&&(b=l,l=o,o=b),y.precision(g)):[[r,l],[n,o]]},y.extentMinor=function(b){return arguments.length?(t=+b[0][0],e=+b[1][0],a=+b[0][1],i=+b[1][1],t>e&&(b=t,t=e,e=b),a>i&&(b=a,a=i,i=b),y.precision(g)):[[t,a],[e,i]]},y.step=function(b){return arguments.length?y.stepMajor(b).stepMinor(b):y.stepMinor()},y.stepMajor=function(b){return arguments.length?(c=+b[0],f=+b[1],y):[c,f]},y.stepMinor=function(b){return arguments.length?(s=+b[0],u=+b[1],y):[s,u]},y.precision=function(b){return arguments.length?(g=+b,d=u$(a,i,90),h=c$(t,e,g),p=u$(l,o,90),m=c$(r,n,g),y):g},y.extentMajor([[-180,-90+Ae],[180,90-Ae]]).extentMinor([[-180,-80-Ae],[180,80+Ae]])}var ms=e=>e,Wg=new St,Hg=new St,f$,d$,Gg,Vg,Ri={point:ft,lineStart:ft,lineEnd:ft,polygonStart:function(){Ri.lineStart=rL,Ri.lineEnd=aL},polygonEnd:function(){Ri.lineStart=Ri.lineEnd=Ri.point=ft,Wg.add(me(Hg)),Hg=new St},result:function(){var e=Wg/2;return Wg=new St,e}};function rL(){Ri.point=iL}function iL(e,t){Ri.point=h$,f$=Gg=e,d$=Vg=t}function h$(e,t){Hg.add(Vg*e-Gg*t),Gg=e,Vg=t}function aL(){h$(f$,d$)}var p$=Ri,Ro=1/0,pf=Ro,gs=-Ro,mf=gs,oL={point:lL,lineStart:ft,lineEnd:ft,polygonStart:ft,polygonEnd:ft,result:function(){var e=[[Ro,pf],[gs,mf]];return gs=mf=-(pf=Ro=1/0),e}};function lL(e,t){e<Ro&&(Ro=e),e>gs&&(gs=e),t<pf&&(pf=t),t>mf&&(mf=t)}var gf=oL,Xg=0,Yg=0,ys=0,yf=0,vf=0,To=0,Jg=0,Qg=0,vs=0,m$,g$,mr,gr,jn={point:ba,lineStart:y$,lineEnd:v$,polygonStart:function(){jn.lineStart=cL,jn.lineEnd=fL},polygonEnd:function(){jn.point=ba,jn.lineStart=y$,jn.lineEnd=v$},result:function(){var e=vs?[Jg/vs,Qg/vs]:To?[yf/To,vf/To]:ys?[Xg/ys,Yg/ys]:[NaN,NaN];return Xg=Yg=ys=yf=vf=To=Jg=Qg=vs=0,e}};function ba(e,t){Xg+=e,Yg+=t,++ys}function y$(){jn.point=sL}function sL(e,t){jn.point=uL,ba(mr=e,gr=t)}function uL(e,t){var n=e-mr,r=t-gr,i=Ot(n*n+r*r);yf+=i*(mr+e)/2,vf+=i*(gr+t)/2,To+=i,ba(mr=e,gr=t)}function v$(){jn.point=ba}function cL(){jn.point=dL}function fL(){b$(m$,g$)}function dL(e,t){jn.point=b$,ba(m$=mr=e,g$=gr=t)}function b$(e,t){var n=e-mr,r=t-gr,i=Ot(n*n+r*r);yf+=i*(mr+e)/2,vf+=i*(gr+t)/2,To+=i,i=gr*e-mr*t,Jg+=i*(mr+e),Qg+=i*(gr+t),vs+=i*3,ba(mr=e,gr=t)}var x$=jn;function w$(e){this._context=e}w$.prototype={_radius:4.5,pointRadius:function(e){return this._radius=e,this},polygonStart:function(){this._line=0},polygonEnd:function(){this._line=NaN},lineStart:function(){this._point=0},lineEnd:function(){this._line===0&&this._context.closePath(),this._point=NaN},point:function(e,t){switch(this._point){case 0:this._context.moveTo(e,t),this._point=1;break;case 1:this._context.lineTo(e,t);break;default:this._context.moveTo(e+this._radius,t),this._context.arc(e,t,this._radius,0,Mt);break}},result:ft};var Kg=new St,Zg,_$,k$,bs,xs,bf={point:ft,lineStart:function(){bf.point=hL},lineEnd:function(){Zg&&E$(_$,k$),bf.point=ft},polygonStart:function(){Zg=!0},polygonEnd:function(){Zg=null},result:function(){var e=+Kg;return Kg=new St,e}};function hL(e,t){bf.point=E$,_$=bs=e,k$=xs=t}function E$(e,t){bs-=e,xs-=t,Kg.add(Ot(bs*bs+xs*xs)),bs=e,xs=t}var $$=bf,A$,xf,D$,S$,F$=class{constructor(e){this._append=e==null?C$:pL(e),this._radius=4.5,this._=""}pointRadius(e){return this._radius=+e,this}polygonStart(){this._line=0}polygonEnd(){this._line=NaN}lineStart(){this._point=0}lineEnd(){this._line===0&&(this._+="Z"),this._point=NaN}point(e,t){switch(this._point){case 0:this._append`M${e},${t}`,this._point=1;break;case 1:this._append`L${e},${t}`;break;default:if(this._append`M${e},${t}`,this._radius!==D$||this._append!==xf){let n=this._radius,r=this._;this._="",this._append`m0,${n}a${n},${n} 0 1,1 0,${-2*n}a${n},${n} 0 1,1 0,${2*n}z`,D$=n,xf=this._append,S$=this._,this._=r}this._+=S$;break}}result(){let e=this._;return this._="",e.length?e:null}};function C$(e){let t=1;this._+=e[0];for(let n=e.length;t<n;++t)this._+=arguments[t]+e[t]}function pL(e){let t=Math.floor(e);if(!(t>=0))throw RangeError(`invalid digits: ${e}`);if(t>15)return C$;if(t!==A$){let n=10**t;A$=t,xf=function(r){let i=1;this._+=r[0];for(let a=r.length;i<a;++i)this._+=Math.round(arguments[i]*n)/n+r[i]}}return xf}function M$(e,t){let n=3,r=4.5,i,a;function o(l){return l&&(typeof r=="function"&&a.pointRadius(+r.apply(this,arguments)),jr(l,i(a))),a.result()}return o.area=function(l){return jr(l,i(p$)),p$.result()},o.measure=function(l){return jr(l,i($$)),$$.result()},o.bounds=function(l){return jr(l,i(gf)),gf.result()},o.centroid=function(l){return jr(l,i(x$)),x$.result()},o.projection=function(l){return arguments.length?(i=l==null?(e=null,ms):(e=l).stream,o):e},o.context=function(l){return arguments.length?(a=l==null?(t=null,new F$(n)):new w$(t=l),typeof r!="function"&&a.pointRadius(r),o):t},o.pointRadius=function(l){return arguments.length?(r=typeof l=="function"?l:(a.pointRadius(+l),+l),o):r},o.digits=function(l){if(!arguments.length)return n;if(l==null)n=null;else{let s=Math.floor(l);if(!(s>=0))throw RangeError(`invalid digits: ${l}`);n=s}return t===null&&(a=new F$(n)),o},o.projection(e).digits(n).context(t)}function wf(e){return function(t){var n=new e0;for(var r in e)n[r]=e[r];return n.stream=t,n}}function e0(){}e0.prototype={constructor:e0,point:function(e,t){this.stream.point(e,t)},sphere:function(){this.stream.sphere()},lineStart:function(){this.stream.lineStart()},lineEnd:function(){this.stream.lineEnd()},polygonStart:function(){this.stream.polygonStart()},polygonEnd:function(){this.stream.polygonEnd()}};function t0(e,t,n){var r=e.clipExtent&&e.clipExtent();return e.scale(150).translate([0,0]),r!=null&&e.clipExtent(null),jr(n,e.stream(gf)),t(gf.result()),r!=null&&e.clipExtent(r),e}function _f(e,t,n){return t0(e,function(r){var i=t[1][0]-t[0][0],a=t[1][1]-t[0][1],o=Math.min(i/(r[1][0]-r[0][0]),a/(r[1][1]-r[0][1])),l=+t[0][0]+(i-o*(r[1][0]+r[0][0]))/2,s=+t[0][1]+(a-o*(r[1][1]+r[0][1]))/2;e.scale(150*o).translate([l,s])},n)}function n0(e,t,n){return _f(e,[[0,0],t],n)}function r0(e,t,n){return t0(e,function(r){var i=+t,a=i/(r[1][0]-r[0][0]),o=(i-a*(r[1][0]+r[0][0]))/2,l=-a*r[0][1];e.scale(150*a).translate([o,l])},n)}function i0(e,t,n){return t0(e,function(r){var i=+t,a=i/(r[1][1]-r[0][1]),o=-a*r[0][0],l=(i-a*(r[1][1]+r[0][1]))/2;e.scale(150*a).translate([o,l])},n)}var O$=16,mL=ie(30*ce);function z$(e,t){return+t?yL(e,t):gL(e)}function gL(e){return wf({point:function(t,n){t=e(t,n),this.stream.point(t[0],t[1])}})}function yL(e,t){function n(r,i,a,o,l,s,u,c,f,d,h,p,m,g){var y=u-r,v=c-i,b=y*y+v*v;if(b>4*t&&m--){var w=o+d,_=l+h,k=s+p,x=Ot(w*w+_*_+k*k),E=Vt(k/=x),$=me(me(k)-1)<1e-6||me(a-f)<1e-6?(a+f)/2:En(_,w),D=e($,E),F=D[0],T=D[1],S=F-r,M=T-i,A=v*S-y*M;(A*A/b>t||me((y*S+v*M)/b-.5)>.3||o*d+l*h+s*p<mL)&&(n(r,i,a,o,l,s,F,T,$,w/=x,_/=x,k,m,g),g.point(F,T),n(F,T,$,w,_,k,u,c,f,d,h,p,m,g))}}return function(r){var i,a,o,l,s,u,c,f,d,h,p,m,g={point:y,lineStart:v,lineEnd:w,polygonStart:function(){r.polygonStart(),g.lineStart=_},polygonEnd:function(){r.polygonEnd(),g.lineStart=v}};function y(E,$){E=e(E,$),r.point(E[0],E[1])}function v(){f=NaN,g.point=b,r.lineStart()}function b(E,$){var D=ya([E,$]),F=e(E,$);n(f,d,c,h,p,m,f=F[0],d=F[1],c=E,h=D[0],p=D[1],m=D[2],O$,r),r.point(f,d)}function w(){g.point=y,r.lineEnd()}function _(){v(),g.point=k,g.lineEnd=x}function k(E,$){b(i=E,$),a=f,o=d,l=h,s=p,u=m,g.point=b}function x(){n(f,d,c,h,p,m,a,o,i,l,s,u,O$,r),g.lineEnd=w,w()}return g}}var vL=wf({point:function(e,t){this.stream.point(e*ce,t*ce)}});function bL(e){return wf({point:function(t,n){var r=e(t,n);return this.stream.point(r[0],r[1])}})}function xL(e,t,n,r,i){function a(o,l){return o*=r,l*=i,[t+e*o,n-e*l]}return a.invert=function(o,l){return[(o-t)/e*r,(n-l)/e*i]},a}function N$(e,t,n,r,i,a){if(!a)return xL(e,t,n,r,i);var o=ie(a),l=ne(a),s=o*e,u=l*e,c=o/e,f=l/e,d=(l*n-o*t)/e,h=(l*t+o*n)/e;function p(m,g){return m*=r,g*=i,[s*m-u*g+t,n-u*m-s*g]}return p.invert=function(m,g){return[r*(c*m-f*g+d),i*(h-f*m-c*g)]},p}function yr(e){return R$(function(){return e})()}function R$(e){var t,n=150,r=480,i=250,a=0,o=0,l=0,s=0,u=0,c,f=0,d=1,h=1,p=null,m=l$,g=null,y,v,b,w=ms,_=.5,k,x,E,$,D;function F(A){return E(A[0]*ce,A[1]*ce)}function T(A){return A=E.invert(A[0],A[1]),A&&[A[0]*Xe,A[1]*Xe]}F.stream=function(A){return $&&D===A?$:$=vL(bL(c)(m(k(w(D=A)))))},F.preclip=function(A){return arguments.length?(m=A,p=void 0,M()):m},F.postclip=function(A){return arguments.length?(w=A,g=y=v=b=null,M()):w},F.clipAngle=function(A){return arguments.length?(m=+A?eL(p=A*ce):(p=null,l$),M()):p*Xe},F.clipExtent=function(A){return arguments.length?(w=A==null?(g=y=v=b=null,ms):s$(g=+A[0][0],y=+A[0][1],v=+A[1][0],b=+A[1][1]),M()):g==null?null:[[g,y],[v,b]]},F.scale=function(A){return arguments.length?(n=+A,S()):n},F.translate=function(A){return arguments.length?(r=+A[0],i=+A[1],S()):[r,i]},F.center=function(A){return arguments.length?(a=A[0]%360*ce,o=A[1]%360*ce,S()):[a*Xe,o*Xe]},F.rotate=function(A){return arguments.length?(l=A[0]%360*ce,s=A[1]%360*ce,u=A.length>2?A[2]%360*ce:0,S()):[l*Xe,s*Xe,u*Xe]},F.angle=function(A){return arguments.length?(f=A%360*ce,S()):f*Xe},F.reflectX=function(A){return arguments.length?(d=A?-1:1,S()):d<0},F.reflectY=function(A){return arguments.length?(h=A?-1:1,S()):h<0},F.precision=function(A){return arguments.length?(k=z$(x,_=A*A),M()):Ot(_)},F.fitExtent=function(A,C){return _f(F,A,C)},F.fitSize=function(A,C){return n0(F,A,C)},F.fitWidth=function(A,C){return r0(F,A,C)},F.fitHeight=function(A,C){return i0(F,A,C)};function S(){var A=N$(n,0,0,d,h,f).apply(null,t(a,o)),C=N$(n,r-A[0],i-A[1],d,h,f);return c=KE(l,s,u),x=jg(t,C),E=jg(c,x),k=z$(x,_),M()}function M(){return $=D=null,F}return function(){return t=e.apply(this,arguments),F.invert=t.invert&&T,S()}}function a0(e){var t=0,n=he/3,r=R$(e),i=r(t,n);return i.parallels=function(a){return arguments.length?r(t=a[0]*ce,n=a[1]*ce):[t*Xe,n*Xe]},i}function wL(e){var t=ie(e);function n(r,i){return[r*t,ne(i)/t]}return n.invert=function(r,i){return[r/t,Vt(i*t)]},n}function _L(e,t){var n=ne(e),r=(n+ne(t))/2;if(me(r)<1e-6)return wL(e);var i=1+n*(2*r-n),a=Ot(i)/r;function o(l,s){var u=Ot(i-2*r*ne(s))/r;return[u*ne(l*=r),a-u*ie(l)]}return o.invert=function(l,s){var u=a-s,c=En(l,me(u))*$n(u);return u*r<0&&(c-=he*$n(l)*$n(u)),[c/r,Vt((i-(l*l+u*u)*r*r)/(2*r))]},o}function kf(){return a0(_L).scale(155.424).center([0,33.6442])}function T$(){return kf().parallels([29.5,45.5]).scale(1070).translate([480,250]).rotate([96,0]).center([-.6,38.7])}function kL(e){var t=e.length;return{point:function(n,r){for(var i=-1;++i<t;)e[i].point(n,r)},sphere:function(){for(var n=-1;++n<t;)e[n].sphere()},lineStart:function(){for(var n=-1;++n<t;)e[n].lineStart()},lineEnd:function(){for(var n=-1;++n<t;)e[n].lineEnd()},polygonStart:function(){for(var n=-1;++n<t;)e[n].polygonStart()},polygonEnd:function(){for(var n=-1;++n<t;)e[n].polygonEnd()}}}function EL(){var e,t,n=T$(),r,i=kf().rotate([154,0]).center([-2,58.5]).parallels([55,65]),a,o=kf().rotate([157,0]).center([-3,19.9]).parallels([8,18]),l,s,u={point:function(d,h){s=[d,h]}};function c(d){var h=d[0],p=d[1];return s=null,r.point(h,p),s||(a.point(h,p),s)||(l.point(h,p),s)}c.invert=function(d){var h=n.scale(),p=n.translate(),m=(d[0]-p[0])/h,g=(d[1]-p[1])/h;return(g>=.12&&g<.234&&m>=-.425&&m<-.214?i:g>=.166&&g<.234&&m>=-.214&&m<-.115?o:n).invert(d)},c.stream=function(d){return e&&t===d?e:e=kL([n.stream(t=d),i.stream(d),o.stream(d)])},c.precision=function(d){return arguments.length?(n.precision(d),i.precision(d),o.precision(d),f()):n.precision()},c.scale=function(d){return arguments.length?(n.scale(d),i.scale(d*.35),o.scale(d),c.translate(n.translate())):n.scale()},c.translate=function(d){if(!arguments.length)return n.translate();var h=n.scale(),p=+d[0],m=+d[1];return r=n.translate(d).clipExtent([[p-.455*h,m-.238*h],[p+.455*h,m+.238*h]]).stream(u),a=i.translate([p-.307*h,m+.201*h]).clipExtent([[p-.425*h+Ae,m+.12*h+Ae],[p-.214*h-Ae,m+.234*h-Ae]]).stream(u),l=o.translate([p-.205*h,m+.212*h]).clipExtent([[p-.214*h+Ae,m+.166*h+Ae],[p-.115*h-Ae,m+.234*h-Ae]]).stream(u),f()},c.fitExtent=function(d,h){return _f(c,d,h)},c.fitSize=function(d,h){return n0(c,d,h)},c.fitWidth=function(d,h){return r0(c,d,h)},c.fitHeight=function(d,h){return i0(c,d,h)};function f(){return e=t=null,c}return c.scale(1070)}function L$(e){return function(t,n){var r=ie(t),i=ie(n),a=e(r*i);return a===1/0?[2,0]:[a*i*ne(t),a*ne(n)]}}function ws(e){return function(t,n){var r=Ot(t*t+n*n),i=e(r),a=ne(i),o=ie(i);return[En(t*a,r*o),Vt(r&&n*a/r)]}}var P$=L$(function(e){return Ot(2/(1+e))});P$.invert=ws(function(e){return 2*Vt(e/2)});function $L(){return yr(P$).scale(124.75).clipAngle(179.999)}var B$=L$(function(e){return(e=zE(e))&&e/ne(e)});B$.invert=ws(function(e){return e});function AL(){return yr(B$).scale(79.4188).clipAngle(179.999)}function Ef(e,t){return[e,Yc(Cg((Ue+t)/2))]}Ef.invert=function(e,t){return[e,2*Oo(OE(t))-Ue]};function DL(){return I$(Ef).scale(961/Mt)}function I$(e){var t=yr(e),n=t.center,r=t.scale,i=t.translate,a=t.clipExtent,o=null,l,s,u;t.scale=function(f){return arguments.length?(r(f),c()):r()},t.translate=function(f){return arguments.length?(i(f),c()):i()},t.center=function(f){return arguments.length?(n(f),c()):n()},t.clipExtent=function(f){return arguments.length?(f==null?o=l=s=u=null:(o=+f[0][0],l=+f[0][1],s=+f[1][0],u=+f[1][1]),c()):o==null?null:[[o,l],[s,u]]};function c(){var f=he*r(),d=t(GT(t.rotate()).invert([0,0]));return a(o==null?[[d[0]-f,d[1]-f],[d[0]+f,d[1]+f]]:e===Ef?[[Math.max(d[0]-f,o),l],[Math.min(d[0]+f,s),u]]:[[o,Math.max(d[1]-f,l)],[s,Math.min(d[1]+f,u)]])}return c()}function $f(e){return Cg((Ue+e)/2)}function SL(e,t){var n=ie(e),r=e===t?ne(e):Yc(n/ie(t))/Yc($f(t)/$f(e)),i=n*Fg($f(e),r)/r;if(!r)return Ef;function a(o,l){i>0?l<-Ue+1e-6&&(l=-Ue+Ae):l>Ue-1e-6&&(l=Ue-Ae);var s=i/Fg($f(l),r);return[s*ne(r*o),i-s*ie(r*o)]}return a.invert=function(o,l){var s=i-l,u=$n(r)*Ot(o*o+s*s),c=En(o,me(s))*$n(s);return s*r<0&&(c-=he*$n(o)*$n(s)),[c/r,2*Oo(Fg(i/u,1/r))-Ue]},a}function FL(){return a0(SL).scale(109.5).parallels([30,30])}function Af(e,t){return[e,t]}Af.invert=Af;function CL(){return yr(Af).scale(152.63)}function ML(e,t){var n=ie(e),r=e===t?ne(e):(n-ie(t))/(t-e),i=n/r+e;if(me(r)<1e-6)return Af;function a(o,l){var s=i-l,u=r*o;return[s*ne(u),i-s*ie(u)]}return a.invert=function(o,l){var s=i-l,u=En(o,me(s))*$n(s);return s*r<0&&(u-=he*$n(o)*$n(s)),[u/r,i-$n(r)*Ot(o*o+s*s)]},a}function OL(){return a0(ML).scale(131.154).center([0,13.9389])}var _s=1.340264,ks=-.081106,Es=893e-6,$s=.003796,Df=Ot(3)/2,zL=12;function j$(e,t){var n=Vt(Df*ne(t)),r=n*n,i=r*r*r;return[e*ie(n)/(Df*(_s+3*ks*r+i*(7*Es+9*$s*r))),n*(_s+ks*r+i*(Es+$s*r))]}j$.invert=function(e,t){for(var n=t,r=n*n,i=r*r*r,a=0,o,l,s;a<zL&&(l=n*(_s+ks*r+i*(Es+$s*r))-t,s=_s+3*ks*r+i*(7*Es+9*$s*r),n-=o=l/s,r=n*n,i=r*r*r,!(me(o)<1e-12));++a);return[Df*e*(_s+3*ks*r+i*(7*Es+9*$s*r))/ie(n),Vt(ne(n)/Df)]};function NL(){return yr(j$).scale(177.158)}function q$(e,t){var n=ie(t),r=ie(e)*n;return[n*ne(e)/r,ne(t)/r]}q$.invert=ws(Oo);function RL(){return yr(q$).scale(144.049).clipAngle(60)}function TL(){var e=1,t=0,n=0,r=1,i=1,a=0,o,l,s=null,u,c,f,d=1,h=1,p=wf({point:function(w,_){var k=b([w,_]);this.stream.point(k[0],k[1])}}),m=ms,g,y;function v(){return d=e*r,h=e*i,g=y=null,b}function b(w){var _=w[0]*d,k=w[1]*h;if(a){var x=k*o-_*l;_=_*o+k*l,k=x}return[_+t,k+n]}return b.invert=function(w){var _=w[0]-t,k=w[1]-n;if(a){var x=k*o+_*l;_=_*o-k*l,k=x}return[_/d,k/h]},b.stream=function(w){return g&&y===w?g:g=p(m(y=w))},b.postclip=function(w){return arguments.length?(m=w,s=u=c=f=null,v()):m},b.clipExtent=function(w){return arguments.length?(m=w==null?(s=u=c=f=null,ms):s$(s=+w[0][0],u=+w[0][1],c=+w[1][0],f=+w[1][1]),v()):s==null?null:[[s,u],[c,f]]},b.scale=function(w){return arguments.length?(e=+w,v()):e},b.translate=function(w){return arguments.length?(t=+w[0],n=+w[1],v()):[t,n]},b.angle=function(w){return arguments.length?(a=w%360*ce,l=ne(a),o=ie(a),v()):a*Xe},b.reflectX=function(w){return arguments.length?(r=w?-1:1,v()):r<0},b.reflectY=function(w){return arguments.length?(i=w?-1:1,v()):i<0},b.fitExtent=function(w,_){return _f(b,w,_)},b.fitSize=function(w,_){return n0(b,w,_)},b.fitWidth=function(w,_){return r0(b,w,_)},b.fitHeight=function(w,_){return i0(b,w,_)},b}function U$(e,t){var n=t*t,r=n*n;return[e*(.8707-.131979*n+r*(-.013791+r*(.003971*n-.001529*r))),t*(1.007226+n*(.015085+r*(-.044475+.028874*n-.005916*r)))]}U$.invert=function(e,t){var n=t,r=25,i;do{var a=n*n,o=a*a;n-=i=(n*(1.007226+a*(.015085+o*(-.044475+.028874*a-.005916*o)))-t)/(1.007226+a*(.015085*3+o*(-.044475*7+.028874*9*a-.005916*11*o)))}while(me(i)>1e-6&&--r>0);return[e/(.8707+(a=n*n)*(-.131979+a*(-.013791+a*a*a*(.003971-.001529*a)))),n]};function LL(){return yr(U$).scale(175.295)}function W$(e,t){return[ie(t)*ne(e),ne(t)]}W$.invert=ws(Vt);function PL(){return yr(W$).scale(249.5).clipAngle(90+Ae)}function H$(e,t){var n=ie(t),r=1+ie(e)*n;return[n*ne(e)/r,ne(t)/r]}H$.invert=ws(function(e){return 2*Oo(e)});function BL(){return yr(H$).scale(250).clipAngle(142)}function G$(e,t){return[Yc(Cg((Ue+t)/2)),-e]}G$.invert=function(e,t){return[-t,2*Oo(OE(e))-Ue]};function IL(){var e=I$(G$),t=e.center,n=e.rotate;return e.center=function(r){return arguments.length?t([-r[1],r[0]]):(r=t(),[r[1],-r[0]])},e.rotate=function(r){return arguments.length?n([r[0],r[1],r.length>2?r[2]+90:90]):(r=n(),[r[0],r[1],r[2]-90])},n([0,0,90]).scale(159.155)}var jL=Math.abs,o0=Math.cos,Sf=Math.sin,Lo=Math.PI,l0=Lo/2;Lo/4;var V$=qL(2);Lo*2,180/Lo,Lo/180;function X$(e){return e>1?l0:e<-1?-l0:Math.asin(e)}function qL(e){return e>0?Math.sqrt(e):0}function UL(e,t){var n=e*Sf(t),r=30,i;do t-=i=(t+Sf(t)-n)/(1+o0(t));while(jL(i)>1e-6&&--r>0);return t/2}function WL(e,t,n){function r(i,a){return[e*i*o0(a=UL(n,a)),t*Sf(a)]}return r.invert=function(i,a){return a=X$(a/t),[i/(e*o0(a)),X$((2*a+Sf(2*a))/n)]},r}var HL=WL(V$/l0,V$,Lo);function GL(){return yr(HL).scale(169.529)}var VL=M$(),s0=["clipAngle","clipExtent","scale","translate","center","rotate","parallels","precision","reflectX","reflectY","coefficient","distance","fraction","lobes","parallel","radius","ratio","spacing","tilt"];function XL(e,t){return function n(){let r=t();return r.type=e,r.path=M$().projection(r),r.copy=r.copy||function(){let i=n();return s0.forEach(a=>{r[a]&&i[a](r[a]())}),i.path.pointRadius(r.path.pointRadius()),i},Yw(r)}}function u0(e,t){if(!e||typeof e!="string")throw Error("Projection type must be a name string.");return e=e.toLowerCase(),arguments.length>1?(Ff[e]=XL(e,t),this):Ff[e]||null}function Y$(e){return e&&e.path||VL}var Ff={albers:T$,albersusa:EL,azimuthalequalarea:$L,azimuthalequidistant:AL,conicconformal:FL,conicequalarea:kf,conicequidistant:OL,equalEarth:NL,equirectangular:CL,gnomonic:RL,identity:TL,mercator:DL,mollweide:GL,naturalEarth1:LL,orthographic:PL,stereographic:BL,transversemercator:IL};for(let e in Ff)u0(e,Ff[e]);var YL=Gt({contour:()=>h0,geojson:()=>g0,geopath:()=>y0,geopoint:()=>v0,geoshape:()=>b0,graticule:()=>x0,heatmap:()=>w0,isocontour:()=>c0,kde2d:()=>d0,projection:()=>rA},1);function JL(){}var Wr=[[],[[[1,1.5],[.5,1]]],[[[1.5,1],[1,1.5]]],[[[1.5,1],[.5,1]]],[[[1,.5],[1.5,1]]],[[[1,1.5],[.5,1]],[[1,.5],[1.5,1]]],[[[1,.5],[1,1.5]]],[[[1,.5],[.5,1]]],[[[.5,1],[1,.5]]],[[[1,1.5],[1,.5]]],[[[.5,1],[1,.5]],[[1.5,1],[1,1.5]]],[[[1.5,1],[1,.5]]],[[[.5,1],[1.5,1]]],[[[1,1.5],[1.5,1]]],[[[.5,1],[1,1.5]]],[]];function J$(){var e=1,t=1,n=l;function r(s,u){return u.map(c=>i(s,c))}function i(s,u){var c=[],f=[];return a(s,u,d=>{n(d,s,u),QL(d)>0?c.push([d]):f.push(d)}),f.forEach(d=>{for(var h=0,p=c.length,m;h<p;++h)if(KL((m=c[h])[0],d)!==-1){m.push(d);return}}),{type:"MultiPolygon",value:u,coordinates:c}}function a(s,u,c){var f=[],d=[],h=p=-1,p,m,g=s[0]>=u,y,v;for(Wr[g<<1].forEach(b);++h<e-1;)m=g,g=s[h+1]>=u,Wr[m|g<<1].forEach(b);for(Wr[g<<0].forEach(b);++p<t-1;){for(h=-1,g=s[p*e+e]>=u,y=s[p*e]>=u,Wr[g<<1|y<<2].forEach(b);++h<e-1;)m=g,g=s[p*e+e+h+1]>=u,v=y,y=s[p*e+h+1]>=u,Wr[m|g<<1|y<<2|v<<3].forEach(b);Wr[g|y<<3].forEach(b)}for(h=-1,y=s[p*e]>=u,Wr[y<<2].forEach(b);++h<e-1;)v=y,y=s[p*e+h+1]>=u,Wr[y<<2|v<<3].forEach(b);Wr[y<<3].forEach(b);function b(w){var _=[w[0][0]+h,w[0][1]+p],k=[w[1][0]+h,w[1][1]+p],x=o(_),E=o(k),$,D;($=d[x])?(D=f[E])?(delete d[$.end],delete f[D.start],$===D?($.ring.push(k),c($.ring)):f[$.start]=d[D.end]={start:$.start,end:D.end,ring:$.ring.concat(D.ring)}):(delete d[$.end],$.ring.push(k),d[$.end=E]=$):($=f[E])?(D=d[x])?(delete f[$.start],delete d[D.end],$===D?($.ring.push(k),c($.ring)):f[D.start]=d[$.end]={start:D.start,end:$.end,ring:D.ring.concat($.ring)}):(delete f[$.start],$.ring.unshift(_),f[$.start=x]=$):f[x]=d[E]={start:x,end:E,ring:[_,k]}}}function o(s){return s[0]*2+s[1]*(e+1)*4}function l(s,u,c){s.forEach(f=>{var d=f[0],h=f[1],p=d|0,m=h|0,g,y=u[m*e+p];d>0&&d<e&&p===d&&(g=u[m*e+p-1],f[0]=d+(c-g)/(y-g)-.5),h>0&&h<t&&m===h&&(g=u[(m-1)*e+p],f[1]=h+(c-g)/(y-g)-.5)})}return r.contour=i,r.size=function(s){if(!arguments.length)return[e,t];var u=Math.floor(s[0]),c=Math.floor(s[1]);return u>=0&&c>=0||L("invalid size"),e=u,t=c,r},r.smooth=function(s){return arguments.length?(n=s?l:JL,r):n===l},r}function QL(e){for(var t=0,n=e.length,r=e[n-1][1]*e[0][0]-e[n-1][0]*e[0][1];++t<n;)r+=e[t-1][1]*e[t][0]-e[t-1][0]*e[t][1];return r}function KL(e,t){for(var n=-1,r=t.length,i;++n<r;)if(i=ZL(e,t[n]))return i;return 0}function ZL(e,t){for(var n=t[0],r=t[1],i=-1,a=0,o=e.length,l=o-1;a<o;l=a++){var s=e[a],u=s[0],c=s[1],f=e[l],d=f[0],h=f[1];if(eP(s,f,t))return 0;c>r!=h>r&&n<(d-u)*(r-c)/(h-c)+u&&(i=-i)}return i}function eP(e,t,n){var r;return tP(e,t,n)&&nP(e[r=+(e[0]===t[0])],n[r],t[r])}function tP(e,t,n){return(t[0]-e[0])*(n[1]-e[1])===(n[0]-e[0])*(t[1]-e[1])}function nP(e,t,n){return e<=t&&t<=n||n<=t&&t<=e}function Q$(e,t,n){return function(r){var i=ur(r),a=n?Math.min(i[0],0):i[0],o=i[1],l=o-a,s=t?o2(a,o,e):l/(e+1);return nn(a+s,o,s)}}function c0(e){O.call(this,null,e)}c0.Definition={type:"Isocontour",metadata:{generates:!0},params:[{name:"field",type:"field"},{name:"thresholds",type:"number",array:!0},{name:"levels",type:"number"},{name:"nice",type:"boolean",default:!1},{name:"resolve",type:"enum",values:["shared","independent"],default:"independent"},{name:"zero",type:"boolean",default:!0},{name:"smooth",type:"boolean",default:!0},{name:"scale",type:"number",expr:!0},{name:"translate",type:"number",array:!0,expr:!0},{name:"as",type:"string",null:!0,default:"contour"}]},G(c0,O,{transform(e,t){if(this.value&&!t.changed()&&!e.modified())return t.StopPropagation;var n=t.fork(t.NO_SOURCE|t.NO_FIELDS),r=t.materialize(t.SOURCE).source,i=e.field||bn,a=J$().smooth(e.smooth!==!1),o=e.thresholds||rP(r,i,e),l=e.as===null?null:e.as||"contour",s=[];return r.forEach(u=>{let c=i(u),f=a.size([c.width,c.height])(c.values,N(o)?o:o(c.values));iP(f,c,u,e),f.forEach(d=>{s.push(Hu(u,_e(l==null?d:{[l]:d})))})}),this.value&&(n.rem=this.value),this.value=n.source=n.add=s,n}});function rP(e,t,n){let r=Q$(n.levels||10,n.nice,n.zero!==!1);return n.resolve==="shared"?r(e.map(i=>oa(t(i).values))):r}function iP(e,t,n,r){let i=r.scale||t.scale,a=r.translate||t.translate;if(de(i)&&(i=i(n,r)),de(a)&&(a=a(n,r)),(i===1||i==null)&&!a)return;let o=(we(i)?i:i[0])||1,l=(we(i)?i:i[1])||1,s=a&&a[0]||0,u=a&&a[1]||0;e.forEach(K$(t,o,l,s,u))}function K$(e,t,n,r,i){let a=e.x1||0,o=e.y1||0,l=t*n<0;function s(f){f.forEach(u)}function u(f){l&&f.reverse(),f.forEach(c)}function c(f){f[0]=(f[0]-a)*t+r,f[1]=(f[1]-o)*n+i}return function(f){return f.coordinates.forEach(s),f}}function Z$(e,t,n){let r=e>=0?e:mp(t,n);return Math.round((Math.sqrt(4*r*r+1)-1)/2)}function f0(e){return de(e)?e:At(+e)}function eA(){var e=s=>s[0],t=s=>s[1],n=Ol,r=[-1,-1],i=960,a=500,o=2;function l(s,u){let c=Z$(r[0],s,e)>>o,f=Z$(r[1],s,t)>>o,d=c?c+2:0,h=f?f+2:0,p=2*d+(i>>o),m=2*h+(a>>o),g=new Float32Array(p*m),y=new Float32Array(p*m),v=g;s.forEach(w=>{let _=d+(+e(w)>>o),k=h+(+t(w)>>o);_>=0&&_<p&&k>=0&&k<m&&(g[_+k*p]+=+n(w))}),c>0&&f>0?(Po(p,m,g,y,c),Bo(p,m,y,g,f),Po(p,m,g,y,c),Bo(p,m,y,g,f),Po(p,m,g,y,c),Bo(p,m,y,g,f)):c>0?(Po(p,m,g,y,c),Po(p,m,y,g,c),Po(p,m,g,y,c),v=y):f>0&&(Bo(p,m,g,y,f),Bo(p,m,y,g,f),Bo(p,m,g,y,f),v=y);let b=u?2**(-2*o):1/_2(v);for(let w=0,_=p*m;w<_;++w)v[w]*=b;return{values:v,scale:1<<o,width:p,height:m,x1:d,y1:h,x2:d+(i>>o),y2:h+(a>>o)}}return l.x=function(s){return arguments.length?(e=f0(s),l):e},l.y=function(s){return arguments.length?(t=f0(s),l):t},l.weight=function(s){return arguments.length?(n=f0(s),l):n},l.size=function(s){if(!arguments.length)return[i,a];var u=+s[0],c=+s[1];return u>=0&&c>=0||L("invalid size"),i=u,a=c,l},l.cellSize=function(s){return arguments.length?((s=+s)>=1||L("invalid cell size"),o=Math.floor(Math.log(s)/Math.LN2),l):1<<o},l.bandwidth=function(s){return arguments.length?(s=Q(s),s.length===1&&(s=[+s[0],+s[0]]),s.length!==2&&L("invalid bandwidth"),r=s,l):r},l}function Po(e,t,n,r,i){let a=(i<<1)+1;for(let o=0;o<t;++o)for(let l=0,s=0;l<e+i;++l)l<e&&(s+=n[l+o*e]),l>=i&&(l>=a&&(s-=n[l-a+o*e]),r[l-i+o*e]=s/Math.min(l+1,e-1+a-l,a))}function Bo(e,t,n,r,i){let a=(i<<1)+1;for(let o=0;o<e;++o)for(let l=0,s=0;l<t+i;++l)l<t&&(s+=n[o+l*e]),l>=i&&(l>=a&&(s-=n[o+(l-a)*e]),r[o+(l-i)*e]=s/Math.min(l+1,t-1+a-l,a))}function d0(e){O.call(this,null,e)}d0.Definition={type:"KDE2D",metadata:{generates:!0},params:[{name:"size",type:"number",array:!0,length:2,required:!0},{name:"x",type:"field",required:!0},{name:"y",type:"field",required:!0},{name:"weight",type:"field"},{name:"groupby",type:"field",array:!0},{name:"cellSize",type:"number"},{name:"bandwidth",type:"number",array:!0,length:2},{name:"counts",type:"boolean",default:!1},{name:"as",type:"string",default:"grid"}]};var aP=["x","y","weight","size","cellSize","bandwidth"];function tA(e,t){return aP.forEach(n=>t[n]==null?0:e[n](t[n])),e}G(d0,O,{transform(e,t){if(this.value&&!t.changed()&&!e.modified())return t.StopPropagation;var n=t.fork(t.NO_SOURCE|t.NO_FIELDS),r=t.materialize(t.SOURCE).source,i=oP(r,e.groupby),a=(e.groupby||[]).map(qe),o=tA(eA(),e),l=e.as||"grid",s=[];function u(c,f){for(let d=0;d<a.length;++d)c[a[d]]=f[d];return c}return s=i.map(c=>_e(u({[l]:o(c,e.counts)},c.dims))),this.value&&(n.rem=this.value),this.value=n.source=n.add=s,n}});function oP(e,t){var n=[],r=c=>c(l),i,a,o,l,s,u;if(t==null)n.push(e);else for(i={},a=0,o=e.length;a<o;++a)l=e[a],s=t.map(r),u=i[s],u||(i[s]=u=[],u.dims=s,n.push(u)),u.push(l);return n}function h0(e){O.call(this,null,e)}h0.Definition={type:"Contour",metadata:{generates:!0},params:[{name:"size",type:"number",array:!0,length:2,required:!0},{name:"values",type:"number",array:!0},{name:"x",type:"field"},{name:"y",type:"field"},{name:"weight",type:"field"},{name:"cellSize",type:"number"},{name:"bandwidth",type:"number"},{name:"count",type:"number"},{name:"nice",type:"boolean",default:!1},{name:"thresholds",type:"number",array:!0},{name:"smooth",type:"boolean",default:!0}]},G(h0,O,{transform(e,t){if(this.value&&!t.changed()&&!e.modified())return t.StopPropagation;var n=t.fork(t.NO_SOURCE|t.NO_FIELDS),r=J$().smooth(e.smooth!==!1),i=e.values,a=e.thresholds||Q$(e.count||10,e.nice,!!i),o=e.size,l,s;return i||(i=(i=t.materialize(t.SOURCE).source,l=tA(eA(),e)(i,!0),s=K$(l,l.scale||1,l.scale||1,0,0),o=[l.width,l.height],l.values)),a=N(a)?a:a(i),i=r.size(o)(i,a),s&&i.forEach(s),this.value&&(n.rem=this.value),this.value=n.source=n.add=(i||[]).map(_e),n}});var p0="Feature",m0="FeatureCollection",lP="MultiPoint";function g0(e){O.call(this,null,e)}g0.Definition={type:"GeoJSON",metadata:{},params:[{name:"fields",type:"field",array:!0,length:2},{name:"geojson",type:"field"}]},G(g0,O,{transform(e,t){var n=this._features,r=this._points,i=e.fields,a=i&&i[0],o=i&&i[1],l=e.geojson||!i&&bn,s=t.ADD,u=e.modified()||t.changed(t.REM)||t.modified($t(l))||a&&t.modified($t(a))||o&&t.modified($t(o));(!this.value||u)&&(s=t.SOURCE,this._features=n=[],this._points=r=[]),l&&t.visit(s,c=>n.push(l(c))),a&&o&&(t.visit(s,c=>{var f=a(c),d=o(c);f!=null&&d!=null&&(f=+f)===f&&(d=+d)===d&&r.push([f,d])}),n=n.concat({type:p0,geometry:{type:lP,coordinates:r}})),this.value={type:m0,features:n}}});function y0(e){O.call(this,null,e)}y0.Definition={type:"GeoPath",metadata:{modifies:!0},params:[{name:"projection",type:"projection"},{name:"field",type:"field"},{name:"pointRadius",type:"number",expr:!0},{name:"as",type:"string",default:"path"}]},G(y0,O,{transform(e,t){var n=t.fork(t.ALL),r=this.value,i=e.field||bn,a=e.as||"path",o=n.SOURCE;!r||e.modified()?(this.value=r=Y$(e.projection),n.materialize().reflow()):o=i===bn||t.modified(i.fields)?n.ADD_MOD:n.ADD;let l=sP(r,e.pointRadius);return n.visit(o,s=>s[a]=r(i(s))),r.pointRadius(l),n.modifies(a)}});function sP(e,t){let n=e.pointRadius();return e.context(null),t!=null&&e.pointRadius(t),n}function v0(e){O.call(this,null,e)}v0.Definition={type:"GeoPoint",metadata:{modifies:!0},params:[{name:"projection",type:"projection",required:!0},{name:"fields",type:"field",array:!0,required:!0,length:2},{name:"as",type:"string",array:!0,length:2,default:["x","y"]}]},G(v0,O,{transform(e,t){var n=e.projection,r=e.fields[0],i=e.fields[1],a=e.as||["x","y"],o=a[0],l=a[1],s;function u(c){let f=n([r(c),i(c)]);f?(c[o]=f[0],c[l]=f[1]):(c[o]=void 0,c[l]=void 0)}return e.modified()?t=t.materialize().reflow(!0).visit(t.SOURCE,u):(s=t.modified(r.fields)||t.modified(i.fields),t.visit(s?t.ADD_MOD:t.ADD,u)),t.modifies(a)}});function b0(e){O.call(this,null,e)}b0.Definition={type:"GeoShape",metadata:{modifies:!0,nomod:!0},params:[{name:"projection",type:"projection"},{name:"field",type:"field",default:"datum"},{name:"pointRadius",type:"number",expr:!0},{name:"as",type:"string",default:"shape"}]},G(b0,O,{transform(e,t){var n=t.fork(t.ALL),r=this.value,i=e.as||"shape",a=n.ADD;return(!r||e.modified())&&(this.value=r=uP(Y$(e.projection),e.field||Tr("datum"),e.pointRadius),n.materialize().reflow(),a=n.SOURCE),n.visit(a,o=>o[i]=r),n.modifies(i)}});function uP(e,t,n){let r=n==null?i=>e(t(i)):i=>{var a=e.pointRadius(),o=e.pointRadius(n)(t(i));return e.pointRadius(a),o};return r.context=i=>(e.context(i),r),r}function x0(e){O.call(this,[],e),this.generator=nL()}x0.Definition={type:"Graticule",metadata:{changes:!0,generates:!0},params:[{name:"extent",type:"array",array:!0,length:2,content:{type:"number",array:!0,length:2}},{name:"extentMajor",type:"array",array:!0,length:2,content:{type:"number",array:!0,length:2}},{name:"extentMinor",type:"array",array:!0,length:2,content:{type:"number",array:!0,length:2}},{name:"step",type:"number",array:!0,length:2},{name:"stepMajor",type:"number",array:!0,length:2,default:[90,360]},{name:"stepMinor",type:"number",array:!0,length:2,default:[10,10]},{name:"precision",type:"number",default:2.5}]},G(x0,O,{transform(e,t){var n=this.value,r=this.generator,i;if(!n.length||e.modified())for(let a in e)de(r[a])&&r[a](e[a]);return i=r(),n.length?t.mod.push($2(n[0],i)):t.add.push(_e(i)),n[0]=i,t}});function w0(e){O.call(this,null,e)}w0.Definition={type:"heatmap",metadata:{modifies:!0},params:[{name:"field",type:"field"},{name:"color",type:"string",expr:!0},{name:"opacity",type:"number",expr:!0},{name:"resolve",type:"enum",values:["shared","independent"],default:"independent"},{name:"as",type:"string",default:"image"}]},G(w0,O,{transform(e,t){if(!t.changed()&&!e.modified())return t.StopPropagation;var n=t.materialize(t.SOURCE).source,r=e.resolve==="shared",i=e.field||bn,a=fP(e.opacity,e),o=cP(e.color,e),l=e.as||"image",s={$x:0,$y:0,$value:0,$max:r?oa(n.map(u=>oa(i(u).values))):0};return n.forEach(u=>{let c=i(u),f=pe({},u,s);r||(f.$max=oa(c.values||[])),u[l]=dP(c,f,o.dep?o:At(o(f)),a.dep?a:At(a(f)))}),t.reflow(!0).modifies(l)}});function cP(e,t){let n;return de(e)?(n=r=>Bu(e(r,t)),n.dep=nA(e)):n=At(Bu(e||"#888")),n}function fP(e,t){let n;return de(e)?(n=r=>e(r,t),n.dep=nA(e)):e?n=At(e):(n=r=>r.$value/r.$max||0,n.dep=!0),n}function nA(e){if(!de(e))return!1;let t=sr($t(e));return t.$x||t.$y||t.$value||t.$max}function dP(e,t,n,r){let i=e.width,a=e.height,o=e.x1||0,l=e.y1||0,s=e.x2||i,u=e.y2||a,c=e.values,f=c?g=>c[g]:Hh,d=bi(s-o,u-l),h=d.getContext("2d"),p=h.getImageData(0,0,s-o,u-l),m=p.data;for(let g=l,y=0;g<u;++g){t.$y=g-l;for(let v=o,b=g*i;v<s;++v,y+=4){t.$x=v-o,t.$value=f(v+b);let w=n(t);m[y+0]=w.r,m[y+1]=w.g,m[y+2]=w.b,m[y+3]=~~(255*r(t))}}return h.putImageData(p,0,0),d}function rA(e){O.call(this,null,e),this.modified(!0)}G(rA,O,{transform(e,t){let n=this.value;return!n||e.modified("type")?(this.value=n=pP(e.type),s0.forEach(r=>{e[r]!=null&&iA(n,r,e[r])})):s0.forEach(r=>{e.modified(r)&&iA(n,r,e[r])}),e.pointRadius!=null&&n.path.pointRadius(e.pointRadius),e.fit&&hP(n,e),t.fork(t.NO_SOURCE|t.NO_FIELDS)}});function hP(e,t){let n=mP(t.fit);t.extent?e.fitExtent(t.extent,n):t.size&&e.fitSize(t.size,n)}function pP(e){let t=u0((e||"mercator").toLowerCase());return t||L("Unrecognized projection type: "+e),t()}function iA(e,t,n){de(e[t])&&e[t](n)}function mP(e){return e=Q(e),e.length===1?e[0]:{type:m0,features:e.reduce((t,n)=>t.concat(gP(n)),[])}}function gP(e){return e.type===m0?e.features:Q(e).filter(t=>t!=null).map(t=>t.type===p0?t:{type:p0,geometry:t})}function yP(e,t){var n,r=1;e??(e=0),t??(t=0);function i(){var a,o=n.length,l,s=0,u=0;for(a=0;a<o;++a)l=n[a],s+=l.x,u+=l.y;for(s=(s/o-e)*r,u=(u/o-t)*r,a=0;a<o;++a)l=n[a],l.x-=s,l.y-=u}return i.initialize=function(a){n=a},i.x=function(a){return arguments.length?(e=+a,i):e},i.y=function(a){return arguments.length?(t=+a,i):t},i.strength=function(a){return arguments.length?(r=+a,i):r},i}function vP(e){let t=+this._x.call(null,e),n=+this._y.call(null,e);return aA(this.cover(t,n),t,n,e)}function aA(e,t,n,r){if(isNaN(t)||isNaN(n))return e;var i,a=e._root,o={data:r},l=e._x0,s=e._y0,u=e._x1,c=e._y1,f,d,h,p,m,g,y,v;if(!a)return e._root=o,e;for(;a.length;)if((m=t>=(f=(l+u)/2))?l=f:u=f,(g=n>=(d=(s+c)/2))?s=d:c=d,i=a,!(a=a[y=g<<1|m]))return i[y]=o,e;if(h=+e._x.call(null,a.data),p=+e._y.call(null,a.data),t===h&&n===p)return o.next=a,i?i[y]=o:e._root=o,e;do i=i?i[y]=[,,,,]:e._root=[,,,,],(m=t>=(f=(l+u)/2))?l=f:u=f,(g=n>=(d=(s+c)/2))?s=d:c=d;while((y=g<<1|m)==(v=(p>=d)<<1|h>=f));return i[v]=a,i[y]=o,e}function bP(e){var t,n,r=e.length,i,a,o=Array(r),l=Array(r),s=1/0,u=1/0,c=-1/0,f=-1/0;for(n=0;n<r;++n)isNaN(i=+this._x.call(null,t=e[n]))||isNaN(a=+this._y.call(null,t))||(o[n]=i,l[n]=a,i<s&&(s=i),i>c&&(c=i),a<u&&(u=a),a>f&&(f=a));if(s>c||u>f)return this;for(this.cover(s,u).cover(c,f),n=0;n<r;++n)aA(this,o[n],l[n],e[n]);return this}function xP(e,t){if(isNaN(e=+e)||isNaN(t=+t))return this;var n=this._x0,r=this._y0,i=this._x1,a=this._y1;if(isNaN(n))i=(n=Math.floor(e))+1,a=(r=Math.floor(t))+1;else{for(var o=i-n||1,l=this._root,s,u;n>e||e>=i||r>t||t>=a;)switch(u=(t<r)<<1|e<n,s=[,,,,],s[u]=l,l=s,o*=2,u){case 0:i=n+o,a=r+o;break;case 1:n=i-o,a=r+o;break;case 2:i=n+o,r=a-o;break;case 3:n=i-o,r=a-o;break}this._root&&this._root.length&&(this._root=l)}return this._x0=n,this._y0=r,this._x1=i,this._y1=a,this}function wP(){var e=[];return this.visit(function(t){if(!t.length)do e.push(t.data);while(t=t.next)}),e}function _P(e){return arguments.length?this.cover(+e[0][0],+e[0][1]).cover(+e[1][0],+e[1][1]):isNaN(this._x0)?void 0:[[this._x0,this._y0],[this._x1,this._y1]]}function Tt(e,t,n,r,i){this.node=e,this.x0=t,this.y0=n,this.x1=r,this.y1=i}function kP(e,t,n){var r,i=this._x0,a=this._y0,o,l,s,u,c=this._x1,f=this._y1,d=[],h=this._root,p,m;for(h&&d.push(new Tt(h,i,a,c,f)),n==null?n=1/0:(i=e-n,a=t-n,c=e+n,f=t+n,n*=n);p=d.pop();)if(!(!(h=p.node)||(o=p.x0)>c||(l=p.y0)>f||(s=p.x1)<i||(u=p.y1)<a))if(h.length){var g=(o+s)/2,y=(l+u)/2;d.push(new Tt(h[3],g,y,s,u),new Tt(h[2],o,y,g,u),new Tt(h[1],g,l,s,y),new Tt(h[0],o,l,g,y)),(m=(t>=y)<<1|e>=g)&&(p=d[d.length-1],d[d.length-1]=d[d.length-1-m],d[d.length-1-m]=p)}else{var v=e-+this._x.call(null,h.data),b=t-+this._y.call(null,h.data),w=v*v+b*b;if(w<n){var _=Math.sqrt(n=w);i=e-_,a=t-_,c=e+_,f=t+_,r=h.data}}return r}function EP(e){if(isNaN(c=+this._x.call(null,e))||isNaN(f=+this._y.call(null,e)))return this;var t,n=this._root,r,i,a,o=this._x0,l=this._y0,s=this._x1,u=this._y1,c,f,d,h,p,m,g,y;if(!n)return this;if(n.length)for(;;){if((p=c>=(d=(o+s)/2))?o=d:s=d,(m=f>=(h=(l+u)/2))?l=h:u=h,t=n,!(n=n[g=m<<1|p]))return this;if(!n.length)break;(t[g+1&3]||t[g+2&3]||t[g+3&3])&&(r=t,y=g)}for(;n.data!==e;)if(i=n,!(n=n.next))return this;return(a=n.next)&&delete n.next,i?(a?i.next=a:delete i.next,this):t?(a?t[g]=a:delete t[g],(n=t[0]||t[1]||t[2]||t[3])&&n===(t[3]||t[2]||t[1]||t[0])&&!n.length&&(r?r[y]=n:this._root=n),this):(this._root=a,this)}function $P(e){for(var t=0,n=e.length;t<n;++t)this.remove(e[t]);return this}function AP(){return this._root}function DP(){var e=0;return this.visit(function(t){if(!t.length)do++e;while(t=t.next)}),e}function SP(e){var t=[],n,r=this._root,i,a,o,l,s;for(r&&t.push(new Tt(r,this._x0,this._y0,this._x1,this._y1));n=t.pop();)if(!e(r=n.node,a=n.x0,o=n.y0,l=n.x1,s=n.y1)&&r.length){var u=(a+l)/2,c=(o+s)/2;(i=r[3])&&t.push(new Tt(i,u,c,l,s)),(i=r[2])&&t.push(new Tt(i,a,c,u,s)),(i=r[1])&&t.push(new Tt(i,u,o,l,c)),(i=r[0])&&t.push(new Tt(i,a,o,u,c))}return this}function FP(e){var t=[],n=[],r;for(this._root&&t.push(new Tt(this._root,this._x0,this._y0,this._x1,this._y1));r=t.pop();){var i=r.node;if(i.length){var a,o=r.x0,l=r.y0,s=r.x1,u=r.y1,c=(o+s)/2,f=(l+u)/2;(a=i[0])&&t.push(new Tt(a,o,l,c,f)),(a=i[1])&&t.push(new Tt(a,c,l,s,f)),(a=i[2])&&t.push(new Tt(a,o,f,c,u)),(a=i[3])&&t.push(new Tt(a,c,f,s,u))}n.push(r)}for(;r=n.pop();)e(r.node,r.x0,r.y0,r.x1,r.y1);return this}function CP(e){return e[0]}function MP(e){return arguments.length?(this._x=e,this):this._x}function OP(e){return e[1]}function zP(e){return arguments.length?(this._y=e,this):this._y}function _0(e,t,n){var r=new k0(t??CP,n??OP,NaN,NaN,NaN,NaN);return e==null?r:r.addAll(e)}function k0(e,t,n,r,i,a){this._x=e,this._y=t,this._x0=n,this._y0=r,this._x1=i,this._y1=a,this._root=void 0}function oA(e){for(var t={data:e.data},n=t;e=e.next;)n=n.next={data:e.data};return t}var Lt=_0.prototype=k0.prototype;Lt.copy=function(){var e=new k0(this._x,this._y,this._x0,this._y0,this._x1,this._y1),t=this._root,n,r;if(!t)return e;if(!t.length)return e._root=oA(t),e;for(n=[{source:t,target:e._root=[,,,,]}];t=n.pop();)for(var i=0;i<4;++i)(r=t.source[i])&&(r.length?n.push({source:r,target:t.target[i]=[,,,,]}):t.target[i]=oA(r));return e},Lt.add=vP,Lt.addAll=bP,Lt.cover=xP,Lt.data=wP,Lt.extent=_P,Lt.find=kP,Lt.remove=EP,Lt.removeAll=$P,Lt.root=AP,Lt.size=DP,Lt.visit=SP,Lt.visitAfter=FP,Lt.x=MP,Lt.y=zP;function Pt(e){return function(){return e}}function Ti(e){return(e()-.5)*1e-6}function NP(e){return e.x+e.vx}function RP(e){return e.y+e.vy}function TP(e){var t,n,r,i=1,a=1;typeof e!="function"&&(e=Pt(e==null?1:+e));function o(){for(var u,c=t.length,f,d,h,p,m,g,y=0;y<a;++y)for(f=_0(t,NP,RP).visitAfter(l),u=0;u<c;++u)d=t[u],m=n[d.index],g=m*m,h=d.x+d.vx,p=d.y+d.vy,f.visit(v);function v(b,w,_,k,x){var E=b.data,$=b.r,D=m+$;if(E){if(E.index>d.index){var F=h-E.x-E.vx,T=p-E.y-E.vy,S=F*F+T*T;S<D*D&&(F===0&&(F=Ti(r),S+=F*F),T===0&&(T=Ti(r),S+=T*T),S=(D-(S=Math.sqrt(S)))/S*i,d.vx+=(F*=S)*(D=($*=$)/(g+$)),d.vy+=(T*=S)*D,E.vx-=F*(D=1-D),E.vy-=T*D)}return}return w>h+D||k<h-D||_>p+D||x<p-D}}function l(u){if(u.data)return u.r=n[u.data.index];for(var c=u.r=0;c<4;++c)u[c]&&u[c].r>u.r&&(u.r=u[c].r)}function s(){if(t){var u,c=t.length,f;for(n=Array(c),u=0;u<c;++u)f=t[u],n[f.index]=+e(f,u,t)}}return o.initialize=function(u,c){t=u,r=c,s()},o.iterations=function(u){return arguments.length?(a=+u,o):a},o.strength=function(u){return arguments.length?(i=+u,o):i},o.radius=function(u){return arguments.length?(e=typeof u=="function"?u:Pt(+u),s(),o):e},o}function LP(e){return e.index}function lA(e,t){var n=e.get(t);if(!n)throw Error("node not found: "+t);return n}function PP(e){var t=LP,n=f,r,i=Pt(30),a,o,l,s,u,c=1;e??(e=[]);function f(g){return 1/Math.min(l[g.source.index],l[g.target.index])}function d(g){for(var y=0,v=e.length;y<c;++y)for(var b=0,w,_,k,x,E,$,D;b<v;++b)w=e[b],_=w.source,k=w.target,x=k.x+k.vx-_.x-_.vx||Ti(u),E=k.y+k.vy-_.y-_.vy||Ti(u),$=Math.sqrt(x*x+E*E),$=($-a[b])/$*g*r[b],x*=$,E*=$,k.vx-=x*(D=s[b]),k.vy-=E*D,_.vx+=x*(D=1-D),_.vy+=E*D}function h(){if(o){var g,y=o.length,v=e.length,b=new Map(o.map((_,k)=>[t(_,k,o),_])),w;for(g=0,l=Array(y);g<v;++g)w=e[g],w.index=g,typeof w.source!="object"&&(w.source=lA(b,w.source)),typeof w.target!="object"&&(w.target=lA(b,w.target)),l[w.source.index]=(l[w.source.index]||0)+1,l[w.target.index]=(l[w.target.index]||0)+1;for(g=0,s=Array(v);g<v;++g)w=e[g],s[g]=l[w.source.index]/(l[w.source.index]+l[w.target.index]);r=Array(v),p(),a=Array(v),m()}}function p(){if(o)for(var g=0,y=e.length;g<y;++g)r[g]=+n(e[g],g,e)}function m(){if(o)for(var g=0,y=e.length;g<y;++g)a[g]=+i(e[g],g,e)}return d.initialize=function(g,y){o=g,u=y,h()},d.links=function(g){return arguments.length?(e=g,h(),d):e},d.id=function(g){return arguments.length?(t=g,d):t},d.iterations=function(g){return arguments.length?(c=+g,d):c},d.strength=function(g){return arguments.length?(n=typeof g=="function"?g:Pt(+g),p(),d):n},d.distance=function(g){return arguments.length?(i=typeof g=="function"?g:Pt(+g),m(),d):i},d}var BP=1664525,IP=1013904223,sA=4294967296;function jP(){let e=1;return()=>(e=(BP*e+IP)%sA)/sA}function qP(e){return e.x}function UP(e){return e.y}var WP=10,HP=Math.PI*(3-Math.sqrt(5));function GP(e){var t,n=1,r=.001,i=1-r**(1/300),a=0,o=.6,l=new Map,s=mO(f),u=cO("tick","end"),c=jP();e??(e=[]);function f(){d(),u.call("tick",t),n<r&&(s.stop(),u.call("end",t))}function d(m){var g,y=e.length,v;m===void 0&&(m=1);for(var b=0;b<m;++b)for(n+=(a-n)*i,l.forEach(function(w){w(n)}),g=0;g<y;++g)v=e[g],v.fx==null?v.x+=v.vx*=o:(v.x=v.fx,v.vx=0),v.fy==null?v.y+=v.vy*=o:(v.y=v.fy,v.vy=0);return t}function h(){for(var m=0,g=e.length,y;m<g;++m){if(y=e[m],y.index=m,y.fx!=null&&(y.x=y.fx),y.fy!=null&&(y.y=y.fy),isNaN(y.x)||isNaN(y.y)){var v=WP*Math.sqrt(.5+m),b=m*HP;y.x=v*Math.cos(b),y.y=v*Math.sin(b)}(isNaN(y.vx)||isNaN(y.vy))&&(y.vx=y.vy=0)}}function p(m){return m.initialize&&m.initialize(e,c),m}return h(),t={tick:d,restart:function(){return s.restart(f),t},stop:function(){return s.stop(),t},nodes:function(m){return arguments.length?(e=m,h(),l.forEach(p),t):e},alpha:function(m){return arguments.length?(n=+m,t):n},alphaMin:function(m){return arguments.length?(r=+m,t):r},alphaDecay:function(m){return arguments.length?(i=+m,t):+i},alphaTarget:function(m){return arguments.length?(a=+m,t):a},velocityDecay:function(m){return arguments.length?(o=1-m,t):1-o},randomSource:function(m){return arguments.length?(c=m,l.forEach(p),t):c},force:function(m,g){return arguments.length>1?(g==null?l.delete(m):l.set(m,p(g)),t):l.get(m)},find:function(m,g,y){var v=0,b=e.length,w,_,k,x,E;for(y==null?y=1/0:y*=y,v=0;v<b;++v)x=e[v],w=m-x.x,_=g-x.y,k=w*w+_*_,k<y&&(E=x,y=k);return E},on:function(m,g){return arguments.length>1?(u.on(m,g),t):u.on(m)}}}function VP(){var e,t,n,r,i=Pt(-30),a,o=1,l=1/0,s=.81;function u(h){var p,m=e.length,g=_0(e,qP,UP).visitAfter(f);for(r=h,p=0;p<m;++p)t=e[p],g.visit(d)}function c(){if(e){var h,p=e.length,m;for(a=Array(p),h=0;h<p;++h)m=e[h],a[m.index]=+i(m,h,e)}}function f(h){var p=0,m,g,y=0,v,b,w;if(h.length){for(v=b=w=0;w<4;++w)(m=h[w])&&(g=Math.abs(m.value))&&(p+=m.value,y+=g,v+=g*m.x,b+=g*m.y);h.x=v/y,h.y=b/y}else{m=h,m.x=m.data.x,m.y=m.data.y;do p+=a[m.data.index];while(m=m.next)}h.value=p}function d(h,p,m,g){if(!h.value)return!0;var y=h.x-t.x,v=h.y-t.y,b=g-p,w=y*y+v*v;if(b*b/s<w)return w<l&&(y===0&&(y=Ti(n),w+=y*y),v===0&&(v=Ti(n),w+=v*v),w<o&&(w=Math.sqrt(o*w)),t.vx+=y*h.value*r/w,t.vy+=v*h.value*r/w),!0;if(!(h.length||w>=l)){(h.data!==t||h.next)&&(y===0&&(y=Ti(n),w+=y*y),v===0&&(v=Ti(n),w+=v*v),w<o&&(w=Math.sqrt(o*w)));do h.data!==t&&(b=a[h.data.index]*r/w,t.vx+=y*b,t.vy+=v*b);while(h=h.next)}}return u.initialize=function(h,p){e=h,n=p,c()},u.strength=function(h){return arguments.length?(i=typeof h=="function"?h:Pt(+h),c(),u):i},u.distanceMin=function(h){return arguments.length?(o=h*h,u):Math.sqrt(o)},u.distanceMax=function(h){return arguments.length?(l=h*h,u):Math.sqrt(l)},u.theta=function(h){return arguments.length?(s=h*h,u):Math.sqrt(s)},u}function XP(e){var t=Pt(.1),n,r,i;typeof e!="function"&&(e=Pt(e==null?0:+e));function a(l){for(var s=0,u=n.length,c;s<u;++s)c=n[s],c.vx+=(i[s]-c.x)*r[s]*l}function o(){if(n){var l,s=n.length;for(r=Array(s),i=Array(s),l=0;l<s;++l)r[l]=isNaN(i[l]=+e(n[l],l,n))?0:+t(n[l],l,n)}}return a.initialize=function(l){n=l,o()},a.strength=function(l){return arguments.length?(t=typeof l=="function"?l:Pt(+l),o(),a):t},a.x=function(l){return arguments.length?(e=typeof l=="function"?l:Pt(+l),o(),a):e},a}function YP(e){var t=Pt(.1),n,r,i;typeof e!="function"&&(e=Pt(e==null?0:+e));function a(l){for(var s=0,u=n.length,c;s<u;++s)c=n[s],c.vy+=(i[s]-c.y)*r[s]*l}function o(){if(n){var l,s=n.length;for(r=Array(s),i=Array(s),l=0;l<s;++l)r[l]=isNaN(i[l]=+e(n[l],l,n))?0:+t(n[l],l,n)}}return a.initialize=function(l){n=l,o()},a.strength=function(l){return arguments.length?(t=typeof l=="function"?l:Pt(+l),o(),a):t},a.y=function(l){return arguments.length?(e=typeof l=="function"?l:Pt(+l),o(),a):e},a}var JP=Gt({force:()=>$0},1),uA={center:yP,collide:TP,nbody:VP,link:PP,x:XP,y:YP},As="forces",E0=["alpha","alphaMin","alphaTarget","velocityDecay","forces"],QP=["static","iterations"],cA=["x","y","vx","vy"];function $0(e){O.call(this,null,e)}$0.Definition={type:"Force",metadata:{modifies:!0},params:[{name:"static",type:"boolean",default:!1},{name:"restart",type:"boolean",default:!1},{name:"iterations",type:"number",default:300},{name:"alpha",type:"number",default:1},{name:"alphaMin",type:"number",default:.001},{name:"alphaTarget",type:"number",default:0},{name:"velocityDecay",type:"number",default:.4},{name:"forces",type:"param",array:!0,params:[{key:{force:"center"},params:[{name:"x",type:"number",default:0},{name:"y",type:"number",default:0}]},{key:{force:"collide"},params:[{name:"radius",type:"number",expr:!0},{name:"strength",type:"number",default:.7},{name:"iterations",type:"number",default:1}]},{key:{force:"nbody"},params:[{name:"strength",type:"number",default:-30,expr:!0},{name:"theta",type:"number",default:.9},{name:"distanceMin",type:"number",default:1},{name:"distanceMax",type:"number"}]},{key:{force:"link"},params:[{name:"links",type:"data"},{name:"id",type:"field"},{name:"distance",type:"number",default:30,expr:!0},{name:"strength",type:"number",expr:!0},{name:"iterations",type:"number",default:1}]},{key:{force:"x"},params:[{name:"strength",type:"number",default:.1},{name:"x",type:"field"}]},{key:{force:"y"},params:[{name:"strength",type:"number",default:.1},{name:"y",type:"field"}]}]},{name:"as",type:"string",array:!0,modify:!1,default:cA}]},G($0,O,{transform(e,t){var n=this.value,r=t.changed(t.ADD_REM),i=e.modified(E0),a=e.iterations||300;if(n?(r&&(t.modifies("index"),n.nodes(t.source)),(i||t.changed(t.MOD))&&fA(n,e,0,t)):(this.value=n=ZP(t.source,e),n.on("tick",KP(t.dataflow,this)),e.static||(r=!0,n.tick()),t.modifies("index")),i||r||e.modified(QP)||t.changed()&&e.restart){if(n.alpha(Math.max(n.alpha(),e.alpha||1)).alphaDecay(1-n.alphaMin()**(1/a)),e.static)for(n.stop();--a>=0;)n.tick();else if(n.stopped()&&n.restart(),!r)return t.StopPropagation}return this.finish(e,t)},finish(e,t){let n=t.dataflow;for(let l=this._argops,s=0,u=l.length,c;s<u;++s)if(c=l[s],!(c.name!==As||c.op._argval.force!=="link")){for(var r=c.op._argops,i=0,a=r.length,o;i<a;++i)if(r[i].name==="links"&&(o=r[i].op.source)){n.pulse(o,n.changeset().reflow());break}}return t.reflow(e.modified()).modifies(cA)}});function KP(e,t){return()=>e.touch(t).run()}function ZP(e,t){let n=GP(e),r=n.stop,i=n.restart,a=!1;return n.stopped=()=>a,n.restart=()=>(a=!1,i()),n.stop=()=>(a=!0,r()),fA(n,t,!0).on("end",()=>a=!0)}function fA(e,t,n,r){var i=Q(t.forces),a,o,l,s;for(a=0,o=E0.length;a<o;++a)l=E0[a],l!==As&&t.modified(l)&&e[l](t[l]);for(a=0,o=i.length;a<o;++a)s=As+a,l=n||t.modified(As,a)?tB(i[a]):r&&eB(i[a],r)?e.force(s):null,l&&e.force(s,l);for(o=e.numForces||0;a<o;++a)e.force(As+a,null);return e.numForces=i.length,e}function eB(e,t){var n,r;for(n in e)if(de(r=e[n])&&t.modified($t(r)))return 1;return 0}function tB(e){var t,n;for(n in K(uA,e.force)||L("Unrecognized force: "+e.force),t=uA[e.force](),e)de(t[n])&&nB(t[n],e[n],e);return t}function nB(e,t,n){e(de(t)?r=>t(r,n):t)}function rB(e,t){return e.parent===t.parent?1:2}function iB(e){return e.reduce(aB,0)/e.length}function aB(e,t){return e+t.x}function oB(e){return 1+e.reduce(lB,0)}function lB(e,t){return Math.max(e,t.y)}function sB(e){for(var t;t=e.children;)e=t[0];return e}function uB(e){for(var t;t=e.children;)e=t[t.length-1];return e}function cB(){var e=rB,t=1,n=1,r=!1;function i(a){var o,l=0;a.eachAfter(function(d){var h=d.children;h?(d.x=iB(h),d.y=oB(h)):(d.x=o?l+=e(d,o):0,d.y=0,o=d)});var s=sB(a),u=uB(a),c=s.x-e(s,u)/2,f=u.x+e(u,s)/2;return a.eachAfter(r?function(d){d.x=(d.x-a.x)*t,d.y=(a.y-d.y)*n}:function(d){d.x=(d.x-c)/(f-c)*t,d.y=(1-(a.y?d.y/a.y:1))*n})}return i.separation=function(a){return arguments.length?(e=a,i):e},i.size=function(a){return arguments.length?(r=!1,t=+a[0],n=+a[1],i):r?null:[t,n]},i.nodeSize=function(a){return arguments.length?(r=!0,t=+a[0],n=+a[1],i):r?[t,n]:null},i}var fB=1664525,dB=1013904223,dA=4294967296;function hB(){let e=1;return()=>(e=(fB*e+dB)%dA)/dA}function pB(e){return typeof e=="object"&&"length"in e?e:Array.from(e)}function mB(e,t){let n=e.length,r,i;for(;n;)i=t()*n--|0,r=e[n],e[n]=e[i],e[i]=r;return e}function gB(e,t){for(var n=0,r=(e=mB(Array.from(e),t)).length,i=[],a,o;n<r;)a=e[n],o&&hA(o,a)?++n:(o=vB(i=yB(i,a)),n=0);return o}function yB(e,t){var n,r;if(A0(t,e))return[t];for(n=0;n<e.length;++n)if(Cf(t,e[n])&&A0(Ds(e[n],t),e))return[e[n],t];for(n=0;n<e.length-1;++n)for(r=n+1;r<e.length;++r)if(Cf(Ds(e[n],e[r]),t)&&Cf(Ds(e[n],t),e[r])&&Cf(Ds(e[r],t),e[n])&&A0(pA(e[n],e[r],t),e))return[e[n],e[r],t];throw Error()}function Cf(e,t){var n=e.r-t.r,r=t.x-e.x,i=t.y-e.y;return n<0||n*n<r*r+i*i}function hA(e,t){var n=e.r-t.r+Math.max(e.r,t.r,1)*1e-9,r=t.x-e.x,i=t.y-e.y;return n>0&&n*n>r*r+i*i}function A0(e,t){for(var n=0;n<t.length;++n)if(!hA(e,t[n]))return!1;return!0}function vB(e){switch(e.length){case 1:return bB(e[0]);case 2:return Ds(e[0],e[1]);case 3:return pA(e[0],e[1],e[2])}}function bB(e){return{x:e.x,y:e.y,r:e.r}}function Ds(e,t){var n=e.x,r=e.y,i=e.r,a=t.x,o=t.y,l=t.r,s=a-n,u=o-r,c=l-i,f=Math.sqrt(s*s+u*u);return{x:(n+a+s/f*c)/2,y:(r+o+u/f*c)/2,r:(f+i+l)/2}}function pA(e,t,n){var r=e.x,i=e.y,a=e.r,o=t.x,l=t.y,s=t.r,u=n.x,c=n.y,f=n.r,d=r-o,h=r-u,p=i-l,m=i-c,g=s-a,y=f-a,v=r*r+i*i-a*a,b=v-o*o-l*l+s*s,w=v-u*u-c*c+f*f,_=h*p-d*m,k=(p*w-m*b)/(_*2)-r,x=(m*g-p*y)/_,E=(h*b-d*w)/(_*2)-i,$=(d*y-h*g)/_,D=x*x+$*$-1,F=2*(a+k*x+E*$),T=k*k+E*E-a*a,S=-(Math.abs(D)>1e-6?(F+Math.sqrt(F*F-4*D*T))/(2*D):T/F);return{x:r+k+x*S,y:i+E+$*S,r:S}}function mA(e,t,n){var r=e.x-t.x,i,a,o=e.y-t.y,l,s,u=r*r+o*o;u?(a=t.r+n.r,a*=a,s=e.r+n.r,s*=s,a>s?(i=(u+s-a)/(2*u),l=Math.sqrt(Math.max(0,s/u-i*i)),n.x=e.x-i*r-l*o,n.y=e.y-i*o+l*r):(i=(u+a-s)/(2*u),l=Math.sqrt(Math.max(0,a/u-i*i)),n.x=t.x+i*r-l*o,n.y=t.y+i*o+l*r)):(n.x=t.x+n.r,n.y=t.y)}function gA(e,t){var n=e.r+t.r-1e-6,r=t.x-e.x,i=t.y-e.y;return n>0&&n*n>r*r+i*i}function yA(e){var t=e._,n=e.next._,r=t.r+n.r,i=(t.x*n.r+n.x*t.r)/r,a=(t.y*n.r+n.y*t.r)/r;return i*i+a*a}function Mf(e){this._=e,this.next=null,this.previous=null}function xB(e,t){if(!(a=(e=pB(e)).length))return 0;var n=e[0],r,i,a,o,l,s,u,c,f,d;if(n.x=0,n.y=0,!(a>1))return n.r;if(r=e[1],n.x=-r.r,r.x=n.r,r.y=0,!(a>2))return n.r+r.r;mA(r,n,i=e[2]),n=new Mf(n),r=new Mf(r),i=new Mf(i),n.next=i.previous=r,r.next=n.previous=i,i.next=r.previous=n;e:for(s=3;s<a;++s){mA(n._,r._,i=e[s]),i=new Mf(i),u=r.next,c=n.previous,f=r._.r,d=n._.r;do if(f<=d){if(gA(u._,i._)){r=u,n.next=r,r.previous=n,--s;continue e}f+=u._.r,u=u.next}else{if(gA(c._,i._)){n=c,n.next=r,r.previous=n,--s;continue e}d+=c._.r,c=c.previous}while(u!==c.next);for(i.previous=n,i.next=r,n.next=r.previous=r=i,o=yA(n);(i=i.next)!==r;)(l=yA(i))<o&&(n=i,o=l);r=n.next}for(n=[r._],i=r;(i=i.next)!==r;)n.push(i._);for(i=gB(n,t),s=0;s<a;++s)n=e[s],n.x-=i.x,n.y-=i.y;return i.r}function wB(e){return Math.sqrt(e.value)}function _B(){var e=null,t=1,n=1,r=m2;function i(a){let o=hB();return a.x=t/2,a.y=n/2,e?a.eachBefore(vA(e)).eachAfter(D0(r,.5,o)).eachBefore(bA(1)):a.eachBefore(vA(wB)).eachAfter(D0(m2,1,o)).eachAfter(D0(r,a.r/Math.min(t,n),o)).eachBefore(bA(Math.min(t,n)/(2*a.r))),a}return i.radius=function(a){return arguments.length?(e=ju(a),i):e},i.size=function(a){return arguments.length?(t=+a[0],n=+a[1],i):[t,n]},i.padding=function(a){return arguments.length?(r=typeof a=="function"?a:WO(+a),i):r},i}function vA(e){return function(t){t.children||(t.r=Math.max(0,+e(t)||0))}}function D0(e,t,n){return function(r){if(i=r.children){var i,a,o=i.length,l=e(r)*t||0,s;if(l)for(a=0;a<o;++a)i[a].r+=l;if(s=xB(i,n),l)for(a=0;a<o;++a)i[a].r-=l;r.r=s+l}}}function bA(e){return function(t){var n=t.parent;t.r*=e,n&&(t.x=n.x+e*t.x,t.y=n.y+e*t.y)}}function kB(){var e=1,t=1,n=0,r=!1;function i(o){var l=o.height+1;return o.x0=o.y0=n,o.x1=e,o.y1=t/l,o.eachBefore(a(t,l)),r&&o.eachBefore(XO),o}function a(o,l){return function(s){s.children&&Iu(s,s.x0,o*(s.depth+1)/l,s.x1,o*(s.depth+2)/l);var u=s.x0,c=s.y0,f=s.x1-n,d=s.y1-n;f<u&&(u=f=(u+f)/2),d<c&&(c=d=(c+d)/2),s.x0=u,s.y0=c,s.x1=f,s.y1=d}}return i.round=function(o){return arguments.length?(r=!!o,i):r},i.size=function(o){return arguments.length?(e=+o[0],t=+o[1],i):[e,t]},i.padding=function(o){return arguments.length?(n=+o,i):n},i}var EB={depth:-1},xA={},S0={};function $B(e){return e.id}function AB(e){return e.parentId}function wA(){var e=$B,t=AB,n;function r(i){var a=Array.from(i),o=e,l=t,s,u,c,f,d,h,p,m,g=new Map;if(n!=null){let y=a.map((w,_)=>DB(n(w,_,i))),v=y.map(_A),b=new Set(y).add("");for(let w of v)b.has(w)||(b.add(w),y.push(w),v.push(_A(w)),a.push(S0));o=(w,_)=>y[_],l=(w,_)=>v[_]}for(c=0,s=a.length;c<s;++c)u=a[c],h=a[c]=new g2(u),(p=o(u,c,i))!=null&&(p+="")&&(m=h.id=p,g.set(m,g.has(m)?xA:h)),(p=l(u,c,i))!=null&&(p+="")&&(h.parent=p);for(c=0;c<s;++c)if(h=a[c],p=h.parent){if(d=g.get(p),!d)throw Error("missing: "+p);if(d===xA)throw Error("ambiguous: "+p);d.children?d.children.push(h):d.children=[h],h.parent=d}else{if(f)throw Error("multiple roots");f=h}if(!f)throw Error("no root");if(n!=null){for(;f.data===S0&&f.children.length===1;)f=f.children[0],--s;for(let y=a.length-1;y>=0&&(h=a[y],h.data===S0);--y)h.data=null}if(f.parent=EB,f.eachBefore(function(y){y.depth=y.parent.depth+1,--s}).eachBefore(qO),f.parent=null,s>0)throw Error("cycle");return f}return r.id=function(i){return arguments.length?(e=ju(i),r):e},r.parentId=function(i){return arguments.length?(t=ju(i),r):t},r.path=function(i){return arguments.length?(n=ju(i),r):n},r}function DB(e){e=`${e}`;let t=e.length;return F0(e,t-1)&&!F0(e,t-2)&&(e=e.slice(0,-1)),e[0]==="/"?e:`/${e}`}function _A(e){let t=e.length;if(t<2)return"";for(;--t>1&&!F0(e,t););return e.slice(0,t)}function F0(e,t){if(e[t]==="/"){let n=0;for(;t>0&&e[--t]==="\\";)++n;if(!(n&1))return!0}return!1}function SB(e,t){return e.parent===t.parent?1:2}function C0(e){var t=e.children;return t?t[0]:e.t}function M0(e){var t=e.children;return t?t[t.length-1]:e.t}function FB(e,t,n){var r=n/(t.i-e.i);t.c-=r,t.s+=n,e.c+=r,t.z+=n,t.m+=n}function CB(e){for(var t=0,n=0,r=e.children,i=r.length,a;--i>=0;)a=r[i],a.z+=t,a.m+=t,t+=a.s+(n+=a.c)}function MB(e,t,n){return e.a.parent===t.parent?e.a:n}function Of(e,t){this._=e,this.parent=null,this.children=null,this.A=null,this.a=this,this.z=0,this.m=0,this.c=0,this.s=0,this.t=null,this.i=t}Of.prototype=Object.create(g2.prototype);function OB(e){for(var t=new Of(e,0),n,r=[t],i,a,o,l;n=r.pop();)if(a=n._.children)for(n.children=Array(l=a.length),o=l-1;o>=0;--o)r.push(i=n.children[o]=new Of(a[o],o)),i.parent=n;return(t.parent=new Of(null,0)).children=[t],t}function zB(){var e=SB,t=1,n=1,r=null;function i(u){var c=OB(u);if(c.eachAfter(a),c.parent.m=-c.z,c.eachBefore(o),r)u.eachBefore(s);else{var f=u,d=u,h=u;u.eachBefore(function(v){v.x<f.x&&(f=v),v.x>d.x&&(d=v),v.depth>h.depth&&(h=v)});var p=f===d?1:e(f,d)/2,m=p-f.x,g=t/(d.x+p+m),y=n/(h.depth||1);u.eachBefore(function(v){v.x=(v.x+m)*g,v.y=v.depth*y})}return u}function a(u){var c=u.children,f=u.parent.children,d=u.i?f[u.i-1]:null;if(c){CB(u);var h=(c[0].z+c[c.length-1].z)/2;d?(u.z=d.z+e(u._,d._),u.m=u.z-h):u.z=h}else d&&(u.z=d.z+e(u._,d._));u.parent.A=l(u,d,u.parent.A||f[0])}function o(u){u._.x=u.z+u.parent.m,u.m+=u.parent.m}function l(u,c,f){if(c){for(var d=u,h=u,p=c,m=d.parent.children[0],g=d.m,y=h.m,v=p.m,b=m.m,w;p=M0(p),d=C0(d),p&&d;)m=C0(m),h=M0(h),h.a=u,w=p.z+v-d.z-g+e(p._,d._),w>0&&(FB(MB(p,u,f),u,w),g+=w,y+=w),v+=p.m,g+=d.m,b+=m.m,y+=h.m;p&&!M0(h)&&(h.t=p,h.m+=v-y),d&&!C0(m)&&(m.t=d,m.m+=g-b,f=u)}return f}function s(u){u.x*=t,u.y=u.depth*n}return i.separation=function(u){return arguments.length?(e=u,i):e},i.size=function(u){return arguments.length?(r=!1,t=+u[0],n=+u[1],i):r?null:[t,n]},i.nodeSize=function(u){return arguments.length?(r=!0,t=+u[0],n=+u[1],i):r?[t,n]:null},i}function NB(e,t,n,r,i){var a=e.children,o,l=a.length,s,u=Array(l+1);for(u[0]=s=o=0;o<l;++o)u[o+1]=s+=a[o].value;c(0,l,e.value,t,n,r,i);function c(f,d,h,p,m,g,y){if(f>=d-1){var v=a[f];v.x0=p,v.y0=m,v.x1=g,v.y1=y;return}for(var b=u[f],w=h/2+b,_=f+1,k=d-1;_<k;){var x=_+k>>>1;u[x]<w?_=x+1:k=x}w-u[_-1]<u[_]-w&&f+1<_&&--_;var E=u[_]-b,$=h-E;if(g-p>y-m){var D=h?(p*$+g*E)/h:g;c(f,_,E,p,m,D,y),c(_,d,$,D,m,g,y)}else{var F=h?(m*$+y*E)/h:y;c(f,_,E,p,m,g,F),c(_,d,$,p,F,g,y)}}}function RB(e,t,n,r,i){(e.depth&1?op:Iu)(e,t,n,r,i)}var TB=(function e(t){function n(r,i,a,o,l){if((s=r._squarify)&&s.ratio===t)for(var s,u,c,f,d=-1,h,p=s.length,m=r.value;++d<p;){for(u=s[d],c=u.children,f=u.value=0,h=c.length;f<h;++f)u.value+=c[f].value;u.dice?Iu(u,i,a,o,m?a+=(l-a)*u.value/m:l):op(u,i,a,m?i+=(o-i)*u.value/m:o,l),m-=u.value}else r._squarify=s=VO(t,r,i,a,o,l),s.ratio=t}return n.ratio=function(r){return e((r=+r)>1?r:1)},n})(HO),LB=Gt({nest:()=>z0,pack:()=>R0,partition:()=>L0,stratify:()=>P0,tree:()=>I0,treelinks:()=>j0,treemap:()=>U0},1);function O0(e,t,n){let r={};return e.each(i=>{let a=i.data;n(a)&&(r[t(a)]=i)}),e.lookup=r,e}function z0(e){O.call(this,null,e)}z0.Definition={type:"Nest",metadata:{treesource:!0,changes:!0},params:[{name:"keys",type:"field",array:!0},{name:"generate",type:"boolean"}]};var PB=e=>e.values;G(z0,O,{transform(e,t){t.source||L("Nest transform requires an upstream data source.");var n=e.generate,r=e.modified(),i=t.clone(),a=this.value;return(!a||r||t.changed())&&(a&&a.each(o=>{o.children&&Wu(o.data)&&i.rem.push(o.data)}),this.value=a=GO({values:Q(e.keys).reduce((o,l)=>(o.key(l),o),BB()).entries(i.source)},PB),n&&a.each(o=>{o.children&&(o=_e(o.data),i.add.push(o),i.source.push(o))}),O0(a,te,te)),i.source.root=a,i}});function BB(){let e=[],t={entries:i=>r(n(i,0),0),key:i=>(e.push(i),t)};function n(i,a){if(a>=e.length)return i;let o=i.length,l=e[a++],s={},u={},c=-1,f,d,h;for(;++c<o;)f=l(d=i[c])+"",(h=s[f])?h.push(d):s[f]=[d];for(f in s)u[f]=n(s[f],a);return u}function r(i,a){if(++a>e.length)return i;let o=[];for(let l in i)o.push({key:l,values:r(i[l],a)});return o}return t}function Hr(e){O.call(this,null,e)}var IB=(e,t)=>e.parent===t.parent?1:2;G(Hr,O,{transform(e,t){(!t.source||!t.source.root)&&L(this.constructor.name+" transform requires a backing tree data source.");let n=this.layout(e.method),r=this.fields,i=t.source.root,a=e.as||r;e.field?i.sum(e.field):i.count(),e.sort&&i.sort(sa(e.sort,o=>o.data)),jB(n,this.params,e),n.separation&&n.separation(e.separation===!1?Ol:IB);try{this.value=n(i)}catch(o){L(o)}return i.each(o=>qB(o,r,a)),t.reflow(e.modified()).modifies(a).modifies("leaf")}});function jB(e,t,n){for(let r,i=0,a=t.length;i<a;++i)r=t[i],r in n&&e[r](n[r])}function qB(e,t,n){let r=e.data,i=t.length-1;for(let a=0;a<i;++a)r[n[a]]=e[t[a]];r[n[i]]=e.children?e.children.length:0}var N0=["x","y","r","depth","children"];function R0(e){Hr.call(this,e)}R0.Definition={type:"Pack",metadata:{tree:!0,modifies:!0},params:[{name:"field",type:"field"},{name:"sort",type:"compare"},{name:"padding",type:"number",default:0},{name:"radius",type:"field",default:null},{name:"size",type:"number",array:!0,length:2},{name:"as",type:"string",array:!0,length:N0.length,default:N0}]},G(R0,Hr,{layout:_B,params:["radius","size","padding"],fields:N0});var T0=["x0","y0","x1","y1","depth","children"];function L0(e){Hr.call(this,e)}L0.Definition={type:"Partition",metadata:{tree:!0,modifies:!0},params:[{name:"field",type:"field"},{name:"sort",type:"compare"},{name:"padding",type:"number",default:0},{name:"round",type:"boolean",default:!1},{name:"size",type:"number",array:!0,length:2},{name:"as",type:"string",array:!0,length:T0.length,default:T0}]},G(L0,Hr,{layout:kB,params:["size","round","padding"],fields:T0});function P0(e){O.call(this,null,e)}P0.Definition={type:"Stratify",metadata:{treesource:!0},params:[{name:"key",type:"field",required:!0},{name:"parentKey",type:"field",required:!0}]},G(P0,O,{transform(e,t){t.source||L("Stratify transform requires an upstream data source.");let n=this.value,r=e.modified(),i=t.fork(t.ALL).materialize(t.SOURCE),a=!n||r||t.changed(t.ADD_REM)||t.modified(e.key.fields)||t.modified(e.parentKey.fields);return i.source=i.source.slice(),a&&(n=i.source.length?O0(wA().id(e.key).parentId(e.parentKey)(i.source),e.key,yn):O0(wA()([{}]),e.key,e.key)),i.source.root=this.value=n,i}});var kA={tidy:zB,cluster:cB},B0=["x","y","depth","children"];function I0(e){Hr.call(this,e)}I0.Definition={type:"Tree",metadata:{tree:!0,modifies:!0},params:[{name:"field",type:"field"},{name:"sort",type:"compare"},{name:"method",type:"enum",default:"tidy",values:["tidy","cluster"]},{name:"size",type:"number",array:!0,length:2},{name:"nodeSize",type:"number",array:!0,length:2},{name:"separation",type:"boolean",default:!0},{name:"as",type:"string",array:!0,length:B0.length,default:B0}]},G(I0,Hr,{layout(e){let t=e||"tidy";if(K(kA,t))return kA[t]();L("Unrecognized Tree layout method: "+t)},params:["size","nodeSize"],fields:B0});function j0(e){O.call(this,[],e)}j0.Definition={type:"TreeLinks",metadata:{tree:!0,generates:!0,changes:!0},params:[]},G(j0,O,{transform(e,t){let n=this.value,r=t.source&&t.source.root,i=t.fork(t.NO_SOURCE),a={};return r||L("TreeLinks transform requires a tree data source."),t.changed(t.ADD_REM)?(i.rem=n,t.visit(t.SOURCE,o=>a[te(o)]=1),r.each(o=>{let l=o.data,s=o.parent&&o.parent.data;s&&a[te(l)]&&a[te(s)]&&i.add.push(_e({source:s,target:l}))}),this.value=i.add):t.changed(t.MOD)&&(t.visit(t.MOD,o=>a[te(o)]=1),n.forEach(o=>{(a[te(o.source)]||a[te(o.target)])&&i.mod.push(o)})),i}});var EA={binary:NB,dice:Iu,slice:op,slicedice:RB,squarify:UO,resquarify:TB},q0=["x0","y0","x1","y1","depth","children"];function U0(e){Hr.call(this,e)}U0.Definition={type:"Treemap",metadata:{tree:!0,modifies:!0},params:[{name:"field",type:"field"},{name:"sort",type:"compare"},{name:"method",type:"enum",default:"squarify",values:["squarify","resquarify","binary","dice","slice","slicedice"]},{name:"padding",type:"number",default:0},{name:"paddingInner",type:"number",default:0},{name:"paddingOuter",type:"number",default:0},{name:"paddingTop",type:"number",default:0},{name:"paddingRight",type:"number",default:0},{name:"paddingBottom",type:"number",default:0},{name:"paddingLeft",type:"number",default:0},{name:"ratio",type:"number",default:1.618033988749895},{name:"round",type:"boolean",default:!1},{name:"size",type:"number",array:!0,length:2},{name:"as",type:"string",array:!0,length:q0.length,default:q0}]},G(U0,Hr,{layout(){let e=YO();return e.ratio=t=>{let n=e.tile();n.ratio&&e.tile(n.ratio(t))},e.method=t=>{K(EA,t)?e.tile(EA[t]):L("Unrecognized Treemap layout method: "+t)},e},params:["method","ratio","size","round","padding","paddingInner","paddingOuter","paddingTop","paddingRight","paddingBottom","paddingLeft"],fields:q0});var UB=Gt({label:()=>Z0},1),W0=4278190080;function WB(e,t){let n=e.bitmap();return(t||[]).forEach(r=>n.set(e(r.boundary[0]),e(r.boundary[3]))),[n,void 0]}function HB(e,t,n,r,i){let a=e.width,o=e.height,l=r||i,s=bi(a,o).getContext("2d"),u=bi(a,o).getContext("2d"),c=l&&bi(a,o).getContext("2d");n.forEach(E=>zf(s,E,!1)),zf(u,t,!1),l&&zf(c,t,!0);let f=H0(s,a,o),d=H0(u,a,o),h=l&&H0(c,a,o),p=e.bitmap(),m=l&&e.bitmap(),g,y,v,b,w,_,k,x;for(y=0;y<o;++y)for(g=0;g<a;++g)w=y*a+g,_=f[w]&W0,x=d[w]&W0,k=l&&h[w]&W0,(_||k||x)&&(v=e(g),b=e(y),!i&&(_||x)&&p.set(v,b),l&&(_||k)&&m.set(v,b));return[p,m]}function H0(e,t,n){return new Uint32Array(e.getImageData(0,0,t,n).data.buffer)}function zf(e,t,n){if(!t.length)return;let r=t[0].mark.marktype;r==="group"?t.forEach(i=>{i.items.forEach(a=>zf(e,a.items,n))}):an[r].draw(e,{items:n?t.map(GB):t})}function GB(e){let t=Hu(e,{});return t.stroke&&t.strokeOpacity!==0||t.fill&&t.fillOpacity!==0?{...t,strokeOpacity:1,stroke:"#000",fillOpacity:0}:t}var Gr=5,Bt=31,Ss=32,Li=new Uint32Array(Ss+1),qn=new Uint32Array(Ss+1);qn[0]=0,Li[0]=~qn[0];for(let e=1;e<=Ss;++e)qn[e]=qn[e-1]<<1|1,Li[e]=~qn[e];function VB(e,t){let n=new Uint32Array(~~((e*t+Ss)/Ss));function r(a,o){n[a]|=o}function i(a,o){n[a]&=o}return{array:n,get:(a,o)=>{let l=o*e+a;return n[l>>>Gr]&1<<(l&Bt)},set:(a,o)=>{let l=o*e+a;r(l>>>Gr,1<<(l&Bt))},clear:(a,o)=>{let l=o*e+a;i(l>>>Gr,~(1<<(l&Bt)))},getRange:(a,o,l,s)=>{let u=s,c,f,d,h;for(;u>=o;--u)if(c=u*e+a,f=u*e+l,d=c>>>Gr,h=f>>>Gr,d===h){if(n[d]&Li[c&Bt]&qn[(f&Bt)+1])return!0}else{if(n[d]&Li[c&Bt]||n[h]&qn[(f&Bt)+1])return!0;for(let p=d+1;p<h;++p)if(n[p])return!0}return!1},setRange:(a,o,l,s)=>{let u,c,f,d,h;for(;o<=s;++o)if(u=o*e+a,c=o*e+l,f=u>>>Gr,d=c>>>Gr,f===d)r(f,Li[u&Bt]&qn[(c&Bt)+1]);else for(r(f,Li[u&Bt]),r(d,qn[(c&Bt)+1]),h=f+1;h<d;++h)r(h,4294967295)},clearRange:(a,o,l,s)=>{let u,c,f,d,h;for(;o<=s;++o)if(u=o*e+a,c=o*e+l,f=u>>>Gr,d=c>>>Gr,f===d)i(f,qn[u&Bt]|Li[(c&Bt)+1]);else for(i(f,qn[u&Bt]),i(d,Li[(c&Bt)+1]),h=f+1;h<d;++h)i(h,0)},outOfBounds:(a,o,l,s)=>a<0||o<0||s>=t||l>=e}}function XB(e,t,n){let r=Math.max(1,Math.sqrt(e*t/1e6)),i=~~((e+2*n+r)/r),a=~~((t+2*n+r)/r),o=l=>~~((l+n)/r);return o.invert=l=>l*r-n,o.bitmap=()=>VB(i,a),o.ratio=r,o.padding=n,o.width=e,o.height=t,o}function YB(e,t,n,r){let i=e.width,a=e.height;return function(o){let l=o.datum.datum.items[r].items,s=l.length,u=o.datum.fontSize,c=rn.width(o.datum,o.datum.text),f=0,d,h,p,m,g,y,v;for(let b=0;b<s;++b)d=l[b].x,p=l[b].y,h=l[b].x2===void 0?d:l[b].x2,m=l[b].y2===void 0?p:l[b].y2,g=(d+h)/2,y=(p+m)/2,v=Math.abs(h-d+m-p),v>=f&&(f=v,o.x=g,o.y=y);return g=c/2,y=u/2,d=o.x-g,h=o.x+g,p=o.y-y,m=o.y+y,o.align="center",d<0&&h<=i?o.align="left":0<=d&&i<h&&(o.align="right"),o.baseline="middle",p<0&&m<=a?o.baseline="top":0<=p&&a<m&&(o.baseline="bottom"),!0}}function Nf(e,t,n,r,i,a){let o=n/2;return e-o<0||e+o>i||t-(o=r/2)<0||t+o>a}function Pi(e,t,n,r,i,a,o,l){let s=i*a/(r*2),u=e(t-s),c=e(t+s),f=e(n-(a/=2)),d=e(n+a);return o.outOfBounds(u,f,c,d)||o.getRange(u,f,c,d)||l&&l.getRange(u,f,c,d)}function JB(e,t,n,r){let i=e.width,a=e.height,o=t[0],l=t[1];function s(u,c,f,d,h){let p=e.invert(u),m=e.invert(c),g=f,y=a,v;if(!Nf(p,m,d,h,i,a)&&!Pi(e,p,m,h,d,g,o,l)&&!Pi(e,p,m,h,d,h,o,null)){for(;y-g>=1;)v=(g+y)/2,Pi(e,p,m,h,d,v,o,l)?y=v:g=v;if(g>f)return[p,m,g,!0]}}return function(u){let c=u.datum.datum.items[r].items,f=c.length,d=u.datum.fontSize,h=rn.width(u.datum,u.datum.text),p=n?d:0,m=!1,g=!1,y=0,v,b,w,_,k,x,E,$,D,F,T,S,M,A,C,P,W;for(let V=0;V<f;++V){for(v=c[V].x,w=c[V].y,b=c[V].x2===void 0?v:c[V].x2,_=c[V].y2===void 0?w:c[V].y2,v>b&&(W=v,v=b,b=W),w>_&&(W=w,w=_,_=W),D=e(v),T=e(b),F=~~((D+T)/2),S=e(w),A=e(_),M=~~((S+A)/2),E=F;E>=D;--E)for($=M;$>=S;--$)P=s(E,$,p,h,d),P&&([u.x,u.y,p,m]=P);for(E=F;E<=T;++E)for($=M;$<=A;++$)P=s(E,$,p,h,d),P&&([u.x,u.y,p,m]=P);!m&&!n&&(C=Math.abs(b-v+_-w),k=(v+b)/2,x=(w+_)/2,C>=y&&!Nf(k,x,h,d,i,a)&&!Pi(e,k,x,d,h,d,o,null)&&(y=C,u.x=k,u.y=x,g=!0))}return m||g?(k=h/2,x=d/2,o.setRange(e(u.x-k),e(u.y-x),e(u.x+k),e(u.y+x)),u.align="center",u.baseline="middle",!0):!1}}var QB=[-1,-1,1,1],KB=[-1,1,-1,1];function ZB(e,t,n,r){let i=e.width,a=e.height,o=t[0],l=t[1],s=e.bitmap();return function(u){let c=u.datum.datum.items[r].items,f=c.length,d=u.datum.fontSize,h=rn.width(u.datum,u.datum.text),p=[],m=n?d:0,g=!1,y=!1,v=0,b,w,_,k,x,E,$,D,F,T,S,M;for(let A=0;A<f;++A){for(b=c[A].x,_=c[A].y,w=c[A].x2===void 0?b:c[A].x2,k=c[A].y2===void 0?_:c[A].y2,p.push([e((b+w)/2),e((_+k)/2)]);p.length;)if([$,D]=p.pop(),!(o.get($,D)||l.get($,D)||s.get($,D))){s.set($,D);for(let C=0;C<4;++C)x=$+QB[C],E=D+KB[C],s.outOfBounds(x,E,x,E)||p.push([x,E]);if(x=e.invert($),E=e.invert(D),F=m,T=a,!Nf(x,E,h,d,i,a)&&!Pi(e,x,E,d,h,F,o,l)&&!Pi(e,x,E,d,h,d,o,null)){for(;T-F>=1;)S=(F+T)/2,Pi(e,x,E,d,h,S,o,l)?T=S:F=S;F>m&&(u.x=x,u.y=E,m=F,g=!0)}}!g&&!n&&(M=Math.abs(w-b+k-_),x=(b+w)/2,E=(_+k)/2,M>=v&&!Nf(x,E,h,d,i,a)&&!Pi(e,x,E,d,h,d,o,null)&&(v=M,u.x=x,u.y=E,y=!0))}return g||y?(x=h/2,E=d/2,o.setRange(e(u.x-x),e(u.y-E),e(u.x+x),e(u.y+E)),u.align="center",u.baseline="middle",!0):!1}}var eI=["right","center","left"],tI=["bottom","middle","top"];function nI(e,t,n,r){let i=e.width,a=e.height,o=t[0],l=t[1],s=r.length;return function(u){let c=u.boundary,f=u.datum.fontSize;if(c[2]<0||c[5]<0||c[0]>i||c[3]>a)return!1;let d=u.textWidth??0,h,p,m,g,y,v,b,w,_,k,x,E,$,D,F;for(let T=0;T<s;++T){if(h=(n[T]&3)-1,p=(n[T]>>>2&3)-1,m=h===0&&p===0||r[T]<0,g=h&&p?Math.SQRT1_2:1,y=r[T]<0?-1:1,v=c[1+h]+r[T]*h*g,x=c[4+p]+y*f*p/2+r[T]*p*g,w=x-f/2,_=x+f/2,E=e(v),D=e(w),F=e(_),!d)if($A(E,E,D,F,o,l,v,v,w,_,c,m))d=rn.width(u.datum,u.datum.text);else continue;if(k=v+y*d*h/2,v=k-d/2,b=k+d/2,E=e(v),$=e(b),$A(E,$,D,F,o,l,v,b,w,_,c,m))return u.x=h?h*y<0?b:v:k,u.y=p?p*y<0?_:w:x,u.align=eI[h*y+1],u.baseline=tI[p*y+1],o.setRange(E,D,$,F),!0}return!1}}function $A(e,t,n,r,i,a,o,l,s,u,c,f){return!(i.outOfBounds(e,n,t,r)||(f&&a||i).getRange(e,n,t,r))}var G0=0,V0=4,X0=8,Y0=0,J0=1,Q0=2,rI={"top-left":G0+Y0,top:G0+J0,"top-right":G0+Q0,left:V0+Y0,middle:V0+J0,right:V0+Q0,"bottom-left":X0+Y0,bottom:X0+J0,"bottom-right":X0+Q0},iI={naive:YB,"reduced-search":JB,floodfill:ZB};function aI(e,t,n,r,i,a,o,l,s,u,c){if(!e.length)return e;let f=Math.max(r.length,i.length),d=oI(r,f),h=lI(i,f),p=sI(e[0].datum),m=p==="group"&&e[0].datum.items[s].marktype,g=m==="area",y=uI(p,m,l,s),v=u===null||u===1/0,b=g&&c==="naive",w=-1,_=-1,k=e.map(D=>{let F=v?rn.width(D,D.text):void 0;return w=Math.max(w,F),_=Math.max(_,D.fontSize),{datum:D,opacity:0,x:void 0,y:void 0,align:void 0,baseline:void 0,boundary:y(D),textWidth:F}});u=u===null||u===1/0?Math.max(w,_)+Math.max(...r):u;let x=XB(t[0],t[1],u),E;if(!b){n&&k.sort((T,S)=>n(T.datum,S.datum));let D=!1;for(let T=0;T<h.length&&!D;++T)D=h[T]===5||d[T]<0;let F=(p&&o||g)&&e.map(T=>T.datum);E=a.length||F?HB(x,F||[],a,D,g):WB(x,o&&k)}let $=g?iI[c](x,E,o,s):nI(x,E,h,d);return k.forEach(D=>D.opacity=+$(D)),k}function oI(e,t){let n=new Float64Array(t),r=e.length;for(let i=0;i<r;++i)n[i]=e[i]||0;for(let i=r;i<t;++i)n[i]=n[r-1];return n}function lI(e,t){let n=new Int8Array(t),r=e.length;for(let i=0;i<r;++i)n[i]|=rI[e[i]];for(let i=r;i<t;++i)n[i]=n[r-1];return n}function sI(e){return e&&e.mark&&e.mark.marktype}function uI(e,t,n,r){let i=a=>[a.x,a.x,a.x,a.y,a.y,a.y];return e?e==="line"||e==="area"?a=>i(a.datum):t==="line"?a=>{let o=a.datum.items[r].items;return i(o.length?o[n==="start"?0:o.length-1]:{x:NaN,y:NaN})}:a=>{let o=a.datum.bounds;return[o.x1,(o.x1+o.x2)/2,o.x2,o.y1,(o.y1+o.y2)/2,o.y2]}:i}var K0=["x","y","opacity","align","baseline"],AA=["top-left","left","bottom-left","top","bottom","top-right","right","bottom-right"];function Z0(e){O.call(this,null,e)}Z0.Definition={type:"Label",metadata:{modifies:!0},params:[{name:"size",type:"number",array:!0,length:2,required:!0},{name:"sort",type:"compare"},{name:"anchor",type:"string",array:!0,default:AA},{name:"offset",type:"number",array:!0,default:[1]},{name:"padding",type:"number",default:0,null:!0},{name:"lineAnchor",type:"string",values:["start","end"],default:"end"},{name:"markIndex",type:"number",default:0},{name:"avoidBaseMark",type:"boolean",default:!0},{name:"avoidMarks",type:"data",array:!0},{name:"method",type:"string",default:"naive"},{name:"as",type:"string",array:!0,length:K0.length,default:K0}]},G(Z0,O,{transform(e,t){function n(a){let o=e[a];return de(o)&&t.modified(o.fields)}let r=e.modified();if(!(r||t.changed(t.ADD_REM)||n("sort")))return;(!e.size||e.size.length!==2)&&L("Size parameter should be specified as a [width, height] array.");let i=e.as||K0;return aI(t.materialize(t.SOURCE).source||[],e.size,e.sort,Q(e.offset==null?1:e.offset),Q(e.anchor||AA),e.avoidMarks||[],e.avoidBaseMark!==!1,e.lineAnchor||"end",e.markIndex||0,e.padding===void 0?0:e.padding,e.method||"naive").forEach(a=>{let o=a.datum;o[i[0]]=a.x,o[i[1]]=a.y,o[i[2]]=a.opacity,o[i[3]]=a.align,o[i[4]]=a.baseline}),t.reflow(r).modifies(i)}});var cI=Gt({loess:()=>e1,regression:()=>n1},1);function DA(e,t){var n=[],r=function(c){return c(l)},i,a,o,l,s,u;if(t==null)n.push(e);else for(i={},a=0,o=e.length;a<o;++a)l=e[a],s=t.map(r),u=i[s],u||(i[s]=u=[],u.dims=s,n.push(u)),u.push(l);return n}function e1(e){O.call(this,null,e)}e1.Definition={type:"Loess",metadata:{generates:!0},params:[{name:"x",type:"field",required:!0},{name:"y",type:"field",required:!0},{name:"groupby",type:"field",array:!0},{name:"bandwidth",type:"number",default:.3},{name:"as",type:"string",array:!0}]},G(e1,O,{transform(e,t){let n=t.fork(t.NO_SOURCE|t.NO_FIELDS);if(!this.value||t.changed()||e.modified()){let r=t.materialize(t.SOURCE).source,i=DA(r,e.groupby),a=(e.groupby||[]).map(qe),o=a.length,l=e.as||[qe(e.x),qe(e.y)],s=[];i.forEach(u=>{Q2(u,e.x,e.y,e.bandwidth||.3).forEach(c=>{let f={};for(let d=0;d<o;++d)f[a[d]]=u.dims[d];f[l[0]]=c[0],f[l[1]]=c[1],s.push(_e(f))})}),this.value&&(n.rem=this.value),this.value=n.add=n.source=s}return n}});var t1={constant:Dp,linear:Sp,log:H2,exp:G2,pow:V2,quad:Fp,poly:X2},fI=(e,t)=>e==="poly"?t:e==="quad"?2:1;function n1(e){O.call(this,null,e)}n1.Definition={type:"Regression",metadata:{generates:!0},params:[{name:"x",type:"field",required:!0},{name:"y",type:"field",required:!0},{name:"groupby",type:"field",array:!0},{name:"method",type:"string",default:"linear",values:Object.keys(t1)},{name:"order",type:"number",default:3},{name:"extent",type:"number",array:!0,length:2},{name:"params",type:"boolean",default:!1},{name:"as",type:"string",array:!0}]},G(n1,O,{transform(e,t){let n=t.fork(t.NO_SOURCE|t.NO_FIELDS);if(!this.value||t.changed()||e.modified()){let r=t.materialize(t.SOURCE).source,i=DA(r,e.groupby),a=(e.groupby||[]).map(qe),o=e.method||"linear",l=e.order==null?3:e.order,s=fI(o,l),u=e.as||[qe(e.x),qe(e.y)],c=t1[o],f=[],d=e.extent;K(t1,o)||L("Invalid regression method: "+o),d!=null&&o==="log"&&d[0]<=0&&(t.dataflow.warn("Ignoring extent with values <= 0 for log regression."),d=null),i.forEach(h=>{if(h.length<=s){t.dataflow.warn("Skipping regression with more parameters than data points.");return}let p=c(h,e.x,e.y,l);if(e.params){f.push(_e({keys:h.dims,coef:p.coef,rSquared:p.rSquared}));return}let m=d||ur(h,e.x),g=y=>{let v={};for(let b=0;b<a.length;++b)v[a[b]]=h.dims[b];v[u[0]]=y[0],v[u[1]]=y[1],f.push(_e(v))};o==="linear"||o==="constant"?m.forEach(y=>g([y,p.predict(y)])):tc(p.predict,m,25,200).forEach(g)}),this.value&&(n.rem=this.value),this.value=n.add=n.source=f}return n}});const ke=11102230246251565e-32,xt=134217729;(3+8*ke)*ke;function r1(e,t,n,r,i){let a,o,l,s,u=t[0],c=r[0],f=0,d=0;c>u==c>-u?(a=u,u=t[++f]):(a=c,c=r[++d]);let h=0;if(f<e&&d<n)for(c>u==c>-u?(o=u+a,l=a-(o-u),u=t[++f]):(o=c+a,l=a-(o-c),c=r[++d]),a=o,l!==0&&(i[h++]=l);f<e&&d<n;)c>u==c>-u?(o=a+u,s=o-a,l=a-(o-s)+(u-s),u=t[++f]):(o=a+c,s=o-a,l=a-(o-s)+(c-s),c=r[++d]),a=o,l!==0&&(i[h++]=l);for(;f<e;)o=a+u,s=o-a,l=a-(o-s)+(u-s),u=t[++f],a=o,l!==0&&(i[h++]=l);for(;d<n;)o=a+c,s=o-a,l=a-(o-s)+(c-s),c=r[++d],a=o,l!==0&&(i[h++]=l);return(a!==0||h===0)&&(i[h++]=a),h}function dI(e,t){let n=t[0];for(let r=1;r<e;r++)n+=t[r];return n}function B(e){return new Float64Array(e)}var hI=(3+16*ke)*ke,pI=(2+12*ke)*ke,mI=(9+64*ke)*ke*ke,Io=B(4),SA=B(8),FA=B(12),CA=B(16),It=B(4);function gI(e,t,n,r,i,a,o){let l,s,u,c,f,d,h,p,m,g,y,v,b,w,_,k,x,E,$=e-i,D=n-i,F=t-a,T=r-a;w=$*T,d=xt*$,h=d-(d-$),p=$-h,d=xt*T,m=d-(d-T),g=T-m,_=p*g-(w-h*m-p*m-h*g),k=F*D,d=xt*F,h=d-(d-F),p=F-h,d=xt*D,m=d-(d-D),g=D-m,x=p*g-(k-h*m-p*m-h*g),y=_-x,f=_-y,Io[0]=_-(y+f)+(f-x),v=w+y,f=v-w,b=w-(v-f)+(y-f),y=b-k,f=b-y,Io[1]=b-(y+f)+(f-k),E=v+y,f=E-v,Io[2]=v-(E-f)+(y-f),Io[3]=E;let S=dI(4,Io),M=pI*o;if(S>=M||-S>=M||(f=e-$,l=e-($+f)+(f-i),f=n-D,u=n-(D+f)+(f-i),f=t-F,s=t-(F+f)+(f-a),f=r-T,c=r-(T+f)+(f-a),l===0&&s===0&&u===0&&c===0)||(M=mI*o+33306690738754706e-32*Math.abs(S),S+=$*c+T*l-(F*u+D*s),S>=M||-S>=M))return S;w=l*T,d=xt*l,h=d-(d-l),p=l-h,d=xt*T,m=d-(d-T),g=T-m,_=p*g-(w-h*m-p*m-h*g),k=s*D,d=xt*s,h=d-(d-s),p=s-h,d=xt*D,m=d-(d-D),g=D-m,x=p*g-(k-h*m-p*m-h*g),y=_-x,f=_-y,It[0]=_-(y+f)+(f-x),v=w+y,f=v-w,b=w-(v-f)+(y-f),y=b-k,f=b-y,It[1]=b-(y+f)+(f-k),E=v+y,f=E-v,It[2]=v-(E-f)+(y-f),It[3]=E;let A=r1(4,Io,4,It,SA);w=$*c,d=xt*$,h=d-(d-$),p=$-h,d=xt*c,m=d-(d-c),g=c-m,_=p*g-(w-h*m-p*m-h*g),k=F*u,d=xt*F,h=d-(d-F),p=F-h,d=xt*u,m=d-(d-u),g=u-m,x=p*g-(k-h*m-p*m-h*g),y=_-x,f=_-y,It[0]=_-(y+f)+(f-x),v=w+y,f=v-w,b=w-(v-f)+(y-f),y=b-k,f=b-y,It[1]=b-(y+f)+(f-k),E=v+y,f=E-v,It[2]=v-(E-f)+(y-f),It[3]=E;let C=r1(A,SA,4,It,FA);return w=l*c,d=xt*l,h=d-(d-l),p=l-h,d=xt*c,m=d-(d-c),g=c-m,_=p*g-(w-h*m-p*m-h*g),k=s*u,d=xt*s,h=d-(d-s),p=s-h,d=xt*u,m=d-(d-u),g=u-m,x=p*g-(k-h*m-p*m-h*g),y=_-x,f=_-y,It[0]=_-(y+f)+(f-x),v=w+y,f=v-w,b=w-(v-f)+(y-f),y=b-k,f=b-y,It[1]=b-(y+f)+(f-k),E=v+y,f=E-v,It[2]=v-(E-f)+(y-f),It[3]=E,CA[r1(C,FA,4,It,CA)-1]}function Rf(e,t,n,r,i,a){let o=(t-a)*(n-i),l=(e-i)*(r-a),s=o-l,u=Math.abs(o+l);return Math.abs(s)>=hI*u?s:-gI(e,t,n,r,i,a,u)}(7+56*ke)*ke,(3+28*ke)*ke,(26+288*ke)*ke*ke,B(4),B(4),B(4),B(4),B(4),B(4),B(4),B(4),B(4),B(8),B(8),B(8),B(4),B(8),B(8),B(8),B(12),B(192),B(192),(10+96*ke)*ke,(4+48*ke)*ke,(44+576*ke)*ke*ke,B(4),B(4),B(4),B(4),B(4),B(4),B(4),B(4),B(8),B(8),B(8),B(8),B(8),B(8),B(8),B(8),B(8),B(4),B(4),B(4),B(8),B(16),B(16),B(16),B(32),B(32),B(48),B(64),B(1152),B(1152),(16+224*ke)*ke,(5+72*ke)*ke,(71+1408*ke)*ke*ke,B(4),B(4),B(4),B(4),B(4),B(4),B(4),B(4),B(4),B(4),B(24),B(24),B(24),B(24),B(24),B(24),B(24),B(24),B(24),B(24),B(1152),B(1152),B(1152),B(1152),B(1152),B(2304),B(2304),B(3456),B(5760),B(8),B(8),B(8),B(16),B(24),B(48),B(48),B(96),B(192),B(384),B(384),B(384),B(768),B(96),B(96),B(96),B(1152);var MA=2**-52,Tf=new Uint32Array(512),OA=class YM{static from(t,n=wI,r=_I){let i=t.length,a=new Float64Array(i*2);for(let o=0;o<i;o++){let l=t[o];a[2*o]=n(l),a[2*o+1]=r(l)}return new YM(a)}constructor(t){let n=t.length>>1;if(n>0&&typeof t[0]!="number")throw Error("Expected coords to contain numbers.");this.coords=t;let r=Math.max(2*n-5,0);this._triangles=new Uint32Array(r*3),this._halfedges=new Int32Array(r*3),this._hashSize=Math.ceil(Math.sqrt(n)),this._hullPrev=new Uint32Array(n),this._hullNext=new Uint32Array(n),this._hullTri=new Uint32Array(n),this._hullHash=new Int32Array(this._hashSize),this._ids=new Uint32Array(n),this._dists=new Float64Array(n),this.update()}update(){let{coords:t,_hullPrev:n,_hullNext:r,_hullTri:i,_hullHash:a}=this,o=t.length>>1,l=1/0,s=1/0,u=-1/0,c=-1/0;for(let $=0;$<o;$++){let D=t[2*$],F=t[2*$+1];D<l&&(l=D),F<s&&(s=F),D>u&&(u=D),F>c&&(c=F),this._ids[$]=$}let f=(l+u)/2,d=(s+c)/2,h,p,m;for(let $=0,D=1/0;$<o;$++){let F=i1(f,d,t[2*$],t[2*$+1]);F<D&&(h=$,D=F)}let g=t[2*h],y=t[2*h+1];for(let $=0,D=1/0;$<o;$++){if($===h)continue;let F=i1(g,y,t[2*$],t[2*$+1]);F<D&&F>0&&(p=$,D=F)}let v=t[2*p],b=t[2*p+1],w=1/0;for(let $=0;$<o;$++){if($===h||$===p)continue;let D=bI(g,y,v,b,t[2*$],t[2*$+1]);D<w&&(m=$,w=D)}let _=t[2*m],k=t[2*m+1];if(w===1/0){for(let F=0;F<o;F++)this._dists[F]=t[2*F]-t[0]||t[2*F+1]-t[1];jo(this._ids,this._dists,0,o-1);let $=new Uint32Array(o),D=0;for(let F=0,T=-1/0;F<o;F++){let S=this._ids[F],M=this._dists[S];M>T&&($[D++]=S,T=M)}this.hull=$.subarray(0,D),this.triangles=new Uint32Array,this.halfedges=new Uint32Array;return}if(Rf(g,y,v,b,_,k)<0){let $=p,D=v,F=b;p=m,v=_,b=k,m=$,_=D,k=F}let x=xI(g,y,v,b,_,k);this._cx=x.x,this._cy=x.y;for(let $=0;$<o;$++)this._dists[$]=i1(t[2*$],t[2*$+1],x.x,x.y);jo(this._ids,this._dists,0,o-1),this._hullStart=h;let E=3;r[h]=n[m]=p,r[p]=n[h]=m,r[m]=n[p]=h,i[h]=0,i[p]=1,i[m]=2,a.fill(-1),a[this._hashKey(g,y)]=h,a[this._hashKey(v,b)]=p,a[this._hashKey(_,k)]=m,this.trianglesLen=0,this._addTriangle(h,p,m,-1,-1,-1);for(let $=0,D,F;$<this._ids.length;$++){let T=this._ids[$],S=t[2*T],M=t[2*T+1];if($>0&&Math.abs(S-D)<=MA&&Math.abs(M-F)<=MA||(D=S,F=M,T===h||T===p||T===m))continue;let A=0;for(let ae=0,ue=this._hashKey(S,M);ae<this._hashSize&&(A=a[(ue+ae)%this._hashSize],!(A!==-1&&A!==r[A]));ae++);A=n[A];let C=A,P;for(;P=r[C],Rf(S,M,t[2*C],t[2*C+1],t[2*P],t[2*P+1])>=0;)if(C=P,C===A){C=-1;break}if(C===-1)continue;let W=this._addTriangle(C,T,r[C],-1,-1,i[C]);i[T]=this._legalize(W+2),i[C]=W,E++;let V=r[C];for(;P=r[V],Rf(S,M,t[2*V],t[2*V+1],t[2*P],t[2*P+1])<0;)W=this._addTriangle(V,T,P,i[T],-1,i[V]),i[T]=this._legalize(W+2),r[V]=V,E--,V=P;if(C===A)for(;P=n[C],Rf(S,M,t[2*P],t[2*P+1],t[2*C],t[2*C+1])<0;)W=this._addTriangle(P,T,C,-1,i[C],i[P]),this._legalize(W+2),i[P]=W,r[C]=C,E--,C=P;this._hullStart=n[T]=C,r[C]=n[V]=T,r[T]=V,a[this._hashKey(S,M)]=T,a[this._hashKey(t[2*C],t[2*C+1])]=C}this.hull=new Uint32Array(E);for(let $=0,D=this._hullStart;$<E;$++)this.hull[$]=D,D=r[D];this.triangles=this._triangles.subarray(0,this.trianglesLen),this.halfedges=this._halfedges.subarray(0,this.trianglesLen)}_hashKey(t,n){return Math.floor(yI(t-this._cx,n-this._cy)*this._hashSize)%this._hashSize}_legalize(t){let{_triangles:n,_halfedges:r,coords:i}=this,a=0,o=0;for(;;){let l=r[t],s=t-t%3;if(o=s+(t+2)%3,l===-1){if(a===0)break;t=Tf[--a];continue}let u=l-l%3,c=s+(t+1)%3,f=u+(l+2)%3,d=n[o],h=n[t],p=n[c],m=n[f];if(vI(i[2*d],i[2*d+1],i[2*h],i[2*h+1],i[2*p],i[2*p+1],i[2*m],i[2*m+1])){n[t]=m,n[l]=d;let g=r[f];if(g===-1){let v=this._hullStart;do{if(this._hullTri[v]===f){this._hullTri[v]=t;break}v=this._hullPrev[v]}while(v!==this._hullStart)}this._link(t,g),this._link(l,r[o]),this._link(o,f);let y=u+(l+1)%3;a<Tf.length&&(Tf[a++]=y)}else{if(a===0)break;t=Tf[--a]}}return o}_link(t,n){this._halfedges[t]=n,n!==-1&&(this._halfedges[n]=t)}_addTriangle(t,n,r,i,a,o){let l=this.trianglesLen;return this._triangles[l]=t,this._triangles[l+1]=n,this._triangles[l+2]=r,this._link(l,i),this._link(l+1,a),this._link(l+2,o),this.trianglesLen+=3,l}};function yI(e,t){let n=e/(Math.abs(e)+Math.abs(t));return(t>0?3-n:1+n)/4}function i1(e,t,n,r){let i=e-n,a=t-r;return i*i+a*a}function vI(e,t,n,r,i,a,o,l){let s=e-o,u=t-l,c=n-o,f=r-l,d=i-o,h=a-l,p=s*s+u*u,m=c*c+f*f,g=d*d+h*h;return s*(f*g-m*h)-u*(c*g-m*d)+p*(c*h-f*d)<0}function bI(e,t,n,r,i,a){let o=n-e,l=r-t,s=i-e,u=a-t,c=o*o+l*l,f=s*s+u*u,d=.5/(o*u-l*s),h=(u*c-l*f)*d,p=(o*f-s*c)*d;return h*h+p*p}function xI(e,t,n,r,i,a){let o=n-e,l=r-t,s=i-e,u=a-t,c=o*o+l*l,f=s*s+u*u,d=.5/(o*u-l*s);return{x:e+(u*c-l*f)*d,y:t+(o*f-s*c)*d}}function jo(e,t,n,r){if(r-n<=20)for(let i=n+1;i<=r;i++){let a=e[i],o=t[a],l=i-1;for(;l>=n&&t[e[l]]>o;)e[l+1]=e[l--];e[l+1]=a}else{let i=n+r>>1,a=n+1,o=r;Fs(e,i,a),t[e[n]]>t[e[r]]&&Fs(e,n,r),t[e[a]]>t[e[r]]&&Fs(e,a,r),t[e[n]]>t[e[a]]&&Fs(e,n,a);let l=e[a],s=t[l];for(;;){do a++;while(t[e[a]]<s);do o--;while(t[e[o]]>s);if(o<a)break;Fs(e,a,o)}e[n+1]=e[o],e[o]=l,r-a+1>=o-n?(jo(e,t,a,r),jo(e,t,n,o-1)):(jo(e,t,n,o-1),jo(e,t,a,r))}}function Fs(e,t,n){let r=e[t];e[t]=e[n],e[n]=r}function wI(e){return e[0]}function _I(e){return e[1]}var zA=1e-6,xa=class{constructor(){this._x0=this._y0=this._x1=this._y1=null,this._=""}moveTo(e,t){this._+=`M${this._x0=this._x1=+e},${this._y0=this._y1=+t}`}closePath(){this._x1!==null&&(this._x1=this._x0,this._y1=this._y0,this._+="Z")}lineTo(e,t){this._+=`L${this._x1=+e},${this._y1=+t}`}arc(e,t,n){e=+e,t=+t,n=+n;let r=e+n,i=t;if(n<0)throw Error("negative radius");this._x1===null?this._+=`M${r},${i}`:(Math.abs(this._x1-r)>zA||Math.abs(this._y1-i)>zA)&&(this._+="L"+r+","+i),n&&(this._+=`A${n},${n},0,1,1,${e-n},${t}A${n},${n},0,1,1,${this._x1=r},${this._y1=i}`)}rect(e,t,n,r){this._+=`M${this._x0=this._x1=+e},${this._y0=this._y1=+t}h${+n}v${+r}h${-n}Z`}value(){return this._||null}},a1=class{constructor(){this._=[]}moveTo(e,t){this._.push([e,t])}closePath(){this._.push(this._[0].slice())}lineTo(e,t){this._.push([e,t])}value(){return this._.length?this._:null}},kI=class{constructor(e,[t,n,r,i]=[0,0,960,500]){if(!((r=+r)>=(t=+t))||!((i=+i)>=(n=+n)))throw Error("invalid bounds");this.delaunay=e,this._circumcenters=new Float64Array(e.points.length*2),this.vectors=new Float64Array(e.points.length*2),this.xmax=r,this.xmin=t,this.ymax=i,this.ymin=n,this._init()}update(){return this.delaunay.update(),this._init(),this}_init(){let{delaunay:{points:e,hull:t,triangles:n},vectors:r}=this,i,a,o=this.circumcenters=this._circumcenters.subarray(0,n.length/3*2);for(let p=0,m=0,g=n.length,y,v;p<g;p+=3,m+=2){let b=n[p]*2,w=n[p+1]*2,_=n[p+2]*2,k=e[b],x=e[b+1],E=e[w],$=e[w+1],D=e[_],F=e[_+1],T=E-k,S=$-x,M=D-k,A=F-x,C=(T*A-S*M)*2;if(Math.abs(C)<1e-9){if(i===void 0){i=a=0;for(let W of t)i+=e[W*2],a+=e[W*2+1];i/=t.length,a/=t.length}let P=1e9*Math.sign((i-k)*A-(a-x)*M);y=(k+D)/2-P*A,v=(x+F)/2+P*M}else{let P=1/C,W=T*T+S*S,V=M*M+A*A;y=k+(A*W-S*V)*P,v=x+(T*V-M*W)*P}o[m]=y,o[m+1]=v}let l=t[t.length-1],s,u=l*4,c,f=e[2*l],d,h=e[2*l+1];r.fill(0);for(let p=0;p<t.length;++p)l=t[p],s=u,c=f,d=h,u=l*4,f=e[2*l],h=e[2*l+1],r[s+2]=r[u]=d-h,r[s+3]=r[u+1]=f-c}render(e){let t=e==null?e=new xa:void 0,{delaunay:{halfedges:n,inedges:r,hull:i},circumcenters:a,vectors:o}=this;if(i.length<=1)return null;for(let u=0,c=n.length;u<c;++u){let f=n[u];if(f<u)continue;let d=Math.floor(u/3)*2,h=Math.floor(f/3)*2,p=a[d],m=a[d+1],g=a[h],y=a[h+1];this._renderSegment(p,m,g,y,e)}let l,s=i[i.length-1];for(let u=0;u<i.length;++u){l=s,s=i[u];let c=Math.floor(r[s]/3)*2,f=a[c],d=a[c+1],h=l*4,p=this._project(f,d,o[h+2],o[h+3]);p&&this._renderSegment(f,d,p[0],p[1],e)}return t&&t.value()}renderBounds(e){let t=e==null?e=new xa:void 0;return e.rect(this.xmin,this.ymin,this.xmax-this.xmin,this.ymax-this.ymin),t&&t.value()}renderCell(e,t){let n=t==null?t=new xa:void 0,r=this._clip(e);if(r===null||!r.length)return;t.moveTo(r[0],r[1]);let i=r.length;for(;r[0]===r[i-2]&&r[1]===r[i-1]&&i>1;)i-=2;for(let a=2;a<i;a+=2)(r[a]!==r[a-2]||r[a+1]!==r[a-1])&&t.lineTo(r[a],r[a+1]);return t.closePath(),n&&n.value()}*cellPolygons(){let{delaunay:{points:e}}=this;for(let t=0,n=e.length/2;t<n;++t){let r=this.cellPolygon(t);r&&(r.index=t,yield r)}}cellPolygon(e){let t=new a1;return this.renderCell(e,t),t.value()}_renderSegment(e,t,n,r,i){let a,o=this._regioncode(e,t),l=this._regioncode(n,r);o===0&&l===0?(i.moveTo(e,t),i.lineTo(n,r)):(a=this._clipSegment(e,t,n,r,o,l))&&(i.moveTo(a[0],a[1]),i.lineTo(a[2],a[3]))}contains(e,t,n){return t=+t,t!==t||(n=+n,n!==n)?!1:this.delaunay._step(e,t,n)===e}*neighbors(e){let t=this._clip(e);if(t)for(let n of this.delaunay.neighbors(e)){let r=this._clip(n);if(r){e:for(let i=0,a=t.length;i<a;i+=2)for(let o=0,l=r.length;o<l;o+=2)if(t[i]===r[o]&&t[i+1]===r[o+1]&&t[(i+2)%a]===r[(o+l-2)%l]&&t[(i+3)%a]===r[(o+l-1)%l]){yield n;break e}}}}_cell(e){let{circumcenters:t,delaunay:{inedges:n,halfedges:r,triangles:i}}=this,a=n[e];if(a===-1)return null;let o=[],l=a;do{let s=Math.floor(l/3);if(o.push(t[s*2],t[s*2+1]),l=l%3==2?l-2:l+1,i[l]!==e)break;l=r[l]}while(l!==a&&l!==-1);return o}_clip(e){if(e===0&&this.delaunay.hull.length===1)return[this.xmax,this.ymin,this.xmax,this.ymax,this.xmin,this.ymax,this.xmin,this.ymin];let t=this._cell(e);if(t===null)return null;let{vectors:n}=this,r=e*4;return this._simplify(n[r]||n[r+1]?this._clipInfinite(e,t,n[r],n[r+1],n[r+2],n[r+3]):this._clipFinite(e,t))}_clipFinite(e,t){let n=t.length,r=null,i,a,o=t[n-2],l=t[n-1],s,u=this._regioncode(o,l),c,f=0;for(let d=0;d<n;d+=2)if(i=o,a=l,o=t[d],l=t[d+1],s=u,u=this._regioncode(o,l),s===0&&u===0)c=f,f=0,r?r.push(o,l):r=[o,l];else{let h,p,m,g,y;if(s===0){if((h=this._clipSegment(i,a,o,l,s,u))===null)continue;[p,m,g,y]=h}else{if((h=this._clipSegment(o,l,i,a,u,s))===null)continue;[g,y,p,m]=h,c=f,f=this._edgecode(p,m),c&&f&&this._edge(e,c,f,r,r.length),r?r.push(p,m):r=[p,m]}c=f,f=this._edgecode(g,y),c&&f&&this._edge(e,c,f,r,r.length),r?r.push(g,y):r=[g,y]}if(r)c=f,f=this._edgecode(r[0],r[1]),c&&f&&this._edge(e,c,f,r,r.length);else if(this.contains(e,(this.xmin+this.xmax)/2,(this.ymin+this.ymax)/2))return[this.xmax,this.ymin,this.xmax,this.ymax,this.xmin,this.ymax,this.xmin,this.ymin];return r}_clipSegment(e,t,n,r,i,a){let o=i<a;for(o&&([e,t,n,r,i,a]=[n,r,e,t,a,i]);;){if(i===0&&a===0)return o?[n,r,e,t]:[e,t,n,r];if(i&a)return null;let l,s,u=i||a;u&8?(l=e+(n-e)*(this.ymax-t)/(r-t),s=this.ymax):u&4?(l=e+(n-e)*(this.ymin-t)/(r-t),s=this.ymin):u&2?(s=t+(r-t)*(this.xmax-e)/(n-e),l=this.xmax):(s=t+(r-t)*(this.xmin-e)/(n-e),l=this.xmin),i?(e=l,t=s,i=this._regioncode(e,t)):(n=l,r=s,a=this._regioncode(n,r))}}_clipInfinite(e,t,n,r,i,a){let o=Array.from(t),l;if((l=this._project(o[0],o[1],n,r))&&o.unshift(l[0],l[1]),(l=this._project(o[o.length-2],o[o.length-1],i,a))&&o.push(l[0],l[1]),o=this._clipFinite(e,o))for(let s=0,u=o.length,c,f=this._edgecode(o[u-2],o[u-1]);s<u;s+=2)c=f,f=this._edgecode(o[s],o[s+1]),c&&f&&(s=this._edge(e,c,f,o,s),u=o.length);else this.contains(e,(this.xmin+this.xmax)/2,(this.ymin+this.ymax)/2)&&(o=[this.xmin,this.ymin,this.xmax,this.ymin,this.xmax,this.ymax,this.xmin,this.ymax]);return o}_edge(e,t,n,r,i){for(;t!==n;){let a,o;switch(t){case 5:t=4;continue;case 4:t=6,a=this.xmax,o=this.ymin;break;case 6:t=2;continue;case 2:t=10,a=this.xmax,o=this.ymax;break;case 10:t=8;continue;case 8:t=9,a=this.xmin,o=this.ymax;break;case 9:t=1;continue;case 1:t=5,a=this.xmin,o=this.ymin;break}(r[i]!==a||r[i+1]!==o)&&this.contains(e,a,o)&&(r.splice(i,0,a,o),i+=2)}return i}_project(e,t,n,r){let i=1/0,a,o,l;if(r<0){if(t<=this.ymin)return null;(a=(this.ymin-t)/r)<i&&(l=this.ymin,o=e+(i=a)*n)}else if(r>0){if(t>=this.ymax)return null;(a=(this.ymax-t)/r)<i&&(l=this.ymax,o=e+(i=a)*n)}if(n>0){if(e>=this.xmax)return null;(a=(this.xmax-e)/n)<i&&(o=this.xmax,l=t+(i=a)*r)}else if(n<0){if(e<=this.xmin)return null;(a=(this.xmin-e)/n)<i&&(o=this.xmin,l=t+(i=a)*r)}return[o,l]}_edgecode(e,t){return(e===this.xmin?1:e===this.xmax?2:0)|(t===this.ymin?4:t===this.ymax?8:0)}_regioncode(e,t){return(e<this.xmin?1:e>this.xmax?2:0)|(t<this.ymin?4:t>this.ymax?8:0)}_simplify(e){if(e&&e.length>4){for(let t=0;t<e.length;t+=2){let n=(t+2)%e.length,r=(t+4)%e.length;(e[t]===e[n]&&e[n]===e[r]||e[t+1]===e[n+1]&&e[n+1]===e[r+1])&&(e.splice(n,2),t-=2)}e.length||(e=null)}return e}},EI=2*Math.PI,qo=Math.pow;function $I(e){return e[0]}function AI(e){return e[1]}function DI(e){let{triangles:t,coords:n}=e;for(let r=0;r<t.length;r+=3){let i=2*t[r],a=2*t[r+1],o=2*t[r+2];if((n[o]-n[i])*(n[a+1]-n[i+1])-(n[a]-n[i])*(n[o+1]-n[i+1])>1e-10)return!1}return!0}function SI(e,t,n){return[e+Math.sin(e+t)*n,t+Math.cos(e-t)*n]}var FI=class JM{static from(t,n=$I,r=AI,i){return new JM("length"in t?CI(t,n,r,i):Float64Array.from(MI(t,n,r,i)))}constructor(t){this._delaunator=new OA(t),this.inedges=new Int32Array(t.length/2),this._hullIndex=new Int32Array(t.length/2),this.points=this._delaunator.coords,this._init()}update(){return this._delaunator.update(),this._init(),this}_init(){let t=this._delaunator,n=this.points;if(t.hull&&t.hull.length>2&&DI(t)){this.collinear=Int32Array.from({length:n.length/2},(d,h)=>h).sort((d,h)=>n[2*d]-n[2*h]||n[2*d+1]-n[2*h+1]);let s=this.collinear[0],u=this.collinear[this.collinear.length-1],c=[n[2*s],n[2*s+1],n[2*u],n[2*u+1]],f=1e-8*Math.hypot(c[3]-c[1],c[2]-c[0]);for(let d=0,h=n.length/2;d<h;++d){let p=SI(n[2*d],n[2*d+1],f);n[2*d]=p[0],n[2*d+1]=p[1]}this._delaunator=new OA(n)}else delete this.collinear;let r=this.halfedges=this._delaunator.halfedges,i=this.hull=this._delaunator.hull,a=this.triangles=this._delaunator.triangles,o=this.inedges.fill(-1),l=this._hullIndex.fill(-1);for(let s=0,u=r.length;s<u;++s){let c=a[s%3==2?s-2:s+1];(r[s]===-1||o[c]===-1)&&(o[c]=s)}for(let s=0,u=i.length;s<u;++s)l[i[s]]=s;i.length<=2&&i.length>0&&(this.triangles=new Int32Array(3).fill(-1),this.halfedges=new Int32Array(3).fill(-1),this.triangles[0]=i[0],o[i[0]]=1,i.length===2&&(o[i[1]]=0,this.triangles[1]=i[1],this.triangles[2]=i[1]))}voronoi(t){return new kI(this,t)}*neighbors(t){let{inedges:n,hull:r,_hullIndex:i,halfedges:a,triangles:o,collinear:l}=this;if(l){let f=l.indexOf(t);f>0&&(yield l[f-1]),f<l.length-1&&(yield l[f+1]);return}let s=n[t];if(s===-1)return;let u=s,c=-1;do{if(yield c=o[u],u=u%3==2?u-2:u+1,o[u]!==t)return;if(u=a[u],u===-1){let f=r[(i[t]+1)%r.length];f!==c&&(yield f);return}}while(u!==s)}find(t,n,r=0){if(t=+t,t!==t||(n=+n,n!==n))return-1;let i=r,a;for(;(a=this._step(r,t,n))>=0&&a!==r&&a!==i;)r=a;return a}_step(t,n,r){let{inedges:i,hull:a,_hullIndex:o,halfedges:l,triangles:s,points:u}=this;if(i[t]===-1||!u.length)return(t+1)%(u.length>>1);let c=t,f=qo(n-u[t*2],2)+qo(r-u[t*2+1],2),d=i[t],h=d;do{let p=s[h],m=qo(n-u[p*2],2)+qo(r-u[p*2+1],2);if(m<f&&(f=m,c=p),h=h%3==2?h-2:h+1,s[h]!==t)break;if(h=l[h],h===-1){if(h=a[(o[t]+1)%a.length],h!==p&&qo(n-u[h*2],2)+qo(r-u[h*2+1],2)<f)return h;break}}while(h!==d);return c}render(t){let n=t==null?t=new xa:void 0,{points:r,halfedges:i,triangles:a}=this;for(let o=0,l=i.length;o<l;++o){let s=i[o];if(s<o)continue;let u=a[o]*2,c=a[s]*2;t.moveTo(r[u],r[u+1]),t.lineTo(r[c],r[c+1])}return this.renderHull(t),n&&n.value()}renderPoints(t,n){n===void 0&&(!t||typeof t.moveTo!="function")&&(n=t,t=null),n=n==null?2:+n;let r=t==null?t=new xa:void 0,{points:i}=this;for(let a=0,o=i.length;a<o;a+=2){let l=i[a],s=i[a+1];t.moveTo(l+n,s),t.arc(l,s,n,0,EI)}return r&&r.value()}renderHull(t){let n=t==null?t=new xa:void 0,{hull:r,points:i}=this,a=r[0]*2,o=r.length;t.moveTo(i[a],i[a+1]);for(let l=1;l<o;++l){let s=2*r[l];t.lineTo(i[s],i[s+1])}return t.closePath(),n&&n.value()}hullPolygon(){let t=new a1;return this.renderHull(t),t.value()}renderTriangle(t,n){let r=n==null?n=new xa:void 0,{points:i,triangles:a}=this,o=a[t*=3]*2,l=a[t+1]*2,s=a[t+2]*2;return n.moveTo(i[o],i[o+1]),n.lineTo(i[l],i[l+1]),n.lineTo(i[s],i[s+1]),n.closePath(),r&&r.value()}*trianglePolygons(){let{triangles:t}=this;for(let n=0,r=t.length/3;n<r;++n)yield this.trianglePolygon(n)}trianglePolygon(t){let n=new a1;return this.renderTriangle(t,n),n.value()}};function CI(e,t,n,r){let i=e.length,a=new Float64Array(i*2);for(let o=0;o<i;++o){let l=e[o];a[o*2]=t.call(r,l,o,e),a[o*2+1]=n.call(r,l,o,e)}return a}function*MI(e,t,n,r){let i=0;for(let a of e)yield t.call(r,a,i,e),yield n.call(r,a,i,e),++i}var OI=Gt({voronoi:()=>o1},1);function o1(e){O.call(this,null,e)}o1.Definition={type:"Voronoi",metadata:{modifies:!0},params:[{name:"x",type:"field",required:!0},{name:"y",type:"field",required:!0},{name:"size",type:"number",array:!0,length:2},{name:"extent",type:"array",array:!0,length:2,default:[[-1e5,-1e5],[1e5,1e5]],content:{type:"number",array:!0,length:2}},{name:"as",type:"string",default:"path"}]};var zI=[-1e5,-1e5,1e5,1e5];G(o1,O,{transform(e,t){let n=e.as||"path",r=t.source;if(!r||!r.length)return t;let i=e.size;i=i?[0,0,i[0],i[1]]:(i=e.extent)?[i[0][0],i[0][1],i[1][0],i[1][1]]:zI;let a=this.value=FI.from(r,e.x,e.y).voronoi(i);for(let o=0,l=r.length;o<l;++o){let s=a.cellPolygon(o);r[o][n]=s&&!RI(s)?NI(s):null}return t.reflow(e.modified()).modifies(n)}});function NI(e){let t=e[0][0],n=e[0][1],r=e.length-1;for(;e[r][0]===t&&e[r][1]===n;--r);return"M"+e.slice(0,r+1).join("L")+"Z"}function RI(e){return e.length===2&&e[0][0]===e[1][0]&&e[0][1]===e[1][1]}var TI=Gt({wordcloud:()=>s1},1),l1=Math.PI/180,Cs=64,Lf=2048;function LI(){var e=[256,256],t,n,r,i,a,o,l,s=NA,u=[],c=Math.random,f={};f.layout=function(){for(var p=d(bi()),m=UI((e[0]>>5)*e[1]),g=null,y=u.length,v=-1,b=[],w=u.map(k=>({text:t(k),font:n(k),style:i(k),weight:a(k),rotate:o(k),size:~~(r(k)+1e-14),padding:l(k),xoff:0,yoff:0,x1:0,y1:0,x0:0,y0:0,hasText:!1,sprite:null,datum:k})).sort((k,x)=>x.size-k.size);++v<y;){var _=w[v];_.x=e[0]*(c()+.5)>>1,_.y=e[1]*(c()+.5)>>1,PI(p,_,w,v),_.hasText&&h(m,_,g)&&(b.push(_),g?II(g,_):g=[{x:_.x+_.x0,y:_.y+_.y0},{x:_.x+_.x1,y:_.y+_.y1}],_.x-=e[0]>>1,_.y-=e[1]>>1)}return b};function d(p){p.width=p.height=1;var m=Math.sqrt(p.getContext("2d").getImageData(0,0,1,1).data.length>>2);p.width=(Cs<<5)/m,p.height=Lf/m;var g=p.getContext("2d");return g.fillStyle=g.strokeStyle="red",g.textAlign="center",{context:g,ratio:m}}function h(p,m,g){for(var y=m.x,v=m.y,b=Math.hypot(e[0],e[1]),w=s(e),_=c()<.5?1:-1,k=-_,x,E,$;(x=w(k+=_))&&(E=~~x[0],$=~~x[1],!(Math.min(Math.abs(E),Math.abs($))>=b));)if(m.x=y+E,m.y=v+$,!(m.x+m.x0<0||m.y+m.y0<0||m.x+m.x1>e[0]||m.y+m.y1>e[1])&&(!g||!BI(m,p,e[0]))&&(!g||jI(m,g))){for(var D=m.sprite,F=m.width>>5,T=e[0]>>5,S=m.x-(F<<4),M=S&127,A=32-M,C=m.y1-m.y0,P=(m.y+m.y0)*T+(S>>5),W,V=0;V<C;V++){W=0;for(var ae=0;ae<=F;ae++)p[P+ae]|=W<<A|(ae<F?(W=D[V*F+ae])>>>M:0);P+=T}return m.sprite=null,!0}return!1}return f.words=function(p){return arguments.length?(u=p,f):u},f.size=function(p){return arguments.length?(e=[+p[0],+p[1]],f):e},f.font=function(p){return arguments.length?(n=wa(p),f):n},f.fontStyle=function(p){return arguments.length?(i=wa(p),f):i},f.fontWeight=function(p){return arguments.length?(a=wa(p),f):a},f.rotate=function(p){return arguments.length?(o=wa(p),f):o},f.text=function(p){return arguments.length?(t=wa(p),f):t},f.spiral=function(p){return arguments.length?(s=WI[p]||p,f):s},f.fontSize=function(p){return arguments.length?(r=wa(p),f):r},f.padding=function(p){return arguments.length?(l=wa(p),f):l},f.random=function(p){return arguments.length?(c=p,f):c},f}function PI(e,t,n,r){if(!t.sprite){var i=e.context,a=e.ratio;i.clearRect(0,0,(Cs<<5)/a,Lf/a);var o=0,l=0,s=0,u=n.length,c,f,d,h,p;for(--r;++r<u;){if(t=n[r],i.save(),i.font=t.style+" "+t.weight+" "+~~((t.size+1)/a)+"px "+t.font,c=i.measureText(t.text+"m").width*a,d=t.size<<1,t.rotate){var m=Math.sin(t.rotate*l1),g=Math.cos(t.rotate*l1),y=c*g,v=c*m,b=d*g,w=d*m;c=Math.max(Math.abs(y+w),Math.abs(y-w))+31>>5<<5,d=~~Math.max(Math.abs(v+b),Math.abs(v-b))}else c=c+31>>5<<5;if(d>s&&(s=d),o+c>=Cs<<5&&(o=0,l+=s,s=0),l+d>=Lf)break;i.translate((o+(c>>1))/a,(l+(d>>1))/a),t.rotate&&i.rotate(t.rotate*l1),i.fillText(t.text,0,0),t.padding&&(i.lineWidth=2*t.padding,i.strokeText(t.text,0,0)),i.restore(),t.width=c,t.height=d,t.xoff=o,t.yoff=l,t.x1=c>>1,t.y1=d>>1,t.x0=-t.x1,t.y0=-t.y1,t.hasText=!0,o+=c}for(var _=i.getImageData(0,0,(Cs<<5)/a,Lf/a).data,k=[];--r>=0;)if(t=n[r],t.hasText){for(c=t.width,f=c>>5,d=t.y1-t.y0,h=0;h<d*f;h++)k[h]=0;if(o=t.xoff,o==null)return;l=t.yoff;var x=0,E=-1;for(p=0;p<d;p++){for(h=0;h<c;h++){var $=f*p+(h>>5),D=_[(l+p)*(Cs<<5)+(o+h)<<2]?1<<31-h%32:0;k[$]|=D,x|=D}x?E=p:(t.y0++,d--,p--,l++)}t.y1=t.y0+E,t.sprite=k.slice(0,(t.y1-t.y0)*f)}}}function BI(e,t,n){n>>=5;for(var r=e.sprite,i=e.width>>5,a=e.x-(i<<4),o=a&127,l=32-o,s=e.y1-e.y0,u=(e.y+e.y0)*n+(a>>5),c,f=0;f<s;f++){c=0;for(var d=0;d<=i;d++)if((c<<l|(d<i?(c=r[f*i+d])>>>o:0))&t[u+d])return!0;u+=n}return!1}function II(e,t){var n=e[0],r=e[1];t.x+t.x0<n.x&&(n.x=t.x+t.x0),t.y+t.y0<n.y&&(n.y=t.y+t.y0),t.x+t.x1>r.x&&(r.x=t.x+t.x1),t.y+t.y1>r.y&&(r.y=t.y+t.y1)}function jI(e,t){return e.x+e.x1>t[0].x&&e.x+e.x0<t[1].x&&e.y+e.y1>t[0].y&&e.y+e.y0<t[1].y}function NA(e){var t=e[0]/e[1];return function(n){return[t*(n*=.1)*Math.cos(n),n*Math.sin(n)]}}function qI(e){var t=4,n=t*e[0]/e[1],r=0,i=0;return function(a){var o=a<0?-1:1;switch(Math.sqrt(1+4*o*a)-o&3){case 0:r+=n;break;case 1:i+=t;break;case 2:r-=n;break;default:i-=t;break}return[r,i]}}function UI(e){for(var t=[],n=-1;++n<e;)t[n]=0;return t}function wa(e){return typeof e=="function"?e:function(){return e}}var WI={archimedean:NA,rectangular:qI},RA=["x","y","font","fontSize","fontStyle","fontWeight","angle"],HI=["text","font","rotate","fontSize","fontStyle","fontWeight"];function s1(e){O.call(this,LI(),e)}s1.Definition={type:"Wordcloud",metadata:{modifies:!0},params:[{name:"size",type:"number",array:!0,length:2},{name:"font",type:"string",expr:!0,default:"sans-serif"},{name:"fontStyle",type:"string",expr:!0,default:"normal"},{name:"fontWeight",type:"string",expr:!0,default:"normal"},{name:"fontSize",type:"number",expr:!0,default:14},{name:"fontSizeRange",type:"number",array:"nullable",default:[10,50]},{name:"rotate",type:"number",expr:!0,default:0},{name:"text",type:"field"},{name:"spiral",type:"string",values:["archimedean","rectangular"]},{name:"padding",type:"number",expr:!0},{name:"as",type:"string",array:!0,length:7,default:RA}]},G(s1,O,{transform(e,t){e.size&&!(e.size[0]&&e.size[1])&&L("Wordcloud size dimensions must be non-zero.");function n(p){let m=e[p];return de(m)&&t.modified(m.fields)}let r=e.modified();if(!(r||t.changed(t.ADD_REM)||HI.some(n)))return;let i=t.materialize(t.SOURCE).source,a=this.value,o=e.as||RA,l=e.fontSize||14,s;if(de(l)?s=e.fontSizeRange:l=At(l),s){let p=l,m=ve("sqrt")().domain(ur(i,p)).range(s);l=g=>m(p(g))}i.forEach(p=>{p[o[0]]=NaN,p[o[1]]=NaN,p[o[3]]=0});let u=a.words(i).text(e.text).size(e.size||[500,500]).padding(e.padding||1).spiral(e.spiral||"archimedean").rotate(e.rotate||0).font(e.font||"sans-serif").fontStyle(e.fontStyle||"normal").fontWeight(e.fontWeight||"normal").fontSize(l).random(xn).layout(),c=a.size(),f=c[0]>>1,d=c[1]>>1,h=u.length;for(let p=0,m,g;p<h;++p)m=u[p],g=m.datum,g[o[0]]=m.x+f,g[o[1]]=m.y+d,g[o[2]]=m.font,g[o[3]]=m.size,g[o[4]]=m.style,g[o[5]]=m.weight,g[o[6]]=m.rotate;return t.reflow(r).modifies(o)}});var GI=Gt({crossfilter:()=>u1,resolvefilter:()=>c1},1),VI=e=>new Uint8Array(e),XI=e=>new Uint16Array(e),Ms=e=>new Uint32Array(e);function YI(){let e=8,t=[],n=Ms(0),r=Pf(0,e),i=Pf(0,e);return{data:()=>t,seen:()=>n=JI(n,t.length),add(a){for(let o=0,l=t.length,s=a.length,u;o<s;++o)u=a[o],u._index=l++,t.push(u)},remove(a,o){let l=t.length,s=Array(l-a),u=t,c,f,d;for(f=0;!o[f]&&f<l;++f)s[f]=t[f],u[f]=f;for(d=f;f<l;++f)c=t[f],o[f]?u[f]=-1:(u[f]=d,r[d]=r[f],i[d]=i[f],s[d]=c,c._index=d++),r[f]=0;return t=s,u},size:()=>t.length,curr:()=>r,prev:()=>i,reset:a=>i[a]=r[a],all:()=>e<257?255:e<65537?65535:4294967295,set(a,o){r[a]|=o},clear(a,o){r[a]&=~o},resize(a,o){(a>r.length||o>e)&&(e=Math.max(o,e),r=Pf(a,e,r),i=Pf(a,e))}}}function JI(e,t,n){return e.length>=t?e:(n||(n=new e.constructor(t)),n.set(e),n)}function Pf(e,t,n){let r=(t<257?VI:t<65537?XI:Ms)(e);return n&&r.set(n),r}function TA(e,t,n){let r=1<<t;return{one:r,zero:~r,range:n.slice(),bisect:e.bisect,index:e.index,size:e.size,onAdd(i,a){let o=this,l=o.bisect(o.range,i.value),s=i.index,u=l[0],c=l[1],f=s.length,d;for(d=0;d<u;++d)a[s[d]]|=r;for(d=c;d<f;++d)a[s[d]]|=r;return o}}}function LA(){let e=Ms(0),t=[],n=0;function r(l,s,u){if(!s.length)return[];let c=n,f=s.length,d=Ms(f),h=Array(f),p,m,g;for(g=0;g<f;++g)h[g]=l(s[g]),d[g]=g;if(h=QI(h,d),c)p=t,m=e,t=Array(c+f),e=Ms(c+f),KI(u,p,m,c,h,d,f,t,e);else{if(u>0)for(g=0;g<f;++g)d[g]+=u;t=h,e=d}return n=c+f,{index:d,value:h}}function i(l,s){let u=n,c,f,d;for(f=0;!s[e[f]]&&f<u;++f);for(d=f;f<u;++f)s[c=e[f]]||(e[d]=c,t[d]=t[f],++d);n=u-l}function a(l){for(let s=0,u=n;s<u;++s)e[s]=l[e[s]]}function o(l,s){let u;return s?u=s.length:(s=t,u=n),[W4(s,l[0],0,u),tp(s,l[1],0,u)]}return{insert:r,remove:i,bisect:o,reindex:a,index:()=>e,size:()=>n}}function QI(e,t){return e.sort.call(t,(n,r)=>{let i=e[n],a=e[r];return i<a?-1:i>a?1:0}),KO(e,t)}function KI(e,t,n,r,i,a,o,l,s){let u=0,c=0,f;for(f=0;u<r&&c<o;++f)t[u]<i[c]?(l[f]=t[u],s[f]=n[u++]):(l[f]=i[c],s[f]=a[c++]+e);for(;u<r;++u,++f)l[f]=t[u],s[f]=n[u];for(;c<o;++c,++f)l[f]=i[c],s[f]=a[c]+e}function u1(e){O.call(this,YI(),e),this._indices=null,this._dims=null}u1.Definition={type:"CrossFilter",metadata:{},params:[{name:"fields",type:"field",array:!0,required:!0},{name:"query",type:"array",array:!0,required:!0,content:{type:"number",array:!0,length:2}}]},G(u1,O,{transform(e,t){return this._dims?e.modified("fields")||e.fields.some(n=>t.modified(n.fields))?this.reinit(e,t):this.eval(e,t):this.init(e,t)},init(e,t){let n=e.fields,r=e.query,i=this._indices={},a=this._dims=[],o=r.length,l=0,s,u;for(;l<o;++l)s=n[l].fname,u=i[s]||(i[s]=LA()),a.push(TA(u,l,r[l]));return this.eval(e,t)},reinit(e,t){let n=t.materialize().fork(),r=e.fields,i=e.query,a=this._indices,o=this._dims,l=this.value,s=l.curr(),u=l.prev(),c=l.all(),f=n.rem=n.add,d=n.mod,h=i.length,p={},m,g,y,v,b,w,_,k,x;if(u.set(s),t.rem.length&&(b=this.remove(e,t,n)),t.add.length&&l.add(t.add),t.mod.length)for(w={},v=t.mod,_=0,k=v.length;_<k;++_)w[v[_]._index]=1;for(_=0;_<h;++_)x=r[_],(!o[_]||e.modified("fields",_)||t.modified(x.fields))&&(y=x.fname,(m=p[y])||(a[y]=g=LA(),p[y]=m=g.insert(x,t.source,0)),o[_]=TA(g,_,i[_]).onAdd(m,s));for(_=0,k=l.data().length;_<k;++_)b[_]||(u[_]===s[_]?w[_]&&s[_]!==c&&d.push(_):f.push(_));return l.mask=(1<<h)-1,n},eval(e,t){let n=t.materialize().fork(),r=this._dims.length,i=0;return t.rem.length&&(this.remove(e,t,n),i|=(1<<r)-1),e.modified("query")&&!e.modified("fields")&&(i|=this.update(e,t,n)),t.add.length&&(this.insert(e,t,n),i|=(1<<r)-1),t.mod.length&&(this.modify(t,n),i|=(1<<r)-1),this.value.mask=i,n},insert(e,t,n){let r=t.add,i=this.value,a=this._dims,o=this._indices,l=e.fields,s={},u=n.add,c=i.size()+r.length,f=a.length,d=i.size(),h,p,m;i.resize(c,f),i.add(r);let g=i.curr(),y=i.prev(),v=i.all();for(h=0;h<f;++h)p=l[h].fname,m=s[p]||(s[p]=o[p].insert(l[h],r,d)),a[h].onAdd(m,g);for(;d<c;++d)y[d]=v,g[d]!==v&&u.push(d)},modify(e,t){let n=t.mod,r=this.value,i=r.curr(),a=r.all(),o=e.mod,l,s,u;for(l=0,s=o.length;l<s;++l)u=o[l]._index,i[u]!==a&&n.push(u)},remove(e,t,n){let r=this._indices,i=this.value,a=i.curr(),o=i.prev(),l=i.all(),s={},u=n.rem,c=t.rem,f,d,h,p;for(f=0,d=c.length;f<d;++f)h=c[f]._index,s[h]=1,o[h]=p=a[h],a[h]=l,p!==l&&u.push(h);for(h in r)r[h].remove(d,s);return this.reindex(t,d,s),s},reindex(e,t,n){let r=this._indices,i=this.value;e.runAfter(()=>{let a=i.remove(t,n);for(let o in r)r[o].reindex(a)})},update(e,t,n){let r=this._dims,i=e.query,a=t.stamp,o=r.length,l=0,s,u;for(n.filters=0,u=0;u<o;++u)e.modified("query",u)&&(s=u,++l);if(l===1)l=r[s].one,this.incrementOne(r[s],i[s],n.add,n.rem);else for(u=0,l=0;u<o;++u)e.modified("query",u)&&(l|=r[u].one,this.incrementAll(r[u],i[u],a,n.add),n.rem=n.add);return l},incrementAll(e,t,n,r){let i=this.value,a=i.seen(),o=i.curr(),l=i.prev(),s=e.index(),u=e.bisect(e.range),c=e.bisect(t),f=c[0],d=c[1],h=u[0],p=u[1],m=e.one,g,y,v;if(f<h)for(g=f,y=Math.min(h,d);g<y;++g)v=s[g],a[v]!==n&&(l[v]=o[v],a[v]=n,r.push(v)),o[v]^=m;else if(f>h)for(g=h,y=Math.min(f,p);g<y;++g)v=s[g],a[v]!==n&&(l[v]=o[v],a[v]=n,r.push(v)),o[v]^=m;if(d>p)for(g=Math.max(f,p),y=d;g<y;++g)v=s[g],a[v]!==n&&(l[v]=o[v],a[v]=n,r.push(v)),o[v]^=m;else if(d<p)for(g=Math.max(h,d),y=p;g<y;++g)v=s[g],a[v]!==n&&(l[v]=o[v],a[v]=n,r.push(v)),o[v]^=m;e.range=t.slice()},incrementOne(e,t,n,r){let i=this.value.curr(),a=e.index(),o=e.bisect(e.range),l=e.bisect(t),s=l[0],u=l[1],c=o[0],f=o[1],d=e.one,h,p,m;if(s<c)for(h=s,p=Math.min(c,u);h<p;++h)m=a[h],i[m]^=d,n.push(m);else if(s>c)for(h=c,p=Math.min(s,f);h<p;++h)m=a[h],i[m]^=d,r.push(m);if(u>f)for(h=Math.max(s,f),p=u;h<p;++h)m=a[h],i[m]^=d,n.push(m);else if(u<f)for(h=Math.max(c,u),p=f;h<p;++h)m=a[h],i[m]^=d,r.push(m);e.range=t.slice()}});function c1(e){O.call(this,null,e)}c1.Definition={type:"ResolveFilter",metadata:{},params:[{name:"ignore",type:"number",required:!0,description:"A bit mask indicating which filters to ignore."},{name:"filter",type:"object",required:!0,description:"Per-tuple filter bitmaps from a CrossFilter transform."}]},G(c1,O,{transform(e,t){let n=~(e.ignore||0),r=e.filter,i=r.mask;if((i&n)===0)return t.StopPropagation;let a=t.fork(t.ALL),o=r.data(),l=r.curr(),s=r.prev(),u=c=>l[c]&n?null:o[c];return a.filter(a.MOD,u),i&i-1?(a.filter(a.ADD,c=>{let f=l[c]&n;return!f&&f^s[c]&n?o[c]:null}),a.filter(a.REM,c=>{let f=l[c]&n;return f&&!(f^(f^s[c]&n))?o[c]:null})):(a.filter(a.ADD,u),a.filter(a.REM,c=>(l[c]&n)===i?o[c]:null)),a.filter(a.SOURCE,c=>u(c._index))}});var ZI="RawCode",ej="Literal",tj="Property",nj="Identifier",rj="ArrayExpression",ij="BinaryExpression",aj="CallExpression",oj="ConditionalExpression",lj="LogicalExpression",sj="MemberExpression",uj="ObjectExpression",cj="UnaryExpression";function Un(e){this.type=e}Un.prototype.visit=function(e){let t,n,r;if(e(this))return 1;for(t=fj(this),n=0,r=t.length;n<r;++n)if(t[n].visit(e))return 1};function fj(e){switch(e.type){case rj:return e.elements;case ij:case lj:return[e.left,e.right];case aj:return[e.callee].concat(e.arguments);case oj:return[e.test,e.consequent,e.alternate];case sj:return[e.object,e.property];case uj:return e.properties;case tj:return[e.key,e.value];case cj:return[e.argument];case nj:case ej:case ZI:default:return[]}}var vr,Z,z,wt,De,Bf=1,Os=2,_a=3,Bi=4,If=5,ka=6,Yt=7,zs=8,dj=9;vr={},vr[Bf]="Boolean",vr[Os]="<end>",vr[_a]="Identifier",vr[Bi]="Keyword",vr[If]="Null",vr[ka]="Numeric",vr[Yt]="Punctuator",vr[zs]="String",vr[dj]="RegularExpression";var hj="ArrayExpression",pj="BinaryExpression",mj="CallExpression",gj="ConditionalExpression",PA="Identifier",yj="Literal",vj="LogicalExpression",bj="MemberExpression",xj="ObjectExpression",wj="Property",_j="UnaryExpression",at="Unexpected token %0",kj="Unexpected number",Ej="Unexpected string",$j="Unexpected identifier",Aj="Unexpected reserved word",Dj="Unexpected end of input",f1="Invalid regular expression",d1="Invalid regular expression: missing /",BA="Octal literals are not allowed in strict mode.",Sj="Duplicate data property in object literal not allowed in strict mode",dt="ILLEGAL",Ns="Disabled.",Fj=RegExp("[\\xAA\\xB5\\xBA\\xC0-\\xD6\\xD8-\\xF6\\xF8-\\u02C1\\u02C6-\\u02D1\\u02E0-\\u02E4\\u02EC\\u02EE\\u0370-\\u0374\\u0376\\u0377\\u037A-\\u037D\\u037F\\u0386\\u0388-\\u038A\\u038C\\u038E-\\u03A1\\u03A3-\\u03F5\\u03F7-\\u0481\\u048A-\\u052F\\u0531-\\u0556\\u0559\\u0561-\\u0587\\u05D0-\\u05EA\\u05F0-\\u05F2\\u0620-\\u064A\\u066E\\u066F\\u0671-\\u06D3\\u06D5\\u06E5\\u06E6\\u06EE\\u06EF\\u06FA-\\u06FC\\u06FF\\u0710\\u0712-\\u072F\\u074D-\\u07A5\\u07B1\\u07CA-\\u07EA\\u07F4\\u07F5\\u07FA\\u0800-\\u0815\\u081A\\u0824\\u0828\\u0840-\\u0858\\u08A0-\\u08B2\\u0904-\\u0939\\u093D\\u0950\\u0958-\\u0961\\u0971-\\u0980\\u0985-\\u098C\\u098F\\u0990\\u0993-\\u09A8\\u09AA-\\u09B0\\u09B2\\u09B6-\\u09B9\\u09BD\\u09CE\\u09DC\\u09DD\\u09DF-\\u09E1\\u09F0\\u09F1\\u0A05-\\u0A0A\\u0A0F\\u0A10\\u0A13-\\u0A28\\u0A2A-\\u0A30\\u0A32\\u0A33\\u0A35\\u0A36\\u0A38\\u0A39\\u0A59-\\u0A5C\\u0A5E\\u0A72-\\u0A74\\u0A85-\\u0A8D\\u0A8F-\\u0A91\\u0A93-\\u0AA8\\u0AAA-\\u0AB0\\u0AB2\\u0AB3\\u0AB5-\\u0AB9\\u0ABD\\u0AD0\\u0AE0\\u0AE1\\u0B05-\\u0B0C\\u0B0F\\u0B10\\u0B13-\\u0B28\\u0B2A-\\u0B30\\u0B32\\u0B33\\u0B35-\\u0B39\\u0B3D\\u0B5C\\u0B5D\\u0B5F-\\u0B61\\u0B71\\u0B83\\u0B85-\\u0B8A\\u0B8E-\\u0B90\\u0B92-\\u0B95\\u0B99\\u0B9A\\u0B9C\\u0B9E\\u0B9F\\u0BA3\\u0BA4\\u0BA8-\\u0BAA\\u0BAE-\\u0BB9\\u0BD0\\u0C05-\\u0C0C\\u0C0E-\\u0C10\\u0C12-\\u0C28\\u0C2A-\\u0C39\\u0C3D\\u0C58\\u0C59\\u0C60\\u0C61\\u0C85-\\u0C8C\\u0C8E-\\u0C90\\u0C92-\\u0CA8\\u0CAA-\\u0CB3\\u0CB5-\\u0CB9\\u0CBD\\u0CDE\\u0CE0\\u0CE1\\u0CF1\\u0CF2\\u0D05-\\u0D0C\\u0D0E-\\u0D10\\u0D12-\\u0D3A\\u0D3D\\u0D4E\\u0D60\\u0D61\\u0D7A-\\u0D7F\\u0D85-\\u0D96\\u0D9A-\\u0DB1\\u0DB3-\\u0DBB\\u0DBD\\u0DC0-\\u0DC6\\u0E01-\\u0E30\\u0E32\\u0E33\\u0E40-\\u0E46\\u0E81\\u0E82\\u0E84\\u0E87\\u0E88\\u0E8A\\u0E8D\\u0E94-\\u0E97\\u0E99-\\u0E9F\\u0EA1-\\u0EA3\\u0EA5\\u0EA7\\u0EAA\\u0EAB\\u0EAD-\\u0EB0\\u0EB2\\u0EB3\\u0EBD\\u0EC0-\\u0EC4\\u0EC6\\u0EDC-\\u0EDF\\u0F00\\u0F40-\\u0F47\\u0F49-\\u0F6C\\u0F88-\\u0F8C\\u1000-\\u102A\\u103F\\u1050-\\u1055\\u105A-\\u105D\\u1061\\u1065\\u1066\\u106E-\\u1070\\u1075-\\u1081\\u108E\\u10A0-\\u10C5\\u10C7\\u10CD\\u10D0-\\u10FA\\u10FC-\\u1248\\u124A-\\u124D\\u1250-\\u1256\\u1258\\u125A-\\u125D\\u1260-\\u1288\\u128A-\\u128D\\u1290-\\u12B0\\u12B2-\\u12B5\\u12B8-\\u12BE\\u12C0\\u12C2-\\u12C5\\u12C8-\\u12D6\\u12D8-\\u1310\\u1312-\\u1315\\u1318-\\u135A\\u1380-\\u138F\\u13A0-\\u13F4\\u1401-\\u166C\\u166F-\\u167F\\u1681-\\u169A\\u16A0-\\u16EA\\u16EE-\\u16F8\\u1700-\\u170C\\u170E-\\u1711\\u1720-\\u1731\\u1740-\\u1751\\u1760-\\u176C\\u176E-\\u1770\\u1780-\\u17B3\\u17D7\\u17DC\\u1820-\\u1877\\u1880-\\u18A8\\u18AA\\u18B0-\\u18F5\\u1900-\\u191E\\u1950-\\u196D\\u1970-\\u1974\\u1980-\\u19AB\\u19C1-\\u19C7\\u1A00-\\u1A16\\u1A20-\\u1A54\\u1AA7\\u1B05-\\u1B33\\u1B45-\\u1B4B\\u1B83-\\u1BA0\\u1BAE\\u1BAF\\u1BBA-\\u1BE5\\u1C00-\\u1C23\\u1C4D-\\u1C4F\\u1C5A-\\u1C7D\\u1CE9-\\u1CEC\\u1CEE-\\u1CF1\\u1CF5\\u1CF6\\u1D00-\\u1DBF\\u1E00-\\u1F15\\u1F18-\\u1F1D\\u1F20-\\u1F45\\u1F48-\\u1F4D\\u1F50-\\u1F57\\u1F59\\u1F5B\\u1F5D\\u1F5F-\\u1F7D\\u1F80-\\u1FB4\\u1FB6-\\u1FBC\\u1FBE\\u1FC2-\\u1FC4\\u1FC6-\\u1FCC\\u1FD0-\\u1FD3\\u1FD6-\\u1FDB\\u1FE0-\\u1FEC\\u1FF2-\\u1FF4\\u1FF6-\\u1FFC\\u2071\\u207F\\u2090-\\u209C\\u2102\\u2107\\u210A-\\u2113\\u2115\\u2119-\\u211D\\u2124\\u2126\\u2128\\u212A-\\u212D\\u212F-\\u2139\\u213C-\\u213F\\u2145-\\u2149\\u214E\\u2160-\\u2188\\u2C00-\\u2C2E\\u2C30-\\u2C5E\\u2C60-\\u2CE4\\u2CEB-\\u2CEE\\u2CF2\\u2CF3\\u2D00-\\u2D25\\u2D27\\u2D2D\\u2D30-\\u2D67\\u2D6F\\u2D80-\\u2D96\\u2DA0-\\u2DA6\\u2DA8-\\u2DAE\\u2DB0-\\u2DB6\\u2DB8-\\u2DBE\\u2DC0-\\u2DC6\\u2DC8-\\u2DCE\\u2DD0-\\u2DD6\\u2DD8-\\u2DDE\\u2E2F\\u3005-\\u3007\\u3021-\\u3029\\u3031-\\u3035\\u3038-\\u303C\\u3041-\\u3096\\u309D-\\u309F\\u30A1-\\u30FA\\u30FC-\\u30FF\\u3105-\\u312D\\u3131-\\u318E\\u31A0-\\u31BA\\u31F0-\\u31FF\\u3400-\\u4DB5\\u4E00-\\u9FCC\\uA000-\\uA48C\\uA4D0-\\uA4FD\\uA500-\\uA60C\\uA610-\\uA61F\\uA62A\\uA62B\\uA640-\\uA66E\\uA67F-\\uA69D\\uA6A0-\\uA6EF\\uA717-\\uA71F\\uA722-\\uA788\\uA78B-\\uA78E\\uA790-\\uA7AD\\uA7B0\\uA7B1\\uA7F7-\\uA801\\uA803-\\uA805\\uA807-\\uA80A\\uA80C-\\uA822\\uA840-\\uA873\\uA882-\\uA8B3\\uA8F2-\\uA8F7\\uA8FB\\uA90A-\\uA925\\uA930-\\uA946\\uA960-\\uA97C\\uA984-\\uA9B2\\uA9CF\\uA9E0-\\uA9E4\\uA9E6-\\uA9EF\\uA9FA-\\uA9FE\\uAA00-\\uAA28\\uAA40-\\uAA42\\uAA44-\\uAA4B\\uAA60-\\uAA76\\uAA7A\\uAA7E-\\uAAAF\\uAAB1\\uAAB5\\uAAB6\\uAAB9-\\uAABD\\uAAC0\\uAAC2\\uAADB-\\uAADD\\uAAE0-\\uAAEA\\uAAF2-\\uAAF4\\uAB01-\\uAB06\\uAB09-\\uAB0E\\uAB11-\\uAB16\\uAB20-\\uAB26\\uAB28-\\uAB2E\\uAB30-\\uAB5A\\uAB5C-\\uAB5F\\uAB64\\uAB65\\uABC0-\\uABE2\\uAC00-\\uD7A3\\uD7B0-\\uD7C6\\uD7CB-\\uD7FB\\uF900-\\uFA6D\\uFA70-\\uFAD9\\uFB00-\\uFB06\\uFB13-\\uFB17\\uFB1D\\uFB1F-\\uFB28\\uFB2A-\\uFB36\\uFB38-\\uFB3C\\uFB3E\\uFB40\\uFB41\\uFB43\\uFB44\\uFB46-\\uFBB1\\uFBD3-\\uFD3D\\uFD50-\\uFD8F\\uFD92-\\uFDC7\\uFDF0-\\uFDFB\\uFE70-\\uFE74\\uFE76-\\uFEFC\\uFF21-\\uFF3A\\uFF41-\\uFF5A\\uFF66-\\uFFBE\\uFFC2-\\uFFC7\\uFFCA-\\uFFCF\\uFFD2-\\uFFD7\\uFFDA-\\uFFDC]"),Cj=RegExp("[\\xAA\\xB5\\xBA\\xC0-\\xD6\\xD8-\\xF6\\xF8-\\u02C1\\u02C6-\\u02D1\\u02E0-\\u02E4\\u02EC\\u02EE\\u0300-\\u0374\\u0376\\u0377\\u037A-\\u037D\\u037F\\u0386\\u0388-\\u038A\\u038C\\u038E-\\u03A1\\u03A3-\\u03F5\\u03F7-\\u0481\\u0483-\\u0487\\u048A-\\u052F\\u0531-\\u0556\\u0559\\u0561-\\u0587\\u0591-\\u05BD\\u05BF\\u05C1\\u05C2\\u05C4\\u05C5\\u05C7\\u05D0-\\u05EA\\u05F0-\\u05F2\\u0610-\\u061A\\u0620-\\u0669\\u066E-\\u06D3\\u06D5-\\u06DC\\u06DF-\\u06E8\\u06EA-\\u06FC\\u06FF\\u0710-\\u074A\\u074D-\\u07B1\\u07C0-\\u07F5\\u07FA\\u0800-\\u082D\\u0840-\\u085B\\u08A0-\\u08B2\\u08E4-\\u0963\\u0966-\\u096F\\u0971-\\u0983\\u0985-\\u098C\\u098F\\u0990\\u0993-\\u09A8\\u09AA-\\u09B0\\u09B2\\u09B6-\\u09B9\\u09BC-\\u09C4\\u09C7\\u09C8\\u09CB-\\u09CE\\u09D7\\u09DC\\u09DD\\u09DF-\\u09E3\\u09E6-\\u09F1\\u0A01-\\u0A03\\u0A05-\\u0A0A\\u0A0F\\u0A10\\u0A13-\\u0A28\\u0A2A-\\u0A30\\u0A32\\u0A33\\u0A35\\u0A36\\u0A38\\u0A39\\u0A3C\\u0A3E-\\u0A42\\u0A47\\u0A48\\u0A4B-\\u0A4D\\u0A51\\u0A59-\\u0A5C\\u0A5E\\u0A66-\\u0A75\\u0A81-\\u0A83\\u0A85-\\u0A8D\\u0A8F-\\u0A91\\u0A93-\\u0AA8\\u0AAA-\\u0AB0\\u0AB2\\u0AB3\\u0AB5-\\u0AB9\\u0ABC-\\u0AC5\\u0AC7-\\u0AC9\\u0ACB-\\u0ACD\\u0AD0\\u0AE0-\\u0AE3\\u0AE6-\\u0AEF\\u0B01-\\u0B03\\u0B05-\\u0B0C\\u0B0F\\u0B10\\u0B13-\\u0B28\\u0B2A-\\u0B30\\u0B32\\u0B33\\u0B35-\\u0B39\\u0B3C-\\u0B44\\u0B47\\u0B48\\u0B4B-\\u0B4D\\u0B56\\u0B57\\u0B5C\\u0B5D\\u0B5F-\\u0B63\\u0B66-\\u0B6F\\u0B71\\u0B82\\u0B83\\u0B85-\\u0B8A\\u0B8E-\\u0B90\\u0B92-\\u0B95\\u0B99\\u0B9A\\u0B9C\\u0B9E\\u0B9F\\u0BA3\\u0BA4\\u0BA8-\\u0BAA\\u0BAE-\\u0BB9\\u0BBE-\\u0BC2\\u0BC6-\\u0BC8\\u0BCA-\\u0BCD\\u0BD0\\u0BD7\\u0BE6-\\u0BEF\\u0C00-\\u0C03\\u0C05-\\u0C0C\\u0C0E-\\u0C10\\u0C12-\\u0C28\\u0C2A-\\u0C39\\u0C3D-\\u0C44\\u0C46-\\u0C48\\u0C4A-\\u0C4D\\u0C55\\u0C56\\u0C58\\u0C59\\u0C60-\\u0C63\\u0C66-\\u0C6F\\u0C81-\\u0C83\\u0C85-\\u0C8C\\u0C8E-\\u0C90\\u0C92-\\u0CA8\\u0CAA-\\u0CB3\\u0CB5-\\u0CB9\\u0CBC-\\u0CC4\\u0CC6-\\u0CC8\\u0CCA-\\u0CCD\\u0CD5\\u0CD6\\u0CDE\\u0CE0-\\u0CE3\\u0CE6-\\u0CEF\\u0CF1\\u0CF2\\u0D01-\\u0D03\\u0D05-\\u0D0C\\u0D0E-\\u0D10\\u0D12-\\u0D3A\\u0D3D-\\u0D44\\u0D46-\\u0D48\\u0D4A-\\u0D4E\\u0D57\\u0D60-\\u0D63\\u0D66-\\u0D6F\\u0D7A-\\u0D7F\\u0D82\\u0D83\\u0D85-\\u0D96\\u0D9A-\\u0DB1\\u0DB3-\\u0DBB\\u0DBD\\u0DC0-\\u0DC6\\u0DCA\\u0DCF-\\u0DD4\\u0DD6\\u0DD8-\\u0DDF\\u0DE6-\\u0DEF\\u0DF2\\u0DF3\\u0E01-\\u0E3A\\u0E40-\\u0E4E\\u0E50-\\u0E59\\u0E81\\u0E82\\u0E84\\u0E87\\u0E88\\u0E8A\\u0E8D\\u0E94-\\u0E97\\u0E99-\\u0E9F\\u0EA1-\\u0EA3\\u0EA5\\u0EA7\\u0EAA\\u0EAB\\u0EAD-\\u0EB9\\u0EBB-\\u0EBD\\u0EC0-\\u0EC4\\u0EC6\\u0EC8-\\u0ECD\\u0ED0-\\u0ED9\\u0EDC-\\u0EDF\\u0F00\\u0F18\\u0F19\\u0F20-\\u0F29\\u0F35\\u0F37\\u0F39\\u0F3E-\\u0F47\\u0F49-\\u0F6C\\u0F71-\\u0F84\\u0F86-\\u0F97\\u0F99-\\u0FBC\\u0FC6\\u1000-\\u1049\\u1050-\\u109D\\u10A0-\\u10C5\\u10C7\\u10CD\\u10D0-\\u10FA\\u10FC-\\u1248\\u124A-\\u124D\\u1250-\\u1256\\u1258\\u125A-\\u125D\\u1260-\\u1288\\u128A-\\u128D\\u1290-\\u12B0\\u12B2-\\u12B5\\u12B8-\\u12BE\\u12C0\\u12C2-\\u12C5\\u12C8-\\u12D6\\u12D8-\\u1310\\u1312-\\u1315\\u1318-\\u135A\\u135D-\\u135F\\u1380-\\u138F\\u13A0-\\u13F4\\u1401-\\u166C\\u166F-\\u167F\\u1681-\\u169A\\u16A0-\\u16EA\\u16EE-\\u16F8\\u1700-\\u170C\\u170E-\\u1714\\u1720-\\u1734\\u1740-\\u1753\\u1760-\\u176C\\u176E-\\u1770\\u1772\\u1773\\u1780-\\u17D3\\u17D7\\u17DC\\u17DD\\u17E0-\\u17E9\\u180B-\\u180D\\u1810-\\u1819\\u1820-\\u1877\\u1880-\\u18AA\\u18B0-\\u18F5\\u1900-\\u191E\\u1920-\\u192B\\u1930-\\u193B\\u1946-\\u196D\\u1970-\\u1974\\u1980-\\u19AB\\u19B0-\\u19C9\\u19D0-\\u19D9\\u1A00-\\u1A1B\\u1A20-\\u1A5E\\u1A60-\\u1A7C\\u1A7F-\\u1A89\\u1A90-\\u1A99\\u1AA7\\u1AB0-\\u1ABD\\u1B00-\\u1B4B\\u1B50-\\u1B59\\u1B6B-\\u1B73\\u1B80-\\u1BF3\\u1C00-\\u1C37\\u1C40-\\u1C49\\u1C4D-\\u1C7D\\u1CD0-\\u1CD2\\u1CD4-\\u1CF6\\u1CF8\\u1CF9\\u1D00-\\u1DF5\\u1DFC-\\u1F15\\u1F18-\\u1F1D\\u1F20-\\u1F45\\u1F48-\\u1F4D\\u1F50-\\u1F57\\u1F59\\u1F5B\\u1F5D\\u1F5F-\\u1F7D\\u1F80-\\u1FB4\\u1FB6-\\u1FBC\\u1FBE\\u1FC2-\\u1FC4\\u1FC6-\\u1FCC\\u1FD0-\\u1FD3\\u1FD6-\\u1FDB\\u1FE0-\\u1FEC\\u1FF2-\\u1FF4\\u1FF6-\\u1FFC\\u200C\\u200D\\u203F\\u2040\\u2054\\u2071\\u207F\\u2090-\\u209C\\u20D0-\\u20DC\\u20E1\\u20E5-\\u20F0\\u2102\\u2107\\u210A-\\u2113\\u2115\\u2119-\\u211D\\u2124\\u2126\\u2128\\u212A-\\u212D\\u212F-\\u2139\\u213C-\\u213F\\u2145-\\u2149\\u214E\\u2160-\\u2188\\u2C00-\\u2C2E\\u2C30-\\u2C5E\\u2C60-\\u2CE4\\u2CEB-\\u2CF3\\u2D00-\\u2D25\\u2D27\\u2D2D\\u2D30-\\u2D67\\u2D6F\\u2D7F-\\u2D96\\u2DA0-\\u2DA6\\u2DA8-\\u2DAE\\u2DB0-\\u2DB6\\u2DB8-\\u2DBE\\u2DC0-\\u2DC6\\u2DC8-\\u2DCE\\u2DD0-\\u2DD6\\u2DD8-\\u2DDE\\u2DE0-\\u2DFF\\u2E2F\\u3005-\\u3007\\u3021-\\u302F\\u3031-\\u3035\\u3038-\\u303C\\u3041-\\u3096\\u3099\\u309A\\u309D-\\u309F\\u30A1-\\u30FA\\u30FC-\\u30FF\\u3105-\\u312D\\u3131-\\u318E\\u31A0-\\u31BA\\u31F0-\\u31FF\\u3400-\\u4DB5\\u4E00-\\u9FCC\\uA000-\\uA48C\\uA4D0-\\uA4FD\\uA500-\\uA60C\\uA610-\\uA62B\\uA640-\\uA66F\\uA674-\\uA67D\\uA67F-\\uA69D\\uA69F-\\uA6F1\\uA717-\\uA71F\\uA722-\\uA788\\uA78B-\\uA78E\\uA790-\\uA7AD\\uA7B0\\uA7B1\\uA7F7-\\uA827\\uA840-\\uA873\\uA880-\\uA8C4\\uA8D0-\\uA8D9\\uA8E0-\\uA8F7\\uA8FB\\uA900-\\uA92D\\uA930-\\uA953\\uA960-\\uA97C\\uA980-\\uA9C0\\uA9CF-\\uA9D9\\uA9E0-\\uA9FE\\uAA00-\\uAA36\\uAA40-\\uAA4D\\uAA50-\\uAA59\\uAA60-\\uAA76\\uAA7A-\\uAAC2\\uAADB-\\uAADD\\uAAE0-\\uAAEF\\uAAF2-\\uAAF6\\uAB01-\\uAB06\\uAB09-\\uAB0E\\uAB11-\\uAB16\\uAB20-\\uAB26\\uAB28-\\uAB2E\\uAB30-\\uAB5A\\uAB5C-\\uAB5F\\uAB64\\uAB65\\uABC0-\\uABEA\\uABEC\\uABED\\uABF0-\\uABF9\\uAC00-\\uD7A3\\uD7B0-\\uD7C6\\uD7CB-\\uD7FB\\uF900-\\uFA6D\\uFA70-\\uFAD9\\uFB00-\\uFB06\\uFB13-\\uFB17\\uFB1D-\\uFB28\\uFB2A-\\uFB36\\uFB38-\\uFB3C\\uFB3E\\uFB40\\uFB41\\uFB43\\uFB44\\uFB46-\\uFBB1\\uFBD3-\\uFD3D\\uFD50-\\uFD8F\\uFD92-\\uFDC7\\uFDF0-\\uFDFB\\uFE00-\\uFE0F\\uFE20-\\uFE2D\\uFE33\\uFE34\\uFE4D-\\uFE4F\\uFE70-\\uFE74\\uFE76-\\uFEFC\\uFF10-\\uFF19\\uFF21-\\uFF3A\\uFF3F\\uFF41-\\uFF5A\\uFF66-\\uFFBE\\uFFC2-\\uFFC7\\uFFCA-\\uFFCF\\uFFD2-\\uFFD7\\uFFDA-\\uFFDC]");function jf(e,t){if(!e)throw Error("ASSERT: "+t)}function Vr(e){return e>=48&&e<=57}function h1(e){return"0123456789abcdefABCDEF".includes(e)}function Rs(e){return"01234567".includes(e)}function Mj(e){return e===32||e===9||e===11||e===12||e===160||e>=5760&&[5760,6158,8192,8193,8194,8195,8196,8197,8198,8199,8200,8201,8202,8239,8287,12288,65279].includes(e)}function Ts(e){return e===10||e===13||e===8232||e===8233}function Ls(e){return e===36||e===95||e>=65&&e<=90||e>=97&&e<=122||e===92||e>=128&&Fj.test(String.fromCharCode(e))}function qf(e){return e===36||e===95||e>=65&&e<=90||e>=97&&e<=122||e>=48&&e<=57||e===92||e>=128&&Cj.test(String.fromCharCode(e))}var Oj={if:1,in:1,do:1,var:1,for:1,new:1,try:1,let:1,this:1,else:1,case:1,void:1,with:1,enum:1,while:1,break:1,catch:1,throw:1,const:1,yield:1,class:1,super:1,return:1,typeof:1,delete:1,switch:1,export:1,import:1,public:1,static:1,default:1,finally:1,extends:1,package:1,private:1,function:1,continue:1,debugger:1,interface:1,protected:1,instanceof:1,implements:1};function IA(){for(;z<wt;){let e=Z.charCodeAt(z);if(Mj(e)||Ts(e))++z;else break}}function p1(e){var t,n,r,i=0;for(n=e==="u"?4:2,t=0;t<n;++t)z<wt&&h1(Z[z])?(r=Z[z++],i=i*16+"0123456789abcdef".indexOf(r.toLowerCase())):be({},at,dt);return String.fromCharCode(i)}function zj(){var e=Z[z],t=0,n,r;for(e==="}"&&be({},at,dt);z<wt&&(e=Z[z++],h1(e));)t=t*16+"0123456789abcdef".indexOf(e.toLowerCase());return(t>1114111||e!=="}")&&be({},at,dt),t<=65535?String.fromCharCode(t):(n=(t-65536>>10)+55296,r=(t-65536&1023)+56320,String.fromCharCode(n,r))}function jA(){var e=Z.charCodeAt(z++),t=String.fromCharCode(e);for(e===92&&(Z.charCodeAt(z)!==117&&be({},at,dt),++z,e=p1("u"),(!e||e==="\\"||!Ls(e.charCodeAt(0)))&&be({},at,dt),t=e);z<wt&&(e=Z.charCodeAt(z),qf(e));)++z,t+=String.fromCharCode(e),e===92&&(t=t.substr(0,t.length-1),Z.charCodeAt(z)!==117&&be({},at,dt),++z,e=p1("u"),(!e||e==="\\"||!qf(e.charCodeAt(0)))&&be({},at,dt),t+=e);return t}function Nj(){for(var e=z++,t;z<wt;){if(t=Z.charCodeAt(z),t===92)return z=e,jA();if(qf(t))++z;else break}return Z.slice(e,z)}function Rj(){var e=z,t=Z.charCodeAt(z)===92?jA():Nj();return{type:t.length===1?_a:Oj.hasOwnProperty(t)?Bi:t==="null"?If:t==="true"||t==="false"?Bf:_a,value:t,start:e,end:z}}function m1(){var e=z,t=Z.charCodeAt(z),n,r=Z[z],i,a,o;switch(t){case 46:case 40:case 41:case 59:case 44:case 123:case 125:case 91:case 93:case 58:case 63:case 126:return++z,{type:Yt,value:String.fromCharCode(t),start:e,end:z};default:if(n=Z.charCodeAt(z+1),n===61)switch(t){case 43:case 45:case 47:case 60:case 62:case 94:case 124:case 37:case 38:case 42:return z+=2,{type:Yt,value:String.fromCharCode(t)+String.fromCharCode(n),start:e,end:z};case 33:case 61:return z+=2,Z.charCodeAt(z)===61&&++z,{type:Yt,value:Z.slice(e,z),start:e,end:z}}}if(o=Z.substr(z,4),o===">>>=")return z+=4,{type:Yt,value:o,start:e,end:z};if(a=o.substr(0,3),a===">>>"||a==="<<="||a===">>=")return z+=3,{type:Yt,value:a,start:e,end:z};if(i=a.substr(0,2),r===i[1]&&"+-<>&|".includes(r)||i==="=>")return z+=2,{type:Yt,value:i,start:e,end:z};if(i==="//"&&be({},at,dt),"<>=!+-*%&|^/".includes(r))return++z,{type:Yt,value:r,start:e,end:z};be({},at,dt)}function Tj(e){let t="";for(;z<wt&&h1(Z[z]);)t+=Z[z++];return t.length===0&&be({},at,dt),Ls(Z.charCodeAt(z))&&be({},at,dt),{type:ka,value:parseInt("0x"+t,16),start:e,end:z}}function Lj(e){let t="0"+Z[z++];for(;z<wt&&Rs(Z[z]);)t+=Z[z++];return(Ls(Z.charCodeAt(z))||Vr(Z.charCodeAt(z)))&&be({},at,dt),{type:ka,value:parseInt(t,8),octal:!0,start:e,end:z}}function qA(){var e,t,n=Z[z];if(jf(Vr(n.charCodeAt(0))||n===".","Numeric literal must start with a decimal digit or a decimal point"),t=z,e="",n!=="."){if(e=Z[z++],n=Z[z],e==="0"){if(n==="x"||n==="X")return++z,Tj(t);if(Rs(n))return Lj(t);n&&Vr(n.charCodeAt(0))&&be({},at,dt)}for(;Vr(Z.charCodeAt(z));)e+=Z[z++];n=Z[z]}if(n==="."){for(e+=Z[z++];Vr(Z.charCodeAt(z));)e+=Z[z++];n=Z[z]}if(n==="e"||n==="E")if(e+=Z[z++],n=Z[z],(n==="+"||n==="-")&&(e+=Z[z++]),Vr(Z.charCodeAt(z)))for(;Vr(Z.charCodeAt(z));)e+=Z[z++];else be({},at,dt);return Ls(Z.charCodeAt(z))&&be({},at,dt),{type:ka,value:parseFloat(e),start:t,end:z}}function Pj(){var e="",t,n,r,i,a=!1;for(t=Z[z],jf(t==="'"||t==='"',"String literal must starts with a quote"),n=z,++z;z<wt;)if(r=Z[z++],r===t){t="";break}else if(r==="\\")if(r=Z[z++],!r||!Ts(r.charCodeAt(0)))switch(r){case"u":case"x":Z[z]==="{"?(++z,e+=zj()):e+=p1(r);break;case"n":e+=`
|